首页 > 其他分享 >移植案例与原理 - HDF驱动框架-OSAL

移植案例与原理 - HDF驱动框架-OSAL

时间:2024-06-19 22:30:40浏览次数:18  
标签:int32 struct drivers 接口 HDF osal OSAL spinlock 移植

为了提升驱动代码在不同内核子系统间的可复用能力,OpenHarmony HDF(Hardware Driver Foundation)驱动框架提供了OSAL(Operating System Abstraction Layer)操作系统抽象层接口。OSAL为驱动程序提供了任务、定时器、互斥锁、信号量等基础库相关接口,使驱动相关的实现不再依赖于具体的内核或POSIX接口,是实现驱动可迁移的基石。OpenHarmony HDF驱动框架已经在LiteOS-M,LiteOS-A,Linux内核完成适配,可直接使用。

本文主要分析下驱动适配代码仓中的OSAL的相关接口,主要以适配LiteOS-M内核的OSAL接口为例。OSAL在HDF驱动框架中的位置,见HDF架构图。

1、OSAL头文件

在文件夹drivers/framework/include/osal中定义了OSAL的头文件,对这些头文件的说明如下。

头文件头文件描述
osal_atomic.h原子变量相关接口
osal_cdev.h字符设备相关接口
osal_file.h文件相关接口
osal_firmware.h固件文件相关接口
osal_io.hI/O操作类接口
osal_irq.h中断相关接口
osal_mem.h内存申请释放接口
osal_mutex.h互斥锁相关接口
osal_sem.h信号量相关接口
osal_spinlock.h自旋锁相关接口
osal_thread.h线程相关接口
osal_time.h时间相关接口
osal_timer.h定时器相关接口

2、原子变量相关接口

在头文件drivers\framework\include\osal\osal_atomic.h中定义了原子变量相关接口。对于LiteOS-M内核,接口实现程序定义在文件drivers\adapter\khdf\liteos_m\osal\include\osal_atomic_def.h中。

接口接口描述
OsalAtomicRead(v)读取原子类型的计数变量值
OsalAtomicSet(v, counter)设置原子类型的计数变量值
OsalAtomicInc原子类型的计数变量值加1
OsalAtomicIncReturn原子类型的计数变量值加1,并返回更新后的值
OsalAtomicDec原子类型的计数变量值减1
OsalAtomicDecReturn原子类型的计数变量值减1,并返回更新后的值
OsalTestBit测试指定变量指定位的值
OsalTestSetBit设置指定变量指定位的值,并返回设置前的值
OsalTestClearBit清除指定变量指定位的值,并返回清除前的值
OsalClearBit清除指定变量指定位的值

3、内存申请释放接口

在头文件drivers\framework\include\osal\osal_mem.h中定义了内存申请释放相关接口。对于LiteOS-M内核,接口实现程序定义在文件drivers\adapter\khdf\liteos_m\osal\src\osal_mem.c中。

接口接口描述
void *OsalMemAlloc(size_t size)申请内存接口
void *OsalMemCalloc(uint32_t size)申请内存接口,并把申请的内存清零
void OsalMemAllocAlign(size_t alignment, size_t size)申请内存接口,内存地址按照指定大小进行边界对齐
void OsalMemFree(void mem)释放内存接口

4、互斥锁相关接口

在头文件drivers\framework\include\osal\osal_mutex.h中定义了互斥锁相关接口。对于LiteOS-M内核,接口实现程序定义在文件drivers\adapter\khdf\liteos_m\osal\src\osal_mutex.c中。

接口接口描述
int32_t OsalMutexInit(struct OsalMutex *mutex)初始化互斥锁
int32_t OsalMutexDestroy(struct OsalMutex *mutex)销毁互斥锁
int32_t OsalMutexLock(struct OsalMutex *mutex)获取互斥锁
int32_t OsalMutexTimedLock(struct OsalMutex *mutex, uint32_t ms)获取到互斥锁或者超时时返回
int32_t OsalMutexUnlock(struct OsalMutex *mutex)释放互斥锁

5、自旋锁相关接口

在头文件drivers\framework\include\osal\osal_spinlock.h中定义了自旋锁相关接口。对于LiteOS-M内核,接口实现程序定义在文件drivers\adapter\khdf\liteos_m\osal\src\osal_spinlock.c中。

接口接口描述
int32_t OsalSpinInit(OsalSpinlock *spinlock)初始化自旋锁
int32_t OsalSpinDestroy(OsalSpinlock *spinlock)销毁自旋锁
int32_t OsalSpinLock(OsalSpinlock *spinlock)获取自旋锁
int32_t OsalSpinUnlock(OsalSpinlock *spinlock)释放自旋锁
int32_t OsalSpinLockIrq(OsalSpinlock *spinlock)获取自旋锁接口,并且去使能中断
int32_t OsalSpinUnlockIrq(OsalSpinlock *spinlock)释放自旋锁接口,并且使能中断
int32_t OsalSpinLockIrqSave(OsalSpinlock *spinlock, uint32_t *flags)获取自旋锁接口,并且去使能中断,保存中断状态
int32_t OsalSpinUnlockIrqRestore(OsalSpinlock *spinlock, uint32_t *flags)释放自旋锁接口,并且使能中断,恢复保存的中断状态

6、信号量相关接口

在头文件drivers\framework\include\osal\osal_sem.h中定义了信号量相关接口。对于LiteOS-M内核,接口实现程序定义在文件drivers\adapter\khdf\liteos_m\osal\src\osal_sem.c中。

接口接口描述
int32_t OsalSemInit(struct OsalSem *sem, uint32_t value)初始化信号量
int32_t OsalSemWait(struct OsalSem *sem, uint32_t ms)等待信号量
int32_t OsalSemPost(struct OsalSem *sem)释放信号量
int32_t OsalSemDestroy(struct OsalSem *sem)销毁信号量

7、线程相关接口

在头文件drivers\framework\include\osal\osal_thread.h中定义了信号量相关接口。对于LiteOS-M内核,接口实现程序定义在文件drivers\adapter\khdf\liteos_m\osal\src\osal_thread.c中。

接口接口描述
int32_t OsalThreadCreate(struct OsalThread *thread, OsalThreadEntry threadEntry, void *entryPara)创建线程
int32_t OsalThreadBind(struct OsalThread *thread, unsigned int cpuID)绑定线程到指定的CPU上运行
int32_t OsalThreadStart(struct OsalThread *thread, const struct OsalThreadParam *param)启动线程
int32_t OsalThreadDestroy(struct OsalThread *thread)销毁线程

8、其他接口

类似还有时间、定时器接口,可以自行查看文件drivers\adapter\khdf\liteos_m\osal\src\osal_time.c、drivers\adapter\khdf\liteos_m\osal\src\osal_timer.c,不再一一列举。

小结

本文介绍了HDF驱动框架子系统中的OSAL接口,后续会介绍更多的HDF驱动框架知识。

如果大家想更加深入的学习 OpenHarmony 开发的内容,不妨可以参考以下相关学习文档进行学习,助你快速提升自己:

OpenHarmony 开发环境搭建:https://qr18.cn/CgxrRy

《OpenHarmony源码解析》:https://qr18.cn/CgxrRy

  • 搭建开发环境
  • Windows 开发环境的搭建
  • Ubuntu 开发环境搭建
  • Linux 与 Windows 之间的文件共享
  • ……

系统架构分析:https://qr18.cn/CgxrRy

  • 构建子系统
  • 启动流程
  • 子系统
  • 分布式任务调度子系统
  • 分布式通信子系统
  • 驱动子系统
  • ……

OpenHarmony 设备开发学习手册:https://qr18.cn/CgxrRy

在这里插入图片描述

OpenHarmony面试题(内含参考答案):https://qr18.cn/CgxrRy

写在最后

  • 如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:
  • 点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。
  • 关注小编,同时可以期待后续文章ing

    标签:int32,struct,drivers,接口,HDF,osal,OSAL,spinlock,移植
    From: https://blog.csdn.net/maniuT/article/details/139809476

相关文章

  • 移植案例与原理 - startup子系统之bootstrap_lite服务启动引导部件(1)
    bootstrap_lite服务启动引导组件提供了各服务和功能的启动入口标识。在SAMGR(Systemabilitymanager,系统服务管理)启动时,会调用bootstrap_lite标识的入口函数,并启动系统服务。本文介绍下移植开发板时如何适配服务启动引导部件bootstrap_lite,并介绍下相关的运行机制原理。bo......
  • 【Ubuntu开发入门之“悟空派wukongpi/香橙派orangepi H3 linux开发②u-boot移植“】
    Ubuntu开发入门之"orangepiH3linux开发@u-boot移植"问题描述解决方法获取u-boot源码编译配置u-boot制作并烧录TF卡结束语郑重声明:本人原创博文,都是实战,均经过实际项目验证出货的转载请标明出处:攻城狮2015Platform:AllwinnerH3OS:Linuxubunt......
  • 移植lvgl
    板子:stm32f407zgt6屏幕:浦阳1.69触摸屏(该款触摸屏幕显示芯片为:ST7789。触摸芯片为:CST816)教程:正点原子移植教程。一、踩坑点启动文件的stack_size要由0x400改为0x800,否则demo会白屏lv_task_tc()可以放在一个定时器中断函数中,每5ms进入一次中断。关键是修改lv_port_d......
  • 海思SD3403,SS928/926,hi3519dv500,hi3516dv500移植yolov7,yolov8(23)SS928/SD3403推理y
    今天抽空测试了一下3403跑yolov8的速度,源码还没改完,后处理还是先用CPU来跑了,这样速度会拖慢一点,先看看效果。实际用的是4T算力的,里面是有两个NPU,一个叫SVP_NNN,一个叫NNN,用的方式还不一样,分别用SVP_ACL接口和ACL接口。我是没有时间去研究ACL,用的SVP_ACL的方式。下面是对比。......
  • N32移植cherry usb
    目前的项目用到了USB,N32自带的USB库比较难用。考虑用开源的USB库。例如tinyusb(比较全)和cherryusb(比较好移植,有地方问)。本文以cherryusb为例子进行讲述,tinyusb放另外一篇文章中去讲。N32和STM32F103的USBIP用的是一致的都是fsdev这个IP,所以N32的移植可以完全参考STM32去搞......
  • 海思SD3403,SS928/926,hi3519dv500,hi3516dv500移植yolov7,yolov8(22)hi3516dv500/19dv5
     最近太忙更新不及时,SS928跑yolov8的文章各位朋友不要催,最近在测试自己魔改的yolov8,测完有结论了跟大家分享。魔改的yolov8在dv500系列里有些小问题,能正常运行,但是优化报错,在做更细致的测试。 先分享一下最近对比RK3588做的测试结果。RK3588算是嵌入式AI里的顶配级别存在......
  • CC2500和CC1101移植说明
    主要通过如何移植、移植注意、关于芯片配置、如何生成导出配置四大步骤来说明CC2500和CC1101移植首先通过下图1这个宏进行选择 &如何移植要移植的部分在CC2500_hal.c和CC2500_hal.h中, 搜索"//移植"就可以定位到库所需的依赖,需要根据您的环境实现这些函数&移植......
  • N32G45XVL-STB之移植LVGL(8.4.0)
    目录概述1系统软硬件1.1软件版本信息1.2 ST7796-LCD1.3 MCUIO与LCDPIN对应关系2认识LVGL2.1 LVGL官网2.2下载V8.4.03移植LVGL3.1硬件驱动实现3.2添加LVGL库文件3.3移植和硬件相关的代码3.3.1驱动接口相关文件介绍3.3.2重新接口函数3.4配置.h文......
  • 034【GD32F470】MQ-3酒精检测传感器STM32移植教程
    2.31MQ-3酒精检测传感器MQ-3气体传感器所使用的气敏材料是在清洁空气中电导率较低的二氧化锡(Sn0)。当传感器所处环境中存在酒精蒸气时,传感器的电导率随空气中酒精蒸气浓度的增加而增大。使用简单的电路即可将电导率的变化转换为与该气体浓度相对应的输出信号。2.31.1......
  • LVGL多端移植测试
    说明:端午在家宅,进行了LVGL的多端移植测试。目标是使用Squreline绘图生成的同一段代码,实现在PC端、安卓端、彩屏单片机端、单色屏单片机端四端显示。最终目标我是想实现在任意一端操作界面,其他几端都能实现同步变化。目前已经实现了四端的简单显示:安卓手机端、墨水屏手机......