關(guān)于stm32 的 USB 轉(zhuǎn)串口 virtual_Com_Port的例程的一些問題
掃描二維碼
隨時(shí)隨地手機(jī)看文章
當(dāng)從虛擬串口到真實(shí)串口發(fā)數(shù)據(jù)時(shí),沒有錯(cuò)誤,但發(fā)送一個(gè)稍微大一點(diǎn)的文件時(shí)(如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ù)會(huì)改變count_out值,而退出后又將count_out改成0了,這肯定會(huì)丟數(shù)。建議你設(shè)計(jì)修改一下這個(gè)緩存轉(zhuǎn)發(fā)機(jī)制。
另外虛擬串口發(fā)數(shù)據(jù)發(fā)的太快了,發(fā)送大數(shù)據(jù)量時(shí)實(shí)際串口發(fā)不過來了。打開虛擬串口時(shí)的參數(shù)限制不了USB端的虛擬串口的速度,這個(gè)參數(shù)只是傳給STM32讓STM32設(shè)置實(shí)際串口參數(shù)用的。
解決辦法:
(1). 自己寫USB轉(zhuǎn)串口的驅(qū)動(dòng),在驅(qū)動(dòng)發(fā)送數(shù)據(jù)的代碼中限制發(fā)送速度。
(2). 自己寫上位機(jī)的串口發(fā)送程序,加上協(xié)議,建立發(fā)送應(yīng)答機(jī)制,保證數(shù)據(jù)發(fā)送成功。
(3). 增大STM32的RAM空間,大到可以緩存下你發(fā)送的最大文件,STM32收到后先緩存下來然后再從串口發(fā)
------解決方案--------------------
voidUSB_To_USART_Send_Data(u8*data_buffer,u8Nb_bytes){u32i;for(i=0;i