|
Битые записи в массиве. |
|
|
|
Jul 16 2018, 06:40
|
Профессионал
    
Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075

|
Я принимаю пакеты данных из очереди Код check_queue = FRTOS1_xQueueReceive(Global_Queue_Handle, <_rec_buff, 0); if(check_queue) { memcpy(queue_buff, lt_rec_buff, 13); } И на основе принятых данных строю запись. Код qRxBuffer[0] = 0x55; qRxBuffer[1] = queue_buff[0]; qRxBuffer[2] = queue_buff[1];
qRxBuffer[3] = time.Day; qRxBuffer[4] = time.Month; qRxBuffer[5] = time.Year; qRxBuffer[6] = time.Hour; qRxBuffer[7] = time.Minute; qRxBuffer[8] = time.Second;
temp.all = globalSysTimer & 0xFFFFFFFF; qRxBuffer[9] = temp.nByte[0]; qRxBuffer[10] = temp.nByte[1]; qRxBuffer[11] = temp.nByte[2]; qRxBuffer[12] = temp.nByte[3];
qRxBuffer[13] = queue_buff[4]; //DLC qRxBuffer[14] = queue_buff[5]; //BYTE 0 qRxBuffer[15] = queue_buff[6]; //BYTE 1 qRxBuffer[16] = queue_buff[7]; //BYTE 2 qRxBuffer[17] = queue_buff[8]; //BYTE 3 qRxBuffer[18] = queue_buff[9]; //BYTE 4 qRxBuffer[19] = queue_buff[10]; //BYTE 5 qRxBuffer[20] = queue_buff[11]; //BYTE 6 qRxBuffer[21] = queue_buff[12]; //BYTE 7
calcRes.all = UTL_CRC_srvCalculate_CRC16_CCITT(qRxBuffer, 22); qRxBuffer[22] = calcRes.nByte[0]; qRxBuffer[23] = calcRes.nByte[1]; Для проверки записи я вывожу ее на терминал Код for (g_idx = 0; g_idx < 24; g_idx++) { send_hex_num16_uart0(qRxBuffer[g_idx]); send_msg_uart0(" ", 1); } send_msg_uart0("\r", 1); Вижу правильные записи. Послал 20 получил 20 - все красиво. Каждую запись я добавляю в массив размером 4096 байт. И когда массив полный - вывожу его на терминал Код //check if there is enough space for the message if ( (4096 - data_index) >= sizeof(qRxBuffer) ) { memcpy(&log_data[data_index], qRxBuffer, sizeof(qRxBuffer)); data_index += sizeof(qRxBuffer); } else //the page is full { data_index = 0;
for (g_idx = 0; g_idx < 4096; g_idx++) { if (&log_data[g_idx] == 0x55) send_msg_uart0("\r", 1);
send_hex_num16_uart0(&log_data[g_idx]); send_msg_uart0(" ", 1); } } И что я вижу? Битые записи! Вот например Код 55 5 0 0 0 0 0 0 0 19 7B 9 0 7 1 9F 80 2E 80 0 0 0 A6 19 55 4 0 0 0 0 0 0 0 2C 7B 9 0 3 1 B B8 0 0 1 B B8 1A 83 55 5 0 0 0 0 0 0 0 2D 7B 9 0 7 1 9F 80 2E 80 0 0 0 D7 27 55 4 0 0 0 0 0 0 0 40 7B 9 0 3 1 B B8 0 0 1 B B8 55 FA 55 5 0 0 0 0 0 0 0 41 7B 9 0 7 1 9F 80 2E 80 0 0 0 98 5E 55 4 0 0 0 0 0 0 0 55 7B 9 0 3 1 B B8 0 0 1 B B8 2F AC 55 5 0 0 0 0 0 0 0 56 7B 9 0 7 1 9F 80 2E 80 0 0 0 24 82 55 4 0 0 0 0 0 0 0 69 7B 9 0 3 1 B B8 0 0 1 B B8 4 99 55 5 0 0 0 0 0 0 0 6A 7B 9 0 7 1 9F 80 2E 80 0 0 0 F B7 55 4 0 0 0 0 0 0 0 7D 7B 9 0 3 1 B B8 0 0 1 B B8 1D 8A Причем битые записи могут быть в разных местах при одной и той же посылке данных. Как? Как записи могли не прописаться в массив в РАМ?
Сообщение отредактировал Jenya7 - Jul 16 2018, 06:43
|
|
|
|
|
 |
Ответов
|
Jul 17 2018, 06:26
|
Гуру
     
Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713

|
Цитата(Arlleex @ Jul 17 2018, 09:16)  Простой, надежный. Переменная длина сообщений вообще радует - сделал себе что-то наподобие мессенджера - при этом не нужны поля размера пакета в структурах обмена и связанные с этим головные боли тоже ушли. COBS слышал, не применял, не знаю  COBS тоже - простой, надёжный, с произвольной длиной сообщений, кодонезависимый. У байт-стаффинговых протоколов есть существенный недостаток: увеличение длины сообщения после кодирования зависит от содержащихся в сообщении данных. Это может быть существенным минусом например когда нужно заранее перед кодированием знать длину вых.сообщения, или когда пропускная способность канала ограничена. У COBS увеличение длины сообщения после кодирования никак не зависит от данных в сообщении: всегда +1 дополнительный байт на каждые 254 входных байтов. Что я и представил формулой: #define CobsCodedOver(payload) ((sizeof(payload) - 1) / 254 + 1)где sizeof(payload) - длина исходного некодированного сообщения. PS: Естественно никакие "размеры пакета" или "контрольные суммы" никакому из кодонезависимых протоколов (ни байт-стаффинговым ни COBS) не нужны. Всё это элементы протоколов более высокого уровня, над фреймером. Но чайники как правило всё это мешают в кучу.
|
|
|
|
Сообщений в этой теме
Jenya7 Битые записи в массиве. Jul 16 2018, 06:40 aaarrr А если так рассмотреть - не битые?
Код55 5 0 0 0 0... Jul 16 2018, 06:46 Jenya7 Цитата(aaarrr @ Jul 16 2018, 12:46) А есл... Jul 16 2018, 07:16  aaarrr Цитата(Jenya7 @ Jul 16 2018, 10:16) не по... Jul 16 2018, 07:17   Jenya7 Цитата(aaarrr @ Jul 16 2018, 13:17) Что я... Jul 16 2018, 07:25  iosifk Цитата(Jenya7 @ Jul 16 2018, 10:16) не по... Jul 16 2018, 07:27   Jenya7 Цитата(iosifk @ Jul 16 2018, 13:27) aaarr... Jul 16 2018, 07:31 ViKo "чексам"... Етить-колотить! Jul 16 2018, 07:48 k155la3 Если протокол бинарный-байтовый, то единственная в... Jul 16 2018, 08:11 aaarrr Цитата(k155la3 @ Jul 16 2018, 11:11) Если... Jul 16 2018, 08:38  k155la3 Цитата(aaarrr @ Jul 16 2018, 11:38) Не ед... Jul 16 2018, 08:42   jcxz Цитата(k155la3 @ Jul 16 2018, 11:42) Да. ... Jul 16 2018, 10:34    k155la3 Цитата(jcxz @ Jul 16 2018, 13:34) . . . Е... Jul 16 2018, 12:05     Jenya7 Цитата(k155la3 @ Jul 16 2018, 18:05) COBS... Jul 16 2018, 12:09      k155la3 Цитата(Jenya7 @ Jul 16 2018, 15:09) а что... Jul 16 2018, 12:13     megajohn Цитата(k155la3 @ Jul 16 2018, 16:05) COBS... Jul 16 2018, 12:29     jcxz Цитата(k155la3 @ Jul 16 2018, 15:05) COBS... Jul 16 2018, 14:15      segment Цитата(jcxz @ Jul 16 2018, 17:15) И разме... Jul 16 2018, 14:26       jcxz Цитата(segment @ Jul 16 2018, 17:26) Пояс... Jul 16 2018, 20:34        segment Цитата(jcxz @ Jul 16 2018, 23:34) Вы почи... Jul 17 2018, 12:48         ViKo Цитата(segment @ Jul 17 2018, 15:48) Нет,... Jul 17 2018, 13:40          segment Цитата(ViKo @ Jul 17 2018, 16:40) Единств... Jul 17 2018, 13:56     Kabdim Цитата(k155la3 @ Jul 16 2018, 15:05) Ну, ... Jul 17 2018, 08:36      k155la3 Цитата(Kabdim @ Jul 17 2018, 11:36) Вот з... Jul 17 2018, 08:56       jcxz Цитата(k155la3 @ Jul 17 2018, 11:56) Не д... Jul 17 2018, 10:34        Arlleex Цитата(jcxz @ Jul 17 2018, 14:34) Вот так... Jul 17 2018, 12:01        k155la3 Цитата(jcxz @ Jul 17 2018, 13:34) Это гра... Jul 17 2018, 16:58         mantech Цитата(k155la3 @ Jul 17 2018, 19:58) С ме... Jul 17 2018, 17:39 jcxz Цитата(k155la3 @ Jul 16 2018, 11:11) спар... Jul 16 2018, 09:32  k155la3 Цитата(jcxz @ Jul 16 2018, 12:32) Опечатк... Jul 16 2018, 09:34 Kabdim Попутно стоит рассказать про "%02X" вмес... Jul 16 2018, 10:10 Jenya7 а теперь простым языком - как создать уникальный з... Jul 16 2018, 11:25 mantech Цитата(Jenya7 @ Jul 16 2018, 14:25) а теп... Jul 16 2018, 12:19 XVR Цитата(Jenya7 @ Jul 16 2018, 14:25) а теп... Jul 16 2018, 13:48  Jenya7 Цитата(XVR @ Jul 16 2018, 19:48) Зачем ва... Jul 16 2018, 13:50   XVR Цитата(Jenya7 @ Jul 16 2018, 16:50) а как... Jul 16 2018, 14:04 HardEgor Цитата(Jenya7 @ Jul 16 2018, 18:25) а теп... Jul 17 2018, 05:39  jcxz Цитата(HardEgor @ Jul 17 2018, 08:39) Дос... Jul 17 2018, 05:54  Arlleex Цитата(jcxz @ Jul 17 2018, 10:26) COBS то... Jul 17 2018, 08:17 k155la3 Giihub, SLIP, COBS Jul 17 2018, 06:18 Kabdim Мне вот всегда такие объяснения лениво писать даже... Jul 17 2018, 10:59 jcxz Цитата(Kabdim @ Jul 17 2018, 13:59) Мне в... Jul 17 2018, 16:21 Dog Pawlowa Вообще-то во многих странах на протоколы связи с у... Jul 18 2018, 05:55
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|