關(guān)于stm32 的 USB 轉(zhuǎn)串口 virtual_Com_Port的例程的一些問題
當(dāng)從虛擬串口到真實串口發(fā)數(shù)據(jù)時,沒有錯誤,但發(fā)送一個稍微大一點的文件時(如1M),誤碼率很高。不知是為什么?
其中:
int main(void)
{
#ifdef DEBUG
debug();
#endif
Set_System();
Set_USBClock();
USB_Interrupts_Config();
USB_Init();
while (1)
{
if (count_out != 0)
{
USB_To_USART_Send_Data(&buffer_out[0], count_out);//這句是發(fā)數(shù)據(jù)的函數(shù),原型如下。
count_out = 0;
}
}
}
其中:
void USB_To_USART_Send_Data(u8* data_buffer, u8 Nb_bytes)
{
u32 i;
for (i = 0; i < Nb_bytes; i++)
{
USART_SendData(USART1, *(data_buffer + i));
while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
}
}
望高手指教。
------解決方案--------------------
首先你的程序有問題,首先你的count_out應(yīng)該是在USB收到數(shù)據(jù)是修改的吧,然后在main中判斷,如果你在USB_To_USART_Send_Data()函數(shù)處理過程中又收到數(shù)據(jù)會改變count_out值,而退出后又將count_out改成0了,這肯定會丟數(shù)。建議你設(shè)計修改一下這個緩存轉(zhuǎn)發(fā)機制。
另外虛擬串口發(fā)數(shù)據(jù)發(fā)的太快了,發(fā)送大數(shù)據(jù)量時實際串口發(fā)不過來了。打開虛擬串口時的參數(shù)限制不了USB端的虛擬串口的速度,這個參數(shù)只是傳給STM32讓STM32設(shè)置實際串口參數(shù)用的。
解決辦法:
(1). 自己寫USB轉(zhuǎn)串口的驅(qū)動,在驅(qū)動發(fā)送數(shù)據(jù)的代碼中限制發(fā)送速度。
(2). 自己寫上位機的串口發(fā)送程序,加上協(xié)議,建立發(fā)送應(yīng)答機制,保證數(shù)據(jù)發(fā)送成功。
(3). 增大STM32的RAM空間,大到可以緩存下你發(fā)送的最大文件,STM32收到后先緩存下來然后再從串口發(fā)
------解決方案--------------------
voidUSB_To_USART_Send_Data(u8*data_buffer,u8Nb_bytes){u32i;for(i=0;i