AVR单片机—(五)、ATMEGA16的USART与PC机串行通信—03

发布者:科技奇思最新更新时间:2017-11-21 来源: eefocus关键字:AVR单片机  ATMEGA16  USART  串行通信 手机看文章 扫描二维码
随时随地手机看文章

五、ATMEGA16的USART与PC机串行通信

五—(03)、PC机发送控制指令控制单片机工作~(这个控制还是比较简单的~~AVR单片机(学习ing)—(五)、ATMEGA16的USART与PC机串行通信—03,不过个人认为还是有水平的~)

还是先上图片~~,然后程序,程序师模块化的,我尽量贴全点~~AVR单片机(学习ing)—(五)、ATMEGA16的USART与PC机串行通信—03

AVR单片机(学习ing)—(五)、ATMEGA16的USART与PC机串行通信—03

AVR单片机(学习ing)—(五)、ATMEGA16的USART与PC机串行通信—03

然后就是程序了

IAR5_2.c

//------------------------------------------------------------------------------
//控制指令的定义(个人感觉这个才是真正应用呢~~给力~)
//上位机界面中,用户需要输入控制下位机的指令
//由于传送的数据比较简单,因此控制指令也可定义的相对简单一些((*^__^*) 嘻嘻……,那本书上写的哦~)
//规定:“(x)”
//指令起始符“(”:表示一条控制指令的开始。
//输出电压值“X”:X=0.00~5.00,表示选择的输出电压值。
//指令结束符“)“:单片机收到此指令后,控制指令结束。
//这里发送采用中断方式,接收采用查询方式!!!符合常用的工作模式,大大提高单片机的工作效率
#include"ioavr.h"
#include"intrinsics.h"
#include"lcdinit.h"
#include"usart.h"
#include"delayics.h"
//------------------------------------------------------------------------------
uchar __flash title[]="Virtal & PWM Test";
uchar flag_recever;                           //定义完成接收标志
uchar flag;                                   //定义接收标志
uchar count_recever;                          //定义接收计数器
uchar temp;
uchar wide;                                   //定义控制脉冲宽度的变量
uint  voltage;                                //定义整形变量
uchar a[]={0,0,0};                            //定义数组并初始化为0
//------------------------------------------------------------------------------
//端口初始化函数
void port_init()
{
  DDRA=0XFF;
  PORTA=0XFF;
  DDRB=0XFF;
  PORTB=0XFF;
 
  DDRD=0X82;
  PORTD=0X7F;
}
//------------------------------------------------------------------------------
//定时器2初始化函数
void timer2_init()
{
  TCNT2=0X01;
  OCR2=0XFF;
  TCCR2=0X61;                                  //相位修正PWM,启动定时器2(不分频)
}
//------------------------------------------------------------------------------
//USART初始化函数
void usart_init()
{
  UCSRA=0X82;                                   //置位RXC(USART接受结束标志),倍速
  UCSRC=0X06;                                   //选择为发送、接收8为数据位
  UBRRL=0X67;
  UBRRH=0X00;                                   //设置波特率9600
  UCSRB=0X98;                                   //置位RXCIE,使能接受结束中断,发送使能,接收使能
}
//------------------------------------------------------------------------------
//芯片初始化函数
void device_init()
{
  port_init();
  timer2_init();
  usart_init();
}
//------------------------------------------------------------------------------
//main
void main()
{
  uint x;
  device_init();
  lcd_init();
  lcd_display_string(0x80,title,16);
  delay_s(1);
 
  SREG=0x80;                                    //开总中断
  while(1)
  {
    if(flag==1)                                 //执行中断程序后,接收数据,falg置位
    {
      SREG=0x00;
      usart_send_char(temp);                   //将收到的数据发送回给PC
      switch(count_recever)                    //判断收到的个数
      {
        //----------------------------------------------------------------------
      case 0:                                  //当收到起始命令时
        if(temp=='(')
          count_recever=1;
        else
          flag_recever=0;
        break;
        //----------------------------------------------------------------------
      case 1:                                  //当收到第二位数据时
        if((temp>=0x30)&&(temp<=0x39))
        {
          a[2]=temp-0x30;
          count_recever=2;
        }
        else
          flag_recever=0;
        break;
        //----------------------------------------------------------------------
      case 2:                                 //当收到第三位数据时
        if(temp=='.')
          count_recever=3;
        else
          flag_recever=0;
        break;
        //----------------------------------------------------------------------
      case 3:                                 //当收到第四位数据时
        if((temp>=0x30)&&(temp<=0x39))
        {
          a[1]=temp-0x30;
          count_recever=4;
        }
        else
          flag_recever=0;
        break;
        //----------------------------------------------------------------------
      case 4:                                 //当收到第五位数据时
        if((temp>=0x30)&&(temp<=0x39))
        {
          a[0]=temp-0x30;
          count_recever=5;
        }
        else
          flag_recever=0;
        break;
        //----------------------------------------------------------------------
      case 5:                                  //当收到结束命令时
        if(temp==')')
        {
          count_recever=0;
          flag_recever=1;
        }
        else
          flag_recever=0;
        break;
        //----------------------------------------------------------------------
      default:
        count_recever=0;
        break;
      }
      flag=0;                                 //清除flag标志,便于以后接受
      SREG=0x80;
    }
    if(flag_recever==1)                       //当收到完整数据时,进行数据转换和PWM输出~
    {
      x=(uint)a[2];
      voltage=x*100;
     
      x=(uint)a[1];
      voltage+=x*10;
     
      x=(uint)a[0];
      voltage+=x;
     
      voltage=(voltage*100)/196;              //对电压值进行变换
      wide=(uchar)voltage;                    //脉冲宽度变量赋值
     
      OCR2=wide;                              //OCR2赋值,输出PWM
      lcd_display_char(0x80+0x40,'O');
      lcd_display_char(0x80+0x40+1,'C');
      lcd_display_char(0x80+0x40+2,'R');
      lcd_display_char(0x80+0x40+3,'2');
      lcd_display_char(0x80+0x40+4,':');
     
      lcd_display_char(0x80+0x40+5,(wide/100)+0x30);
      lcd_display_char(0x80+0x40+6,(wide0/10)+0x30);
      lcd_display_char(0x80+0x40+7,(wide)+0x30);
     
      lcd_display_char(0x80+0x40+11,a[2]+0x30);
      lcd_display_char(0x80+0x40+12,'.');
      lcd_display_char(0x80+0x40+13,a[1]+0x30);
      lcd_display_char(0x80+0x40+14,a[0]+0x30);
      lcd_display_char(0x80+0x40+15,'V');
     
      flag_recever=0;                         //清零flag_recever(这个是必须的~~呵呵)
    }
  }
}
//------------------------------------------------------------------------------
//USART_RXC
#pragma vector=USART_RXC_vect
__interrupt void usart_rxc()
{
  temp=UDR;
  flag=1;
}

USART.c

//------------------------------------------------------------------------------
//可供其它文件调用的USART函数,方便移植
#include"ioavr.h"
#include"intrinsics.h"
//------------------------------------------------------------------------------
typedef unsigned char uchar;
typedef unsigned int  uint;
#define UDRE 5
#define RXC  7
//------------------------------------------------------------------------------
//发送5~8位数据位的帧
void usart_send_char(uchar i)
{
  while(!(UCSRA&(1<  UDR=i;
}
//------------------------------------------------------------------------------
//接收5~8位数据位的帧
uchar usart_receive_char()
{
  while(!(UCSRA&(1<  return(UDR);
}
//------------------------------------------------------------------------------
//发送多个帧,其中每个帧为5~8位
void usart_send_string(char *s)
{
  while(*s)                                 //发送一个字符串,字符串以"0"结束,它也就结束喽
  {
    usart_send_char(*s);
    s++;
  }
}

LcdInit.c(这个我好像写过~~~下回我就不贴出来了~~太多了~)

//------------------------------------------------------------------------------
//LCD1602的初始化程序—可调用函数
#include"ioavr.h"
#include"intrinsics.h"
#include"delayics.h"
#include"bitics.h"
#include"lcdinit.h"
//------------------------------------------------------------------------------
//RS、RW、EN引脚输出高低电平的宏定义
#define lcd_rs_1  SET_BIT(PORTB,0)
#define lcd_rs_0  CLR_BIT(PORTB,0)
#define lcd_rw_1  SET_BIT(PORTB,1)
#define lcd_rw_0  CLR_BIT(PORTB,1)
#define lcd_en_1  SET_BIT(PORTB,2)
#define lcd_en_0  CLR_BIT(PORTB,2)
//------------------------------------------------------------------------------
#define data_port PORTA
#define busy  0x80
//------------------------------------------------------------------------------
//LCD写数据函数
void lcd_write_data(uchar dat)
{
  lcd_rs_1;
  lcd_rw_0;
  data_port=dat;
  delay_ms(1);
  lcd_en_1;
  delay_ms(1);
  lcd_en_0;
}
//------------------------------------------------------------------------------
//LCD写指令函数
void  lcd_write_command(uchar com)
{
  lcd_rs_0;
  lcd_rw_0;
  data_port=com;
  delay_ms(1);
  lcd_en_1;
  delay_ms(1);
  lcd_en_0;
}
//------------------------------------------------------------------------------
//LCD初始化函数
void lcd_init()
{
  lcd_write_command(0x01);
  delay_ms(1);
  lcd_write_command(0x38);
  delay_ms(1);
  lcd_write_command(0x0c);
  delay_ms(1);
  lcd_write_command(0x06);
  delay_ms(1);
}
//------------------------------------------------------------------------------
//LCD显示一个字节函数
void  lcd_display_char(uchar add,uchar dat)
{
  lcd_write_command(add);
  delay_ms(1);
  lcd_write_data(dat);
  delay_ms(1);
}
//------------------------------------------------------------------------------
//LCD显示多个字节函数
void  lcd_display_string(uchar add,uchar __flash *s,uchar num)
{
  uchar i;
  lcd_write_command(add);
  for(i=0;i  {
    lcd_write_data(s[i]);
    delay_ms(1);
  }
}


关键字:AVR单片机  ATMEGA16  USART  串行通信 引用地址:AVR单片机—(五)、ATMEGA16的USART与PC机串行通信—03

上一篇:AVR单片机I/O口位操作,置位、清位、取反
下一篇:AVR单片机—(五)、ATMEGA16的USART与PC机串行通信—02

推荐阅读最新更新时间:2024-03-16 15:46

PC机与单片机串行通信中实现命令批处理
    摘要: 介绍PC机与MCS-51单片机通信批处理命令的实现思想、方法、通信协议和C51程序平台。为PC机与单片机间串行通信程序设计提供一种方法上的新思路。     关键词: 批处理 MCS-51单片机 通信协议 在PC机与MCS-51单片机之间进行串行通信时,基本是一对一的,即用PC机向单片机每发1条命令,就等待单片机的1条返回信息。这样可能把大量时间浪费在PC机与单片机的通信过程中了。为此笔者经过实践,设计出可以批处理执行PC机发给单片机的命令,就像DOS操作系统中的批处理命令一样,可连续批处理信息,结果当然提高了系统速度。文中提供了部分平台式C51软件源代码,以供大家参考。 1 通信协议
[工业控制]
AVR单片机全系列性能参数表
AVR单片机全系列性能参数表 包括:tiny11,tiny12,tiny13,tiny15L,tiny2313,tiny26,tiny26L,tiny28L,tiny28V,90S1200, 90S2313 Mega128,Mega128L,Mega16,Mega16L,Mega162,Mega162L,Mega162V, Mega169,Mega169L,Mega169V,Mega32,Mega32L 包括:Mega48,Mega88,Mega168,Mega64,Mega64L,Mega8,Mega8L,Mega8515, Mega8515L,Mega8535,Mega8535L
[单片机]
<font color='red'>AVR单片机</font>全系列性能参数表
XMEGA128学习笔记5-串口USART
Xmega128的串口非常强大,最多能支持8个串口。串口又有四种模式: 1、异步 2、同步 3、IRDA红外模式 4、SPI主模式 今天我们就使用CVAVR代码向导生成简单串口测试程序,实现每1s打印“HELLO WORLD”字符串,同时能将接收到数据回显到串口调试助手上。 第一步:打开中断,因为我们需要实现串口回显的功能。 第二步:从开发板的原理图可以看到串口是在PC2和PC3脚,所以需要设置GPIO,经过CVAVR的提示PC3初始输出电平为1能够更加稳定: 第三步设置串口:使能接收和发送功能,并开启接收中断。 第四步:最后生成代码,加入以下代码: 最后编译下载,复位后可以看到效果图:
[单片机]
XMEGA128学习笔记5-串口<font color='red'>USART</font>
怎样学好AVR单片机
  随着各IC厂商推出各种高性能的单片机,51单片机已经远远不能满足大家对高性能单片机的需求。目前很多公司和学校已经开始转向AVR单片机了,相信在未来几年,AVR将会非常兴旺,所以学习AVR单片机将会很有前途。   相比经典的51系列来说,AVR单片机突出的优点主要有以下几点:   一、速度快。AVR是精简指令集单片机,其速度可以达到1MIPS/秒,理论上是传统的51的12倍,实际上在10倍左右。   二、片上资源丰富。MEGA系列片上具备JTAG仿真和下载功能。片内含有看门狗电路、片内程序Flash、片内数据RAM、同步串行接口SPI、异步串口UART、内嵌AD转换器、EEPROM、模拟比较器、PWM定时计数器、TWI(
[单片机]
STM32串口USART1中断接收和中断发送
  先贴出中断函数:    view plain copy   void USART1_IRQHandler(void){   IF (USART_GetiTStatus(USART1, USART_IT_RXNE) != RESET) {   USART_ClearITPendingBit(USART1, USART_IT_RXNE);   USART1_Buffer =USART_ReceiveData(USART1); //USART1_Buffesh是一个自己定义的接收数组   if(i 3){   SendFlag = 1;   }   }   if(USART_GetITStatus(USART1, USART_I
[单片机]
AVR单片机-- I/O口的使用
简介:本文章主要通过程序控制实现按键控制LED 灯的亮灭,按一下亮,再按一下灭,如此循环往复,并学习AVR 单片机的I/O口如何配置为输入和输出。 //文件名:delay_rest.c //文件描述:实现按键控制LED 灯的亮灭,按一下亮,再按一 //下灭,如此循环往复。 //实验目的:学习AVR 单片机的I/O口如何配置为输入和输出 //当前版本号:V1.0 //--------------------------------------------------------------------- //----------------------------start------------------
[单片机]
MSP430学习笔记——USART
MSP430F149有两个USART通讯端口,其性能完全一样,每个通讯口可通过RS232和RS485等芯片转换,与之相应的串行接口电路通讯。MSP430F149支持串行异步和同步通讯,每种方式都具有独立的帧格式和独立的控制寄存器。 USART异步通信 MSP430串行异步通信模式通过两个引脚:接收引脚URXD和发送引脚UTXD与外界相连。异步帧格式由一个起始位,7或8个数据位,校验位(奇/偶/无),1个地址位,和1或2个停止位。从最低位开始发送和接收。异步模式下,传送数据以字符为单位。 在异步模式下,USART支持两种多机模式,即线路空闲和地址位多机模式。 (1)线路空闲多机模式: 在这种模式下,数据块被空闲时间
[单片机]
MSP430学习笔记——<font color='red'>USART</font>
串行通信联网技术在冶金自动化监控领域发展与应用
近些年来,冶金行业的自动化系统的应用发展得越来越快,生产中各环节的监控系统应用也越来越多。由于串行通讯方式实现方便,系统费用低,所以许多监控系统大都采用串行通讯技术来实现。但因以太网及现场总线的广泛应用,一些与PLC等控制设备连接的监控系统,多采用以太网及现场总线的通讯方式。其实现场总线与RS485在物理界面上是一致的,只是各种现场总线有自己的通讯协议而已。总体来讲,串行通讯技术的应用非常广泛,尤其是支持串口设备联入以太网的接口装置,会使串口设备的联网更加方便、应用也会更加广泛。   生产运营各环节中的串行通讯设备联网状况   在冶金行业中,串行通讯技术主要应用于以下三个方面:   (1) 生产工艺过程监控系统;   
[工业控制]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
  • 嵌入式系统调试仿真工具
    嵌入式硬件系统设计出来后就要进行调试,不管是硬件调试还是软件调试或者程序固化,都需要用到调试仿真工具。 随着处理器新品种、新 ...
  • 最近困扰在心中的一个小疑问终于解惑了~~
    最近在驱动方面一直在概念上不能很好的理解 有时候结合别人写的一点usb的例子能有点感觉,但是因为arm体系里面没有像单片机那样直接讲解引脚 ...
  • 学习ARM开发(1)
    做任何事情之前,一定要想好目标。没有目标的事情是做不好的,也做不成。我的目标就是学习ARM开发,当然是深入的学习。目标如下 :1、学习A ...
  • 学习ARM开发(2)
    天是星期天,刚好在家里休息。又是学习ARM的大好时机了。早上起得很早,因为都想着怎么样搞好这个ARM开发环境,总是心急的。搞得睡觉,也睡 ...
  • 学习ARM开发(4)
    已经把CPU大体架构学会了,当然我之前已经学习过80X86的结构,所以对于像RISC的计算机,也能想像到它是什么样的东西。如果没有学习过《微机 ...
  • 学习ARM开发(6)
  • 学习ARM开发(7)
  • 学习ARM开发(8)
  • 学习ARM开发(9)
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved