串口发送与接收数据

串口发送与接收数据,第1张

使用RS-485串口进行通讯。

1.定义串口接收数据的缓冲区,最大可以保存64个字节 u8 RS485_RX_BUF1[64]

2.定义接收发送数据的长度 u8 RS485_RX_CNT

3.发送数据的函数一般有两个printf和 USART_SendData,这里主要说USART_SendData的使用。printf实现的是格式化字符串,字符串比较有优势。

USART_SendData传递单个字符和指令。

4.给发送方定义一个标记位 u32 flags_send1flags_send1

5.要发送的事件很多定义一个枚举类型的数据,将所有要发送的事件放入枚举类型数据中。

枚举类型数据将第一个定为1,其他的数据依次加1.

6.定义一个发送事件函数SendCmd(u8 cmd)

定义

7.假设要传递E_CKEYDN_INUSE1事件,要实现事件的传递,就应该将事件做参数传入SendCmd(u8 cmd)函数

此时flags_send1 |= EBIT(9)=由第四点知道flags_send1是一个32位的无符号整型数据。所以 flags_send1 = 0000 0000 0000 0000 0000 0001 1111 1111

8.(1)UARTSend1()函数

此时的flags_send1 = 0000 0000 0000 0000 0000 0001 1111 1111

sb[2] = (flags_send1 >>0) &0xff = 1111 1111

sb[3] = (flags_send1 >>8) &0xff = 0000 0001

sb[4] = (flags_send1 >>16) &0xff = 0000 0000

sb[5] = (flags_send1 >>24) &0xff = 0000 0000

(2)checksum()函数

d0=(senddata >>0) &0xff=0000 0001 1111 1111

d1=(senddata >>8) &0xff=0000 0001 &0xff=0000 0000 0000 0001

d2=(senddata >>16) &0xff=0000 0000 &0xff = 0000 0000 0000 0000

d3=(senddata >>24) &0xff=0000 0000 &0xff = 0000 0000 0000 0000

sum=0000 0010 0000 0000

~sum=1111 1101 1111 1111

sb[6] = (sum >>0) &0xff = 1111 1111 &0xff = 1111 1111

sb[7] = (sum >>8) &0xff = 1111 1101

(3)

为什么定义sb[8]的前两位是0x55,0xaa?

0xaa是1010 1010,0x55是0101 0101在通讯编码原理中,应该避免过多的重复0或者1,因为当传输变成一个长0/1时,一个脉冲干扰就会将数据截断,增加误码的概率。若通讯机不能接受10101010或者01010101,那么就是线路出现问题。这是一个判断线路状态的手段。

9.串口1接收数据

(1)通过UARTRead1()函数实现

receive += (RS485_RX_BUF1[2] <<0) = 0000 0000 0000 0000 0000 0000 1111 1111

receive += (RS485_RX_BUF1[3] <<8) = 0000 0000 0000 0000 0000 0001 1111 1111

receive += (RS485_RX_BUF1[4] <<16) = 0000 0000 0000 0000 0000 0001 1111 1111

receive += (RS485_RX_BUF1[5] <<24) = 0000 0000 0000 0000 0000 0001 1111 1111

(2)将receive传入checksum(u32 senddata)函数中

d0= 0000 0000 1111 1111

d1=0000 0000 0000 0001

d2= 0000 0000 0000 0000

d3=0000 0000 0000 0000

sum=0000 0001 0000 0000

~sum = 1111 1110 1111 1111

(3)定义接收数据标记位是 u32 flags_receive1

通过判断RS485_RX_BUF1[6] 、RS485_RX_BUF1是否等于 ((sum >>0) &0xff)、((sum >>8) &0xff))来判断读入的数据是不是正确的。

RS485_RX_BUF2[6] ==1111 1111

RS485_RX_BUF2[7] == 1111 1110

正确时

接收到的数据是flags_receive1 = receive= 0000 0000 0000 0000 0000 0001 1111 1111;

不正确时 flags_receive1 |= EBIT(E_ERROR)接收数据标记位置为错误位。

我用的新唐芯片,8051内核,跟51差不多,望采纳

void UART_Initial (void)

{

P02_Quasi_Mode //Setting UART pin as Quasi mode for transmit

P16_Quasi_Mode //Setting UART pin as Quasi mode for transmit

SCON_1 = 0x50 //UART1 Mode1,REN_1=1,TI_1=1

T3CON = 0x08 //T3PS2=0,T3PS1=0,T3PS0=0(Prescale=1), UART1 in MODE 1

clr_BRCK

RH3= HIBYTE(65536 - (1000000/u32Baudrate)-1) /*16 MHz */

RL3= LOBYTE(65536 - (1000000/u32Baudrate)-1) /*16 MHz */

set_TR3//Trigger Timer3

}

以上是初始化的

void Send_Data_To_UART1(UINT8 c)

{

TI_1 = 0

SBUF_1 = c

while(TI_1==0)

}

这个是发送

void UART_isr (void) interrupt 4 //串行中断服务程序

{

if (RI_1==1)

{ /* if reception occur */

clr_RI_1/* clear reception flag for next reception */

Receive_Date[c] = SBUF_1

if (Receive_Date[0] == First_Date)

{

c++

}

else if(Receive_Date_Size >0 &&Receive_Date_Size <4)

{

c++

}

else if(Receive_Date[c] == Last_Date &&Receive_Date_Size ==4)

{

c = 0

Flag_Receive_One = 1

}

else

{

c = 0

}

}

}

接收


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12060644.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存