1e41f4b71Sopenharmony_ci# PIN
2e41f4b71Sopenharmony_ci
3e41f4b71Sopenharmony_ci## 概述<a name="section1"></a>
4e41f4b71Sopenharmony_ci
5e41f4b71Sopenharmony_ci### 功能简介<a name="section2"></a>
6e41f4b71Sopenharmony_ci
7e41f4b71Sopenharmony_ciPIN即管脚控制器,用于统一管理各SoC的管脚资源,对外提供管脚复用功能:包括管脚推拉方式、管脚推拉强度以及管脚功能。
8e41f4b71Sopenharmony_ci
9e41f4b71Sopenharmony_ciPIN接口定义了操作PIN管脚的通用方法集合,包括:
10e41f4b71Sopenharmony_ci
11e41f4b71Sopenharmony_ci- 获取/释放管脚描述句柄:传入管脚名与链表中每个控制器下管脚名进行匹配,匹配则会获取一个管脚描述句柄,操作完PIN管脚后释放该管脚描述句柄。
12e41f4b71Sopenharmony_ci
13e41f4b71Sopenharmony_ci- 设置/获取管脚推拉方式:推拉方式可以是上拉、下拉以及悬空。
14e41f4b71Sopenharmony_ci
15e41f4b71Sopenharmony_ci- 设置/获取管脚推拉强度:用户可根据实际设置管脚推拉强度大小。
16e41f4b71Sopenharmony_ci
17e41f4b71Sopenharmony_ci- 设置/获取管脚功能:通过管脚功能名设置/获取管脚功能,实现管脚复用。
18e41f4b71Sopenharmony_ci
19e41f4b71Sopenharmony_ci### 基本概念<a name="section3"></a>
20e41f4b71Sopenharmony_ci
21e41f4b71Sopenharmony_ciPIN是一个软件层面的概念,目的是为了统一各SoC的PIN管脚管理,对外提供管脚复用功能,配置PIN管脚的电气特性。
22e41f4b71Sopenharmony_ci
23e41f4b71Sopenharmony_ci- SoC(System on Chip)
24e41f4b71Sopenharmony_ci
25e41f4b71Sopenharmony_ci    系统级芯片,也有称作片上系统,通常是面向特定用途将微处理器、模拟IP核、数字IP核和存储器集成在单一芯片的标准产品。
26e41f4b71Sopenharmony_ci
27e41f4b71Sopenharmony_ci- 管脚复用
28e41f4b71Sopenharmony_ci
29e41f4b71Sopenharmony_ci    由于芯片自身的引脚数量有限,无法满足日益增多的外接需求。此时可以通过软件层面的寄存器设置,让引脚工作在不同的状态,从而实现相同引脚完成不同功能的目的。
30e41f4b71Sopenharmony_ci
31e41f4b71Sopenharmony_ci### 运作机制<a name="section4"></a>
32e41f4b71Sopenharmony_ci
33e41f4b71Sopenharmony_ci在HDF框架中,同类型设备对象较多时(可能同时存在十几个同类型配置器),若采用独立服务模式,则需要配置更多的设备节点,且相关服务会占据更多的内存资源。相反,采用统一服务模式可以使用一个设备服务作为管理器,统一处理所有同类型对象的外部访问(这会在配置文件中有所体现),实现便捷管理和节约资源的目的。PIN模块接口适配模式采用统一服务模式。
34e41f4b71Sopenharmony_ci
35e41f4b71Sopenharmony_ci在统一模式下,所有的控制器都被核心层统一管理,并由核心层统一发布一个服务供接口层,因此这种模式下驱动无需再为每个控制器发布服务。
36e41f4b71Sopenharmony_ci
37e41f4b71Sopenharmony_ciPIN模块各分层作用:
38e41f4b71Sopenharmony_ci
39e41f4b71Sopenharmony_ci- 接口层提供获取PIN管脚、设置PIN管脚推拉方式、获取PIN管脚推拉方式、设置PIN管脚推拉强度、获取PIN管脚推拉强度、设置PIN管脚功能、获取PIN管脚功能、释放PIN管脚的接口。
40e41f4b71Sopenharmony_ci
41e41f4b71Sopenharmony_ci- 核心层主要提供PIN管脚资源匹配,PIN管脚控制器的添加、移除以及管理的能力,通过钩子函数与适配层交互。
42e41f4b71Sopenharmony_ci
43e41f4b71Sopenharmony_ci- 适配层主要是将钩子函数的功能实例化,实现具体的功能。
44e41f4b71Sopenharmony_ci
45e41f4b71Sopenharmony_ci**图 1**  PIN统一服务模式
46e41f4b71Sopenharmony_ci![PIN统一服务模式](figures/统一服务模式结构图.png)
47e41f4b71Sopenharmony_ci
48e41f4b71Sopenharmony_ci### 约束与限制<a name="section5"></a>
49e41f4b71Sopenharmony_ci
50e41f4b71Sopenharmony_ciPIN模块目前只支持小型系统LiteOS-A内核。
51e41f4b71Sopenharmony_ci
52e41f4b71Sopenharmony_ci## 使用指导<a name="section6"></a>
53e41f4b71Sopenharmony_ci
54e41f4b71Sopenharmony_ci### 场景介绍<a name="section7"></a>
55e41f4b71Sopenharmony_ci
56e41f4b71Sopenharmony_ciPIN模块仅是一个软件层面的概念,主要工作是管脚资源管理。使用复用管脚时,通过设置管脚功能、设置管脚推拉方式、设置管脚推拉强度来适配指定场景的需求。
57e41f4b71Sopenharmony_ci
58e41f4b71Sopenharmony_ci### 接口说明<a name="section8"></a>
59e41f4b71Sopenharmony_ci
60e41f4b71Sopenharmony_ciPIN模块提供的主要接口如表1所示,具体API详见//drivers/hdf_core/framework/include/platform/pin_if.h61e41f4b71Sopenharmony_ci
62e41f4b71Sopenharmony_ci**表 1**  PIN驱动API接口功能介绍
63e41f4b71Sopenharmony_ci<a name="table1"></a>
64e41f4b71Sopenharmony_ci
65e41f4b71Sopenharmony_ci| **接口名** | **描述** |
66e41f4b71Sopenharmony_ci| ------------------------------------------------------------ | ---------------- |
67e41f4b71Sopenharmony_ci| DevHandle PinGet(const char \*pinName) | 获取管脚描述句柄 |
68e41f4b71Sopenharmony_ci| void PinPut(DevHandle handle) | 释放管脚描述句柄 |
69e41f4b71Sopenharmony_ci| int32_t PinSetPull(DevHandle handle, enum PinPullType pullType) | 设置管脚推拉方式 |
70e41f4b71Sopenharmony_ci| int32_t PinGetPull(DevHandle handle, enum PinPullType \*pullType) | 获取管脚推拉方式 |
71e41f4b71Sopenharmony_ci| int32_t PinSetStrength(DevHandle handle, uint32_t strength) | 设置管脚推拉强度 |
72e41f4b71Sopenharmony_ci| int32_t PinGetStrength(DevHandle handle, uint32_t \*strength) | 获取管脚推拉强度 |
73e41f4b71Sopenharmony_ci| int32_t PinSetFunc(DevHandle handle, const char \*funcName) | 设置管脚功能 |
74e41f4b71Sopenharmony_ci| int32_t PinGetFunc(DevHandle handle, const char \**funcName) | 获取管脚功能 |
75e41f4b71Sopenharmony_ci
76e41f4b71Sopenharmony_ci>![](../public_sys-resources/icon-note.gif) **说明:**<br>
77e41f4b71Sopenharmony_ci>本文涉及PIN的所有接口,支持内核态及用户态使用。
78e41f4b71Sopenharmony_ci
79e41f4b71Sopenharmony_ci### 开发步骤<a name="section9"></a>
80e41f4b71Sopenharmony_ci
81e41f4b71Sopenharmony_ci使用PIN设备的一般流程如图2所示。
82e41f4b71Sopenharmony_ci
83e41f4b71Sopenharmony_ci**图 2** PIN使用流程图<a name="fig2"></a>  
84e41f4b71Sopenharmony_ci![PIN使用流程图](figures/PIN使用流程图.png) 
85e41f4b71Sopenharmony_ci
86e41f4b71Sopenharmony_ci#### 获取PIN管脚描述句柄
87e41f4b71Sopenharmony_ci
88e41f4b71Sopenharmony_ci在使用PIN进行管脚操作时,首先要调用PinGet获取管脚描述句柄,该函数会返回匹配传入管脚名的管脚描述句柄。
89e41f4b71Sopenharmony_ci
90e41f4b71Sopenharmony_ci```c
91e41f4b71Sopenharmony_ciDevHandle PinGet(const char *pinName);
92e41f4b71Sopenharmony_ci```
93e41f4b71Sopenharmony_ci
94e41f4b71Sopenharmony_ci**表 2**  PinGet参数和描述
95e41f4b71Sopenharmony_ci
96e41f4b71Sopenharmony_ci<a name="table2"></a>
97e41f4b71Sopenharmony_ci
98e41f4b71Sopenharmony_ci| 参数 | 描述 |
99e41f4b71Sopenharmony_ci| ---------- | ----------------------- |
100e41f4b71Sopenharmony_ci| pinName | 字符指针类型,管脚名 |
101e41f4b71Sopenharmony_ci| **返回值** | **描述** |
102e41f4b71Sopenharmony_ci| NULL | 获取PIN管脚描述句柄失败 |
103e41f4b71Sopenharmony_ci| handle | PIN管脚描述句柄 |
104e41f4b71Sopenharmony_ci
105e41f4b71Sopenharmony_ci假设PIN需要操作的管脚名为P18,获取其管脚描述句柄的示例如下:
106e41f4b71Sopenharmony_ci
107e41f4b71Sopenharmony_ci```c
108e41f4b71Sopenharmony_ciDevHandle handle = NULL;    // PIN管脚描述句柄
109e41f4b71Sopenharmony_ci
110e41f4b71Sopenharmony_cichar pinName = "P18";       // PIN管脚名
111e41f4b71Sopenharmony_cihandle = PinGet(pinName);
112e41f4b71Sopenharmony_ciif (handle == NULL) {
113e41f4b71Sopenharmony_ci    HDF_LOGE("PinGet: get handle failed!\n");
114e41f4b71Sopenharmony_ci    return HDF_FAILURE;
115e41f4b71Sopenharmony_ci}
116e41f4b71Sopenharmony_ci```
117e41f4b71Sopenharmony_ci
118e41f4b71Sopenharmony_ci#### PIN设置管脚推拉方式
119e41f4b71Sopenharmony_ci
120e41f4b71Sopenharmony_ciPIN设置管脚推拉方式的函数如下所示:
121e41f4b71Sopenharmony_ci
122e41f4b71Sopenharmony_ci```c
123e41f4b71Sopenharmony_ciint32_t PinSetPull(DevHandle handle, enum PinPullType pullType);
124e41f4b71Sopenharmony_ci```
125e41f4b71Sopenharmony_ci
126e41f4b71Sopenharmony_ci**表 3**  参数和描述
127e41f4b71Sopenharmony_ci
128e41f4b71Sopenharmony_ci<a name="table3"></a>
129e41f4b71Sopenharmony_ci
130e41f4b71Sopenharmony_ci| 参数 | 描述 |
131e41f4b71Sopenharmony_ci| ---------- | ----------------------- |
132e41f4b71Sopenharmony_ci| handle | DevHandle类型,PIN管脚描述句柄 |
133e41f4b71Sopenharmony_ci| pullType | 枚举类型,PIN管脚推拉方式 |
134e41f4b71Sopenharmony_ci| **返回值** | **描述**          |
135e41f4b71Sopenharmony_ci| HDF_SUCCESS | PIN设置管脚推拉方式成功 |
136e41f4b71Sopenharmony_ci| 负数 | PIN设置管脚推拉方式失败 |
137e41f4b71Sopenharmony_ci
138e41f4b71Sopenharmony_ci假设PIN要设置的管脚推拉方式为上拉,其实例如下:
139e41f4b71Sopenharmony_ci
140e41f4b71Sopenharmony_ci```c
141e41f4b71Sopenharmony_ciint32_t ret;
142e41f4b71Sopenharmony_cienum PinPullType pullTypeNum;
143e41f4b71Sopenharmony_ci
144e41f4b71Sopenharmony_ci// PIN设置管脚推拉方式
145e41f4b71Sopenharmony_cipullTypeNum = 1;
146e41f4b71Sopenharmony_ciret = PinSetPull(handle, pullTypeNum);
147e41f4b71Sopenharmony_ciif (ret != HDF_SUCCESS) {
148e41f4b71Sopenharmony_ci    HDF_LOGE("PinSetPull: failed, ret %d\n", ret);
149e41f4b71Sopenharmony_ci    return ret;
150e41f4b71Sopenharmony_ci}
151e41f4b71Sopenharmony_ci```
152e41f4b71Sopenharmony_ci
153e41f4b71Sopenharmony_ci#### PIN获取管脚推拉方式
154e41f4b71Sopenharmony_ci
155e41f4b71Sopenharmony_ciPIN获取管脚推拉方式的函数如下所示:
156e41f4b71Sopenharmony_ci
157e41f4b71Sopenharmony_ci```c
158e41f4b71Sopenharmony_ciint32_t PinGetPull(DevHandle handle, enum PinPullType *pullType);
159e41f4b71Sopenharmony_ci```
160e41f4b71Sopenharmony_ci
161e41f4b71Sopenharmony_ci**表 4**  PinGetPull参数和描述
162e41f4b71Sopenharmony_ci
163e41f4b71Sopenharmony_ci<a name="table4"></a>
164e41f4b71Sopenharmony_ci
165e41f4b71Sopenharmony_ci| 参数 | 描述 |
166e41f4b71Sopenharmony_ci| ---------- | ------------------------- |
167e41f4b71Sopenharmony_ci| handle | DevHandle类型,PIN管脚描述句柄 |
168e41f4b71Sopenharmony_ci| pullType | 枚举类型指针,接收PIN管脚推拉方式 |
169e41f4b71Sopenharmony_ci| **返回值** | **描述**            |
170e41f4b71Sopenharmony_ci| HDF_SUCCESS | PIN获取管脚推拉方式成功 |
171e41f4b71Sopenharmony_ci| 负数 | PIN获取管脚推拉方式失败 |
172e41f4b71Sopenharmony_ci
173e41f4b71Sopenharmony_ciPIN获取管脚推拉方式的实例如下:
174e41f4b71Sopenharmony_ci
175e41f4b71Sopenharmony_ci```c
176e41f4b71Sopenharmony_ciint32_t ret;
177e41f4b71Sopenharmony_cienum PinPullType pullTypeNum;
178e41f4b71Sopenharmony_ci
179e41f4b71Sopenharmony_ci// PIN获取管脚推拉方式
180e41f4b71Sopenharmony_ciret = PinGetPull(handle, &pullTypeNum);
181e41f4b71Sopenharmony_ciif (ret != HDF_SUCCESS) {
182e41f4b71Sopenharmony_ci    HDF_LOGE("PinGetPull: failed, ret %d\n", ret);
183e41f4b71Sopenharmony_ci    return ret;
184e41f4b71Sopenharmony_ci}
185e41f4b71Sopenharmony_ci```
186e41f4b71Sopenharmony_ci
187e41f4b71Sopenharmony_ci#### PIN设置管脚推拉强度
188e41f4b71Sopenharmony_ci
189e41f4b71Sopenharmony_ciPIN设置管脚推拉强度函数如下所示:
190e41f4b71Sopenharmony_ci
191e41f4b71Sopenharmony_ci```c
192e41f4b71Sopenharmony_ciint32_t PinSetStrength(DevHandle handle, uint32_t strength);
193e41f4b71Sopenharmony_ci```
194e41f4b71Sopenharmony_ci
195e41f4b71Sopenharmony_ci**表 5**  PinSetStrength参数和描述
196e41f4b71Sopenharmony_ci
197e41f4b71Sopenharmony_ci<a name="table5"></a>
198e41f4b71Sopenharmony_ci
199e41f4b71Sopenharmony_ci| 参数 | 描述 |
200e41f4b71Sopenharmony_ci| ---------- | ----------------------- |
201e41f4b71Sopenharmony_ci| handle | DevHandle类型,管脚描述句柄 |
202e41f4b71Sopenharmony_ci| strength | uint32_t类型,PIN管脚推拉强度 |
203e41f4b71Sopenharmony_ci| **返回值** | **描述**          |
204e41f4b71Sopenharmony_ci| HDF_SUCCESS | PIN设置管脚推拉强度成功 |
205e41f4b71Sopenharmony_ci| 负数 | PIN设置管脚推拉强度失败 |
206e41f4b71Sopenharmony_ci
207e41f4b71Sopenharmony_ci假设PIN要设置的管脚推拉强度为2,其实例如下:
208e41f4b71Sopenharmony_ci
209e41f4b71Sopenharmony_ci```c
210e41f4b71Sopenharmony_ciint32_t ret;
211e41f4b71Sopenharmony_ciuint32_t strengthNum;
212e41f4b71Sopenharmony_ci// PIN设置管脚推拉强度
213e41f4b71Sopenharmony_cistrengthNum = 2;
214e41f4b71Sopenharmony_ciret = PinSetStrength(handle, strengthNum);
215e41f4b71Sopenharmony_ciif (ret != HDF_SUCCESS) {
216e41f4b71Sopenharmony_ci    HDF_LOGE("PinSetStrength: failed, ret %d\n", ret);
217e41f4b71Sopenharmony_ci    return ret;
218e41f4b71Sopenharmony_ci}
219e41f4b71Sopenharmony_ci```
220e41f4b71Sopenharmony_ci
221e41f4b71Sopenharmony_ci#### PIN获取管脚推拉强度
222e41f4b71Sopenharmony_ci
223e41f4b71Sopenharmony_ciPIN设置管脚推拉强度后,可以通过PIN获取管脚推拉强度接口来查看PIN管脚推拉强度,PIN获取管脚推拉强度的函数如下所示:
224e41f4b71Sopenharmony_ci
225e41f4b71Sopenharmony_ci```c
226e41f4b71Sopenharmony_ciint32_t PinGetStrength(DevHandle handle, uint32_t *strength);
227e41f4b71Sopenharmony_ci```
228e41f4b71Sopenharmony_ci
229e41f4b71Sopenharmony_ci**表 6**  PinGetStrength参数和描述
230e41f4b71Sopenharmony_ci
231e41f4b71Sopenharmony_ci<a name="table6"></a>
232e41f4b71Sopenharmony_ci
233e41f4b71Sopenharmony_ci| 参数 | 描述 |
234e41f4b71Sopenharmony_ci| ---------- | ------------------------- |
235e41f4b71Sopenharmony_ci| handle | DevHandle类型,管脚描述句柄 |
236e41f4b71Sopenharmony_ci| strength | uint32_t类型指针,接收PIN管脚推拉强度 
237e41f4b71Sopenharmony_ci| **返回值** | **描述**            |
238e41f4b71Sopenharmony_ci| HDF_SUCCESS | PIN获取管脚推拉强度成功 |
239e41f4b71Sopenharmony_ci| 负数 | PIN获取管脚推拉强度失败 |
240e41f4b71Sopenharmony_ci
241e41f4b71Sopenharmony_ciPIN获取管脚推拉强度的实例如下:
242e41f4b71Sopenharmony_ci
243e41f4b71Sopenharmony_ci```c
244e41f4b71Sopenharmony_ciint32_t ret;
245e41f4b71Sopenharmony_ciuint32_t strengthNum;
246e41f4b71Sopenharmony_ci
247e41f4b71Sopenharmony_ci// PIN获取管脚推拉强度
248e41f4b71Sopenharmony_ciret = PinGetStrength(handle, &strengthNum);
249e41f4b71Sopenharmony_ciif (ret != HDF_SUCCESS) {
250e41f4b71Sopenharmony_ci    HDF_LOGE("PinGetStrength: failed, ret %d\n", ret);
251e41f4b71Sopenharmony_ci    return ret;
252e41f4b71Sopenharmony_ci}
253e41f4b71Sopenharmony_ci```
254e41f4b71Sopenharmony_ci
255e41f4b71Sopenharmony_ci#### PIN设置管脚功能
256e41f4b71Sopenharmony_ci
257e41f4b71Sopenharmony_ci管脚功能特指的是管脚复用的功能,每个管脚功能都不相同,管脚功能名详细可以参考//device/soc/hisilicon/hi3516dv300/sdk_liteos/hdf_config/pin/pin_config.hcs258e41f4b71Sopenharmony_ci
259e41f4b71Sopenharmony_ciPIN设置管脚功能函数如下所示:
260e41f4b71Sopenharmony_ci
261e41f4b71Sopenharmony_ci```c
262e41f4b71Sopenharmony_ciint32_t PinSetFunc(DevHandle handle, const char *funcName);
263e41f4b71Sopenharmony_ci```
264e41f4b71Sopenharmony_ci
265e41f4b71Sopenharmony_ci**表 7**  PinSetFunc参数和描述
266e41f4b71Sopenharmony_ci
267e41f4b71Sopenharmony_ci<a name="table7"></a>
268e41f4b71Sopenharmony_ci
269e41f4b71Sopenharmony_ci| 参数 | 描述 |
270e41f4b71Sopenharmony_ci| ---------- | ------------------- |
271e41f4b71Sopenharmony_ci| handle | DevHandle类型,管脚描述句柄 |
272e41f4b71Sopenharmony_ci| funcName | 字符指针类型,PIN管脚功能名 |
273e41f4b71Sopenharmony_ci| **返回值** | **描述**      |
274e41f4b71Sopenharmony_ci| HDF_SUCCESS | PIN设置管脚功能成功 |
275e41f4b71Sopenharmony_ci| 负数 | PIN设置管脚功能失败 |
276e41f4b71Sopenharmony_ci
277e41f4b71Sopenharmony_ci假设PIN需要设置的管脚功能为LSADC_CH1(ADC通道1),其实例如下:
278e41f4b71Sopenharmony_ci
279e41f4b71Sopenharmony_ci```c
280e41f4b71Sopenharmony_ciint32_t ret;
281e41f4b71Sopenharmony_cichar funcName = "LSADC_CH1";
282e41f4b71Sopenharmony_ci
283e41f4b71Sopenharmony_ci// PIN设置管脚功能
284e41f4b71Sopenharmony_ciret = PinSetFunc(handle, funcName);
285e41f4b71Sopenharmony_ciif (ret != HDF_SUCCESS) {
286e41f4b71Sopenharmony_ci    HDF_LOGE("PinSetFunc: failed, ret %d\n", ret);
287e41f4b71Sopenharmony_ci    return ret;
288e41f4b71Sopenharmony_ci}
289e41f4b71Sopenharmony_ci```
290e41f4b71Sopenharmony_ci
291e41f4b71Sopenharmony_ci#### PIN获取管脚功能
292e41f4b71Sopenharmony_ci
293e41f4b71Sopenharmony_ciPIN设置管脚功能后,可以通过PIN获取管脚功能接口来查看PIN管脚功能,PIN获取管脚功能的函数如下所示:
294e41f4b71Sopenharmony_ci
295e41f4b71Sopenharmony_ci```c
296e41f4b71Sopenharmony_ciint32_t PinGetFunc(DevHandle handle, const char **funcName);
297e41f4b71Sopenharmony_ci```
298e41f4b71Sopenharmony_ci
299e41f4b71Sopenharmony_ci**表 8**  PinGetFunc参数和描述
300e41f4b71Sopenharmony_ci
301e41f4b71Sopenharmony_ci<a name="table8"></a>
302e41f4b71Sopenharmony_ci
303e41f4b71Sopenharmony_ci| 参数 | 描述 |
304e41f4b71Sopenharmony_ci| ---------- | --------------------- |
305e41f4b71Sopenharmony_ci| handle | DevHandle类型,管脚描述句柄 |
306e41f4b71Sopenharmony_ci| funcName | 字符类型双指针,接收PIN管脚功能 |
307e41f4b71Sopenharmony_ci| **返回值** | **描述**        |
308e41f4b71Sopenharmony_ci| HDF_SUCCESS | PIN获取管脚功能成功 |
309e41f4b71Sopenharmony_ci| 负数 | PIN获取管脚功能失败 |
310e41f4b71Sopenharmony_ci
311e41f4b71Sopenharmony_ciPIN获取管脚功能的实例如下:
312e41f4b71Sopenharmony_ci
313e41f4b71Sopenharmony_ci```c
314e41f4b71Sopenharmony_ciint32_t ret;
315e41f4b71Sopenharmony_cichar *funcName = NULL;
316e41f4b71Sopenharmony_ci
317e41f4b71Sopenharmony_ci// PIN获取管脚功能
318e41f4b71Sopenharmony_ciret = PinGetFunc(handle, &funcName);
319e41f4b71Sopenharmony_ciif (ret != HDF_SUCCESS) {
320e41f4b71Sopenharmony_ci    HDF_LOGE("PinGetFunc: failed, ret %d\n", ret);
321e41f4b71Sopenharmony_ci    return ret;
322e41f4b71Sopenharmony_ci}
323e41f4b71Sopenharmony_ci```
324e41f4b71Sopenharmony_ci
325e41f4b71Sopenharmony_ci####  释放PIN管脚描述句柄
326e41f4b71Sopenharmony_ci
327e41f4b71Sopenharmony_ciPIN不再进行任何操作后,需要释放PIN管脚描述管脚句柄,函数如下所示:
328e41f4b71Sopenharmony_ci
329e41f4b71Sopenharmony_ci```c
330e41f4b71Sopenharmony_civoid PinPut(DevHandle handle);
331e41f4b71Sopenharmony_ci```
332e41f4b71Sopenharmony_ci
333e41f4b71Sopenharmony_ci**表 9**  PinPut参数和描述
334e41f4b71Sopenharmony_ci
335e41f4b71Sopenharmony_ci<a name="table9"></a>
336e41f4b71Sopenharmony_ci
337e41f4b71Sopenharmony_ci| 参数 | 描述 |
338e41f4b71Sopenharmony_ci| ---------- | -------------- |
339e41f4b71Sopenharmony_ci| handle | DevHandle类型,管脚描述句柄 |
340e41f4b71Sopenharmony_ci| **返回值** | **描述** |
341e41f4b71Sopenharmony_ci| NA | 无返回值 |
342e41f4b71Sopenharmony_ci
343e41f4b71Sopenharmony_ciPIN销毁管脚描述句柄实例如下:
344e41f4b71Sopenharmony_ci
345e41f4b71Sopenharmony_ci```c
346e41f4b71Sopenharmony_ciPinPut(handle);
347e41f4b71Sopenharmony_ci```
348e41f4b71Sopenharmony_ci
349e41f4b71Sopenharmony_ci## 使用实例<a name="section10"></a>
350e41f4b71Sopenharmony_ci
351e41f4b71Sopenharmony_ci下面将基于Hi3516DV300开发板展示使用PIN设置管脚相关属性完整操作,步骤主要如下:
352e41f4b71Sopenharmony_ci
353e41f4b71Sopenharmony_ci1. 传入要设置的管脚名,获取PIN管脚描述句柄。
354e41f4b71Sopenharmony_ci
355e41f4b71Sopenharmony_ci2. 通过PIN管脚描述句柄以及推拉方式pullTypeNum设置管脚推拉方式,如果操作失败则释放PIN管脚描述句柄。
356e41f4b71Sopenharmony_ci
357e41f4b71Sopenharmony_ci3. 通过PIN管脚描述句柄,并用pullTypeNum承接获取的管脚推拉方式,如果操作失败则释放PIN管脚描述句柄。
358e41f4b71Sopenharmony_ci
359e41f4b71Sopenharmony_ci4. 通过PIN管脚描述句柄以及推拉强度strengthNum设置管脚推拉强度,如果操作失败则释放PIN管脚描述句柄。
360e41f4b71Sopenharmony_ci
361e41f4b71Sopenharmony_ci5. 通过PIN管脚描述句柄,并用strengthNum承接获取的管脚推拉强度,如果操作失败则释放PIN管脚描述句柄。
362e41f4b71Sopenharmony_ci
363e41f4b71Sopenharmony_ci5. 通过PIN管脚描述句柄以及管脚功能名funName设置管脚功能,如果操作失败则释放PIN管脚描述句柄。
364e41f4b71Sopenharmony_ci
365e41f4b71Sopenharmony_ci6. 通过PIN管脚描述句柄,并用funName承接获取的管脚功能名,如果操作失败则释放PIN管脚描述句柄。
366e41f4b71Sopenharmony_ci
367e41f4b71Sopenharmony_ci7. 使用完PIN后,不再对管脚进行操作,释放PIN管脚描述句柄。
368e41f4b71Sopenharmony_ci
369e41f4b71Sopenharmony_ci```c
370e41f4b71Sopenharmony_ci#include "hdf_log.h"                              // 标准日志打印头文件
371e41f4b71Sopenharmony_ci#include "pin_if.h"                               // PIN标准接口头文件
372e41f4b71Sopenharmony_ci
373e41f4b71Sopenharmony_ciint32_t PinTestSample(void)
374e41f4b71Sopenharmony_ci{
375e41f4b71Sopenharmony_ci    int32_t ret;
376e41f4b71Sopenharmony_ci    uint32_t strengthNum;
377e41f4b71Sopenharmony_ci    enum PinPullType pullTypeNum;
378e41f4b71Sopenharmony_ci    char *pinName = NULL;
379e41f4b71Sopenharmony_ci    const char *funcName = NULL;
380e41f4b71Sopenharmony_ci    DevHandle handle = NULL;
381e41f4b71Sopenharmony_ci
382e41f4b71Sopenharmony_ci    // PIN管脚名,要填写实际要设置的管脚名
383e41f4b71Sopenharmony_ci    pinName = "P18"; 
384e41f4b71Sopenharmony_ci    // PIN获取管脚描述句柄
385e41f4b71Sopenharmony_ci    handle = PinGet(pinName);
386e41f4b71Sopenharmony_ci    if (handle == NULL) {
387e41f4b71Sopenharmony_ci        HDF_LOGE("PinTestSample: pin get fail!\n");
388e41f4b71Sopenharmony_ci        return -1;
389e41f4b71Sopenharmony_ci    }
390e41f4b71Sopenharmony_ci    // PIN设置管脚推拉方式为上拉 
391e41f4b71Sopenharmony_ci    pullTypeNum = 1;
392e41f4b71Sopenharmony_ci    ret = PinSetPull(handle, pullTypeNum);
393e41f4b71Sopenharmony_ci    if (ret != HDF_SUCCESS) {
394e41f4b71Sopenharmony_ci        HDF_LOGE("PinTestSample: pin set pull fail, ret:%d\n", ret);
395e41f4b71Sopenharmony_ci        goto ERR;
396e41f4b71Sopenharmony_ci    }
397e41f4b71Sopenharmony_ci    // PIN获取管脚推拉方式 
398e41f4b71Sopenharmony_ci    ret = PinGetPull(handle, &pullTypeNum);
399e41f4b71Sopenharmony_ci    if (ret != HDF_SUCCESS) {
400e41f4b71Sopenharmony_ci        HDF_LOGE("PinTestSample: pin get pull fail, ret:%d\n", ret);
401e41f4b71Sopenharmony_ci        goto ERR;
402e41f4b71Sopenharmony_ci    }
403e41f4b71Sopenharmony_ci    // PIN设置管脚推拉强度为2 
404e41f4b71Sopenharmony_ci    strengthNum = 2;
405e41f4b71Sopenharmony_ci    ret = PinSetStrength(handle, strengthNum);
406e41f4b71Sopenharmony_ci    if (ret != HDF_SUCCESS) {
407e41f4b71Sopenharmony_ci        HDF_LOGE("PinTestSample: pin set strength fail, ret:%d\n", ret);
408e41f4b71Sopenharmony_ci        goto ERR;
409e41f4b71Sopenharmony_ci    }
410e41f4b71Sopenharmony_ci    // PIN获取管脚推拉强度 
411e41f4b71Sopenharmony_ci    ret = PinGetStrength(handle, &strengthNum);
412e41f4b71Sopenharmony_ci    if (ret != HDF_SUCCESS) {
413e41f4b71Sopenharmony_ci        HDF_LOGE("PinTestSample: pin get strength fail, ret:%d\n", ret);
414e41f4b71Sopenharmony_ci        goto ERR;
415e41f4b71Sopenharmony_ci    }
416e41f4b71Sopenharmony_ci    // PIN设置管脚功能为LSADC_CH1 
417e41f4b71Sopenharmony_ci    funcName = "LSADC_CH1";
418e41f4b71Sopenharmony_ci    ret = PinSetFunc(handle, funcName);
419e41f4b71Sopenharmony_ci    if (ret != HDF_SUCCESS) {
420e41f4b71Sopenharmony_ci        HDF_LOGE("PinTestSample: pin set func fail, ret:%d\n", ret);
421e41f4b71Sopenharmony_ci        goto ERR;
422e41f4b71Sopenharmony_ci    }
423e41f4b71Sopenharmony_ci    // PIN获取管脚功能 
424e41f4b71Sopenharmony_ci    ret = PinGetFunc(handle, &funcName);
425e41f4b71Sopenharmony_ci    if (ret != HDF_SUCCESS) {
426e41f4b71Sopenharmony_ci        HDF_LOGE("PinTestSample: pin get func fail, ret:%d\n", ret);
427e41f4b71Sopenharmony_ci        goto ERR;
428e41f4b71Sopenharmony_ci    }
429e41f4b71Sopenharmony_ci    HDF_LOGD("PinTestSample: function tests end.", __func__);
430e41f4b71Sopenharmony_ciERR:
431e41f4b71Sopenharmony_ci    // 释放PIN管脚描述句柄 
432e41f4b71Sopenharmony_ci    PinPut(handle); 
433e41f4b71Sopenharmony_ci    return ret;
434e41f4b71Sopenharmony_ci}
435e41f4b71Sopenharmony_ci```
436