完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
下面程序通讯不正确,发送和接收的数据不匹配,望各路大侠帮我找出问题,在下感激不尽。。。。。。
#include #include sfr16 TMR3RL = 0x92; //定时器3重装载寄存器 sfr16 TMR3 = 0x94; //定时器3计数器 #define uchar unsigned char #define uint unsigned int #define BAUDRATE 9600 //波特率bps #define CLKOUT 11059200 //外部晶振,修改也要修改OSCXCN #define SMODVAL 0 //SMOD的值,修改请也修改PCONVAL #define PCONVAL 0x00 //PCON的值,=0x00时SMOD0=0; =0x80时SMOD0=1 #define TXVAL (256-CLKOUT*(SMODVAL+1)/BAUDRATE/384) //定时器初值 bit readFlag = 0; //读标志 uchar readCounts = 0; //已经读取的字符个数,与MAX_LEN比较 uchar trdata[6]="0e0f0f"; //要接收/发送的字符串 uchar high; uchar low; void UART0_Init(void); //串口UART0初始化 void Send_Char(uchar ch); //发送单个字符 void Send_String(uchar * str, uint len); //发送一个字符串 void UART0_ISR(); //串口中断服务程序,接收字符 main() { C8051F310DeviceInit(); UART0_Init(); EA = 1; while(1) { if(readFlag) //已经读取 { readFlag = 0; //清零 Send_String(trdata,6); //发送字符串 } } } void UART0_Init(void) //串口初始化 { SCON0 = 0x50; //选择串口方式1,波特率可变 SCON0=0101,0000 TMOD = 0x20; //选择T1,方式2,自动再装入8位计数器 TH1 = (int)TXVAL;//T1初值,根据波特率,时钟等计算. 0xF4, bps=4800bps TL1 = (int)TXVAL; ES0 = 1; //UART0中断开启 TR1 = 1; //启动定时器T1 PCON |= PCONVAL; //PCON=0x00,SMOD = 0 PCON=0x80,SMOD=1 ti0 = 1; //声明TX0就绪,可以发送 TR0 = 1; } void Send_Char(uchar ch) //发送单个字符 { SBUF0 = ch; //送入缓冲区 while(TI0 == 0); //等待发送完毕 TI0 = 0; //软件清零 } void Send_String(uchar * str,uint len) //发送字符串,调用Send_Char() len字符串长度 { uint k = 0; do { Send_Char(*(str + k)); k++; } while(k < len); } void UART0_ISR(void) interrupt 4 using 1 //UART0中断服务程序. 接收字符 { uchar rxch; if(RI0) //中断标志 RI0=1 数据完整接收 { RI0 = 0; //软件清零 rxch = SBUF0; //读缓冲 if(readCounts>=6) { readCounts = 0; readFlag = 1; } trdata[readCounts] = rxch; //存入数组,供发送 readCounts++; } } #include #include static void WatchDogInit (void) { PCA0MD &= ~0x40; } static void SysClkInit (void) { unsigned int i; OSCXCN = 0x67; //采用外部晶振11.0592MHz,不分频. 选型OSCXCN=0110,0111 for(i=0;i<256;i++); //等待>1ms while(!(OSCXCN&0x80)); //查询直到XTLVLD=1,晶振稳定 OSCICN = 0x88; //切换到外部振荡器,允许时钟失效监测器. OSCICN=1000,1000 } static void PortInit (void) { XBR0 = 0x05; //允许UART0,RX,TX连到2个端口引脚. XBR0=0000,0101 XBR1 = 0x40; //允许交叉开关和弱上电 P0MDIN |= 0x30; //P0.4/5不配置为模拟输入 P0MDOUT |= 0x30; //P0.4/5为推拉方式输出,即TX0,RX0所在的端口 P0SKIP = 0x0c; P1MDIN=0xff; P1MDOUT=0xff; P2MDIN=0xff; P2MDOUT=0xff; } void C8051F310DeviceInit (void) { WatchDogInit(); SysClkInit(); PortInit(); } |
|
相关推荐
1个回答
|
|
到底是什么问题呢?
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-TF卡烧录流程之烧写过程
1044 浏览 0 评论
1552 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-mfgtools烧录流程之烧写原理
1304 浏览 0 评论
请问SPH0641LU4H这款麦克风如何在不使用I2S的情况下,单纯通过GPIO来进行驱动且正常读取数据呢
979 浏览 1 评论
576 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
12096 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-3 05:58 , Processed in 0.483869 second(s), Total 70, Slave 53 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号