当前位置:首页 > 单片机 > 单片机
[导读]C51跟atmega64的串行通信。相关理论知识这里就不多说,只提几个: 51的UART所用的几个寄存器SCON:SM0 SM1 SM2 REN RB8 TX8 RI TIPCON: SMOD -- -- -- --- --- PD IDLET2CON: TF2 EXF2 RCLK TCLK

C51跟atmega64的串行通信。相关理论知识这里就不多说,只提几个:

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 da
ta )
{
/* Wait for empty transmit buffer */
while ( !( UCSR0A & (1<<UDRE0)) )
;
/* Copy ninth bit to TXB8 */
UCSR0B &= ~(1<<TXB80);
//if ( da
ta & 0x0100 )
//UCSR0B |= (1<<TXB80);
/* Put da
ta into buffer, sends the data */
UDR0 = da
ta;
}

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 da
ta 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,任务完成了,改天实验一下!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭