0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

OpenHarmony标准系统开机时长优化

OpenAtom OpenHarmony 来源:未知 2023-04-08 02:50 次阅读

点击蓝字 ╳ 关注我们


开源项目 OpenHarmony
是每个人的 OpenHarmony

戴学跃

深圳市优博终端科技有限公司

OpenHarmony知识体系工作组

简介

万物互联时代,产品性能至关重要,而系统启动时间是系统性能的重要组成部分,因为用户必须等待系统启动完成后才能使用设备。对于经常需要进行冷启动的汽车等设备而言,较短的启动时间至关重要(没有人喜欢在等待几十秒后才能输入导航目的地),在金融交易设备、电子商务服务器、实时通信设备同样也有较高的应用场景,那我们该如何在OpenAtom OpenHarmony(简称OpenHarmony ) 标准系统现有的能力下,完成秒级开机?本文由深圳市优博终端科技有限公司的研发同学介绍一套关于优化OpenHarmony标准系统开机时长优化的方案,通过对硬件、Kernel、 Framework的相应优化让系统开机时长尽量缩短。

效果展示

下面给出系统开机时长优化前后的对比效果视频,优化前的开机时长在18秒左右,优化后的开机时间在7秒左右。



开发环境

硬件平台:RK3588
系统版本:OpenHarmony 3.1 Release
开发语言:C、 C++

四步带你体验OpenHarmony标准系统开机时长优化

一、调整硬件资源使用率
调整硬件资源相应配置参数使之尽可能地达到最优运行状态,这里所指的硬件资源是指 RAM、FLASH。

RAM:运存的调优需要根据厂商的指导文档在设备树文件<.dtsi文件>中进行调整,比如设定运存的时钟频率 memory-frequency、
设定内存带宽 memory-bandwidth、内存时序 memory-timings 等,Kernel 层可以对 swappiness、dirty_ratio、dirty_background_ratio、min_free_kbytes等相应值进行调整,来达到运存的性能调优。

FLASH:比如对 physical_block_size 项进行调整,目前 OpenHarmony 采用的文件系统为 ext4,可以在熟悉ext4文件系统后,然后对其中缓存、模式、压缩、清理等方向进行调优。减少KMSG与HiLog 日志输出,调整其输出等级。

二、Kernel 启动时长优化
Kernel 启动阶段会进行硬件检测、驱动加载、文件系统挂载、设置网络等,其中耗时比较长的基本上为驱动加载,因为这中间会有重复尝试跟 Sleep 的时间,需要重点关注,在 Kernel 启动的过程中可以将一些无用的子系统进行裁剪,比如 bootchart。

三、系统框架启动时长优化
在系统层启动时,需要启动很多服务,可以采用并行启动系统必要服务,延迟启动非必要服务,这些服务从加载到启动完成、其中比较耗时的有 so 加载,可采用多线程的方式对其进行加载,下面贴出多线程加载多个 so 文件的 Demo 代码;
#include 
#include
#include
#include
#include
void thread_func(void* handle){
// 空函数
}
int main(){
std::vector<std::string> lib_names = {"mpp1.so", "mpp2.so", "mpp3.so"};
std::vector<void*> handles;
for (const auto& lib_name : lib_names) {
void* handle = dlopen(lib_name.c_str(), RTLD_LAZY);
if (handle == nullptr) {
std::cerr << "Error loading library " << lib_name << ": " << dlerror() << std::endl;
return 1;
}
handles.push_back(handle);
}
std::vector<std::thread> threads;
for (const auto& handle : handles) {
threads.emplace_back(thread_func, handle);
}
for (auto& thread : threads) {
thread.join();
}
for (const auto& handle : handles) {
dlclose(handle);
}
return 0;
}
如果发现加载的单个so文件过大时,可采用多线程分段加载此so 文件。

四、 开机动画显示优化
优化思路大致为进入 bootAnimation 的 main 函数后,将动画图片采用数组或者链表的方式进行预加载,开启每秒60帧的刷新率,此处为什么要开60帧,因为如果设定为30帧时,出现掉帧的情况后,会出现肉眼可见的卡顿。当图片播放完成后,延迟几百毫秒左右再进入桌面,因为Launcher 加载已安装的 app ,需要一定的时间。下面是开机动画优化的部分内容 :
1.提高开机动画、渲染进程优先级;
"services" : [{
"name" : "render_service",
"path" : ["/system/bin/render_service"],
"uid" : "root",
"importance" : -20,
"gid" : ["system", "shell", "uhid", "root"]
}, {
"name" : "bootanimation",
"path" : ["/system/bin/bootanimation"],
"once" : 1,
"importance" : -20,
"uid" : "root",
"gid" : ["system", "shell", "uhid", "root"]
}
]
2. 提前加载开机动画图片;
ReadZipFile(BOOT_PIC_ZIP, imageVector_, jsonConfig);
imgVecSize_ = static_cast<int32_t>(imageVector_.size());
if (imgVecSize_ <= 0) {
PostTask(std::bind(&AppExecFwk::Stop, runner_));
LOGE("zip pic num is 0.");
return;
}


SortZipFile(imageVector_);
3.指定开机动画显示帧率;
OHOS::FrameCallback fcb = {
.userData_ = this,
.callback_ = std::bind(&BootAnimation::onVsync, this),
};
int32_t changefreq = static_cast<int32_t>((1000.0 / freq_) / 16);
ret=receiver_->SetVSyncRate(fcb,changefreq);
开机优化需要借助一些工具来分析比如串口工具、bootchart 生成的可视化图表来进行分析。
OpenHarmony 标准系统默认集成了bootchart,下面介绍如何使用bootchart 工具来获取开机性能数据及生成性能图片:
(1)开机完成后,运行 hdc_std shell
(2)运行 begetctl bootchart enable
(3)运行 reboot 或者断电重启
(4)运行 begetctl bootchart stop
(5)运行 begetctl bootchart disable
(6)进入到/data/bootchart/文件夹下查看是否有
(7)header、proc_diskstats.log、proc_ps.log、proc_stat.log
(8)在/data/bootchart/目录下执行命令:tar -czf bootchart.tgz *
(9)将bootchart.tgz 导出到本地磁盘上
(10)hdc_std file recv /data/bootchart/bootchart.tgz ./
(11)生成开机性能图片 java -jar bootchart.jar bootchart.tgz
上面的bootchart.jar 需要下载源码去编译生成或者下载他人已经编译好的jar包。源码下载地址 https://sourceforge.net/projects/bootchart/ 。

下图为 bootchart 生成的 OpenHarmony性能可视化视图


总结

通过本篇文章介绍,您对OpenHarmony标准系统下性能优化的功能应该有了初步的了解。如果您对本篇文章内容感兴趣,可以根据本篇文章介绍进行研究和使用。同时也欢迎更多开发者与我们共享开发成果,分享技术解读与经验心得。


原文标题:OpenHarmony标准系统开机时长优化

文章出处:【微信公众号:OpenAtom OpenHarmony】欢迎添加关注!文章转载请注明出处。

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

    关注

    57

    文章

    2372

    浏览量

    42911
  • OpenHarmony
    +关注

    关注

    25

    文章

    3729

    浏览量

    16407

原文标题:OpenHarmony标准系统开机时长优化

文章出处:【微信号:gh_e4f28cfa3159,微信公众号:OpenAtom OpenHarmony】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    AM574x延长开机时间(POH)

    电子发烧友网站提供《AM574x延长开机时间(POH).pdf》资料免费下载
    发表于 10-10 09:22 0次下载
    AM574x延长<b class='flag-5'>开机时</b>间(POH)

    基于ArkTS语言的OpenHarmony APP应用开发:HelloOpenharmony

    1、程序简介该程序是基于OpenHarmony标准系统编写的UI应用类:HelloOpenHarmony。本案例是基于API9接口开发。本案例已在OpenHarmony凌蒙派-RK35
    的头像 发表于 09-15 08:09 423次阅读
    基于ArkTS语言的<b class='flag-5'>OpenHarmony</b> APP应用开发:Hello<b class='flag-5'>Openharmony</b>

    AM62x延长开机时间应用说明

    电子发烧友网站提供《AM62x延长开机时间应用说明.pdf》资料免费下载
    发表于 09-13 10:01 0次下载
    AM62x延长<b class='flag-5'>开机时</b>间应用说明

    瑞芯微RK3566鸿蒙开发板OpenHarmony标准系统应用兼容性测试指导

    本文OpenHarmony标准系统应用兼容性测试指导,适用鸿蒙系统软件开发测试的新手入门学习课程,设备为触觉智能的瑞芯微RK3566开发板,型号Purple Pi OH。是Laval官方社区主荐的一款鸿蒙开发主板。
    的头像 发表于 09-10 11:56 422次阅读
    瑞芯微RK3566鸿蒙开发板<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>应用兼容性测试指导

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeMap

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的安全关联容器:SafeMap。OpenHarmony提供了一个线程安全的map实现。SafeMap在STLmap基础上封装互斥锁
    的头像 发表于 08-30 12:42 392次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>的C++公共基础类库案例:SafeMap

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeQueue

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的线程安全队列:SafeQueue。线程安全队列,是在dequeue的基础上封装std::lock_guard,以此实现线程的相关
    的头像 发表于 08-30 12:41 332次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>的C++公共基础类库案例:SafeQueue

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeStack

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的线程安全队列:SafeQueue。线程安全队列,是在dequeue的基础上封装std::lock_guard,以此实现线程的相关
    的头像 发表于 08-30 12:41 357次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>的C++公共基础类库案例:SafeStack

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeBlockQueue

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的读写锁:SafeBlockQueue。线程安全阻塞队列SafeBlockQueue类,提供阻塞和非阻塞版的入队入队和出队接口,并提
    的头像 发表于 08-30 12:41 328次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>的C++公共基础类库案例:SafeBlockQueue

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeStack

    /a28_utils_safestack 2、基础知识 C++公共基础类库为标准系统提供了一些常用的C++开发工具类,包括: 文件、路径、字符串相关操作的能力增强接口 读写锁、信号量、定时器、线程增强及线程池等接口
    发表于 08-21 14:51

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeQueue

    /a27_utils_safequeue 2、基础知识 C++公共基础类库为标准系统提供了一些常用的C++开发工具类,包括: 文件、路径、字符串相关操作的能力增强接口 读写锁、信号量、定时器、线程增强及线程池等
    发表于 08-21 10:56

    请求推荐无需NPU的OpenHarmony标准系统ARM开发板

    请教一下大佬们,目前的需求是在国产ARM开发板上跑OpenHarmony标准系统,无需NPU/GPU,其它配置(CPU、RAM等)可以尽量高点,价位在2k以内,球球推荐!感谢大佬们!
    发表于 08-16 16:25

    OpenHarmony标准系统C++公共基础类库案例:HelloWorld

    1、程序简介该程序是基于凌蒙派OpenHarmony-v3.2.1标准系统C++公共基础类库的简单案例:HelloWorld。主要讲解C++公共基础类库案例如何搭建和编译。2、程序解析2.1、创建
    的头像 发表于 08-13 08:23 546次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>C++公共基础类库案例:HelloWorld

    基于OpenHarmony标准系统的C++公共基础类库案例:ThreadPoll

    1、程序简介 该程序是基于OpenHarmony标准系统的C++公共基础类库的线程池处理:ThreadPoll。 本案例完成如下工作: 创建1个线程池,设置该线程池内部有1024个线程空间。 启动5
    发表于 08-12 11:42

    OpenHarmony开机优化

    对其进行详细的性能分析,从而优化系统启动速度和运行效率。 三丶开机优化 开机优化的主要目的是为了
    发表于 07-01 16:39

    鸿蒙OpenHarmony南向:【Hi3516标准系统入门(命令行方式)】

    除小型系统外,Hi3516DV300开发板还支持标准系统。此章节简要介绍如何使用命令行在Hi3516DV300开发板上进行标准系统的开发。
    的头像 发表于 05-08 09:26 910次阅读
    鸿蒙<b class='flag-5'>OpenHarmony</b>南向:【Hi3516<b class='flag-5'>标准系统</b>入门(命令行方式)】