历史上的今天
今天是:2025年04月28日(星期一)
2018年04月28日 | 如何实现W7100A中的UART(二)
2018-04-28 来源:eefocus
大家好, 我们昨天为大家分享了如何实现W7100A中的UART。今天继续为大家分享第二部分,明天将会继续为大家分享最后一部分。
如何实现W7100A中的UART第一部分请参考:http://blog.csdn.net/wiznet2012/article/details/7593285
4. 2, 9位UART,固定波特率
void Init_iMCU(void) { SCON = 0x90; // 串行模式2, SM00 = 1, SM01 = 0, REN=1 PCON &= 0x7F; // fosc/64(SMOD = 0), fosc/32(SMOD = 1) } void PutByte(unsigned char byData) { SBUF = byData; // 向串行缓存器中写入数据 while(!TI); // 等待所有的数据记录完成 TI = 0; // 清除传输中断 }
unsigned char GetByte(void) { unsigned char byData; // 等待数据接收 while(!RI); RI = 0; //清除RI byData = SBUF; //读取数据 return byData; }
void main() { Init_iMCU(); //调用Init_iMCU函数 while(1) PutByte(GetByte()); //回送(Echo-back)接收到的数据 } |
波特率的UART模式2是固定内部时钟的fosc/32或fosc/64。具体选择fosc/32还是fosc/64要根据SMOD0的位来确定。考虑到W7100A的内部时钟,产生的高速波特率时钟的范围为2.7 ~ 1.4MHz。如同模式0的情况,一般不使用模式3,因为波特率是固定的且时钟频率过快。
在这些示例程序中,将SCON寄存器设定为0x90。为了设置波特率,还要设置SMOD0,
PCON寄存器的最高位(波特率 = fosc/32)。其它实现输出信息的代码也和第2章中介绍的接收过程的程序类似。
5. 3, 9位UART,可变波特率
5.1 定时器1(timer 1)时钟源
void Init_iMCU(void) { SCON = 0xD0; // 串行模式3, SM00 = 1, SM01 =1, REN=1 TMOD |= 0x20; // 定时器1(Timer1)模式2 PCON |= 0x80; // SMOD0 = 1 TL1 = 0xFC; // 波特率115200bps TH1 = 0xFC; //请参考W7100A数据手册 TR1 = 1; // 启动定时器1(Timer1) } void PutByte(unsigned char byData) { SBUF = byData; // 向串行缓存器中写入数据 while(!TI); // 等待数据记录完成 TI = 0; // 清除传输中断 }
unsigned char GetByte(void) { unsigned char byData; //等待数据接收 while(!RI); RI = 0; //清除RI byData = SBUF; // 读取数据 return byData; }
void main() { Init_iMCU(); //调用Init_iMCU函数 while(1) PutByte(GetByte()); //回送(Echo-back)接收到的数据 } |
UART在模式3下,可以交换使用定时器1(Timer1)和定时器2(Timer2)来设定波特率的值。在这一章节,我们使用定时器1(Timer1)来设置波特率的值,信息请参考W7100A数据手册。与模式1不同的是,停止位之前多了1位。这一增加位可以用作奇偶校验或者多重处理器通信,详情请参考W7100A数据手册。
在示例程序中,将SCON寄存器设置为0xD0,定时器1(Timer1)工作在模式2下。为了能设置波特率,需要设置PCON寄存器的SMOD位,同时TH1寄存器的值设为0xFC。这样设置完成后,波特率的值为115200bps。其它实现输出信息的代码也和第2章中介绍的接收过程的程序类似。
5.2 定时器2(timer 2)时钟源
void Init_iMCU(void) { SCON = 0xD0; //串行模式3, SM00 = 1, SM01 =1, REN=1 T2CON = 0x30; //定时器2(Timer2)波特率发生器模式 TH2 = 0xFF; //波特率设定为115200bps TL2 = 0xE8; // 请参考W7100A数据手册 RLDH = 0xFF; // 波特率重载值设为115200bps RLDL = 0xE8; // 波特率重载值设为115200bps TR2 = 1; // 启动定时器2(Timer2) }
void PutByte(unsigned char byData) { SBUF = byData; // 向串行缓存器中写入数据 while(!TI); // 等待数据记录完成 TI = 0; // 清除传输中断 }
unsigned char GetByte(void) { unsigned char byData; //等待数据接收 while(!RI); RI = 0; //清除RI byData = SBUF; //读取数据 return byData; }
void main() { Init_iMCU(); //调用Init_iMCU函数 while(1) PutByte(GetByte()); //回送(Echo-back)接收到的数据 } |
UART在模式3可以交换使用定时器1(Timer1)和定时器2(Timer2)来设置波特率。在这一章节,利用定时器2(Timer2)来设置波特率。更多的详细信息请参考W7100A数据手册。与模式1不同的是,在停止位之前多了1位,此位可以用于奇偶校验或者多重处理器通信。具体的细节可以参考W7100A数据手册。
在上面的程序中,将SCON寄存器设为0xD0,定时器2(Timer2)设定为波特率发生器模式。为了能够设定波特率,还需要将TH2和TL2的值分别设为0xFF和0xE8。都设置完成后,波特率的值就变成115200bps。重载值RLDH和RLDL也必须相应的设置为0xFF和0xE8。其它实现输出信息的代码也和第2章中介绍的接收过程的程序类似。
下一篇:如何实现W7100A中的UART
史海拾趣
|
RFID 方案 让我们了解一些使用传统方法的 RFID 方案: 整合承运人的移动运输队:可以更迅速地与运输队取得联系。政府干预的减少将对运输市场的控制从托运人转到了承运人手中。 改善内部操作:您可以通过消费品的容器、托盘或物品级别的跟踪 ...… 查看全部问答> |
|
今天下午的课程刚好讲到DSP的定点和浮点运算。 老师说: 定点运算的位数已经达到了32位精度,在很多场合都可以不用浮点。 因为浮点计算加法时候实在是很麻烦,需要对位。比定点复杂。 浮点计算就是能表示38位,比定点的表示范围要大。 我想知 ...… 查看全部问答> |
|
DSP5509实例视频教程,欢迎大家免费下载。 电驴下载地址:http://www.verycd.com/topics/2788098/ QQ中转站下载:QQ号码1353686381 ,密码weierda DSP5509开发板视频教程目录 第一讲 CCS安装与建立第一个helloworld程序 43.06’ ...… 查看全部问答> |
|
IPerf在WinCE ARMV4I下运行提示缺少component或相关libraries 想要测Wi-Fi模块的带宽, 在网上Down了一个IPerf源代码,板子上用的是ARMV4I, 编译器选ARMV4I, Build后,把iperf.exe copy到板子上运行, 错误提示:\"Cannot find \'IPERF\' (or one of its components). Makesure the path and filename are corr ...… 查看全部问答> |
|
我在周立功代码的基础上改程序,去掉#include \"systemInit.h\"之后,会出现C:\\Keil\\ARM\\INC\\Luminary\\timer.h(105): error: #20: identifier \"tBoolean\" is undefined,以前的程序都是引用StellarisWare的inc库的啊,这次怎么 ...… 查看全部问答> |




