реклама на сайте
подробности

 
 
> Задержки для COM порта под Win XP, Программирование на С++ Builder
AKK
сообщение Oct 7 2005, 03:23
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 29-09-05
Пользователь №: 9 060



Доброго всем времени суток.
При иннициализации порта:
hCom = CreateFile("COM3", GENERIC_READ | GENERIC_WRITE,0, NULL,OPEN_EXISTING, 0,NULL );
Устанавливаются следующие задержки на чтение:
COMMTIMEOUTS times;
...
times.ReadIntervalTimeout = MAXDWORD;
times.ReadTotalTimeoutMultiplier = MAXDWORD;
times.ReadTotalTimeoutConstant = 5;
...
Далее в программе происходит запись в порт 8 байт, и прием одного байта ответа:
WriteFile(hCom,Buffer,8,&b,NULL);
ReadFile (hCom,&i,1,&b,NULL);
И все это происходит в цикле.
Собственно проблема: на осциллографе видно, что передача 8 байт и ответный байт на скорости 9600 укладываются примерно в 10 мс, а следующая посылка данных происходит примерно только через 30 мс. Откуда берется это время - не понятно. При попытке читат 2 байта из порта (второго байта нет, т.е. должен происходить таймаут) картина полностью идентична описаной. При коде:
WriteFile(hCom,Buffer,8,&b,NULL);
ReadFile (hCom,&i,1,&b,NULL);
ReadFile (hCom,&i,1,&b,NULL);
задержка возрастает примерно до 100 мс. :-(.
При увеличении скорости порта до 19200 скорость передачи данных сократилась незначительно: задержка между посылками возросла на то же самое время, на какое сократилось время передачи данных.
Да, забыл: СОМ3 - это порт для преобразователя USB-RS485. Т.е. с компутера данные реально отправляются на через USB порт на преобразователь, и далее по линии RS485. Данные снимались осциллографом на преобразователе со стороны RS485, но преобразователь тут точно не при чем, он был испытан на самодельном устройстве - USB передатчике, никаких левых задержек не наблюдалось.
Кто знает в чем дело - помогите, плз. Кто не знает - может выдвигать версии, все будет внимательно рассмотрено, проверено.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Tech
сообщение Oct 7 2005, 04:58
Сообщение #2


Участник
*

Группа: Участник
Сообщений: 20
Регистрация: 1-12-04
Пользователь №: 1 267



У меня фунции работы с COM портом выделены в отдельный поток, запускаются по событиям и работают асинхронно. Задержек не наблюдаю даже при очень загруженной системе (кроме работы с FDD и т.п.). Хотя сначала делал синхронные прием и передачу и тоже задержек не видел.
Пробовал и аппаратный и эмулируемый (на PL2303) порты пока только под W2K.

Покажите, по возможности, значения всех полей структуры DCB, и кусок кода реализации цикла.
Go to the top of the page
 
+Quote Post
AKK
сообщение Oct 7 2005, 07:18
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 29-09-05
Пользователь №: 9 060



Цитата(Tech @ Oct 7 2005, 10:58)
Покажите, по возможности, значения всех полей структуры DCB, и кусок кода реализации цикла.
*


Собственно код иннициализации:
hCom = CreateFile("COM3", GENERIC_READ | GENERIC_WRITE,0,NULL,OPEN_EXISTING,0, NULL);
if (hCom == INVALID_HANDLE_VALUE)
{
Application->MessageBox...
return;
};
GetCommState (hCom, &dcb);
GetCommTimeouts (hCom, &times);

dcb.BaudRate = CBR_9600;
dcb.ByteSize = 8;
dcb.fParity = true;
dcb.Parity = MARKPARITY;
dcb.StopBits = ONESTOPBIT;
SetCommState(hCom, &dcb);

times.ReadIntervalTimeout = MAXDWORD;
times.ReadTotalTimeoutMultiplier = MAXDWORD;
times.ReadTotalTimeoutConstant = 5;
times.WriteTotalTimeoutMultiplier = MAXDWORD;
times.WriteTotalTimeoutConstant = 3;
SetCommTimeouts(hCom,&times);

PurgeComm(hCom,PURGE_TXCLEAR);
PurgeComm(hCom,PURGE_RXCLEAR);

Кусок цикла:
uchar buff[9];

for (b=0x200; b<0x020000;b+=8)
{
for (i=0;i<8;i++) buff[i] = buffer[b+i];
if ( !SetData(buff, 9) ) return;
addr += 8;
}

Функция SetData:
bool TFMain::SetData( uchar* Buffer, uchar Amount)
{
ulong b;
uchar i;

Buffer[Amount-1] = 0;
for (i=0; i<(Amount-1);i++) Buffer[Amount-1] ^= Buffer[i];

WriteFile(hCom,Buffer,Amount,&b,NULL);
PurgeComm(hCom,PURGE_RXCLEAR);

ReadFile (hCom,&i,1,&b,NULL);

if ( (i==Buffer[Amount-1]) && (b==1) ) return true;
else return false
}
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 18th July 2025 - 04:32
Рейтинг@Mail.ru


Страница сгенерированна за 0.01538 секунд с 7
ELECTRONIX ©2004-2016