CC1310 SimpleLink SDK PIN/GPIO的使用

2023-12-21 11:52

本文主要是介绍CC1310 SimpleLink SDK PIN/GPIO的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.声明配置并初始化PIN

在“CC1310_LAUNCHXL.h”文件中预定义

#define CC1310_LAUNCHXL_PIN_BEEP              IOID_3
#define CC1310_LAUNCHXL_PIN_RS485_TEN         IOID_0
#define CC1310_LAUNCHXL_PIN_SYSLED            IOID_9
#define CC1310_LAUNCHXL_PIN_ALMLED            IOID_8
/* UART Board */
#define CC1310_LAUNCHXL_UART_RX               IOID_1          /* RXD */
#define CC1310_LAUNCHXL_UART_TX               IOID_2          /* TXD */

在文件“CC1310_LAUNCHXL.c”中配置如下:

const PIN_Config BoardGpioInitTable[] = {CC1310_LAUNCHXL_PIN_RS485_TEN | PIN_GPIO_OUTPUT_EN | PIN_GPIO_LOW | PIN_PUSHPULL | PIN_DRVSTR_MAX,       /* LOW RECEIVE          */CC1310_LAUNCHXL_PIN_BEEP | PIN_GPIO_OUTPUT_EN | PIN_GPIO_LOW | PIN_PUSHPULL | PIN_DRVSTR_MAX,       /* LOW OFF          */     CC1310_LAUNCHXL_PIN_SYSLED | PIN_GPIO_OUTPUT_EN | PIN_GPIO_HIGH | PIN_PUSHPULL | PIN_DRVSTR_MAX,       /* HIGH OFF          */CC1310_LAUNCHXL_PIN_ALMLED | PIN_GPIO_OUTPUT_EN | PIN_GPIO_HIGH | PIN_PUSHPULL | PIN_DRVSTR_MAX,       /* HIGH OFF          */CC1310_LAUNCHXL_UART_RX | PIN_INPUT_EN | PIN_PULLDOWN,                                              /* UART RX via debugger back channel */CC1310_LAUNCHXL_UART_TX | PIN_GPIO_OUTPUT_EN | PIN_GPIO_LOW | PIN_PUSHPULL,                         /* UART TX via debugger back channel */PIN_TERMINATE
};

初始化PIN如下:
#include <ti/drivers/PIN.h>

void CC1310_LAUNCHXL_initGeneral(void)
{Power_init();if (PIN_init(BoardGpioInitTable) != PIN_SUCCESS) {/* Error with PIN_init */while (1);}/* Perform board-specific initialization *///Board_initHook();
}

PIN初始化后,我们已经可以使用driver/PIN.h文件中提供的API使用这些引脚了,如果我们想要直接使用某些引脚实现IO功能的话可以直接调用PIN_open()函数,但是在有操作系统的应用程序中并不推荐这样做,因为这并非线程安全的。上面PIN_init函数会将我们需要的引脚配置为GPIO可用的状态,但是在想使用这些引脚作为GPIO之前,还需要完成GPIO外设的初始化。

2.声明配置并初始化GPIO

#include <ti/drivers/GPIO.h>

在“CC1310_LAUNCHXL.c”文件中

/**  =============================== GPIO ===============================*/
#include <ti/drivers/GPIO.h>
#include <ti/drivers/gpio/GPIOCC26XX.h>/** Array of Pin configurations* NOTE: The order of the pin configurations must coincide with what was*       defined in CC1310_LAUNCHXL.h* NOTE: Pins not used for interrupts should be placed at the end of the*       array. Callback entries can be omitted from callbacks array to*       reduce memory usage.*/
GPIO_PinConfig gpioPinConfigs[] = {GPIOCC26XX_DIO_00 | GPIO_CFG_OUT_STD | GPIO_CFG_OUT_HIGH,  /* RS485 设置默认高则为发送状态 */GPIOCC26XX_DIO_01 | GPIO_DO_NOT_CONFIG,  /* UART RX */GPIOCC26XX_DIO_02 | GPIO_DO_NOT_CONFIG,  /* UART TX */GPIOCC26XX_DIO_03 | GPIO_CFG_OUT_STD | GPIO_CFG_OUT_LOW,  /* BEEP 默认不发声音*/GPIOCC26XX_DIO_07 | GPIO_DO_NOT_CONFIG,  /* NO USE  */GPIOCC26XX_DIO_06 | GPIO_DO_NOT_CONFIG,  /* NO USE */GPIOCC26XX_DIO_04 | GPIO_DO_NOT_CONFIG,  /* NO USE */GPIOCC26XX_DIO_05 | GPIO_DO_NOT_CONFIG,  /* NO USE *//* ALARM LED 默认不亮*/GPIOCC26XX_DIO_08 | GPIO_CFG_OUT_STD | GPIO_CFG_OUT_HIGH, /* SYS LED 默认不亮*/GPIOCC26XX_DIO_09 | GPIO_CFG_OUT_STD | GPIO_CFG_OUT_HIGH, 
};/** Array of callback function pointers* NOTE: The order of the pin configurations must coincide with what was*       defined in CC1310_LAUNCH.h* NOTE: Pins not used for interrupts can be omitted from callbacks array to*       reduce memory usage (if placed at end of gpioPinConfigs array).*/
GPIO_CallbackFxn gpioCallbackFunctions[] = {NULL,  /*  */NULL,  /*  */NULL,  /*  */NULL,  /* */
};const GPIOCC26XX_Config GPIOCC26XX_config = {.pinConfigs = (GPIO_PinConfig *)gpioPinConfigs,.callbacks = (GPIO_CallbackFxn *)gpioCallbackFunctions,.numberOfPinConfigs = CC1310_LAUNCHXL_GPIOCOUNT,.numberOfCallbacks  = sizeof(gpioCallbackFunctions)/sizeof(GPIO_CallbackFxn),.intPriority = (~0)
};

以上 GPIOCC26XX_DIO_?? 其实就是 IOID_? , 在“ti\drivers\gpio\GPIOCC26XX.h”文件中有声明如下:

#define GPIOCC26XX_DIO_00    IOID_0    /*!< @hideinitializer */
#define GPIOCC26XX_DIO_01    IOID_1    /*!< @hideinitializer */
#define GPIOCC26XX_DIO_02    IOID_2    /*!< @hideinitializer */
#define GPIOCC26XX_DIO_03    IOID_3    /*!< @hideinitializer */
#define GPIOCC26XX_DIO_04    IOID_4    /*!< @hideinitializer */
#define GPIOCC26XX_DIO_05    IOID_5    /*!< @hideinitializer */
#define GPIOCC26XX_DIO_06    IOID_6    /*!< @hideinitializer */
#define GPIOCC26XX_DIO_07    IOID_7    /*!< @hideinitializer */

在“CC1310_LAUNCHXL.h”文件中声明GPIOName,注意这个声明的顺序必须与以上“”文件中gpioPinConfigs声明一样。

/*!*  @def    CC1310_LAUNCHXL_GPIOName*  @brief  Enum of GPIO names*/
typedef enum CC1310_LAUNCHXL_GPIOName {CC1310_RS485_EN = 0, //485CC1310_LAUNCHXL_GPIO_S2,CC1310_LAUNCHXL_SPI_MASTER_READY,CC1310_BEEP,CC1310_LAUNCHXL_GPIO_LED_GREEN,CC1310_LAUNCHXL_GPIO_LED_RED,CC1310_LAUNCHXL_GPIO_TMP116_EN,CC1310_LAUNCHXL_GPIO_SPI_FLASH_CS,CC1310_ALMLED,CC1310_SYSLED,CC1310_LAUNCHXL_GPIOCOUNT
} CC1310_LAUNCHXL_GPIOName;

3.GPIO的使用

头文件:

#include <ti/drivers/GPIO.h>

使用前调用
GPIO_init();
API调用:

GPIO_write(uint_least8_t index, unsigned int value);
uint_fast8_t GPIO_read(uint_least8_t index);
void GPIO_toggle(uint_least8_t index);

例子:

GPIO_write(CC1310_LAUNCHXL_BEEP , 1);  //测试发声
GPIO_write(CC1310_LAUNCHXL_SYSLED, 1); //测试 信号接收指示 
GPIO_write(CC1310_LAUNCHXL_ALMLED, 1); //测试 4G转发指示
Task_sleep( 100000 / Clock_tickPeriod );
GPIO_toggle(CC1310_LAUNCHXL_BEEP);  //测试发声
GPIO_toggle(CC1310_LAUNCHXL_SYSLED);  //测试
GPIO_toggle(CC1310_LAUNCHXL_ALMLED);  //测试

对于CC1310,TI论坛上建议选用PIN系列的驱动。
The GPIO driver is supported for all device families except CC26xx/CC13xx. For the CC26xx/CC13xx device family, the PIN driver should be used. There is a GPIO driver for the CC26xx/CC13xx family within the driver product, however it is not promoted nor supported for external customer use.

这篇关于CC1310 SimpleLink SDK PIN/GPIO的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/519892

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

Ubuntu如何分配​​未使用的空间

《Ubuntu如何分配​​未使用的空间》Ubuntu磁盘空间不足,实际未分配空间8.2G因LVM卷组名称格式差异(双破折号误写)导致无法扩展,确认正确卷组名后,使用lvextend和resize2fs... 目录1:原因2:操作3:报错5:解决问题:确认卷组名称​6:再次操作7:验证扩展是否成功8:问题已解