高通QSSI方式导致CI编译失败问题记录

news2025/1/10 21:33:00

一、问题背景
1、QSSI说明
QSSI 是 Qualcomm Single System Image 的缩写,高通平台从Android Q开始,为了解决Android碎片化问题,把system.img和vendor.img进一步拆分,增加了QSSI编译选项,QSSI就是用来编译system.img的。

2、有QSSI和没有QSSI的编译流程对比
没有QSSI时:

 source build/envsetup.sh
 lunch target
 make

有QSSI时:

#编译system.img
$ source build/envsetup.sh
$ lunch qssi
$ make
#编译其他img
$ source build/envsetup.sh
$ lunch target
$ make

3、编译方式的变化
增加了QSSI的编译选项,高通平台的编译模式也对应发生了变化,从传统的make编译脚本变为使用build.sh文件进行编译。
从只编译一个target选项,到现在需要分别编译QSSI和target两个部分。

二、问题介绍
1、问题现象
jenkins搭建CI,new build可以编译成功,但是remake一直编译失败,查看编译脚本,对比了new和remake的区别,

参考图示,可以发现,new编译前会做make clean的动作,清理编译产物,但是remake时只进行了更新编译,之前的编译产物还是存在的。

编译方式的不同,导致了不同的编译结果。
在这里插入图片描述
2、log分析
1)分析报错log,log显示如下:
在这里插入图片描述
报错提示找不到qssi-target_files-xxx.zip压缩包。但是按照报错提示路径去找压缩包时,可以看到对应压缩包文件是存在的,而且压缩包不止一个,同目录下同时存在多个带有数字后缀的压缩包,所有就有两个疑问:
a、为什么会产生这么多带有数字编号的压缩包?
b、已经存在对应的压缩包了,为什么还会因为找不到压缩包而报错?

2)带着上述疑问,同步使用另外一台机器编译,发现如下:
在这里插入图片描述
同样remake,本地可以编译成功,但是jenkins CI编译fail,并且CI报错的文件压缩包名,跟本地生成的包名有差异?

3)分析代码
首先查找qssi*-target_files-*.zip压缩包文件名的由来,在build/make/core/version_defaults.mk文件中
在这里插入图片描述
可以看到文件名字tag是通过匹配HAS_BUILD_NUMBER宏来决定的,匹配成功文件名tag即带有数字编号,匹配不成功,文件名tag就是编译机器的用户名,本地机器环境中没有BUILD_NUMBER宏,所有生成的压缩包名固定不变,但jenkins环境存在BUILD_NUMBER编译宏,所以生成的压缩包名跟随jenkins编译序号变化。再叠加remake操作,编译产物没有被清理,就会导致编译生成的文件目录里有一系列带编译序号的压缩包存在。

4)既然压缩包存在,为什么会匹配失败呢?
在编译脚本build.sh文件中,OTA生成函数中会将需要check的压缩包查找出来,这个查找使用的是"find"模糊匹配,Jenkins编译时就会匹配出多个文件包,并且会将匹配出来的多个包当成一个文件名,在进行校验的时候,就会因为包名不一致校验失败,导致编译报错。
在这里插入图片描述以上描述可以理解成:
在这里插入图片描述
BUILD_NUMBER是jenkins的特定宏,高通的编译脚本里也应用了这个宏,所以CI remake的时候匹配成功了,编译生成产物就会带有数字编号,如qssi-target-files-1907.zip等,再加上remake编译,不清理编译产物,就会导致编译目录里存在多个带有数字编号的压缩包,find模糊查找到多个压缩包,并把它们当成一个文件,导致校验fail编译失败了。

三、解决方案
CI执行编译前,主动在CI jenkins job中将相关报错文件删除,保证编译目录下只存在一个压缩包。
在这里插入图片描述
四、经验共享
高通有QSSI编译选项的平台,在CI搭建过程中,都存在这个问题,所以解决方案同样适用,目前此方案已应用到后续高通项目。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/430879.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据结构(ArrayList)

文章目录一、线性表二、顺序表2.1 ArrayList(1)概念(2)ArrayList 的构造(3)ArrayList 的方法(4) ArrayList的遍历(5)ArrayList的优缺点2.2 链表一、线性表 概…

symmetric funtion and antisymmetric function(对称性函数和反对称性函数)

symmetric funtion and antisymmetric functionantisymmetric functionsymmetric funtion附录今天看资料的时候遇到了一个说法,文中提及,f(x)f\left(x\right)f(x) 是一个 antisymmetric function,看到这个说法有点儿懵,这里特来记…

上海亚商投顾:沪指逼近3400点 CPO概念股再度爆发

上海亚商投顾前言:无惧大盘涨跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。 市场情绪沪指今日震荡反弹,午后逼近3400点关口,创业板指则小幅调整。CPO概念股再度爆发,…

[oeasy]python00134_[趣味拓展]python起源_历史_Guido人生_ABC编程语言_Tanenbaum

python 历史 回忆上次内容 颜文字是kaomoji 把字符变成一种图画的方法一层叠一层很多好玩儿的kaomoji是一层层堆叠起来的meme 虚拟的表情也在真实世界有巨大影响 一步步地影响 字符编码就是这样一步步发展过来的python也是 一步步 发展到今天的 python究竟是 怎么发展的呢&…

异常(throwable)

异常 异常分类 (1)Throwable类 所有的异常类型都是它的子类,它派生两个子类Error、Exception。 (2)Error类 表示仅靠程序本身无法恢复的严重错误(内存溢出动态链接失败、虚拟机错误)&#…

分布式定时任务

本文引用了谷粒商城的课程 定时任务 定时任务是我们系统里面经常要用到的一些功能。如每天的支付订单要与支付宝进行对账操作、每个月定期进行财务汇总、在服务空闲时定时统计当天所有信息数据等。 定时任务有个非常流行的框架Quartz和Java原生API的Timer类。Spring框架也可以…

【面试题】20个常见的前端算法题,你全都会吗?

现在面试中,算法出现的频率越来越高了,大厂基本必考 今天给大家带来20个常见的前端算法题,重要的地方已添加注释,如有不正确的地方,欢迎多多指正💕 大厂面试题分享 面试题库 前后端面试题库 (…

Spring 6 正式“抛弃”feign

近期,Spring 6 的第一个 GA 版本发布了,其中带来了一个新的特性——HTTP Interface。这个新特性,可以让开发者将 HTTP 服务,定义成一个包含特定注解标记的方法的 Java 接口,然后通过对接口方法的调用,完成 …

Simulink仿真封装中的参数个对话框设置

目录 参数和对话框窗格 初始化窗格 文档窗格 为了更加直观和清晰的分析仿真,会将多个元件实现的一个功能封装在一起,通过参数对话框窗格,可以使用参数、显示和动作选项板中的对话框控制设计封装对话框。如图所示: 参数和对话框…

刘二大人《Pytorch深度学习实践》第六讲逻辑斯蒂回归

文章目录线性回归和逻辑斯蒂回归的区别课上代码交叉熵函数的理解线性回归和逻辑斯蒂回归的区别 线性回归一般用于预测连续值变量,如房价预测问题。 线性回归的一般表达式为: 代价函数为MSE(均方误差): 其中权重thet…

Linux Shell 实现一键部署二进制Rabbitmq

rabbitmq 前言 RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而集群和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代…

openai的whisper语音识别介绍

openAI发布了chatgpt,光环一时无两。但是openAI不止有这一个项目,它的其他项目也非常值得我们去研究学习。 今天说说这个whisper项目 https://github.com/openai/whisper ta是关于语音识别的。它提出了一种通过大规模的弱监督来实现的语音识别的方法。…

C++之深入解析STL unordered_map的底层实现原理

C STL 标准库中,不仅是 unordered_map 容器,所有无序容器的底层实现都采用的是哈希表存储结构。更准确地说,是用“链地址法”(又称“开链法”)解决数据存储位置发生冲突的哈希表,整个存储结构如下所示&…

JVM 垃圾收集器详解

一、垃圾收集器 如果说收集算法是内存回收的方法论,那垃圾收集器就是内存回收的实践者。《Java虚拟机规范》中对垃圾收集器应该如何实现并没有做出任何规定,因此不同的厂商、不同版本的虚拟机所包含的垃圾收集器都可能会有很大差别,不同的虚…

基于遗传算法的中药药对挖掘系统的设计与实现

用数据挖掘技术研究了中药方剂配伍的规律。主要工作:分析了关联规则存在的问题,引入双向关联规则的概念;介绍了遗传算法的基本原理,研究了遗传算法在数据挖掘中的应用;将方剂库转换为位图矩阵,大大提高搜索…

Mac重启清理缓存会怎么样 mac清理缓存怎么清理

众所周知,Mac电脑有着流畅的操作系统,因此,很多用户都会选择使用Mac电脑办公。随着日常使用,系统缓存数据越来越大,某些Mac电脑(尤其是小内存版本的Mac电脑)可能会出现“系统”占存储空间比例较…

初始单片机.md

1.如何将HEX文件烧录到单片机 STC-ISP STC-ISP是一款单片机下载编程烧录软件,是针对STC系列单片机而设计的,可下载STC89系列、12C2052系列和12C5410等系列的STC单片机,使用简便。 思路:将电脑磁盘上已存在的文件通过串口的方式下…

python中第三方库xlrd和xlwt的使用教程

excel文档名称为联系人.xls,内容如下: 一、xlrd模块用法 1.打开excel文件并获取所有sheet import xlrd# 打开Excel文件读取数据 data xlrd.open_workbook(联系人.xls)sheet_name data.sheet_names() # 获取所有sheet名称 print(sheet_name) # [银…

python依次运行多个代码遇到的同步与异步问题

1、要实现在一个Python代码运行完后紧接着运行另一个Python代码,可以使用Python的subprocess模块。该模块可以创建新进程并与之交互,可以用于在Python代码中启动新的程序或脚本。 下面是一个示例代码,用于在运行完code1.py后紧接着运行code2…

论文配色方案(收藏)

方案一:复古 系列色——十六进制颜色码: 0780cf - 765005 - fa6d1d - 0e2c82 - b6b51f - da1f18 - 701866 - f47a75 - 009db2 - 024b51 - 0780cf - 765005 系列色——RGB颜色值: (7,128,207)-(118,80,5&…