Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
e716d144
D
Docs
项目概览
OpenHarmony
/
Docs
大约 1 年 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
e716d144
编写于
5月 17, 2022
作者:
O
openharmony_ci
提交者:
Gitee
5月 17, 2022
浏览文件
操作
浏览文件
下载
差异文件
!3923 【OpenHarmony开源贡献者计划2022】PIN相关格式及表达问题
Merge pull request !3923 from king_he/pin-1
上级
a69078e6
9c672da1
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
57 addition
and
62 deletion
+57
-62
zh-cn/device-dev/driver/driver-platform-pin-des.md
zh-cn/device-dev/driver/driver-platform-pin-des.md
+40
-48
zh-cn/device-dev/driver/driver-platform-pin-develop.md
zh-cn/device-dev/driver/driver-platform-pin-develop.md
+17
-14
未找到文件。
zh-cn/device-dev/driver/driver-platform-pin-des.md
浏览文件 @
e716d144
# PIN
-
[
概述
](
#section1
)
-
[
功能简介
](
#section2
)
-
[
基本概念
](
#section3
)
-
[
运作机制
](
#section4
)
-
[
约束与限制
](
#section5
)
-
[
使用指导
](
#section6
)
-
[
场景介绍
](
#section7
)
-
[
接口说明
](
#section8
)
-
[
开发步骤
](
#section9
)
-
[
使用实例
](
#section10
)
## 概述<a name="section1"></a>
### 功能简介<a name="section2"></a>
-
PIN即管脚控制器,用于统一管理各SoC厂商管脚资源,对外提供管脚复用功能:包括管脚推拉方式、管脚推拉强度以及管脚功能。
-
PIN接口定义了操作PIN管脚的通用方法集合,包括:
-
获取/释放管脚描述句柄: 传入管脚名与链表中每个控制器下管脚名进行匹配,匹配则会获取一个管脚描述句柄,操作完PIN管脚后释放该管脚描述句柄。
-
设置/获取管脚推拉方式:推拉方式可以是上拉、下拉以及悬空。
-
设置/获取管脚推拉强度:用户可根据实际设置管脚推拉强度大小。
-
设置/获取管脚功能:通过管脚功能名设置/获取管脚功能,实现管脚复用。
PIN即管脚控制器,用于统一管理各SoC厂商管脚资源,对外提供管脚复用功能:包括管脚推拉方式、管脚推拉强度以及管脚功能。
PIN接口定义了操作PIN管脚的通用方法集合,包括:
-
获取/释放管脚描述句柄: 传入管脚名与链表中每个控制器下管脚名进行匹配,匹配则会获取一个管脚描述句柄,操作完PIN管脚后释放该管脚描述句柄。
-
设置/获取管脚推拉方式:推拉方式可以是上拉、下拉以及悬空。
-
设置/获取管脚推拉强度:用户可根据实际设置管脚推拉强度大小。
-
设置/获取管脚功能:通过管脚功能名设置/获取管脚功能,实现管脚复用。
### 基本概念<a name="section3"></a>
PIN是一个软件层面的概念,目的是为了统一各SoC厂商PIN管脚管理,对外提供管脚复用功能,配置PIN管脚的电气特性。
...
...
@@ -35,9 +24,12 @@ PIN是一个软件层面的概念,目的是为了统一各SoC厂商PIN管脚
### 运作机制<a name="section4"></a>
在HDF框架中,PIN模块暂不支持用户态,所以不需要发布服务
,接口适配模式采用无服务模式,用于不需要在用户态提供API的设备类型,或者
没有用户态和内核区分的OS系统,其关联方式是DevHandle直接指向设备对象内核态地址(DevHandle是一个void类型指针)。
在HDF框架中,PIN模块暂不支持用户态,所以不需要发布服务
。接口适配模式采用无服务模式,用于不需要在用户态提供API的设备类型。对于
没有用户态和内核区分的OS系统,其关联方式是DevHandle直接指向设备对象内核态地址(DevHandle是一个void类型指针)。
PIN模块各分层作用:接口层提供获取PIN管脚、设置PIN管脚推拉方式、获取PIN管脚推拉方式、设置PIN管脚推拉强度、获取PIN管脚推拉强度、设置PIN管脚功能、获取PIN管脚功能、释放PIN管脚的接口。核心层主要提供PIN管脚资源匹配,PIN管脚控制器的添加、移除以及管理的能力,通过钩子函数与适配层交互。适配层主要是将钩子函数的功能实例化,实现具体的功能。
PIN模块各分层作用:
-
接口层提供获取PIN管脚、设置PIN管脚推拉方式、获取PIN管脚推拉方式、设置PIN管脚推拉强度、获取PIN管脚推拉强度、设置PIN管脚功能、获取PIN管脚功能、释放PIN管脚的接口。
-
核心层主要提供PIN管脚资源匹配,PIN管脚控制器的添加、移除以及管理的能力,通过钩子函数与适配层交互。
-
适配层主要是将钩子函数的功能实例化,实现具体的功能。
**图 1**
PIN无服务模式
<a
name=
"fig14423182615525"
></a>
![](
figures/无服务模式结构图.png
"PIN无服务模式"
)
...
...
@@ -67,10 +59,10 @@ PIN模块提供的主要接口如[表1](#table1)所示,更多关于接口的
| int32_t PinGetPull(DevHandle handle, enum PinPullType
*
pullType); | 获取管脚推拉方式 |
| int32_t PinSetStrength(DevHandle handle, uint32_t strength); | 设置管脚推拉强度 |
| int32_t PinGetStrength(DevHandle handle, uint32_t
*
strength); | 获取管脚推拉强度 |
| int32_t PinSetFunc(DevHandle handle, const char
*
funcName); | 设置管脚功能
|
| int32_t PinGetFunc(DevHandle handle, const char
**
funcName); | 获取管脚功能
|
| int32_t PinSetFunc(DevHandle handle, const char
*
funcName); | 设置管脚功能 |
| int32_t PinGetFunc(DevHandle handle, const char
**
funcName); | 获取管脚功能 |
>![](../public_sys-resources/icon-note.gif) **说明:**
>![](../public_sys-resources/icon-note.gif) **说明:**
<br>
>本文涉及的所有接口,仅限内核态使用,不支持在用户态使用。
### 开发步骤<a name="section9"></a>
...
...
@@ -88,14 +80,14 @@ PIN模块提供的主要接口如[表1](#table1)所示,更多关于接口的
DevHandle PinGet(const char *pinName);
```
**表 2**
PinGet参数和
返回值
描述
**表 2**
PinGet参数和描述
<a
name=
"table2"
></a>
| 参数 |
参数
描述 |
| 参数 | 描述 |
| ---------- | ----------------------- |
| pinName | 管脚名 |
|
**返回值**
|
**
返回值
描述**
|
|
**返回值**
|
**描述**
|
| NULL | 获取PIN管脚描述句柄失败 |
| handle | PIN管脚描述句柄 |
...
...
@@ -119,15 +111,15 @@ PIN设置管脚推拉方式的函数如下所示:
int32_t PinSetPull(DevHandle handle, enum PinPullType pullType);
```
**表 3**
参数和
返回值
描述
**表 3**
参数和描述
<a
name=
"table3"
></a>
| 参数 |
参数
描述 |
| 参数 | 描述 |
| ---------- | ----------------------- |
| handle | PIN管脚描述句柄 |
| pullType | PIN管脚推拉方式 |
|
**返回值**
|
**
返回值
描述**
|
|
**返回值**
|
**描述**
|
| 0 | PIN设置管脚推拉方式成功 |
| 负数 | PIN设置管脚推拉方式失败 |
...
...
@@ -153,15 +145,15 @@ PIN获取管脚推拉方式的函数如下所示:
int32_t PinGetPull(DevHandle handle, enum PinPullType *pullType);
```
**表 4**
PinGetPull参数和
返回值
描述
**表 4**
PinGetPull参数和描述
<a
name=
"table4"
></a>
| 参数 |
参数
描述 |
| 参数 | 描述 |
| ---------- | ------------------------- |
| handle | PIN管脚描述句柄 |
| pullType | 接收PIN管脚推拉方式的指针 |
|
**返回值**
|
**
返回值
描述**
|
|
**返回值**
|
**描述**
|
| 0 | PIN获取管脚推拉方式成功 |
| 负数 | PIN获取管脚推拉方式失败 |
...
...
@@ -186,15 +178,15 @@ PIN设置管脚推拉强度函数如下所示:
int32_t PinSetStrength(DevHandle handle, uint32_t strength);
```
**表 5**
PinSetStrength参数和
返回值
描述
**表 5**
PinSetStrength参数和描述
<a
name=
"table5"
></a>
| 参数 |
参数
描述 |
| 参数 | 描述 |
| ---------- | ----------------------- |
| handle | 管脚描述句柄 |
| strength | PIN管脚推拉强度 |
|
**返回值**
|
**
返回值
描述**
|
|
**返回值**
|
**描述**
|
| 0 | PIN设置管脚推拉强度成功 |
| 负数 | PIN设置管脚推拉强度失败 |
...
...
@@ -220,15 +212,15 @@ PIN设置管脚推拉强度后,可以通过PIN获取管脚推拉强度接口
int32_t PinGetStrength(DevHandle handle, uint32_t *strength);
```
**表 6**
PinGetStrength参数和
返回值
描述
**表 6**
PinGetStrength参数和描述
<a
name=
"table6"
></a>
| 参数 |
参数
描述 |
| 参数 | 描述 |
| ---------- | ------------------------- |
| handle | 管脚描述句柄 |
| strength | 接收PIN管脚推拉强度的指针 |
|
**返回值**
|
**
返回值
描述**
|
|
**返回值**
|
**描述**
|
| 0 | PIN获取管脚推拉强度成功 |
| 负数 | PIN获取管脚推拉强度失败 |
...
...
@@ -255,15 +247,15 @@ PIN设置管脚功能函数如下所示:
int32_t PinSetFunc(DevHandle handle, const char *funcName);
```
**表 7**
PinSetFunc参数和
返回值
描述
**表 7**
PinSetFunc参数和描述
<a
name=
"table7"
></a>
| 参数 |
参数
描述 |
| 参数 | 描述 |
| ---------- | ------------------- |
| handle | 管脚描述句柄 |
| funcName | PIN管脚功能名 |
|
**返回值**
|
**
返回值
描述**
|
|
**返回值**
|
**描述**
|
| 0 | PIN设置管脚功能成功 |
| 负数 | PIN设置管脚功能失败 |
...
...
@@ -288,15 +280,15 @@ PIN设置管脚功能后,可以通过PIN获取管脚功能接口来查看PIN
int32_t PinGetFunc(DevHandle handle, const char **funcName);
```
**表 8**
PinGetFunc参数和
返回值
描述
**表 8**
PinGetFunc参数和描述
<a
name=
"table8"
></a>
| 参数 |
参数
描述 |
| 参数 | 描述 |
| ---------- | --------------------- |
| handle | 管脚描述句柄 |
| funcName | 接收PIN管脚功能名指针 |
|
**返回值**
|
**
返回值
描述**
|
|
**返回值**
|
**描述**
|
| 0 | PIN获取管脚功能成功 |
| 负数 | PIN获取管脚功能失败 |
...
...
@@ -321,14 +313,14 @@ PIN不再进行任何操作后,需要释放PIN管脚描述管脚句柄,函
void PinPut(DevHandle handle);
```
**表 9**
PinPut参数和
返回值
描述
**表 9**
PinPut参数和描述
<a
name=
"table9"
></a>
| 参数 |
参数
描述 |
| 参数 | 描述 |
| ---------- | -------------- |
| handle | 管脚描述句柄 |
|
**返回值**
|
**
返回值
描述**
|
|
**返回值**
|
**描述**
|
| NA | 无返回值 |
PIN销毁管脚描述句柄实例如下:
...
...
@@ -339,7 +331,7 @@ PinPut(handle);
## 使用实例<a name="section10"></a>
使用PIN设置管脚相关属性完整使用可以参考如下示例代码,
示例代码
步骤主要如下:
使用PIN设置管脚相关属性完整使用可以参考如下示例代码,步骤主要如下:
1.
传入要设置的管脚名,获取PIN管脚描述句柄。
2.
通过PIN管脚描述句柄以及推拉方式pullTypeNum设置管脚推拉方式,如果操作失败则释放PIN管脚描述句柄。
3.
通过PIN管脚描述句柄,并用pullTypeNum承接获取的管脚推拉方式,如果操作失败则释放PIN管脚描述句柄。
...
...
@@ -413,4 +405,4 @@ ERR:
/* 释放PIN管脚描述句柄 */
PinPut(handle);
return ret;
}
}
\ No newline at end of file
zh-cn/device-dev/driver/driver-platform-pin-develop.md
浏览文件 @
e716d144
...
...
@@ -20,9 +20,12 @@ PIN是一个软件层面的概念,目的是为了统一各SoC厂商PIN管脚
### 运作机制
在HDF框架中,PIN模块暂不支持用户态,所以不需要发布服务
,接口适配模式采用无服务模式(如图1所示),用于不需要在用户态提供API的设备类型,或者
没有用户态和内核区分的OS系统,其关联方式是DevHandle直接指向设备对象内核态地址(DevHandle是一个void类型指针)。
在HDF框架中,PIN模块暂不支持用户态,所以不需要发布服务
。接口适配模式采用无服务模式(如图1所示),用于不需要在用户态提供API的设备类型。对于
没有用户态和内核区分的OS系统,其关联方式是DevHandle直接指向设备对象内核态地址(DevHandle是一个void类型指针)。
PIN模块各分层作用:接口层提供获取PIN管脚、设置PIN管脚推拉方式、获取PIN管脚推拉方式、设置PIN管脚推拉强度、获取PIN管脚推拉强度、设置PIN管脚功能、获取PIN管脚功能、释放PIN管脚的接口。核心层主要提供PIN管脚资源匹配,PIN管脚控制器的添加、移除以及管理的能力,通过钩子函数与适配层交互。适配层主要是将钩子函数的功能实例化,实现具体的功能。
PIN模块各分层作用:
-
接口层提供获取PIN管脚、设置PIN管脚推拉方式、获取PIN管脚推拉方式、设置PIN管脚推拉强度、获取PIN管脚推拉强度、设置PIN管脚功能、获取PIN管脚功能、释放PIN管脚的接口。
-
核心层主要提供PIN管脚资源匹配,PIN管脚控制器的添加、移除以及管理的能力,通过钩子函数与适配层交互。
-
适配层主要是将钩子函数的功能实例化,实现具体的功能。
**图 1**
无服务模式结构图
...
...
@@ -58,12 +61,12 @@ struct PinCntlrMethod {
| 成员函数 | 入参 | 出参 | 返回值 | 功能 |
| ------------ | ------------------------------------------- | ------ | ---- | ---- |
| SetPinPull |
**cntlr**
:结构体指针,核心层Pin控制器
;
<br>
**index**
:uint32_t变量,管脚索引号;
<br/>
**pullType**
:枚举常量,Pin管脚推拉方式;
| 无 |HDF_STATUS相关状态|PIN设置管脚推拉方式|
| GetPinPull |
**cntlr**
:结构体指针,核心层Pin控制器
;
<br/>
**index**
:uint32_t变量,管脚索引号; |
**pullType**
:枚举常量指针,传出Pin管脚推拉方式;
| HDF_STATUS相关状态 | PIN获取管脚推拉方式 |
| SetPinStrength |
**cntlr**
:结构体指针,核心层Pin控制器
;
<br/>
**index**
:uint32_t变量,管脚索引号;
<br/>
**strength**
:uint32_t变量,Pin推拉强度;
| 无 | HDF_STATUS相关状态 | PIN设置推拉强度 |
| GetPinStrength |
**cntlr**
:结构体指针,核心层Pin控制器
;
<br/>
**index**
:uint32_t变量,管脚索引号; |
**strength**
:uint32_t变量指针,传出Pin推拉强度;
| HDF_STATUS相关状态 | PIN获取推拉强度 |
| SetPinFunc |
**cntlr**
:结构体指针,核心层Pin控制器
;
<br/>
**index**
:uint32_t变量,管脚索引号;
<br/>
**funcName**
:char指针常量,传入Pin管脚功能;
| 无 | HDF_STATUS相关状态 | PIN设置管脚功能 |
| GetPinFunc |
**cntlr**
:结构体指针,核心层Pin控制器
;
<br/>
**index**
:uint32_t变量,管脚索引号; |
**funcName**
:char双重指针常量,传出Pin管脚功能;
| HDF_STATUS相关状态 | PIN获取管脚功能 |
| SetPinPull |
**cntlr**
:结构体指针,核心层Pin控制器
<br>
**index**
:uint32_t变量,管脚索引号
<br/>
**pullType**
:枚举常量,Pin管脚推拉方式
| 无 |HDF_STATUS相关状态|PIN设置管脚推拉方式|
| GetPinPull |
**cntlr**
:结构体指针,核心层Pin控制器
<br/>
**index**
:uint32_t变量,管脚索引号 |
**pullType**
:枚举常量指针,传出Pin管脚推拉方式
| HDF_STATUS相关状态 | PIN获取管脚推拉方式 |
| SetPinStrength |
**cntlr**
:结构体指针,核心层Pin控制器
<br/>
**index**
:uint32_t变量,管脚索引号
<br/>
**strength**
:uint32_t变量,Pin推拉强度
| 无 | HDF_STATUS相关状态 | PIN设置推拉强度 |
| GetPinStrength |
**cntlr**
:结构体指针,核心层Pin控制器
<br/>
**index**
:uint32_t变量,管脚索引号 |
**strength**
:uint32_t变量指针,传出Pin推拉强度
| HDF_STATUS相关状态 | PIN获取推拉强度 |
| SetPinFunc |
**cntlr**
:结构体指针,核心层Pin控制器
<br/>
**index**
:uint32_t变量,管脚索引号
<br/>
**funcName**
:char指针常量,传入Pin管脚功能
| 无 | HDF_STATUS相关状态 | PIN设置管脚功能 |
| GetPinFunc |
**cntlr**
:结构体指针,核心层Pin控制器
<br/>
**index**
:uint32_t变量,管脚索引号 |
**funcName**
:char双重指针常量,传出Pin管脚功能
| HDF_STATUS相关状态 | PIN获取管脚功能 |
### 开发步骤
...
...
@@ -125,7 +128,7 @@ PIN模块适配包含以下四个步骤:
}
```
-
添加pin_config.hcs器件属性文件。
在device/soc/hisilicon/hi3516dv300/sdk_liteos/hdf_config/pin/pin_config.hcs目录下配置器件属性
,其中配置参数如下:
在device/soc/hisilicon/hi3516dv300/sdk_liteos/hdf_config/pin/pin_config.hcs目录下配置器件属性,其中配置参数如下:
```
c
root
{
platform
{
...
...
@@ -162,7 +165,7 @@ PIN模块适配包含以下四个步骤:
}
......
// 对应管脚控制器下的每个管脚,按实际添加
}
......
//
每个管脚控制器对应一个controller节点,如存在多个Pin控制器,请依次添加对应的controller节点。
......
//
每个管脚控制器对应一个controller节点,如存在多个Pin控制器,请依次添加对应的controller节点
}
}
}
...
...
@@ -281,7 +284,7 @@ PIN模块适配包含以下四个步骤:
-
Init函数
入参:
HdfDeviceObject这个是整个驱动对外暴露的接口参数,具备
HCS
配置文件的信息。
HdfDeviceObject这个是整个驱动对外暴露的接口参数,具备
hcs
配置文件的信息。
返回值:
HDF
\_
STATUS相关状态(下表为部分展示,如需使用其他状态,可见/drivers/framework/include/utils/hdf
\_
base.h中HDF
\_
STATUS 定义)。
...
...
@@ -371,11 +374,11 @@ PIN模块适配包含以下四个步骤:
}
```
-
Release
函数
-
Release函数
入参:
HdfDeviceObject
是整个驱动对外暴露的接口参数,具备 HCS
配置文件的信息。
HdfDeviceObject
是整个驱动对外暴露的接口参数,具备hcs
配置文件的信息。
返回值:
...
...
@@ -383,7 +386,7 @@ PIN模块适配包含以下四个步骤:
函数说明:
释放内存和删除控制器,该函数需要在驱动入口结构体中赋值给 Release 接口
, 当HDF框架调用Init函数初始化驱动失败时,可以调用 Release
释放驱动资源。
释放内存和删除控制器,该函数需要在驱动入口结构体中赋值给 Release 接口
。当HDF框架调用Init函数初始化驱动失败时,可以调用Release
释放驱动资源。
```
c
static
void
Hi35xxPinRelease
(
struct
HdfDeviceObject
*
device
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录