RK3568 Android13 源码编译

提示:RK3568 Android13 源码编译 脚本,源码编译管理方式优化


假设 源码 sdk 已经在ubuntu 上部署好了。接下来是编译的工作,这里核心规整编译脚本,对编译步骤简要给出。

获取源码

假设所有的编译环境编译脚本已经配置,拿到android 源码,解压

tar -vxf rk3568android13full20240918.tar.xz


drwxrwxr-x 37 wfc    wfc     4096 Mar 13 17:38 rk3568_android13
drwxr-xr-x  2 nobody nogroup 4096 Feb  6 00:10 rk3568_android13_full_20240918.tar



在这里插入图片描述

设置屏幕配置

最终是需要屏幕来显示的,如果自己只是拿个开发板学习而言,这里可以不配置的。但是还是建议根据自己的实际屏幕 来进行配置,没有屏幕显示 则呢么搞开发呢?

确认屏幕

确定要使用的屏幕种类,这个支持的屏幕是根据硬件方案选型来决定的

修改源码的设备树

修改源码kernel-5.10/arch/arm64/boot/dts/rockchip目录下的topeet-screen-lcds.dtsi文件。

路径: rk3568_android13/kernel-5.10/arch/arm64/boot/dts/rockchip/topeet-screen-lcds.dtsi

根据自己需求,修改对应的值:

rockchip$ cat topeet-screen-lcds.dtsi 
/************************单屏显示******************************/
#define LCD_TYPE_MIPI       //in vp 1
//#define LCD_TYPE_LVDS_10_1_1024X600  //in vp 2
//#define LCD_TYPE_LVDS_10_1_1280X800_gt911  //in vp 2
//#define LCD_TYPE_LVDS_10_1_1280X800_gt9271 //in vp 2
//#define LCD_TYPE_LVDS_7_0   //in vp 2
//#define LCD_TYPE_HDMI_VP0   //hdmi in vp 0
//#define LCD_TYPE_HDMI_VP1   //hdmi in vp 1
//#define LCD_TYPE_EDP_VGA //in vp 0 


修改线程数

在编译Android系统时,可以通过调整线程数来控制并行编译的任务数量,使用多线程可以加快构建速度。要注意根据Ubuntu的处理器内核总数以及内存大小来设置合适的线程数。过高的线程数可能导致系统资源的竞争,过低的线程数则不能充分利用系统的并行处理能力。找到合适的线程数可以加快编译速度,提高效率

可以在build.sh编译脚本中修改线程数,如下图所示:
在这里插入图片描述

这里注意一点:
线程数建议配置机器的3/4 ,配置过高编译失败,配置过低浪费了机器性能。

整体编译Android固件

注意:编译系统时一定要使用普通权限编译。

配置JDK java 环境 source javaenv.sh

进入到rk3568android13文件夹,输入以下命令设置java版本为1.8版本,确认java版本
是1.8版本之后,才可以进行下一步编译,如下图所示:

wfc@wfc-X99:~/wfc/Android/android13/rk3568_android13$ source javaenv.sh
wfc@wfc-X99:~/wfc/Android/android13/rk3568_android13$ java -version
openjdk version "1.8.0_442"
OpenJDK Runtime Environment (build 1.8.0_442-8u442-b06~us1-0ubuntu1~20.04-b06)
OpenJDK 64-Bit Server VM (build 25.442-b06, mixed mode)

使能编译 build/envsetup.sh lunch topeet_rk3568-userdebug

输入以下命令使能编译环境:

wfc@wfc-X99:~/wfc/Android/android13/rk3568_android13$ source build/envsetup.sh
wfc@wfc-X99:~/wfc/Android/android13/rk3568_android13$ lunch topeet_rk3568-userdebug

在这里插入图片描述

整体编译固件 ./build.sh-AUCKu

最后输入以下命令开始整体编译了

./build.sh-AUCKu

在这里插入图片描述

等待编译结束,在指定的文件下生成 打包相关的包文件

优化编译脚本,提升效率

上面介绍了配置环境,整编脚本。这里需要讲的就是整体编译脚本 如何写成脚本,执行编译脚本即可 直接编译。不用一步两步三步。 如下 ,在 源码目录写一个.sh 脚本,将编译的命令全部写在脚本里面,如下:

wfc_build.sh


wfc@wfc-X99:~/wfc/Android/android13/rk3568_android13$ cat wfc_build.sh 
#!/bin/bash
source javaenv.sh
source build/envsetup.sh
lunch topeet_rk3568-userdebug
./build.sh -AUCKu

当我们需要编译固件的时候,直接 执行 脚本即可。

./wfc_build.sh 

拓展

可以进一步优化脚本,写入固件属性值、日期、编译完成后 删除部分冗余文件,下面举一个例子

#!/bin/bash

#生成软件路径
FS_SW_BIN_PATH=rockdev

# WFC_CLOUD_20250311_V1.0.0.0
#项目名
export FS_PRODUCT_NAME=SM666_CLOUD
#日期
FS_SW_DATE=20250312
#版本号
export FS_PRODUCT_VERSION=1.0.0.0
#完整项目软件版本名
export FS_SW_VERSION=${FS_PRODUCT_NAME}_${FS_SW_DATE}_V${FS_PRODUCT_VERSION}

function binPac()
{
	source build/envsetup.sh
	lunch rk3566_r-userdebug
	./build.sh -UKAoup	#	带OTA
#	./build.sh -UKAup	#	无OTA	

	mkdir ./${FS_SW_BIN_PATH}/${FS_SW_VERSION}

	cp ./${FS_SW_BIN_PATH}/Image-rk3566_r/update.img ./${FS_SW_BIN_PATH}/${FS_SW_VERSION}/${FS_SW_VERSION}.img
	
	cp ./${FS_SW_BIN_PATH}/Image-rk3566_r/rk3566_r-ota-*.zip ./${FS_SW_BIN_PATH}/${FS_SW_VERSION}/${FS_SW_VERSION}_ota.zip
	
	rm -rf ./${FS_SW_BIN_PATH}/Image-rk3566_r
	
    return 0;
}


binPac;

总结

  • 这里以 RK3568 Android13 编译流程做了一个总结,RK体系356X 系列配置基本这个流程,参数稍微修改。
  • 其它平台,如MTK 平台,脚本的应用非常广泛,实际开发中 也是如此。
### SQL 中用于计算字符串长度的函数 在不同的数据库管理系统 (DBMS) 中,用于计算字符串长度的函数可能有所不同。以下是几种常见 DBMS 的实现方式: #### MySQL 和 SQLite `LENGTH()` 函数返回的是字符串所占用的字节数,而 `CHAR_LENGTH()` 或者 `CHARACTER_LENGTH()` 则返回字符串中的实际字符数[^1]。 ```sql SELECT LENGTH(name) AS byte_length, CHAR_LENGTH(name) AS char_count, name FROM user; ``` #### Oracle Oracle 提供了多种函数来处理字符串长度的计算。其中: - `LENGTH()` 计算字符串的实际字符数量。 - `LENGTHB()` 计算字符串的字节长度(适用于多字节字符集环境)。需要注意的是,在某些情况下,如果输入字符串过长(超过 4000 字符),可能会导致错误,此时需要其他方法替代[^2]。 示例代码如下: ```sql -- 使用 LENGTH() 获取字符数 SELECT LENGTH('测试字符串') AS char_count FROM dual; -- 使用 LENGTHB() 获取字节数 SELECT LENGTHB('测试字符串') AS byte_length FROM dual; ``` 对于超长字符串的情况,可以通过 PL/SQL 编写自定义逻辑或者借助外部工具完成更复杂的操作。 #### SQL Server 在 Microsoft SQL Server 中,通常会使用 `LEN()` 来获得字符串的字符数目。注意这里不区分单双字节编码下的差异;另外还有专门针对 Unicode 类型列设计好的 NCHAR/NVARCHAR 支持版本即 DATALENGTH()[^4]。 例子展示如何调用这些内置功能: ```sql -- LEN(): 返回排除尾随空格后的字符计数值 SELECT LEN('example ') AS example_len; -- DATALENGTH(): 给定表达式的总存储大小以位为单位报告回来 SELECT DATALENGTH(N'你好世界') AS data_length_in_bytes; ``` 综上所述,不同类型的 RDBMS 都有自己的特定做法去解决这个问题,并且提供了丰富的选项让用户依据具体场景选取最合适的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

野火少年

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值