OpenHarmony富设备移植指南(2)从postmarketOS获取移植资源

描述

 

开篇引言

安卓设备的引导需要boot.img镜像,其中含有内核镜像,设备树,boot配置文件,initrd.img根文件系统镜像,开发板因为是开发用途,系统引导基本没有限制,而成品安卓手机往往有各种限制,我们需要通过刷入postmarketOS进行确认手机是否可以启动第三方系统,从中获取引导启动的相关信息以及文件,并仿照postmarketOS的引导镜像创建我们自己的引导镜像。

 

1,准备postmarketOS编译环境

参照​​pmbootstrap - postmarketOS​​ 中的 Installation  -- From git 准备编译环境

  1.   $ git clone https://git.sr.ht/~postmarketos/pmbootstrap
  2.   $ mkdir -p ~/.local/bin
  3.   $ ln -s "$PWD/pmbootstrap/pmbootstrap.py" ~/.local/bin/pmbootstrap
  4.   $ pmbootstrap --version
  5.   1.50.1

 

2,执行初始化

  1. 1.  pmbootstrap init
开发板

 

或者替换使用镜像源,不然会有网络问题,需要替换两个镜像源地址,postmarketOS镜像,和Alpine Linux镜像

使用以下命令设置设置成清华源进行初始化,也可以根据镜像源列表找自己喜欢的设置

  1. 1.  pmbootstrap --mirror-pmOS https://mirrors.tuna.tsinghua.edu.cn/postmarketOS/ --mirror-alpine https://mirrors.tuna.tsinghua.edu.cn/alpine/ 


postmarketOS镜像源列表:​​postmarketOS // Official postmarketOS Mirrors​​

Alpine Linux镜像源列表:​​Mirror health (alpinelinux.org)​

 

3,编译安卓格式的刷机包

  1. 1.  pmbootstrap install --android-recovery-zip

编译时间会比较长,中间会提示创建进入手机系统的新密码

如果中途出现错误,可以重试几次,仍然不行的话删除整个work目录,重新执行初始化再编译刷机包,最终结果如下

开发板

 

4,导出刷机包

  1. 1.  pmbootstrap export
开发板

 

 

执行以下命令找到刷机包位置

cd $(dirname $(readlink /tmp/postmarketOS-export/pmos-*.zip))

 

开发板

 

至此拿到刷机包

 

开发板

 

查找资料的时候有参考这篇文章的方案二部分,在此贴出

​​手机运行Docker: 从修改内核到刷入原生Linux | yzddMr6's Blog​

 

5,刷入手机验证并获取芯片控制器名称

音量上+电源开机进入twrp(twrp的安装是搞机必备,网上教程很多,在此不再重复)

​​小米(Mi) 6小米(Mi) 6 手机刷 TWRP 方法,刷三方Recovery方法(解决卡米问题)刷机解锁 (onfix.cn)​​​

点击安装

 

开发板

 

点击刷机包

 

开发板

 

确认刷入

 

开发板

 

刷机会出现错误,不用管

 

开发板

 

刷完重启,等待一段时间直到显示welcome信息

 

开发板

 

输入用户名:user,密码:自己之前设置的,进入系统

 

开发板

 

 

至此确认手机正常运行Linux系统,显示,触摸等正常工作。

 

6,解包获取移植需要的资料

解包获取的资料:

bootimg.cfg:boot分区配置信息,内核启动参数

config:默认内核编译配置,后续适配内核在此基础进行变更

firmware:启动加载必须的驱动固件文件

 

右键解压缩pmos-xiaomi-sagit.zip得到pmos-xiaomi-sagit

 

开发板

 

 

同样使用右键解压缩rootfs.tar.gz得到rootfs,在rootfs/boot文件夹拿到boot.img和内核编译的config配置

 

开发板

 

安装安卓boot打包解包工具:

  1.  sudo apt update
  2.   sudo apt install abootimg

 

把boot.img复制到任意的文件夹,然后使用以下命令解包:

  1. 1.  abootimg -x boot.img

 

得到boot分区配置bootimg.cfg

 

开发板

 

 

查看initrd.img文件格式为gzip压缩文件

 

开发板

 

使用gzip解压,发现解压失败,原因为后缀名不支持,我们使用mv命令复制initrd.img为initrd.img.gz,然后使用解压命令就可以成功解压了,解压后原来的initrd.img会被解压出的文件替换掉,这时initrd.img的格式为cpio镜像文件

 

开发板

 

使用cpio解压initrd.img镜像

  1. 1.  cpio -idmv < initrd.img

得到我们需要的boot阶段所必须的固件firmware,后面要编译进OH的ramdisk镜像中

 

开发板

 

 

7,获取正常启动的log

参考上面手机运行docker那篇文章,用usb连接电脑,设置好驱动

打开命令提示符,使用ssh连接Linux,ip是固定的172.16.42.1

 

  1. 1.  ssh user@172.16.42.1

 

开发板

 

输入dmesg打印输出内核log,这个是正常的内核启动log,复制下来保存好以便移植时启动出错或者驱动有问题时方便进行对照

  1. 1.  dmesg

 

开发板

 

8,获取设备名,分区信息

连接Linux,输入以下命令获取信息

 

获取USB控制器名称,后面移植hdc连接程序会用到

  1.   ls /sys/class/udc/
  2.   a800000.usb

 

获取存储控制器名称,后面配置分区会用到

  1.  ls /sys/devices/platform/soc

 

暂时判断1da4000.ufshc为存储控制器名称

 

开发板

 

 

重启,进入twrp,输入以下命令进入recovery的shell

  1. 1.  adb shell

 

开发板

 

 

输入以下命令可以交叉确认1da4000.ufshc为存储控制器名称

  1. 1.  ls dev/block/platform/soc/

 

开发板

 

获取分区信息

  1. 1.  ls -al /dev/block/platform/soc/1da4000.ufshc/by-name/

 

 

开发板开发板开发板

手机上勾选挂载vendor分区

 

开发板

 

  1. 1.  df -h

 

开发板

 

确认vendor分区对应到sde42  -> cust

system分区因为安装pmOS的缘故无法挂载,但是可以确定分区映射关系是,

/dev/block/platform/soc/1da4000.ufshc/by-name/cust   ---> sde42  --->  vendor

/dev/block/platform/soc/1da4000.ufshc/by-name/system   ---> sde43  --->  system

/dev/block/platform/soc/1da4000.ufshc/by-name/userdata   ---> sda17  ---> data

 

至此移植需要提前准备的信息基本讲完,下篇开始讲解OpenHarmony编译的部分,敬请期待

 

 

 

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分