|
|
本帖最后由 DATOUDAda 于 2019-9-29 09:51 編輯
問(wèn)題:1、我開個(gè)串口中斷接收數(shù)據(jù),想要接收到第一個(gè)數(shù)據(jù)如0XAD,單片機(jī)發(fā)送自己的地址過(guò)去,例如單片機(jī)收到了0XAD,然后就
USART_SendData(DEBUG_USARTx,(DMX512_para_set.g_DMX512_address>>2));
USART_SendData(DEBUG_USARTx,(DMX512_para_set.g_DMX512_address&0xFF));給串口助手。接下來(lái)我再
通過(guò)串口助手發(fā)送一幀數(shù)據(jù),除開0X2D的幀頭和0X08的指令長(zhǎng)度,單片機(jī)用數(shù)組將剩下的8個(gè)BYTE存起來(lái)。但是這個(gè)時(shí)候存
入的數(shù)組是錯(cuò)漏的如:
3%G76(PFOON_6G{C]VQZUN1.png (51.49 KB, 下載次數(shù): 28)
下載附件
2019-9-27 16:56 上傳
2、當(dāng)我把 USART_SendData(DEBUG_USARTx,(DMX512_para_set.g_DMX512_address>>2));
USART_SendData(DEBUG_USARTx,(DMX512_para_set.g_DMX512_address&0xFF));不放在串口中斷里,而是當(dāng)我
接收到0XAD時(shí),就令USART1_ADDRESS_TX_FLAG=1;然后在main函數(shù)里符合USART1_ADDRESS_TX_FLAG=1的IF條件再執(zhí)行
發(fā)送地址,后面的數(shù)組接收就不會(huì)錯(cuò)漏了。為什么,百思不得其解!!!!!
4EXKJB~E(0PCMHPD`N)O)GL.png (44.46 KB, 下載次數(shù): 34)
下載附件
2019-9-27 17:11 上傳
/////////////完整代碼/////////////
/////////////問(wèn)題:為什么接收跟發(fā)送不能放在同個(gè)中斷函數(shù)里里?////////////
希望論友們給點(diǎn)力
void DEBUG_USART_IRQHandler(void)
{
int i;
if(USART_GetITStatus(DEBUG_USARTx,USART_IT_RXNE)==SET)
{
USART_ClearITPendingBit(DEBUG_USARTx, USART_IT_RXNE);
USART_receive_data_9bit = USART_ReceiveData(DEBUG_USARTx); //USART_ReceiveData內(nèi)部已經(jīng) & (uint16_t)0x01FF
if(USART_receive_data_9bit==0xAD&&Order_Length==0)
{
USART_SendData(DEBUG_USARTx,(DMX512_para_set.g_DMX512_address>>2));
USART_SendData(DEBUG_USARTx,(DMX512_para_set.g_DMX512_address&0xFF));
USART1_ADDRESS_TX_FLAG=1;
}
else if((USART_receive_data_9bit)==0X2D&&Order_Length==0&&USART1_ADDRESS_TX_FLAG==1) //標(biāo)志位閱后即焚
{
USART1_HEADER_FLAG=1;
USART1_ADDRESS_TX_FLAG=0;
}
else if(USART1_HEADER_FLAG==1&&USART_receive_data_9bit==0x08&&Order_Length==0)//標(biāo)志位閱后即焚
{
Order_Length=0X08;
USART1_HEADER_FLAG=0;
}
else if(Order_Length==0x08)
{
g_packet_receive_from_DMX512[slot_counter]=USART_receive_data_9bit;//正常數(shù)據(jù)把第九位刪掉
g_DMX512_data_receive_change_or_not=DMX512_DATA_CHANGE;
slot_counter++;
if(slot_counter==8)
{
Order_Length=0;
}
}
}
|
|