1.高通提前公布骁龙865/765源码:三方ROM刷机包进展如何?
2.高通提前公布骁龙865/765源码,高通高通三方ROM刷机包能更快搞起来吗?
3.OpenHarmony 3GPP协议开发深度剖析——一文读懂RIL
高通提前公布骁龙865/765源码:三方ROM刷机包进展如何?
结论:高通已经发布了骁龙(kona)和骁龙(lito)移动平台的厂商厂商部分源码,为第三方ROM开发者打开了新大门。源码源码
在去年底的下载下载骁龙峰会上,两大芯片的安装亮相后,已有众多手机厂商基于这些平台推出了新品。高通高通莽荒记源码四个月后,厂商厂商高通打破常规,源码源码将骁龙和的下载下载部分源码开发资料上传至Code Aurora论坛(CAF),关注的安装核心在于对Linux内核和AOSP框架的定制修改,旨在支持这些尖端芯片的高通高通运行。 以往,厂商厂商高通会将修改后的源码源码Linux内核、AOSP代码和软件工具以BSP形式提供给OEM和ODM厂商,下载下载如小米和三星S,安装让他们借此进行软硬件的调试和优化。现在,修改华硕固件源码随着这批新源码的公布,第三方ROM的开发者,如LieageOS、CM和魔趣等,将迎来加速发展的契机。 对比去年,高通在骁龙源码的公开时间上,今年提前了一个月,显示出公司对于开放源码支持的重视,预示着更多个性化和定制化操作系统的可能性正在逐渐扩大。高通提前公布骁龙/源码,三方ROM刷机包能更快搞起来吗?
结论:高通已公布骁龙/的部分源码,为三方ROM刷机包的开发铺平了道路。
在去年底的骁龙峰会上,高通重磅推出骁龙和骁龙移动平台,随后市场迅速涌现了多款基于这两款芯片的金手指捕鱼源码手机新品。四个月后,高通打破常规,开始在Code Aurora论坛上分享部分骁龙和平台的核心源码开发资料。 这些源码的开放并非新鲜事,它们包含了高通对Linux内核和AOSP框架的定制改动,旨在优化对骁龙/芯片的支持。在过去,像小米、三星S等厂商在进行软硬件调试和优化时,都曾依赖高通提供的BSP(板级支持包)。 此次源码的公开,无疑为基于骁龙/的第三方固件,如LieageOS、CM、魔趣等提供了更强的技术支持,加速了这些第三方ROM的白色币圈源码开发进程。值得注意的是,与去年高通在5月公开骁龙源码相比,今年的发布时间提前了一个月,显示出高通对开发者社区的积极响应和对开源精神的持续投入。OpenHarmony 3GPP协议开发深度剖析——一文读懂RIL
市场上针对终端操作系统3GPP协议开发的相关资料较为稀缺,即便在Android领域,相关学习文档也较为有限,更不用说专门的协议开发书籍了。这可能与市场需求有关,目前市场上从事前后端软件开发的人员最多,包括我自己。
鉴于我在某手机协议开发团队工作过一段时间,对协议的AP侧和CP侧开发都有所涉猎,因此我尝试基于OpenAtom OpenHarmony(以下简称“OpenHarmony”)源码编写一些内容,旨在帮助大家了解协议开发领域,尽可能将3gpp协议内容与OpenHarmony电话子系统模块相结合进行讲解。soulmate社交系统源码据我所知,目前终端协议开发人才非常紧缺。首先声明,我不是协议专家,且已离开该领域五六年,如有错误,欢迎指正。
谈到终端协议开发,我首先想到的就是RIL。
CP:Communication Processor(通信处理器),通常理解为modem侧,也可以理解为底层协议,这部分由各个modem芯片厂商完成(如海思、高通)。
AP:Application Processor(应用处理器),通常指手机终端,通常理解为上层协议,主要由操作系统Telephony服务进行处理。
RIL:Radio Interface Layer(无线电接口层),通常理解为硬件抽象层,即AP侧将通信请求传给CP侧的中间层。
AT指令:AT指令是应用于终端设备与PC应用之间连接与通信的指令。
常规的Modem开发与调试可以使用AT指令进行操作,而各家的Modem芯片的AT指令都会有各自的差异。因此,手机终端厂商为了能在各种不同型号的产品中集成不同modem芯片,需要进行解耦设计来屏蔽各家AT指令的差异。
于是,OpenHarmony采用RIL对Modem进行HAL(硬件抽象),作为系统与Modem之间的通信桥梁,为AP侧提供控制Modem的接口,各Modem厂商则负责提供对应于AT命令的Vender RIL(这些一般为封装好的so库),从而实现操作系统与Modem间的解耦。
框架层:Telephony Service,电话子系统核心服务模块,主要功能是初始化RIL管理、SIM卡和搜网模块。对应OpenHarmony的源码仓库OpenHarmony/telephony_core_service。这个模块也是非常重要的一个模块,后期单独再做详细解读。
硬件抽象层:即我们要讲的RIL,对应OpenHarmony的源码仓库OpenHarmony/telephony_ril_adapter。RIL Adapter模块主要包括厂商库加载,业务接口实现以及事件调度管理。主要用于屏蔽不同modem厂商硬件差异,为上层提供统一的接口,通过注册HDF服务与上层接口通讯。
芯片层:Modem芯片相关代码,即CP侧,这些代码各个Modem厂商是不开放的,不出现在OpenHarmony中。
硬件抽象层又被划分为hril_hdf层、hril层和venderlib层。
hril_hdf层:HDF服务,基于OpenHarmony HDF框架,提供hril层与Telephony Service层进行通讯。
hril层:hril层的各个业务模块接口实现,比如通话、短彩信、数据业务等。
vendorlib层:各Modem厂商提供的对应于AT命令库,各个厂商可以出于代码闭源政策,在这里以so库形式提供。目前源码仓中已经提供了一套提供代码的AT命令操作,至于这个是针对哪个型号modem芯片的,我后续了解清楚再补充。
下面是ril_adapter仓的源码结构:
本文解读RIL层很小一部分代码,RIL是如何通过HDF与Telephony连接上的,以后更加完整的逻辑梳理会配上时序图讲解,会更加清晰。首先,我们要对OpenHarmony的HDF(Hardware Driver Foundation)驱动框架做一定了解,最好是动手写一个Demo案例,具体的可以单独去官网查阅HDF资料。
首先,找到hril_hdf.c文件的代码,它承担的是驱动业务部分,源码中是不带中文注释的,为了梳理清楚流程,我给源码关键部分加上了中文注释。
上述代码中配置了对应该驱动的moduleName为"hril_hdf",因此我们需要去找到对应驱动的配置文件,以HiDV开发板为例,它的驱动配置在vendor_hisilicon/HiDV/hdf_config/uhdf/device_info.hcs代码中可以找到,如下:
这里可以发现该驱动对应的服务名称为cellular_radio1,那么telephony_core_service通过HDF与RIL进行通信肯定会调用到该服务名称,因此无查找telephony_core_service的相关代码,可以很快定位到telephony_core_service/services/tel_ril/src/tel_ril_manager.cpp该代码,该代码中有一个关键类TelRilManager,它用来负责管理tel_ril。
看tel_ril_manager.cpp中的一个关键函数ConnectRilAdapterService,它就是用来通过HDF框架获取RIL_ADAPTER的服务,之前定义过RIL_ADAPTER_SERVICE_NAME常量为"cellular_radio1",它就是在vendor_hisilicon/XXXX/hdf_config/uhdf/device_info.hcs中配置的hril_hdf驱动对应的服务名称。