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

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

3天内不再提示

如何进行OpenHarmony音频特性架构设计和开发工作

OpenAtom OpenHarmony 来源:OpenAtom OpenHarmony 作者:OpenAtom OpenHarmony 2022-05-11 10:02 次阅读

本期 OpenAtom OpenHarmony(以下简称“OpenHarmony”)开发者故事,我们特别采访了 2 月代码最佳贡献者、一位接触 OpenHarmony 1 年左右,2022 年初便完成高难度开发项目的开发者——润和软件资深软件开发工程师赵海鹏。
赵海鹏是润和 OpenHarmony 南向业务媒体领域负责人,主要承担 Audio 开发工作。在 RK3568 平台 Audio Driver Model 适配开发过程中,在突遇西安疫情的情况下,硬件和沟通问题都面临巨大的挑战,面对急迫性的项目需求,赵海鹏和他的伙伴迎难而上,通过各种渠道去协调设备,把做好的固件寄送出去,协调软件所的伙伴们做远程测试,包括焊接等等,几乎每天在线工作及沟通 12 个小时以上,最终克服困难圆满完成任务。
我们与赵海鹏一起聊了他加入 OpenHarmony 生态的初心、对 OpenHarmony 架构适配的理解、工作中遇到的难题和攻克的过程、以及开源过程的心得与教训等话题。现将专访内容整理如下,希望对你有所启发。

Q1

请简要介绍下自己,以及所在开发团队

大家好,我是润和软件资深软件开发工程师赵海鹏。我从 2020 年 10 月份开始正式接触 OpenHarmony 开源项目,开始了解框架和结构。目前在润和软件主要负责 OpenHarmony 南向业务媒体领域。

Q2

作为开发领域知名的技术大牛,您最初为什么会选择加入OpenHarmony生态、参与开源共建呢?您认为,OpenHarmony项目最吸引人的点在哪里?

第一个层面,从大的环境来说,OpenHarmony 是创新的操作系统,这是吸引我的首要因素。

第二个层面,从个人成长来说,我希望在 OpenHarmony 发展的初期加入进来,这样会让我对整个系统框架的演变更为清楚,个人的成长机会点相对比较多。

Q3

您方便给我们介绍一下这个产品吗,或者这段经历吗?这么短时间达成了这样好的效果,请问您的“秘诀”都有哪些呢?

"秘诀"谈不上,主要学习和工作过程中,多给自己提问题,带着问题去学习与研究;同时,针对过程遇到问题不断总结与积累,形成知识库。

我接着说一下主要贡献的特性。我们目标是把社区上非海思芯片第三方平台 RK3568 的 Audio 驱动适配起来。因为 Openharmony Audio 驱动框架是 ADM,原生的驱动是 ALSA,差异相对来说比较大。为了加快进度协调软件所的一个伙伴和我一起联合开发,正好赶上西安的疫情,我就一直在家里专注的搞研发,需要交流就通过线上沟通。过程中会遇到很多困难,调试 Audio 驱动,需要一些硬件设备(示波器、逻辑分析仪等)的支撑,而处在疫情环境下,有的设备是缺少的,西安的快递也很难进来,我们通过各种渠道去协调设备,然后把做好的固件发出去,让中科院软件所的伙伴做远程测试,包括焊接等等。

另外,我们任务的时间节点比较紧张,只有不到一个月左右的时间,Audio 驱动代码裁剪过后还有三万行,也就是我们要把三万代码读懂再适配到 OpenHarmony 上,给我们的工作也增加了难度,但是我们都一一克服,坚挺过来,最终完成了任务。

Q4

能开发出这么一个优秀的产品,将核心代码合入主干,您和您的团队一定付出了很多。可以请您给我们分享一下,开发这个产品的整个过程,包括前期、中期、后期,您们具体都做了哪些工作,投入了多少人力和资源吗?

在前期,内核代码中 Audio 相关的有 10w+ 的代码,需要做裁剪成最小集合,另外,需要梳理主线上 ADM 的代码框架,参考:https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/driver/driver-peripherals-audio-des.md。

中间阶段,进入真正的开发过程中,我先把框架做好,然后按照模块分工合作开发。当时因为是线上办公,每天的工作时间都在 12 小时以上,双方通过线上会议交流,出现问题及时沟通及时解决。

后期主要是调试阶段,当时信号有一些问题,中科院软件所的硬件工程师帮我们焊接,然后采样并把信号图像回传到我们这边,再做分析,然后再做下一个方案的调整,遇到一些难以解决的问题,也会求助 ADM 框架负责人。为了保证较高的工作效率,这些都在线上会议进行沟通。

另外,调试过程中发现框架存在一些不友好不完善的地方,在适配过程中不断完善,形成了 Linux 相对简单适配的方案并形成文档,在社区上发布。该方案存在的问题是不兼容 LiteOS,没有完全实现 ADM 的优化能力。

b2f3fdbc-d062-11ec-bce3-dac502259ad0.png

Q5

在整个开发进程中,您和您的团队遇到过哪些技术上或其他方面的难题呢?这些难题又是如何被逐一解决的?在这些难题被解决的过程中,您总结了哪些宝贵的经验or教训呢?

技术问题:RK3568 平台的 codec 组件使用的 RK809,此芯片不是单一的 Codec 功能还包含电源管理的模块,使用同一路 I2C 控制通道,拆分难度大,可能还要设计电源管理模块。

解决方案:借助 Linux 原生驱动,ADM 的驱动接口初始化节点调用对应的 probe 函数,按照此思路触类旁通,其余模块也按照的这样的操作,减少驱动代码开发对寄存器的依赖,提升开发效率。具体的方案在 RK3568 驱动适配文档中有说明,请关注。

Q6

加入OpenHarmony生态以来,您最大的惊喜是什么?或者有哪些具体的收获?

收获的第一个层面,是我以前的工作经历相对来说是单个模块或者单个特性,而现在有机会面对整个系统。同时,OpenHarmony 正经历从 0 到 1 的过程,在我们工作的过程中可以深入了解整个系统,获得比较全面的认知,对能力的提升空间比较大。

第二层面针对系统的设计,以前我只需要考虑需求内部实现逻辑、流程、接口等。现在做需求设计的时候,先考虑外部依赖,定义接口,然后再去设计具体的需求的框架,软件分层等等。

Q7

OpenHarmony目前仍处在开发探索阶段,很多共建单位和生态伙伴还不清楚开源项目的玩法,或不知该如何着手进行开发。可以请您给大家分享一条,您认为最重要或最值得分享的心得吗?

我觉得最主要的是结合自己过往的工作背景或者环境,如果没有太多经验,可以从 mini system 入手,如果有一些安卓或者 Linux 的经验,可以从 standard system 入手。总之,一定要从自己熟悉的模块入手,这样才能触类旁通,通过边学边拆的方式,熟悉度才会越来越高。

入手之后,需要集中在单点上深入研究,把一个点深度了解后,其他点学习的就会比较快。同时也要看看整体的架构,如果对架构都不了解的话,是不足以支撑后续开发和项目工作,至少需要有概念性的认知。

Q8

开放性问题,可以畅所欲言,请问您还有话想告诉大家?

从驱动系统上来讲,目前 OpenHarmony 的驱动是基于 HDF 开发的,既可以在 Linux 上运行,也可以在 LiteOS 上运行,便于移植。但目前成熟度不够,适配难度较高。对开发者来说不太友好,希望各共建单位和开源开发者一起去完善,让平台驱动适配更容易。

审核编辑 :李倩

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

    关注

    28

    文章

    2596

    浏览量

    79951
  • OpenHarmony
    +关注

    关注

    23

    文章

    3214

    浏览量

    15155

原文标题:赵海鹏:如何进行 OpenHarmony 音频特性架构设计和开发工作

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

收藏 人收藏

    评论

    相关推荐

    交换芯片架构设

    交换芯片架构设计是网络通信中的关键环节,它决定了交换机的性能、功能和扩展性。
    的头像 发表于 03-18 14:12 168次阅读

    LTSpice能不能进行任意降压型DC-DC的环路特性分析,如何进行

    LTSpice能不能进行任意降压型DC-DC的环路特性分析,如何进行
    发表于 01-04 07:09

    智能座舱主流音频架构设计方案

    蔚来汽车NT1/NT2平台座舱音频系统的软件架构设计和研发工作都由我负责,涉及到Android、QNX、Hypervisor等系统的音频设计。今
    发表于 12-28 16:54 353次阅读
    智能座舱主流<b class='flag-5'>音频</b><b class='flag-5'>架构设</b>计方案

    润开鸿基于高性能RISC-V开源架构DAYU800通过OpenHarmony兼容性测评

    近期,江苏润开鸿数字科技有限公司(以下简称“润开鸿”)基于高性能RISC-V开源架构处理器研发的OpenHarmony标准系统开发平台HH-SCDAYU800通过OpenHarmony
    发表于 12-14 17:33

    OpenHarmony应用开发涉及的主要因素与UX设计规范

    多种不同的设备开发应用时,有如下设计原则: 差异性,充分了解所要支持的设备,包括屏幕尺寸、交互方式、使用场景、用户人群等,对设备的特性进行针对性的设计。 一致性,除了要考虑每个设备的特性
    发表于 09-25 15:03

    Qt For OpenHarmony

    ,13年C++/Qt开发相关工作经验,曾任职Qt公司,担任技术支持、Qt咨询师,协助国内多家Qt企业版用户完成基于Qt的软件框架搭建,参与Qt开源社区Bug维护及修改,在基于Qt框架的软件架构设
    发表于 09-15 15:39

    开源机密计算平台:蓬莱-OpenHarmony

    -OpenHarmony的项目中,开发了蓬莱可信执行环境并提供了通用的解决方案。目前主要做的四项工作有:(1)提出面向OpenHarmony的通用TEE
    发表于 09-07 16:08

    SWE.2软件架构设

    过程ID : SWE.2 过程名称 : 软件架构设计 过程目的 : 软件架构设计过程目的是建立一个架构设计,识别哪些软件需求应该分配给软件的哪些要素,并根据已定义的标准评估软件架构设
    的头像 发表于 08-24 09:43 496次阅读

    基于分级安全的OpenHarmony架构设

    本文源自 OpenHarmony TSC 官方《峰会回顾第1期 | 基于分级安全的OpenHarmony架构设计》 演讲嘉宾 | 付天福 回顾整理 | 廖涛 排版校对 | 李萍萍 嘉宾简介 付天福
    发表于 08-04 10:39

    润开鸿成功举办“基于RISC-V架构OpenHarmony应用开发创意赛”Workshop

    OpenHarmony应用开发创意赛”专场顺利举办,活动邀请多位专家、导师与开发者围绕面向RISC-V的OpenHarmony生态及本赛事的赛题/赛制展开近两个小时的面对面交
    的头像 发表于 06-21 10:00 496次阅读
    润开鸿成功举办“基于RISC-V<b class='flag-5'>架构</b>的<b class='flag-5'>OpenHarmony</b>应用<b class='flag-5'>开发</b>创意赛”Workshop

    OpenHarmony 3.2 Release新特性解读之驱动HCS

    新的特性,极大的方便了驱动开发工作。其中针对HCS文件开发提供新的开发思路,本文就简单介绍一下相关内容。 1 、HCS宏式解析 1.1 HC
    的头像 发表于 05-30 21:45 483次阅读

    开放原子开源基金会OpenHarmony开发者大会2023演讲资料汇总

    、交通、教育、政务、家居等众多行业,OpenHarmony生态发展欣欣向荣。 本届OpenHarmony开发者大会将对OpenHarmony 3.2Release新
    发表于 05-29 16:34

    架构与微架构设

    下面将从芯片的架构设计、微架构设计、使用设计文档、设计分区、时钟域和时钟组、架构调整与性能改进、处理器微架构设计策略等角度进行说明,并以视频
    的头像 发表于 05-08 10:42 847次阅读
    <b class='flag-5'>架构</b>与微<b class='flag-5'>架构设</b>计

    OpenHarmony 3.2 Release特性更新简析

    模型,OpenHarmony API 9新增模型,提供了应用程序必备的组件和运行机制。开发者可以基于该模型进行复杂应用开发,使应用开发更简单
    发表于 04-21 10:43

    开放原子开源基金会OpenHarmony开发者大会2023圆满举办

    正式发布,该版本系统能力进一步完善,全面提升了复杂带屏设备体验。OpenHarmony项目管理委员会主席任革林从系统流畅、系统性能、应用性能、分布式能力、开发效率五个方面对新版本的技术特性进行
    发表于 04-21 10:12