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

 
 
> Битые записи в массиве.
Jenya7
сообщение Jul 16 2018, 06:40
Сообщение #1


Профессионал
*****

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



Я принимаю пакеты данных из очереди
Код
check_queue = FRTOS1_xQueueReceive(Global_Queue_Handle, &lt_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
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Dog Pawlowa
сообщение Jul 18 2018, 05:55
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 702
Регистрация: 14-07-06
Пользователь №: 18 823



Вообще-то во многих странах на протоколы связи с устройствами есть стандарты.
Типичный протокол не предусматривает передачи любых данных.
Старый добрый пакет STX data ETX BCC1 BCC2 вместе с запросами и подтверждениями ENQ/ DLE вполне решает все проблемы.

Длина/скорость передачи критичны в единицах случаев.
Возвращайтесь к истокам, коллеги! wink.gif


--------------------
Уходя, оставьте свет...
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- 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   Для связи между платами (или MCU<->CPU/FPGA)...   Jul 17 2018, 06:16
|- - jcxz   Цитата(Arlleex @ Jul 17 2018, 09:16) Прос...   Jul 17 2018, 06:26
|- - 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


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

 


RSS Текстовая версия Сейчас: 27th April 2024 - 13:51
Рейтинг@Mail.ru


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