高通QFIL dump 整个flash镜像

目录

导出为一个partition.bin的方案

导出所有分区的方案


导出为一个partition.bin的方案

通常QFIL下载的xml,我们使用高通提供的ptool工具(本人之前的文章中有提到)生成的rawprogram0_BLANK_GPT.xml可以派上用场,另外需要普及一个简单的概念

program 在高通的xml配置中表示下载;

read 表示读取.

<?xml version="1.0" ?>
<data>
  <!--NOTE: This is an ** Autogenerated file **-->
  <!--NOTE: This file writes a VALID but EMPTY partition table to sector 0 **-->
  <!--NOTE: Sector size is 512bytes-->
  <program SECTOR_SIZE_IN_BYTES="512" file_sector_offset="0" filename="gpt_empty0.bin" label="PrimaryGPT" num_partition_sectors="33" partofsingleimage="false" physical_partition_number="0" readbackverify="false" size_in_KB="16.5" sparse="false" start_byte_hex="0x0" start_sector="0"/>
</data>

我们想备份dump整个emmc的数据,下面几个点需要关注:

  1. emmc的总大小

关于flash的总大小,QFIL工具可以很容易的读取出,但是需要注意,机器切换至EDL模式后,先load一个和该设备对应的firmware的版本,然后

高通QFIL dump 整个flash镜像

比如,当前我这边设备的总block数是0x747c000,16进制换算为10进制数为 122142720此处就代表整个flash的sectors扇区

高通QFIL dump 整个flash镜像

而根据xml的配置

我们的num_partition_sectors = 122142720

 单位 SECTOR_IN_BYTES为512Byte,所以,我们对应的flash总大小size_in_KB 

(122142720 * 512)/1024 = 122142720/2 = 61071360KB

于是,我们最后得到的dump整个emmc为一个镜像的二进制文件配置

<?xml version="1.0" ?>
<data>
  <!--NOTE: This is an ** Autogenerated file **-->
  <!--NOTE: Sector size is 512bytes-->
  <read SECTOR_SIZE_IN_BYTES="512" file_sector_offset="0" filename="partition.bin" label="PrimaryGPT" num_partition_sectors="122142720" physical_partition_number="0" size_in_KB="61071360.0" sparse="false" start_byte_hex="0x0" start_sector="0"/>
</data>

接下来主要是一样选择patch0.xml及漫长的等待读取过程.

2. 高通gpt分区表的格式和算法

SECTOR_SIZE_IN_BYTES="512"  每个扇区的字节数,flash的type为emmc一般是512,之前做过的的UFS项目为4096

filename="partition.bin" 分区的名称

num_partition_sectors="122142720"  分区的总扇区数

size_in_KB="61071360.0" 分区的实际大小,单位为KB

sparse="false" 是否以打散的方式read或program

start_byte_hex="0x0" 起始地址

start_sector 起始扇区

通常情况下,有分区表前提下,对于dump flash数据而言,基本需要计算的主要是sectors或者是实际的大小即可.

通常 下一分区的start_sector - 上一分区的start_sector = 上一分区的num_partition_sectors

导出所有分区的方案

对于所有分区导出,稍微比oneimage麻烦一些,

1. 需要原始的未被打散的rawprogram0.xml

2. 所有分区的filename都必须填充,只要是partition.xml里的分区,都要加上

高通QFIL dump 整个flash镜像

A/B分区的填写相应的a/b 镜像,非A/B的直接bak镜像,总而言及就是filename 不能空.

3. 最重要的userdata大小的计算

方便说明,我上传了处理项目对应的计算举例,

  • 以sectors的计算如下:

读取的sectors数,从上面我们通过QFIL拿到了sector数为122142720

userdata的扇区数 为 122142720-33-21758464 = 100384223

<program SECTOR_SIZE_IN_BYTES="512" file_sector_offset="0" filename="userdata.img" label="userdata" num_partition_sectors="100384223" partofsingleimage="false" physical_partition_number="0" programbackverify="false" size_in_KB="50192112.0" sparse="false" start_byte_hex="0x298040000" start_sector="21758464"/>
  <program SECTOR_SIZE_IN_BYTES="512" file_sector_offset="0" filename="gpt_main0.bin" label="PrimaryGPT" num_partition_sectors="34" partofsingleimage="true" physical_partition_number="0" programbackverify="false" size_in_KB="17.0" sparse="false" start_byte_hex="0x0" start_sector="0"/>
  <program SECTOR_SIZE_IN_BYTES="512" file_sector_offset="0" filename="gpt_backup0.bin" label="BackupGPT" num_partition_sectors="33" partofsingleimage="true" physical_partition_number="0" programbackverify="false" size_in_KB="16.5" sparse="false" start_byte_hex="(512*NUM_DISK_SECTORS)-16896." start_sector="NUM_DISK_SECTORS-33."/>

size_in_KB = (100384351 * 512) / 2 = 50192111.5KB

  • 以读取partition方式计算:

adb shell

ls -al /dev/block/by-name/userdata

lrwxrwxrwx 1 root root 21 1970-01-01 08:41 /dev/block/by-name/userdata -> /dev/block/mmcblk0p87

cat /proc/partitions 查看对应blk的大小

cat /proc/partitions | grep mmcblk0p87

259       55   50192111 mmcblk0p87

50192111KB即是userdata对应size的大小.

发现了一个小问题,以sector计算的大小实际是50192111.5,但读取partition的值是50192111,最终填了50192111.5,然后导出的usserdata大小50192112KB.

上一篇:Mysql创建表时同时进行分区


下一篇:2021华为Java面试真题:合肥java开发招聘程序员