本案例主要是如何在小凌派-RK2206开发板上使用IOT库的GPIO接口,进行GPIO编程开发。
例程将创建一个任务,通过配置GPIO引脚,实现GPIO读写操作。
GPIO在日常设备中非常常见,以下我们将演示IOT库的GPIO接口如何进行GPIO口配置,以及GPIO口读写操作。
base/iot_hardware/peripheral/interfaces/kits/iot_gpio.h
unsigned int IoTGpioInit(unsigned int id);
描述:
初始化GPIO设备。
参数:
参数 | 类型 | 描述 |
---|---|---|
id | unsigned int | GPIOID编号 |
返回值:
返回值 | 描述 |
---|---|
IOT_SUCCESS | 成功 |
IOT_FAILURE | 失败 |
实现:
hal_iot_gpio.c
文件在device/rockchip/rk2206/adapter/hals/iot_hardware/wifiiot_lite
目录下。
unsigned int IoTGpioInit(unsigned int id)
{
unsigned int ret = 0;
if (id > GPIO0_PC7 && id != GPIO1_PD0) {
PRINT_ERR("id(%d) > %d || id(%d) != %d\\n", id, GPIO0_PC7, GPIO1_PD0);
return IOT_FAILURE;
}
ret = LzGpioInit(id);
if (ret != LZ_HARDWARE_SUCCESS) {
return IOT_FAILURE;
}
ret = PinctrlSet(id, MUX_FUNC0, PULL_KEEP, DRIVE_LEVEL0);
if (ret != LZ_HARDWARE_SUCCESS) {
return IOT_FAILURE;
}
return IOT_SUCCESS;
}
unsigned int IoTGpioDeinit(unsigned int id);
描述:
取消初始化GPIO设备。
参数:
参数 | 类型 | 描述 |
---|---|---|
id | unsigned int | GPIOID编号 |
返回值:
返回值 | 描述 |
---|---|
IOT_SUCCESS | 成功 |
IOT_FAILURE | 失败 |
实现:
hal_iot_gpio.c
文件在device/rockchip/rk2206/adapter/hals/iot_hardware/wifiiot_lite
目录下。
unsigned int IoTGpioDeinit(unsigned int id)
{
unsigned int ret = 0;
if (id > GPIO0_PC7 && id != GPIO1_PD0) {
PRINT_ERR("id(%d) > %d || id(%d) != %d\\n", id, GPIO0_PC7, GPIO1_PD0);
return IOT_FAILURE;
}
ret = LzGpioDeinit(id);
if (ret != LZ_HARDWARE_SUCCESS) {
return IOT_FAILURE;
}
return IOT_SUCCESS;
}
unsigned int IoTGpioSetDir(unsigned int id, IotGpioDir dir);
描述:
设置GPIO引脚的方向。
参数:
参数 | 类型 | 描述 |
---|---|---|
id | unsigned int | GPIOID编号 |
dir | IotGpioDir | GPIO方向 |
其中,dir对应于如下表所示:
IotGpioDir | 描述 |
---|---|
IOT_GPIO_DIR_IN | 输入 |
IOT_GPIO_DIR_OUT | 输出 |
返回值:
返回值 | 描述 |
---|---|
IOT_SUCCESS | 成功 |
IOT_FAILURE | 失败 |
实现:
hal_iot_gpio.c
文件在device/rockchip/rk2206/adapter/hals/iot_hardware/wifiiot_lite
目录下。
unsigned int IoTGpioSetDir(unsigned int id, IotGpioDir dir)
{
unsigned int ret = 0;
if (id > GPIO0_PC7 && id != GPIO1_PD0) {
PRINT_ERR("id(%d) > %d || id(%d) != %d\\n", id, GPIO0_PC7, GPIO1_PD0);
return IOT_FAILURE;
}
ret = LzGpioSetDir(id, (LzGpioDir)dir);
if (ret != LZ_HARDWARE_SUCCESS) {
return IOT_FAILURE;
}
return IOT_SUCCESS;
}
unsigned int IoTGpioGetDir(unsigned int id, IotGpioDir *dir);
描述:
获取GPIO引脚的方向。
参数:
参数 | 类型 | 描述 |
---|---|---|
id | unsigned int | GPIOID编号 |
dir | IotGpioDir | GPIO方向指针 |
返回值:
返回值 | 描述 |
---|---|
IOT_SUCCESS | 成功 |
IOT_FAILURE | 失败 |
实现:
hal_iot_gpio.c
文件在device/rockchip/rk2206/adapter/hals/iot_hardware/wifiiot_lite
目录下。
unsigned int IoTGpioGetDir(unsigned int id, IotGpioDir *dir)
{
unsigned int ret = 0;
if (id > GPIO0_PC7 && id != GPIO1_PD0) {
PRINT_ERR("id(%d) > %d || id(%d) != %d\\n", id, GPIO0_PC7, GPIO1_PD0);
return IOT_FAILURE;
}
ret = LzGpioGetDir(id, (LzGpioDir *)dir);
if (ret != LZ_HARDWARE_SUCCESS) {
return IOT_FAILURE;
}
return IOT_SUCCESS;
}
unsigned int IoTGpioSetOutputVal(unsigned int id, IotGpioValue val);
描述:
设置GPIO引脚的输出电平值。
参数:
参数 | 类型 | 描述 |
---|---|---|
id | unsigned int | GPIOID编号 |
val | IotGpioValue | 电平 |
其中,val对应于如下表所示:
IotGpioValue | 描述 |
---|---|
IOT_GPIO_VALUE0 | 低电平 |
IOT_GPIO_VALUE1 | 高电平 |
返回值:
返回值 | 描述 |
---|---|
IOT_SUCCESS | 成功 |
IOT_FAILURE | 失败 |
实现:
hal_iot_gpio.c
文件在device/rockchip/rk2206/adapter/hals/iot_hardware/wifiiot_lite
目录下。
unsigned int IoTGpioSetOutputVal(unsigned int id, IotGpioValue val)
{
unsigned int ret = 0;
if (id > GPIO0_PC7 && id != GPIO1_PD0) {
PRINT_ERR("id(%d) > %d || id(%d) != %d\\n", id, GPIO0_PC7, GPIO1_PD0);
return IOT_FAILURE;
}
ret = LzGpioSetVal(id, (LzGpioValue)val);
if (ret != LZ_HARDWARE_SUCCESS) {
return IOT_FAILURE;
}
return IOT_SUCCESS;
}
unsigned int IoTGpioGetOutputVal(unsigned int id, IotGpioValue *val);
描述:
获取GPIO引脚的输出电平值。
参数:
参数 | 类型 | 描述 |
---|---|---|
id | unsigned int | GPIOID编号 |
val | IotGpioValue | 电平指针 |
返回值:
返回值 | 描述 |
---|---|
IOT_SUCCESS | 成功 |
IOT_FAILURE | 失败 |
实现:
hal_iot_gpio.c
文件在device/rockchip/rk2206/adapter/hals/iot_hardware/wifiiot_lite
目录下。
unsigned int IoTGpioGetOutputVal(unsigned int id, IotGpioValue *val)
{
unsigned int ret = 0;
if (id > GPIO0_PC7 && id != GPIO1_PD0) {
PRINT_ERR("id(%d) > %d || id(%d) != %d\\n", id, GPIO0_PC7, GPIO1_PD0);
return IOT_FAILURE;
}
ret = LzGpioGetVal(id, (LzGpioValue *)val);
if (ret != LZ_HARDWARE_SUCCESS) {
return IOT_FAILURE;
}
return IOT_SUCCESS;
}
unsigned int IoTGpioGetInputVal(unsigned int id, IotGpioValue *val);
描述:
获取GPIO引脚的输入电平值。
参数:
参数 | 类型 | 描述 |
---|---|---|
id | unsigned int | GPIOID编号 |
val | IotGpioValue | 电平指针 |
返回值:
返回值 | 描述 |
---|---|
IOT_SUCCESS | 成功 |
IOT_FAILURE | 失败 |
实现:
hal_iot_gpio.c
文件在device/rockchip/rk2206/adapter/hals/iot_hardware/wifiiot_lite
目录下。
unsigned int IoTGpioGetInputVal(unsigned int id, IotGpioValue *val)
{
unsigned int ret = 0;
if (id > GPIO0_PC7 && id != GPIO1_PD0) {
PRINT_ERR("id(%d) > %d || id(%d) != %d\\n", id, GPIO0_PC7, GPIO1_PD0);
return IOT_FAILURE;
}
ret = LzGpioGetVal(id, (LzGpioValue *)val);
if (ret != LZ_HARDWARE_SUCCESS) {
return IOT_FAILURE;
}
return IOT_SUCCESS;
}
主要代码分析
gpio_example
函数中,创建一个任务。
void gpio_example()
{
unsigned int thread_id;
TSK_INIT_PARAM_S task = {0};
unsigned int ret = LOS_OK;
task.pfnTaskEntry = (TSK_ENTRY_FUNC)gpio_thread;
task.uwStackSize = 2048;
task.pcName = "gpio_thread";
task.usTaskPrio = 24;
ret = LOS_TaskCreate(&thread_id, &task);
if (ret != LOS_OK) {
printf("Falied to create gpio_thread ret:0x%x\\n", ret);
return;
}
}
gpio_thread
任务中调用IOT库的GPIO接口初始化、配置、读写GPIO。
void gpio_thread()
{
unsigned int cur = 0;
IotGpioValue value = IOT_GPIO_VALUE0;
IoTGpioInit(GPIO_TEST);
while (1) {
printf("***************GPIO Example*************\\r\\n");
printf("Write GPIO\\n");
IoTGpioSetDir(GPIO_TEST, IOT_GPIO_DIR_OUT);
if (cur == 0) {
IoTGpioSetOutputVal(GPIO_TEST, cur);
IoTGpioGetOutputVal(GPIO_TEST, &value);
printf("\\tgpio set %d => gpio get %d\\n", cur, value);
cur = 1;
} else {
IoTGpioSetOutputVal(GPIO_TEST, cur);
IoTGpioGetOutputVal(GPIO_TEST, &value);
printf("\\tgpio set %d => gpio get %d\\n", cur, value);
cur = 0;
}
/* 睡眠1秒 */
LOS_Msleep(1000);
printf("Read GPIO\\n");
IoTGpioSetDir(GPIO_TEST, IOT_GPIO_DIR_IN);
IoTGpioGetInputVal(GPIO_TEST, &value);
printf("\\tgpio get %d\\n", value);
/* 睡眠1秒 */
LOS_Msleep(1000);
printf("\\n");
}
}
修改 vendor/lockzhiner/rk2206/sample
路径下 BUILD.gn 文件,指定 iot_gpio_example
参与编译。
"./b18_iot_gpio:iot_gpio_example",
**修改 **device/lockzhiner/rk2206/sdk_liteos
路径下 Makefile 文件,添加 -liot_gpio_example
参与编译。
hardware_LIBS = -lhal_iothardware -lhardware -lshellcmd -liot_gpio_example
示例代码编译烧录代码后,按下开发板的RESET按键,通过串口助手查看日志,显示如下:
***************GPIO Example*************
Write GPIO
gpio set 0 => gpio get 0
Read GPIO
gpio get 0
***************GPIO Example*************
Write GPIO
gpio set 1 => gpio get 1
Read GPIO
gpio get 1