"); //-->
51的UART所用的几个寄存器
SCON:SM0 SM1 SM2 REN RB8 TX8 RI TI
PCON: SMOD -- -- -- --- --- PD IDLE
T2CON: TF2 EXF2 RCLK TCLK EXEN2 TR2 C/_T CP/_RL2
TH2,TL2
波特率为9600bps
avr:atmega64的USART的两个
所用到的寄存器
这里用的是uart0,所以初始化时应该设置相关的寄存器有:
UCSR0A : RXC TXC UDRE FE DOR UPE U2X MPCM
UCSR0C :-- UMSEL UPM1 UPM0 USBS UCSZ1 UCSZ0 UCPOL
UBRR0H 、 UBRR0L、
UCSR0B :RXCIE TXCIE UDRIE RXEN TXEN UCSZ2 RXB8 TXB8
别问我这些都是代表什么含义,不懂自己翻书去。。
proteus仿真如下图:


仿真结果如下图所示:


其中要注意的是:
因为我在仿真中只能选择atmega64的CKSEL Fuse中的8MHz,所以在AVR的程序中初始化波特率是按8MHz来计算的。所以仿真归仿真,注意实际中应用。
51单片机用定时器1来产生波特率时,看书据说模式2下,12MHz时最高只能到达4800bps。这里就只好用定时器2来。不过也挺好用的。。仿真时用的是8052核。。否则没反应不要怪我哦。。
最后把程序附上,里面有些变量声明了没有用到,当初只是实验。。
51的:
#include "reg52.h"
#define AA 0x61
#define commun_symbol 0x31
sbit LED=P2^0;
unsigned char Tx[]={"my name is seven!"};
void uart_init(void)
{
SCON = 0x50;
RCAP2H = 0xFF;
RCAP2L = 0xD9;
TH2 = 0xFF;
TL2 = 0xD9;
T2CON = 0x34;
}
void uart_send(unsigned char byData)
{
TI=0;
SBUF=byData;
while(TI==0);
TI=1;
}
unsigned char uart_receive(void)
{
RI=0;
while(RI==0);
RI=1;
return(SBUF);
}
void main()
{
unsigned char byBuff,i;
uart_init();
uart_send(commun_symbol);
while(1)
{
byBuff=uart_receive();
LED=1;
if(byBuff==0x31)
{
for(i=0;i<20;i++)
{
P1=byBuff;
uart_send(Tx[i]);
}
}
}
}
atmega64的程序:
两个文件,一个是将函数模块化,别一个是主函数,调用(- -!最近习惯将程序模块化。。。)
//------------------uart.c---------------------
//----这里将通信函数模块化------------
#include <iom64v.h>
void uart0_init(void)
{
UCSR0B = 0x00; //disable while setting baud rate
UCSR0A = 0x00;
UCSR0C = 0x06;
UBRR0L = 0x33; //set baud rate lo
UBRR0H = 0x00; //set baud rate hi
UCSR0B = 0x18;
}
void uart0_Transmit( unsigned char data )
{
/* Wait for empty transmit buffer */
while ( !( UCSR0A & (1<<UDRE0)) )
;
/* Copy ninth bit to TXB8 */
UCSR0B &= ~(1<<TXB80);
//if ( data & 0x0100 )
//UCSR0B |= (1<<TXB80);
/* Put data into buffer, sends the data */
UDR0 = data;
}
unsigned char uart0_Receive( void )
{
/* 等待接收数据*/
while ( !(UCSR0A & (1<<RXC0)) )
;
/* 从缓冲器中获取并返回数据*/
return UDR0;
}
//--------------main.c-----------
//--------------------------------
#include <iom64v.h>
#include "spi.h"
#define commun_symbol 0x31
//-----------send a commun_symbol-----
//-----------receive a commun_symbol--
// <--no,continue receive||||||yes-->receive the data and send
void main()
{
unsigned char bybuff;
DDRB=0xff;
PORTB=0xff;
uart0_init();
{
do
{
bybuff=uart0_Receive();
}
while (bybuff!=commun_symbol);//commun_symbol);
while(1)
{
uart0_Transmit(bybuff);
bybuff=uart0_Receive();
PORTB=(0xff|bybuff);
}
}
}
ok,任务完成了,改天实验一下!
专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
用Maxim套片设计TD-SCDMA终端射频收发信机
可编程控制器EDA教程 12
Q3报价谈判启动 内存供应链吃紧 报价看涨
红色飓风FPGA普及行动 第二讲:FPGA设计入门
混音放大电路
AI驱动内存革新 台积电与三星引领存储技术抢攻万亿商机
用CPLD实现单片机与ISA总线接口的并行通信
用GC1012B构建可编程数字无线电接收机
机器人吸盘可以像真正的章鱼一样适应周围环境
爆炸声响彻巴格达 炮弹打入驻伊美军司令部
2024-28 年先进晶圆厂产能将增长69%
低音调制放大电路
国产「十万卡」集群开始落地
神经脑植入物提供近乎即时的语音
音频混频放大电路
3纳米制程有谱! 台积美二厂提前上线
10月风河时讯
在自己写的程序里面如何调用一个可执行文件
具有高低音控制的音频功放
高保真前置放大电路
中国50%的人生病不敢去医院 主要原因是药价高
用PIC单片机控制DDS芯片AD9852实现雷达跳频系统
可编程控制器EDA教程 11
Red Hat老总建议消费者放弃Linux 选用Windows
从起居室到开阔的道路:为更多汽车带来优质音响
可编程控制器EDA教程 13
Nissan推出第三代e-POWER技术 可用电力直驱马达
什么是量子电池,如何构建量子电池?
红色飓风FPGA普及行动 第一讲:FPGA系统设计基础
用8位单片机实现串口-以太网转换器