作者:Diemit 打包 boot.img 镜像 boot.img 打包流程如下:
①修改内核启动参数修改 boot.img 大小:原解压出的大小是 8m 多,我们的内核因为把模块编译进内核的缘故,容量会增大,导致使用原有配置文件会无法成功打包,所以我们增大到 16m,小米 6 的 boot 分区有 64m 不会影响 boot.img 的刷入。bootsize = 0x1000000 修改并添加内核启动参数:cmdline = clk_ignore_unused cnotallow=tty1 cnotallow=ttyGS0,115200 no_console_suspend hardware=sagit default_boot_device=1da4000.ufshc ohos.required_mount.system=/dev/block/platform/soc/1da4000.ufshc/by-name/system@/usr@ext4@ro,barrier=1@wait,required ohos.required_mount.vendor=/dev/block/platform/soc/1da4000.ufshc/by-name/cust@/vendor@ext4@ro,barrier=1@wait,required 其中 hardware 和 default_boot_device 为 OH 初始化时用于识别设备的参数,实测不配置也不影响启动。 hardware=sagit default_boot_device=1da4000.ufshc
ohos.required_mount.system=/dev/block/platform/soc/1da4000.ufshc/by-name/system@/usr@ext4@ro,barrier=1@wait,required ohos.required_mount.vendor=/dev/block/platform/soc/1da4000.ufshc/by-name/cust@/vendor@ext4@ro,barrier=1@wait,required cnotallow=tty1 是为启动日志输出到屏幕,后续可以进行观察 OH 的渲染框架是否接管屏幕 cnotallow=ttyGS0,115200 为开启串口控制台,后续方便进行输入命令,进行 debug 调试等。 其他可按需配置,启动参数参考标准 Linux。 ②打包带设备树的内核命令如下,直接用 cat 命令,把内核和设备树二进制文件直接输出成 Image.gz-dtb。 cat ${KERNEL_IMAGE_FILE} ${DTB} > '${OUT_PKG_DIR}/Image.gz-dtb' ③打包 boot.img命令如下,使用 abootimg 工具,--create 指定进行 boot.img 创建的位置,-f 指定 bootimg.cfg 位置,-k 指定带设备树内核的位置,-r 指定 ramdisk.img 的位置。 abootimg --create '${OUT_PKG_DIR}/boot.img' -f ${BOOTCFG} -k '${OUT_PKG_DIR}/Image.gz-dtb' -r '${OUT_PKG_DIR}/ramdisk.img' OH 的编译框架已经帮我们打包好了 system.img 和 vendor.img,在 out/packages/phone/images 中,复制 boot.img,system.img 和 vendor.img 到电脑中,准备进行刷机工作。 注意:刷机会格式化手机,请使用备用机进行刷机,刷机前有需要的话请把手机的数据复制到电脑,刷机有风险,请自行判断,变砖概不负责!!!刷入镜像 ①TWRP 刷入镜像按音量键上+电源开机进入 TWRP,这时 TWRP 会进入 MTP 模式,把刷机镜像复制进手机。 选择安装: 选择刷入镜像,这时才会显示我们的刷机文件: 选择 boot.img,选择 boot 分区: 滑动确认刷入: 按两次返回,选择 system.img,选择 system 分区: 同样按两次返回,选择 vendor.img,选择 vendor 分区: 回到主页,选择清除,选择格式化 Data 分区: 输入 yes,格式化完成后重启: ②fastboot 刷入镜像按音量键下+开机键进入 fastboot 模式,连接电脑,装好驱动,使用以下命令进行刷机: fastboot flash boot (boot.img的路径)fastboot flash system (system.img的路径)fastboot flash vendor (vendor.img的路径)fastboot erase userdatafastboot reboot 简单调试经验分享 ①设备不断重启上篇文章中我们配置了 usb 串口,如果内核驱动正常的话手机使用 usb 连接电脑会自动识别为 com 设备,这时我们使用 xshell,mobaxterm 等工具查看串口日志。 比如一般不断重启是因为 render_service 的崩溃,渲染服务是关键服务,OH 设置了崩溃会自动重启: 为了调试我们先更改一下设置,让它不自动重启,找到渲染服务的配置,把 critical 第一个参数从 1 改成 0,这样就不会自动重启了。 ②使用 modetest 测试 DRM 驱动要使 OH 能顺利点亮,我们首先要确认内核 DRM 驱动是否正常工作,这里我使用的是 modetest 进行测试。 modetest 的代码已经存在 libdrm 的仓库中,但是没有加入 OH 的编译框架,有需要的同学可以参考我移植树莓的 board 仓,里面的 test 文件夹中有写好的配置。 编译好 modetest 之后直接运行是没有效果的,因为 OH 的渲染服务占用了显卡,我们先把渲染服务关闭: service_control stop render_service 关闭渲染服务之后,我们运行 modetest,modetest 会遍历设备所有的显卡,并打印出信息: modetest 查看 log: ......trying to open device 'msm'...doneEncoders:id crtc type possible crtcs possible clones 31 81 DSI 0x00000001 0x00000001Connectors:id encoder status name size (mm) modes encoders32 31 connected DSI-1 64x114 1 31 modes: index name refresh (Hz) hdisp hss hse htot vdisp vss vse vtot) #0 1080x1920 60.00 1080 1200 1216 1256 1920 1924 1926 1930 145444 flags: ; type: preferred, driver ...... 我们可以找到,我们的驱动模块名为 msm,Connector id 为 32,mode 名为 1080x1920。 查看 modetest 支持的命令,配置这两个参数: -M module use the given driver-s <connector_id>[,<connector_id>][@<crtc_id>]:[#<mode index>]<mode>[-<vrefresh>][@<format>] set a mode 我的命令简化为: modetest -M msm -s 32:1080x1920 运行命令后,手机屏幕显示出颜色条纹,即为 DRM 驱动工作正常: ③OH 渲染框架调试配置 hilog 打印等级,启动屏幕调试 hilog 打印: 使用命令启动渲染服务,并过滤只显示 display 相关的内容: hilog -D 0xD001400 & service_control start render_service 打通串口并能显示 log 信息之后就是各种调试代码了,这部分操作就跟开发板差不多了,接下去就是对照 log 跟代码不断拉扯了,教程只能到这里了,祝各位调试顺利。 |
|