From e613855a4fb6096a116c7fef5a3fa69d468c885b Mon Sep 17 00:00:00 2001 From: topjohnwu Date: Wed, 24 Feb 2021 02:27:13 -0800 Subject: [PATCH] Do not check PXA header signatures Fix #3876 --- app/src/main/java/com/topjohnwu/signing/SignBoot.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/com/topjohnwu/signing/SignBoot.java b/app/src/main/java/com/topjohnwu/signing/SignBoot.java index 38f008f8c..5a64cb20d 100644 --- a/app/src/main/java/com/topjohnwu/signing/SignBoot.java +++ b/app/src/main/java/com/topjohnwu/signing/SignBoot.java @@ -196,6 +196,9 @@ public class SignBoot { int secondSize = image.getInt(); image.getLong(); // second_addr + tags_addr int pageSize = image.getInt(); + if (pageSize >= 0x02000000) { + throw new IllegalArgumentException("Invalid image header: PXA header detected"); + } int length = pageSize // include the page aligned image header + ((kernelSize + pageSize - 1) / pageSize) * pageSize + ((ramdskSize + pageSize - 1) / pageSize) * pageSize @@ -214,8 +217,7 @@ public class SignBoot { image.getLong(); // dtb address } if (image.position() != headerSize) { - throw new IllegalArgumentException( - "Invalid image header: invalid header length"); + throw new IllegalArgumentException("Invalid image header: invalid header length"); } } else { // headerVersion is 0 or actually dt/extra size in this case