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 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.h。 61e41f4b71Sopenharmony_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> **说明:**<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 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.hcs。 258e41f4b71Sopenharmony_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