一、硬件连接

串口 引脚
TXD DIO_2
RXD DIO_3

二、移植文件

链接:https://pan.baidu.com/s/1fE8XWgvdzYiF1bdUzTDxUg 提取码:r5s2
uart.cuart.h 两个文件拖拽至CCS工程的Application文件夹下

添加文件过程中,选项选择如下

2.1 uart.c

/********************************************************************** INCLUDES*/
#include <xdc/runtime/Assert.h>
#include <xdc/runtime/Types.h>
#include <xdc/runtime/Log.h>#include <ti/sysbios/BIOS.h>
#include <ti/drivers/power/PowerCC26XX.h>
#include <ti/drivers/uart/UARTCC26XX.h>
#include "board.h"
#include "util.h"#include "board_uart.h"/******************************************************************************* DEFINITIONS*/
#define UART_RX                 IOID_2  // 接收引脚
#define UART_TX                 IOID_3  // 发送引脚/********************************************************************** LOCAL VARIABLES*/
// 串口号
typedef enum{UART0 = 0,UARTCOUNT
} UARTName;// 流控制所需的配置
static const UARTCC26XX_HWAttrsV2 s_UART_CC26XXHWAttrs[UARTCOUNT] = {{.baseAddr       = UART0_BASE,.powerMngrId    = PowerCC26XX_PERIPH_UART0,.intNum         = INT_UART0_COMB,.intPriority    = ~0,.swiPriority    = 0,.txPin          = UART_TX,.rxPin          = UART_RX,.ctsPin         = PIN_UNASSIGNED,.rtsPin         = PIN_UNASSIGNED}
};// 串口目标
static UARTCC26XX_Object s_UART_CC26XXObject[UARTCOUNT];
static const UART_Config s_UART_Config[UARTCOUNT] = {{.fxnTablePtr = &UARTCC26XX_fxnTable,.object      = &s_UART_CC26XXObject[UART0],.hwAttrs     = &s_UART_CC26XXHWAttrs[UART0]},
};// 串口句柄
static UART_Handle s_UART_Handle;// 串口参数
static UART_Params s_UART_Params;/********************************************************************** GLOBAL VARIABLES*/
uint8_t g_UART_RxBuf[UART_MAX_NUM_RX_BYTES] = {0};
uint8_t g_UART_TxBuf[UART_MAX_NUM_TX_BYTES] = {0};
uint32_t g_UART_WantedRxBytes;
uint8_t g_UART_Size;// 串口定时器
Clock_Struct g_UART_Clock;/********************************************************************** PUBLIC FUNCTIONS*//**@brief 串口驱动初始化@param none@return none
*/
void UART_Init(UART_Callback UART_ReadCallback)
{// 初始化为默认值UART_Params_init(&s_UART_Params);// 参数设置s_UART_Params.baudRate      = 115200;s_UART_Params.writeDataMode = UART_DATA_BINARY;s_UART_Params.readMode      = UART_MODE_CALLBACK;s_UART_Params.readDataMode  = UART_DATA_BINARY;s_UART_Params.readCallback  = UART_ReadCallback;// 打开串口s_UART_Handle = s_UART_Config[0].fxnTablePtr->openFxn((UART_Handle)&s_UART_Config[0], &s_UART_Params);// 启动串口局部返回功能,为了能在串口接收到数据时及时进回调函数。如果没有这条语句,将会在缓冲区满时才进入。s_UART_Config[0].fxnTablePtr->controlFxn(s_UART_Handle, UARTCC26XX_CMD_RETURN_PARTIAL_ENABLE, NULL);// 开始第一次的读取等待g_UART_WantedRxBytes = UART_MAX_NUM_RX_BYTES;UART_Receive(g_UART_RxBuf, g_UART_WantedRxBytes);
}/**@brief 串口的写数据的函数@param pUART_TxBuf 写缓冲区@param UART_Len 数据长度@return none
*/
void UART_Send(uint8_t* pUART_TxBuf, uint8_t UART_Len)
{s_UART_Config[0].fxnTablePtr->writeFxn(s_UART_Handle, pUART_TxBuf, UART_Len);
}/**@brief 串口的读数据的函数@param pUART_RxBuf 读缓冲区@param UART_Len 数据长度@return none
*/
void UART_Receive(uint8_t* pUART_RxBuf, uint8_t UART_Len)
{s_UART_Config[0].fxnTablePtr->readFxn(s_UART_Handle, pUART_RxBuf, UART_Len);
}/**@brief 串口的读数据回调函数@param UART_Handle 串口句柄@param pUART_RxBuf 接收缓冲区@param UART_Size:接收数据大小@return none
*/
void UART_ReadCallback(UART_Handle UART_Handle, void *pUART_RxBuf, size_t UART_Size)
{// 保存数据g_UART_Size = UART_Size;memcpy(g_UART_RxBuf, pUART_RxBuf, g_UART_Size);// 启动定时器Util_startClock(&g_UART_Clock);
}/*************************************END OF FILE*************************************/

2.2 uart.h

#ifndef _BOARD_UART_H_
#define _BOARD_UART_H_/********************************************************************** INCLUDES*/
#include <ti/drivers/UART.h>
#include <ti/sysbios/knl/Clock.h>/******************************************************************************* DEFINITIONS*/
#define UART_MAX_NUM_RX_BYTES   60      // 最大接收字节
#define UART_MAX_NUM_TX_BYTES   60      // 最大发送字节/********************************************************************** EXTERNAL VARIABLES*/
extern uint8_t g_UART_RxBuf[UART_MAX_NUM_RX_BYTES];
extern uint8_t g_UART_TxBuf[UART_MAX_NUM_TX_BYTES];
extern uint32_t g_UART_WantedRxBytes;
extern uint8_t g_UART_Size;extern Clock_Struct g_UART_Clock;       // 串口定时器/********************************************************************** TYPEDEFS*/
typedef void (*UART_Callback) (UART_Handle handle, void *pBuf, size_t count);/********************************************************************** API FUNCTIONS*/
void UART_Init(UART_Callback UART_ReadCallback);
void UART_Send(uint8_t* npUART_TxBuf, uint8_t nUART_Len);
void UART_Receive(uint8_t* npUART_RxBuf, uint8_t nUART_Len);
void UART_ReadCallback(UART_Handle UART_Handle, void *pUART_RxBuf, size_t UART_Size);#endif /* _BOARD_UART_H_ */

三、API调用

需包含头文件 uart.h

UART_Init

功能 初始化串口驱动
函数定义 void UART_Init(UART_Callback UART_ReadCallback)
参数 UART回调函数
返回

UART_Send

功能 串口的写数据的函数
函数定义 void UART_Send(uint8_t* pUART_TxBuf, uint8_t UART_Len)
参数1 pUART_TxBuf:写缓冲区
参数2 UART_Len:数据长度
返回

UART_Receive

功能 串口的读数据的函数
函数定义 void UART_Receive(uint8_t* pUART_RxBuf, uint8_t UART_Len)
参数1 pUART_RxBuf:读缓冲区
参数2 UART_Len:数据长度
返回

四、流程

① 串口收到数据
② 从底层发送数据到应用层的回调函数UART_ReadCallback中
③ 在回调函数UART_ReadCallback中保存数据
④ 启动串口处理事件的定时器
⑤ 在uart_performTask函数中做自定义串口数据处理
注:如果直接在串口回调函数中做处理,会导致“收发一段时间后无法发出数据”的现象。

五、使用例子

1)添加头文件(例multi_role.c中)

#include "uart.h"

2)添加初始化代码(multi_role.c的multi_role_init函数末尾中)
初始化时传入应用层的串口回调函数,以便串口接收到数据时能传到应用层中。

// 串口初始化
UART_Init(UART_ReadCallback);
UART_Send("TEST\r\n", 6);
// 串口处理定时器初始化
Util_constructClock(&g_UART_Clock, multi_role_clockHandler, 0, 0, false, UART_EVT);

3)修改串口处理事件的宏
以multi_role工程为例,在multi_role.c的CONSTANTS常量定义中,加入UART_EVT,id号递增。

// Internal Events for RTOS application
#define MR_ICALL_EVT                         ICALL_MSG_EVENT_ID // Event_Id_31
#define MR_QUEUE_EVT                         UTIL_QUEUE_EVENT_ID // Event_Id_30
#define MR_STATE_CHANGE_EVT                  Event_Id_00
#define MR_CHAR_CHANGE_EVT                   Event_Id_01
#define MR_CONN_EVT_END_EVT                  Event_Id_02
#define MR_KEY_CHANGE_EVT                    Event_Id_03
#define MR_PAIRING_STATE_EVT                 Event_Id_04
#define MR_PASSCODE_NEEDED_EVT               Event_Id_05
#define MR_PERIODIC_EVT                      Event_Id_06
#define UART_EVT                             Event_Id_07    // 串口事件

在MR_ALL_EVENTS事件集合定义中,加入刚刚的自定义串口事件。

#define MR_ALL_EVENTS                        (MR_ICALL_EVT           | \MR_QUEUE_EVT            | \MR_STATE_CHANGE_EVT     | \MR_CHAR_CHANGE_EVT      | \MR_CONN_EVT_END_EVT     | \MR_KEY_CHANGE_EVT       | \MR_PAIRING_STATE_EVT    | \MR_PERIODIC_EVT         | \MR_PASSCODE_NEEDED_EVT  | \UART_EVT)

4)添加串口处理事件的处理
在multi_role.c的multi_role_taskFxn函数中尾部加入。

/*----------------- 串口处理事件 ------------------*/
if (events & UART_EVT)
{// 串口处理函数uart_performTask();
}

5)添加串口事件处理函数
在multi_role.c尾部添加

/*********************************************************************
* @fn     uart_performTask
*
* @brief   串口事件的处理函数,在此函数自定义串口处理功能
*
* @param   none
*
* @return  none
*/
static void uart_performTask(void)
{// 发送数据     UART_Send(g_UART_RxBuf, g_UART_Size);// 开始新一轮的读取等待UART_Receive(g_UART_RxBuf, g_UART_WantedRxBytes);
}

6)声明串口事件处理函数
在multi_role.c的LOCAL FUNCTIONS局部函数中加入

static void uart_performTask(void);

7)修改配置中的预编译
默认 BOARD_DISPLAY_USE_UARTBOARD_DISPLAY_USE_UART_ANSI 两个宏是为1的,本来TI工程的串口使用,现在要把这两个宏修改为0。


• 由 Leung 写于 2019 年 3 月 7 日

• 参考:【CC2640R2F】香瓜CC2640R2F之串口

CC2640R2F学习笔记(6)——UART串口使用相关推荐

  1. CC2640R2F学习笔记(七.UART)

    文章目录 一.配置UART 二.导入工程"empty" 三.代码改动 四.试验现象 一.配置UART 在SYSFONFIG中增加一个UART端口,配置如下: 保存Board.c和B ...

  2. CC2640R2F学习笔记(一.开发环境)

    文章目录 前言 一.硬件 二.操作系统 三.SDK 四.CCS 前言 以下列出CC2640R2F学习笔记所基于的软.硬件平台,笔记的所有实验.代码都是在这些平台上来进行的. 一.硬件 开发板LAUNC ...

  3. CC2640R2F学习笔记(九.总结)

    文章目录 前言 正文 总结 前言 注意:本文章仅代表作者对开发CC2640的一些理解,并非权威,仅供参考,如有错误欢迎指正. 正文 本想用CC2640R2F开发一个小产品,看重它的是价格便宜,尤其是几 ...

  4. STM32Cube学习篇(1)---UART串口通信

    学习目标: 熟悉串口的通信原理 掌握串口基本配置 掌握UART收发中断控制 1.串口通信协议 1.1物理层 串口通讯的物理层有很多标准及变种,RS-232 标准主要规定了信号 的用途.通讯接口以及信号 ...

  5. STC51单片机学习笔记8——stc12c56 串口显示AD(多路ad)

    stc12c56 串口显示AD(多路ad). AD中断设置 AUXR: ADC_CONTR: //#define ADC_POWER 0x80后面不能加分号,不然就会错.其他定义必须加分号!!! // ...

  6. STC51单片机学习笔记4——stc12c56 串口

    stc12c56 串口(没有用独立波特率发生器,用T1不分频.中断式接受与发送) //烧写程序时,一定要选用外部晶振(烧写软件默认为内部晶振(5M~6M)) //烧写时,有时候写不进去,尝试断开地线, ...

  7. STC51单片机学习笔记9——stc12c52 串口显示AD(单路ad+led指示灯)

    stc12le5204ad 为8位AD //烧写程序时,一定要选用外部晶振(烧写软件默认为内部晶振(5M~6M)),不然还会影响ADC //烧写时,有时候写不进去,尝试断开地线,然后接上上电 #inc ...

  8. 【MSP430G2553】图形化开发笔记(5) UART 串口及printf

    目录 概述 UART 的初始化 使用 Grace 配置 UART 介绍 用例:UART模式 FIFO的思想 使用 FIFO 发送 UART 数据 使用 FIFO 接收 UART 数据 FIFO编程 U ...

  9. stm32学习笔记-9 USART串口

    9 USART串口 文章目录 9 USART串口 9.1 串口通信协议 9.2 stm32的片上外设-USART 9.3 USART收发相关实验 9.3.1 实验1:串口发送 9.3.2 实验2:移植 ...

最新文章

  1. 《智能家居产品 从设计到运营》——第2章 技术搭台——与智能家居相关的技术...
  2. 使用范型观察者模式观察多个数据的实现
  3. Chrome浏览器官方离线安装包下载
  4. Exchange Server 2016管理系列课件50.DAG管理之激活数据库副本
  5. 【VB测绘程序设计】第一章 VB测绘程序设计概述
  6. 关于@Import注解的几个问题
  7. 高德软件有限公司python试题 及 答案
  8. 真强啊!建议每一个打算学Java的人都来看看!
  9. 11. 判断是给属性前加typeof 可以同时判断属性是否存在
  10. apk一键脱壳工具_海量破解、修改、无广告软件一键获取!一个工具就能轻松搞定!...
  11. 怎么让代码的逻辑更清晰?
  12. 如何避免“被贷款”影响个人信用记录?
  13. Python打印车次信息
  14. 再也不用熬夜爆肝做汇报了!PPT生成神器ChatBCG来啦!
  15. QT INSTALLS使用
  16. 使用easypoi导入导出excel,SSM和SpringBoot通用代码
  17. java产品经理_产品经理必懂的技术那点事儿:成为全栈产品经理
  18. linux 浏览器问题
  19. Vue基础—模版语法指令精细版
  20. 使用express脚手架创建项目

热门文章

  1. dreamcast游戏_Dreamcast Collection游戏百度网盘下载-DC游戏合集下载PC硬盘版-西西游戏下载...
  2. 初步操作3dmax可编辑多边形建模-做一个杯子
  3. 机电传动控制个人课程报告
  4. Vuforia直播笔记
  5. APP测试相关理论,积累一点是一点(面试向)
  6. 基于C语言实现把WAV双声道文件差分成两个单声道文件
  7. 机器学习实践:气象数据分析-10
  8. C# 控件属性一览表
  9. 北京、上海家庭年收入情况统计 (zz)
  10. Echarts 根据页面宽度自适应