//接收缓存区
u8 RS485_RX_BUF[64]; //接收缓冲,最大64个字节.
//接收到的数据长度
u8 RS485_RX_CNT=0;
void UART4_IRQHandler(void)
{
u8 res;
if(USART_GetITStatus(UART4, USART_IT_RXNE) != RESET) //接收到数据
{
led8=0;
res =USART_ReceiveData(UART4); //读取接收到的数据
if(RS485_RX_CNT<64)
{
RS485_RX_BUF[RS485_RX_CNT]=res; //记录接收到的值
RS485_RX_CNT++; //接收数据增加1
}
if((RS485_RX_BUF[0]==9)&&(RS485_RX_BUF[1]==9))
{
led1 = 0;
}
if((RS485_RX_BUF[0]==8)&&(RS485_RX_BUF[1]==8))
{
led2 = 0;
}
if((RS485_RX_BUF[0]==7)&&(RS485_RX_BUF[1]==7))
{
led3 = 0;
}
}
}
void Init_MAX485(u32 bound)
{
USART_InitTypeDef USART_InitStructure;
NVIC_InitTypeDef NVIC_InitStructure;
USART_InitStructure.USART_BaudRate = bound;//波特率设置
USART_InitStructure.USART_WordLength = USART_WordLength_8b;//8位数据长度
USART_InitStructure.USART_StopBits = USART_StopBits_1;//一个停止位
USART_InitStructure.USART_Parity = USART_Parity_No;///奇偶校验位
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//收发模式
USART_Init(UART4, &USART_InitStructure); //初始化串口
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
NVIC_InitStructure.NVIC_IRQChannel = UART4_IRQn; //使能串口2中断
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; //先占优先级2级
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //从优先级2级
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //使能外部中断通道
NVIC_Init(&NVIC_InitStructure); //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器
USART_ITConfig(UART4, USART_IT_RXNE, ENABLE);//开启中断
USART_Cmd(UART4, ENABLE); //使能串口
RS485_TX_EN=0; //默认为接收模式
}
void RS485_Send_Data(u8 *buf, u16 len)
{
u8 t;
RS485_TX_EN=1; //设置为发送模式
for(t=0; t<len; t++)
{
while(USART_GetFlagStatus(UART4, USART_FLAG_TC) == RESET);
USART_SendData(UART4, buf[t]);
}
while(USART_GetFlagStatus(UART4, USART_FLAG_TC) == RESET);
RS485_RX_CNT=0;
RS485_TX_EN=0; //设置为接收模式
}
void RS485_Receive_Data(u8 *buf,u8 *len)
{
u8 rxlen=RS485_RX_CNT;
u8 i=0;
*len=0; //默认为0
delay_ms(10); //等待10ms,连续超过10ms没有接收到一个数据,则认为接收结束
if(rxlen==RS485_RX_CNT&&rxlen)//接收到了数据,且接收完成了
{
for(i=0;i<rxlen;i++)
{
buf[i]=RS485_RX_BUF[i];
}
*len=RS485_RX_CNT; //记录本次数据长度
RS485_RX_CNT=0; //清零
}
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
RS485_Receive_Data(&ABC,&BCD);
2、RS485_Receive_Data这个函数处理数据的方式你不觉得有问题么?为什么不放到中断里直接操作全局变量ABC[]数组。
如下:
RS485_TX_EN=1; //设置为发送模式
delay_ms(3);
你去仔细查看下是不是你的工程用错了startup_stm32f10x_xxx.s文件。startup_stm32f10x_hd.s和startup_stm32f10x_md.s是要根据芯片的大小来选取的。如果HD的芯片用成了md的.s启动文件。可能会出现串口通信只能发送不能接收的情况。
新手就是懒的自己建立工程然后就随便拷贝一个工程就开始修改代码了,殊不知工程里的.s文件没有用对。然后开始编程,反复修改代码,然后开始怀疑人生……
..不用485芯片· 我·直接用串口就可以通讯。。。新手也不会把启动文件都搞错的。
一周热门 更多>