• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# rom_ram_analyzer
2
3## 目的
4
5分析各部件的rom占用,结果以xls和json格式进行保存
6
7## 支持产品
8
9理论上可以支持所有产品,只要在config.yaml中进行了配置即可,目前已配置产品包括:
101. ipcamera_hispark_taurus
111. ipcamera_hispark_taurus_linux
121. wifiiot_hispark_pegasus
131. hispark_pegasus_mini_system
141. hispark_taurus_mini_system
15
16## 代码思路
17
181. 扫描BUILD.gn文件,收集各个target的编译产物及其对应的component_name, subsystem_name信息,并存储到config.yaml中的gn_info_file字段指定的json文件中。如果BUILD.gn中没有查找到,则直接使用get_subsytem_component.py中预先收集好的数据(根据bundle.json192. 根据配置文件config.yaml扫描产品的编译产物目录,得到真实的编译产物信息(主要是大小)
203. 用真实的编译产物与从BUILD.gn中收集的信息进行匹配,从而得到编译产物-大小-所属部件的对应信息
214. 如果匹配失败,会直接利用grep到项目路径下进行模糊搜索,取出现次数top1的BUILD.gn,并根据该BUILD.gn文件去查找子系统和部件
225. 如果还搜索失败,则将其归属到NOTFOUND
23
24## 说明
25
261. 关于UNDEFINED:如果target的声明中和get_subsystem_component.py(原作者:陈毓德)脚本的运行结果中都没有查找到子系统和部件信息,则为UNDEFINED
271. 关于NOTFOUND:表示对应的编译产物没有在BUILD.gn的扫描结果中匹配(包括模糊匹配)到
281. 本工具是基于gn的template进行匹配,如果新增了自定义的template,则需要相应在代码中进行配置
291. 由于本工具是进行的静态扫描,且部分gn文件中使用了较为复杂的gn语法,因此本工具的**准确率无法达到100%,结果仅供参考**
301. rk3568因为主要使用的是自定义的template,所以能够在编译阶段收集更多有效信息,因此建议使用standard目录下的脚本进行分析
31
32**子系统及部件的查找过程**
33
341. 先查找target声明中的subsystem_name字段和part_name字段,如果查找到,则使用target声明中的作为结果
351. 否则到get_subsystem_component.py的运行结果(默认是会保存到sub_com_info.json文件)中查找
361. 如果上述两个地方都没有查找到,则使用UNDEFINED作为子系统名和部件名进行保存
37
38**建议**
39
40因为是静态扫描,因此过于复杂的gn语法会导致扫描BUILD.gn文件时无法确定其编译产物,典型的:在for循环中嵌套target声明.因此就本工具来说,不建议使用过于复杂的gn语法.
41
42## 使用
43
44前置条件:
45
461. 获取整个本文件所在的整个目录
471. 对系统进行编译
481. linux平台
491. python3
501. 安装requirements
51    ```txt
52    xlwt==1.3.0
53    ```
54
551. `python3 rom_analysis.py --product_name {your_product_name} --oh_path {root_path_of_oh} [-g] [-s] [-b]`运行代码,其中-g表示直接使用上次扫描的BUILD.gn的结果,-s表示直接使用已有的子系统和部件信息,此二者默认都会重新扫描, -b表示在结果中添加各部件的baseline信息(根据bundle.json).eg: `python3 rom_analysis.py --product_name ipcamera_hispark_taurus -b`.
561. 运行完毕会产生4个json文件及一个xls文件,如果是默认配置,各文件描述如下:
57   - gn_info.json:BUILD.gn的分析结果
58   - sub_com_info.json:从bundle.json中进行分析获得的各部件及其对应根目录的信息
59   - {product_name}_product.json:该产品实际的编译产物信息,根据config.yaml进行收集
60   - **{product_name}_result.json:各部件的rom大小分析结果**
61   - **{product_name}_result.xls:各部件的rom大小分析结果**
62   - rom_ram_baseline.json:各部件在bundle.json中定义的rom和ram的基线
63
64## 新增对产品的支持
65
66config.yaml中进行配置即可,格式说明如下:
67```yaml
68ipcamera_hispark_taurus: # 产品名称,需要和命令行参数中的-p参数一致
69  product_infofile: ipcamera_hispark_taurus_product.json # 保存编译产物信息的json文件
70  output_name: ipcamera_hispark_taurus_result.json # 保存结果的文件的名字
71  product_dir: # [required]
72    root: out/hispark_taurus/ipcamera_hispark_taurus/rootfs # 待分析的编译产物的根目录
73    relative: # 针对性分析的子目录,key无所谓,value应当是root的子目录. 作者通常是使用so作为动态库文件目录的key,bin作为可执行文件目录的key,a作为静态库文件目录的key
74      bin: bin
75      so: usr/lib
76      etc: etc
77    rest: True  # 是否将上面root目录下除了relative指定的目录归到etc并进行匹配
78  query_order:  # 匹配顺序,key应当何relative字段中的key一致,value应当在上面的target_type字段中,脚本会按照配置的顺序对文件进行匹配.对于归类为etc的产品,会匹配target_type中的所有模板类型,找到即可.因此query_order中无需配置etc项.
79    so:
80      - shared_library
81      - ohos_shared_library
82      - ohos_prebuilt_shared_library
83      - lite_library
84      - lite_component
85      - target
86    bin:
87      - executable
88      - ohos_executable
89      - lite_component
90```
91
92## 新增template
93
94为了提高准确率,本工具是按照gn的template类型对BUILD.gn进行扫描,因此如果BUILD.gn中新增了template,需要在代码层数进行相应的更改.主要是在config.py中配置Processor,并在config.yaml中添加相应内容
95
96## 如何提高准确率
97
981. 如果已知编译产物不可能从某些目录下的BUILD.gn产生,则可以将其对应目录加入到config.yaml的black_list,从而不对该目录下的BUILD.gn进行扫描,以减少出错概率
991. 对于已知检测错误的或NOTFOUND的编译产物,如果知道其正确的部件和子系统,可在config.yaml中的manual_config进行配置
100