1

我的设备有一个功能齐全且经过测试的官方 boot.img。

但是当我尝试解压并重新打包时(没有任何修改),内核无法像往常一样启动。

当我尝试启动新内核并且设备似乎卡在显示徽标时,我在屏幕左上角收到“内核不是 seandroid 强制执行”文本。

我正在使用位于此处的 bootimg-tools:https ://github.com/pbatard/bootimg-tools

这是我打开它的方式:

$ ./unmkbootimg -i stock/boot.img 
kernel written to 'kernel' (11273048 bytes)
ramdisk written to 'ramdisk.cpio.gz' (2856269 bytes)

To rebuild this boot image, you can use the command:
  mkbootimg --base 0 --pagesize 2048 --kernel_offset 0x00008000 --ramdisk_offset 0x01000000 --second_offset 0x00f00000 --tags_offset 0x00000100 --cmdline 'console=ttyS1,115200n8' --kernel kernel --ramdisk ramdisk.cpio.gz -o stock/boot.img

我在 unpack 命令中使用相同的命令来重新打包它:

$ ./mkbootimg --base 0 --pagesize 2048 --kernel_offset 0x00008000 --ramdisk_offset 0x01000000 --second_offset 0x00f00000 --tags_offset 0x00000100 --cmdline 'console=ttyS1,115200n8' --kernel kernel --ramdisk ramdisk.cpio.gz -o stock/boot.img

我不知道这里有什么问题,我什至不确定这是否是使 zImage 可启动的正确方法。

任何帮助将不胜感激。

谢谢你。

4

1 回答 1

3

我需要使用最新的工具。

boot.img 文件格式似乎在过去几年发生了变化。

工作工具位于:https ://github.com/GameTheory-/mktool/tree/master/tools 。.jar 工具对我不起作用,但后端工具对我有用 :)

* 打开包装 *

$ ./unpackbootimg -i stock/boot.img -o stockoutdir
BOARD_KERNEL_CMDLINE console=ttyS1,115200n8
BOARD_KERNEL_BASE 00000000
BOARD_NAME 
BOARD_PAGE_SIZE 2048
BOARD_HASH_TYPE sha1
BOARD_KERNEL_OFFSET 00008000
BOARD_RAMDISK_OFFSET 01000000
BOARD_SECOND_OFFSET 00f00000
BOARD_TAGS_OFFSET 00000100
BOARD_DT_SIZE 673792

* 再次打包 *

$ ./mkbootimg --kernel stockoutdir/boot.img-zImage --ramdisk stockoutdir/boot.img-ramdisk.gz --cmdline "console=ttyS1,115200n8" --base 00000000 --pagesize 2048 --dt stockoutdir/boot.img-dt --kernel_offset 00008000 --ramdisk_offset 01000000 --second_offset 00f00000 --tags_offset 00000100 --hash sha1 -o custom.img

于 2019-08-14T10:40:15.440 回答