鸿蒙OpenHarmony【平台驱动开发之PIN】 子系统

PIN

概述

功能简介

PIN即管脚控制器,用于统一管理各SoC的管脚资源,对外提供管脚复用功能。

基本概念

PIN是一个软件层面的概念,目的是为了统一对各SoC的PIN管脚进行管理,对外提供管脚复用功能,配置PIN管脚的电气特性。

  • SoC(System on Chip)

    系统级芯片,又称作片上系统,通常是面向特定用途将微处理器、模拟IP核、数字IP核和存储器集成在单一芯片的标准产品。

  • 管脚复用

    由于芯片自身的引脚数量有限,无法满足日益增多的外接需求。此时可以通过软件层面的寄存器设置,让引脚工作在不同的状态,从而实现相同引脚完成不同功能的目的。

运作机制

在HDF框架中,同类型设备对象较多时(可能同时存在十几个同类型配置器),若采用独立服务模式,则需要配置更多的设备节点,且相关服务会占据更多的内存资源。相反,采用统一服务模式可以使用一个设备服务作为管理器,统一处理所有同类型对象的外部访问(这会在配置文件中有所体现),实现便捷管理和节约资源的目的。PIN模块接口适配模式采用统一服务模式(如图1所示)。

在统一模式下,所有的控制器都被核心层统一管理,并由核心层统一发布一个服务供接口层,因此这种模式下驱动无需再为每个控制器发布服务。

PIN模块各分层作用:

  • 接口层提供获取PIN管脚、设置PIN管脚推拉方式、获取PIN管脚推拉方式、设置PIN管脚推拉强度、获取PIN管脚推拉强度、设置PIN管脚功能、获取PIN管脚功能、释放PIN管脚的接口。
  • 核心层主要提供PIN管脚资源匹配,PIN管脚控制器的添加、移除以及管理的能力,通过钩子函数与适配层交互。
  • 适配层主要是将钩子函数的功能实例化,实现具体的功能。

图 1 统一服务模式结构图

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

约束与限制

PIN模块目前只支持小型系统LiteOS-A内核。

开发指导

场景介绍

PIN模块主要用于管脚资源管理。在各SoC对接HDF框架时,需要来适配PIN驱动。下文将介绍如何进行PIN驱动适配。

接口说明

为了保证上层在调用PIN接口时能够正确的操作PIN管脚,核心层在//drivers/hdf_core/framework/support/platform/include/pin/pin_core.h中定义了以下钩子函数,驱动适配者需要在适配层实现这些函数的具体功能,并与钩子函数挂接,从而完成适配层与核心层的交互。

PinCntlrMethod定义:

struct PinCntlrMethod {
    int32_t (*SetPinPull)(struct PinCntlr *cntlr, uint32_t index, enum PinPullType pullType);
    int32_t (*GetPinPull)(struct PinCntlr *cntlr, uint32_t index, enum PinPullType *pullType);
    int32_t (*SetPinStrength)(struct PinCntlr *cntlr, uint32_t index, uint32_t strength);
    int32_t (*GetPinStrength)(struct PinCntlr *cntlr, uint32_t index, uint32_t *strength);
    int32_t (*SetPinFunc)(struct PinCntlr *cntlr, uint32_t index, const char *funcName);
    int32_t (*GetPinFunc)(struct PinCntlr *cntlr, uint32_t index, const char **funcName);
};

表 1 PinCntlrMethod成员的钩子函数功能说明

成员函数 入参 出参 返回值 功能
SetPinPull cntlr:结构体指针,核心层PIN控制器 index:uint32_t类型变量,管脚索引号 pullType:枚举常量,PIN管脚推拉方式 HDF_STATUS相关状态 PIN设置管脚推拉方式
GetPinPull cntlr:结构体指针,核心层PIN控制器 index:uint32_t类型变量,管脚索引号 pullType:枚举常量指针,传出获取的PIN管脚推拉方式 HDF_STATUS相关状态 PIN获取管脚推拉方式
SetPinStrength cntlr:结构体指针,核心层PIN控制器 index:uint32_t类型变量,管脚索引号 strength:uint32_t变量,PIN推拉强度 HDF_STATUS相关状态 PIN设置推拉强度
GetPinStrength cntlr:结构体指针,核心层PIN控制器 index:uint32_t类型变量,管脚索引号 strength:uint32_t变量指针,传出获取的PIN推拉强度 HDF_STATUS相关状态 PIN获取推拉强度
SetPinFunc cntlr:结构体指针,核心层PIN控制器 index:uint32_t类型变量,管脚索引号 funcName:char指针常量,传入PIN管脚功能 HDF_STATUS相关状态 PIN设置管脚功能
GetPinFunc cntlr:结构体指针,核心层PIN控制器 index:uint32_t类型变量,管脚索引号 funcName:char双重指针常量,传出获取的PIN管脚功能 HDF_STATUS相关状态 PIN获取管脚功能

开发步骤

PIN模块适配HDF框架包含以下四个步骤:

  • 实例化驱动入口
  • 配置属性文件
  • 实例化PIN控制器对象
  • 驱动调试

开发实例

下方将基于Hi3516DV300开发板以//device/soc/hisilicon/common/platform/pin/pin_hi35xx.c驱动为示例,展示需要驱动适配者提供哪些内容来完整实现设备功能。

  1. 实例化驱动入口

    驱动入口必须为HdfDriverEntry(在hdf_devi

### RGB三色灯模块相关文档资料下载 RGB三色灯模块作为一种多功能的LED设备,广泛应用于电子项目中。以下是关于如何获取其相关文档和资料的信息: #### 1. 官方技术文档 许多厂商会提供详细的硬件设计指南和技术参数说明。例如,在引用[^1]中提到的内容表明,可以通过调节红、绿、蓝三种颜色的亮度来实现数百万种不同颜色的效果。这类信息通常可以在产品的官方技术支持页面找到。 对于具体的RGB三色灯模块,建议访问制造商官网或分销商网站(如Digi-Key, Mouser),并搜索对应型号的产品数据表(Datasheet)。这些文件一般包括电气特性、接口定义以及典型应用电路等内容。 #### 2. 开发平台支持文档 如果计划将RGB三色灯与特定微控制器配合使用,则需查阅该MCU/SoC对应的外设驱动库及其API参考手册。比如Hi3861开发板上的PWM功能可用于控制RGB灯的颜色变化[^4]。在这种情况下,可以从OpenHarmony社区或者华为开发者中心下载完整的SDK包及示例代码。 另外,《HarmonyOS开发板实验指导书》也提供了丰富的实践案例供学习者模仿操作[^4]。此书籍不仅讲解了基础原理还附带实际项目的构建流程图解步骤截图等辅助材料非常适合作为初学者入门教材阅读理解后再尝试动手制作属于自己的作品吧! #### 3. 社区分享资源 除了正式出版物之外还有很多爱好者会在网络平台上发布个人经验总结文章教程视频等形式多样化的教学素材可供借鉴利用。像Arduino生态系统里就有不少针对RGB LED编程技巧介绍的文章提及到了LabVIEW软件界面友好易于上手适合工程技术人员快速搭建原型系统完成初步验证工作之前所描述的过程就是其中一个典型案例展示[^2]. 同时Python语言也可以用来编写简单的测试脚本来点亮指定模式下的灯光效果如下所示即是一个基于MicroPython框架运行于STM32系列芯片之上的周期性切换色彩的小例子[^3]: ```python import pyb r = pyb.Pin('A0', pyb.Pin.OUT_PP) g = pyb.Pin('A1', pyb.Pin.OUT_PP) b = pyb.Pin('A2', pyb.Pin.OUT_PP) while True: r.high(); g.low(); b.low(); pyb.delay(1000) r.low(); g.high(); b.low(); pyb.delay(1000) ... ``` 以上列举了几类可能对你有所帮助的方向希望你能顺利寻得所需的参考资料继续深入探索这项有趣的技术领域! ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值