CC2430基础——串口测试实验
1、《main.c》
#define ENABLE_ALL_INTERRUPT() (IEN0 |= 0x80)
#define DISABLE_ALL_INTERRUPT() (IEN0 &= ~0x80)
#include"ioCC2430.h"
#define uchar unsigned char
#define uint unsigned int
#define BYTE unsigned char
extern void UARTxISRopen(void); //开串口接收中断服务函数
extern void SET_UART0_ISR(void); //串口中断接收设置函数
extern void initUART(void); //初始化函数
main( void )
{
uchar temp = 0;
SLEEP &= ~0x04; //晶振 reset 2:Both oscillators powered up
while(!(SLEEP & 0x40)); //上电等待外晶振起振 XOSC is powered up and stable
CLKCON &= ~0x47; //reset 6:Main clock oscillator select: 32 MHz crystal oscillator
//TICHSPD128分频,CLKSPD不分频
SLEEP |= 0x04; //set 2:Oscillator not selected by OSC bit powered down
//关闭不用的RC振荡器
//先让两个振荡器都起振;等待晶体振荡器起振并稳定;
//通过CLKCON的OSC位把主时钟选择32M晶体振荡器;
//再让没有被CLKCON的OSC位选择的振荡器停止起振(关RC振荡器)
initUART(); //初始化
UARTxISRopen(); //开串口中断
ENABLE_ALL_INTERRUPT(); //开全局中断
while(1);
}
振荡器起振稳定——>设置主时钟——>初始化串口——>开串口中断——>开全局中断
//----------------------------------------------------------------------------
2、《uart.c》
#include"ioCC2430.h"
unsigned uarttemp;
#define ENABLE_ALL_INTERRUPT() (IEN0 |= 0x80) //开全局中断
#define DISABLE_ALL_INTERRUPT() (IEN0 &= ~0x80) //关全局中断
#define IO_PER_LOC_UART0_AT_PORT0_PIN2345() do { PERCFG = (PERCFG&~0x01)|0x00; } while (0)
//reste 0:USART0 I/O location: Alternative 1 location
//选择USART0为通道1:P0.2345
#define uchar unsigned char
#define CRYSTAL 0x00
#define RC 0x01
#define HIGH_STOP 0x02 //停止位为高电平
#define LOW_STOP 0x00 //停止位为低电平
#define CLKSPD (CLKCON & 0x07) //32KHZ and 32MHZ crystal oscilliator;32MHZ ticks
#define TRANSFER_MSB_FIRST 0x80 //最高位先发送
#define TRANSFER_MSB_LAST 0x00 //最高位后发送
//LSB(Least Significant Bit),意为最低有效位
//MSB(Most Significant Bit),意为最高有效位
#define UART_ENABLE_RECEIVE 0x40 //UART接收使能
#define UART_SETUP(uart, baudRate, options) \
do \
{ \
if((uart) == 0) \ //if uart=0,chose USART0_UART/SPI
{ \
if(PERCFG & 0x01) \ //if U0CFG=1,chose location 2
{ \
P1SEL |= 0x30; \ //then P1.4/5 set as peripheral I/O
} //P1.4/5分别是RX,TX两条线,UART可由这两线组成,也可再加上RT,CT这两条
else \ //if U0CFG=0,chose location 1
{
P0SEL |= 0x0C; \ //then P0.2/3 set as peripheral I/O;同样为RX,TX两线
} \
} \
else \ //if uart=1,chose USART1_UART/SPI
{ \
if(PERCFG & 0x02) \ //if U1CFG=1,chose location 2
{ \
P1SEL |= 0xC0; \ //then P1.6/7 set as peripheral I/O
}
else \ //if U1CFG=0 ,chose location 1
{ \
P0SEL |= 0x30; \ //then P0.4/5 set as peripheral I/O
} \
} \
//以上进行USATR通道选择设置
// ##中间的uart根据上面的设置为0或1
U##uart##GCR = BAUD_E((baudRate),CLKSPD); \ //设置波特率指数值
//U##uart##GCR:普通控制寄存器
U##uart##BAUD = BAUD_M(baudRate); \ //设置波特率尾数值
//U##uart##BAUD:波特率控制寄存器
\
U##uart##CSR |= 0x80; \ //USART设为UART模式
//U##uart##CSR:控制及状态寄存器
U##uart##UCR |= ((options) | 0x80); \ //chose UART stop bit level and set FLUSH bit
//U##uart##UCR :UART控制寄存器
\
if((options) & TRANSFER_MSB_FIRST) \ //options=0x02:High stop bit
{ \ // 0x02/0x00 & 0x80
U##uart##GCR |= 0x20; \ //MSB first
} \ //对于options=0x00这种情况,估计是以GCR寄存器默认的LSB first方式
U##uart##CSR |= 0x40; \ //Receiver enabled 接收使能
} while(0) // The macros in this section are available for both SPI and UART operation.
#define SET_MAIN_CLOCK_SOURCE(source) \ //source=CRYSTAL(0x00)/RC(0x01)
do { \
if(source) //RC Oscillator
{ \
CLKCON |= 0x40; //set 7, 16MHZ HF RC Oscillator
while(!HIGH_FREQUENCY_RC_OSC_STABLE); // wait for stable
if(TICKSPD == 0)
{ \
CLKCON |= 0x08; //set 3,16MHZ Timer ticks output
} \
SLEEP |= 0x04; //set 2,"oscillator not slected by OSC bit" powered down
} \//因为这里是用RC Oscillator,因此在CLKCON中的OSC位
//选择16M的RC;无论在SLEEP中有没有选择让它起振,
//通过OSC位选择的振荡器都会起振。最后SLEEP |= 0x04
//确定所用振荡器由CLKCON中的OSC位来选择,
//那这里是选择了16M的RC,因而CRYSTAL没有起振。
else //CRYSTAL Oscillator
{ \
SLEEP &= ~0x04; //reset 2,both oscillator powered up;
while(!XOSC_STABLE); //wait for stable
asm("NOP"); \
CLKCON &= ~0x47; //rest 6: 32M crystal oscillator;这里也应该是默认的16M ticks吧?
SLEEP |= 0x04; \ //首先SLEEP选择了两个振荡器都起振
} \ //然后通过CLKON的OSC位选择了32M的主时钟晶体振荡器
}while (0) //最后SLEEP |= 0x04确定所用振荡器由CLKCON中
//的OSC位来选择,那这里是选择了32M的CRYSTAL,因而
//晶体振荡器起振,RC振荡器没有起振
// BAUD_E along with BAUD_M decides the UART baud rate
// and the SPI master SCK clock frequency
// BAUD_E和BAUD_M共同决定了波特率,参见波特率计算公式
// BAUD_E=Baud rate exponent value 指数值 BAUD_E[4:0]在U0/1GCR寄存器中
// BAUD_M=Baud rate mantissa value 尾数值 BAUD_M[7:0]在U0/1BAUD寄存器中
#define BAUD_E(baud, clkDivPow) // The macros in this section simplify UART operation.
( \ //此处为多级条件运算
(baud==2400) ? 6 +clkDivPow : \ //表达式1?表达式2:表达式3
(baud==4800) ? 7 +clkDivPow : \ //1真为2;1假为3
(baud==9600) ? 8 +clkDivPow : \
(baud==14400) ? 8 +clkDivPow : \
(baud==19200) ? 9 +clkDivPow : \
(baud==28800) ? 9 +clkDivPow : \
(baud==38400) ? 10 +clkDivPow : \
(baud==57600) ? 10 +clkDivPow : \
(baud==76800) ? 11 +clkDivPow : \
(baud==115200) ? 11 +clkDivPow : \
(baud==153600) ? 12 +clkDivPow : \
(baud==230400) ? 12 +clkDivPow : \
(baud==307200) ? 13 +clkDivPow : \
0 )
#define BAUD_M(baud) ( \
(baud==2400) ? 59 : \
(baud==4800) ? 59 : \
(baud==9600) ? 59 : \
(baud==14400) ? 216 : \
(baud==19200) ? 59 : \
(baud==28800) ? 216 : \
(baud==38400) ? 59 : \
(baud==57600) ? 216 : \
(baud==76800) ? 59 : \
(baud==115200) ? 216 : \
(baud==153600) ? 59 : \
(baud==230400) ? 216 : \
(baud==307200) ? 59 : \
0)
//以上宏定义的函数:UART_SETUP(uart, baudRate, options) 设置波特率
// SET_MAIN_CLOCK_SOURCE(source) 设置主时钟
// BAUD_E(baud, clkDivPow) 设置波特率的指数值
// BAUD_M(baud) 设置波特率的尾数值
#define XOSC_STABLE (SLEEP & 0x40) //XOSC is powered up and stable
#define TICKSPD ((CLKCON & 0x38) >> 3)
#define HIGH_FREQUENCY_RC_OSC_STABLE (SLEEP & 0x20) //HF RCOSC is powered up and stable
void ChangUartBaund(uchar temp);
void initUART(void);
void SET_UART0_ISR(void);
//*****************************************************************************
//串口初始化函数
//串口参数设置为57600,8,None,1,None
//打开串口,允许接收
//*****************************************************************************
void initUART(void)
{
IO_PER_LOC_UART0_AT_PORT0_PIN2345(); //reste 0:USART0 I/O location: Alternative 1 location
SET_MAIN_CLOCK_SOURCE(CRYSTAL); //主时钟时钟源设置函数(设置成晶体振荡器)
UART_SETUP(0, 9600, HIGH_STOP); //波特率设置函数(将波特率设置成9600)
U0CSR = 0xC5; //U0CSR(USART0控制和状态)
//1100 0101 ;UART mode; receiver enable; received byte ready; USART busy in transmit
// or receive mode;
}
//------------------------------------------------------------------------
//describe:chang baund
//return:
//in:
//------------------------------------------------------------------------
void ChangUartBaund(uchar temp)
{
switch(temp)
{
case '0':UART_SETUP(0, 2400, HIGH_STOP);break;
case '1':UART_SETUP(0, 4800, HIGH_STOP);break;
case '2':UART_SETUP(0, 9600, HIGH_STOP);break;
case '3':UART_SETUP(0, 14400, HIGH_STOP);break;
case '4':UART_SETUP(0, 19200, HIGH_STOP);break;
case '5':UART_SETUP(0, 28800, HIGH_STOP);break;
case '6':UART_SETUP(0, 38400, HIGH_STOP);break;
case '7':UART_SETUP(0, 57600, HIGH_STOP);break;
case '8':UART_SETUP(0, 76800, HIGH_STOP);break;
case '9':UART_SETUP(0, 115200, HIGH_STOP);break;
default: UART_SETUP(0, 9600, HIGH_STOP);break;
}
}
//example 9600;
//------------------------------------------------------------------------
//describe:open the uart isr(中断服务程序)
//return:
//in:
//本例串口接收程序是运用中断来完成的,所以首先要设置ISR
//------------------------------------------------------------------------
void SET_UART0_ISR(void) //串口接收设置函数
{
U0CSR |= 0xd0; //1101 0000;UART mode; receiver enable; Byte received with incorrect stop bit level
U0UCR |= 0x02; //UART stop bit level: High stop bit
}
void UARTxISRopen(void) //开串口接收中断函数
{
U0CSR |= 0x40; //receiver enable;
IEN0 |= 0X04; //开串口接收中断 'URX0IE = 1',
}
#pragma vector = URX0_VECTOR
__interrupt void URX0_ISR(void)
{
uarttemp = U0DBUF; //串口调试软件发送的数据给uarttemp
U0DBUF = uarttemp; //把接收到的数据返送串口软件显示
}
//---------------------------------------------------------------------------------
转载于:https://www.cnblogs.com/LakeFollow/archive/2012/07/09/2582901.html
CC2430基础——串口测试实验相关推荐
- Zigbee之旅(八):几个重要的CC2430基础实验——看门狗
Zigbee之旅(八):几个重要的CC2430基础实验--看门狗 一.承上启下 再好的操作系统,不管是现在的Win7还是以后Win8.Win9,总会出现BlueScreen的时候,更何况是小小的单片机 ...
- 树莓派4bpython串口通信解读数据_树莓派基础实验36:通用串口通信实验
一.介绍 对于树莓派 3B+来说,他的UART功能有三种: 1.内部蓝牙使用: 2.控制终端使用: 3.与其他设备进行串口通信. 在树莓派基础实验35:USB TO TTL模块实验中学习了通过串口对树 ...
- Zigbee之旅(九):几个重要的CC2430基础实验——系统睡眠及中断唤醒
Zigbee之旅(九):几个重要的CC2430基础实验--系统睡眠及中断唤醒 一.承上启下 这一篇,我们来讨论一下CC2430的睡眠功能及唤醒方法.在实际运用中的CC2430节点一般是靠电池来供电,因 ...
- 485串口测试工具软件_探索者 STM32F407 开发板资料连载第三十一章 485 实验
1)实验平台:alientek 阿波罗 STM32F767 开发板2)摘自<STM32F7 开发指南(HAL 库版)>关注官方微信号公众号,获取更多资料:正点原子 第三十一章 485 实验 ...
- 嵌入式STM32入门之STM32基础串口通信
STM32基础串口通信 一.前言 二.串口协议 (1)浅谈设备通信方式 (2)具体串口协议 (3)STM32的串口通信 (4)RS-232通信协议 (5)USB To TTL(CH340) 5.1 C ...
- 【正点原子FPGA连载】第十四章 串口通信实验 -摘自【正点原子】新起点之FPGA开发指南_V2.1
1)实验平台:正点原子新起点V2开发板 2)平台购买地址:https://detail.tmall.com/item.htm?id=609758951113 2)全套实验源码+手册+视频下载地址:ht ...
- Arduino mega 2560 上传项目总是出错最全解决方案以及串口测试教程
一:串口识别和驱动安装需要保证准确无误 1.运行arduino mega 2560 首先需要安装串口驱动,这样我们用USB将板子和我们计算机连接的时候,使得我们的计算机能够识别连接的串口并且能够连接上 ...
- 【正点原子STM32连载】第五十八章 USB虚拟串口(Slave)实验 摘自【正点原子】MiniPro STM32H750 开发指南_V1.1
1)实验平台:正点原子MiniPro H750开发板 2)平台购买地址:https://detail.tmall.com/item.htm?id=677017430560 3)全套实验源码+手册+视频 ...
- TCS3200颜色传感器测试实验:
收藏自用,转自:http://www.eefocus.com/zhang700309/blog/13-08/296390_6c438.html TCS3200颜色传感器是一款全彩的颜色检测器,包括了一 ...
- TCS3200颜色传感器测试实验
TCS3200颜色传感器测试实验 2013-08-02 17:18:24 分享: 标签: Arduino TCS3200 传感器 TCS3200颜色传感器是一款全彩的颜色检测器,包括了一块TAO ...
最新文章
- 使用NFS启动Tiny4412开发板根文件系统
- BindingException异常第一种解决办法
- [architecture]-Cortex-A53的configuration signals
- 在字符串末尾添加字符使其成为回文串
- msf生成php,使用msfpayload生成后门(asp,aspx,php,jsp,exe)等
- 上海德拓人工智能事业部招聘图像算法工程师
- html5画安卓机器人,HTML5用户笔画形状检测机器人
- 机械制造技术基础【3】
- 3D模型在线转换,CAD格式转换,Solidworks版本转换
- 推送之信鸽推送详解 Think Different
- python中的上一步和下一步快捷键
- python selenium 验证码识别_Python+Selenium+PIL+Tesseract真正自动识别验证码进行一键登录...
- 2022-04-21 Android开发扫描二维码
- 微信小程序--优购页面制作
- YYDS!迅雷的代码结构,竟然被大佬“扒了精光”!
- 西门子PLC封装TCP通讯块和调试助手进行TCP仿真测试
- EasyExcel导出Excel表格到浏览器,并通过Postman测试导出Excel【入门案例】
- Allegro的PCB封装包含哪些文件,指定PCB封装库路径教程
- jadx 反编译apk
- 2022-2028年中国汽车儿童安全座椅行业发展前景分析及市场需求预测报告
热门文章
- 钽电容器为什么被要求降额到额定值的1/3使用
- Could not set the project description for 'hotelseqbid.ws' because the project d
- SSM框架整合(Spring+SpringMVC+MyBatis)附源码
- 设计模式:个人理解关于代理和委托模式的一点区别
- html转换opml,asp.net下URL网址重写成.html格式、RSS、OPML的知识总结
- python进行图像识别与分类_使用机器学习模型快速进行图像分类识别
- java上传图片裁剪_上传图像之裁剪
- 不看绝对血亏!Javastream并行不安全
- OA系统审批流程思路梳理
- 2019DeeCamp夏令营总结