|
CRC32, uint32_t |
|
|
|
Mar 1 2015, 21:16
|

Гуру
     
Группа: Свой
Сообщений: 2 957
Регистрация: 19-09-06
Из: Москва
Пользователь №: 20 514

|
Добрый день! Нужна софтовая реализация. Не проблема, гугел их находит не задумываясь Но из того, что я находил, даже табличная реализация считает по 1 байту А хотелось бы найти подсчет сразу по 32 бита, не по 8. Благо мой массив данных всегда кратен 4 байтам, а аппаратного CRC на борту контроллера нет По идее, это же должно увеличить производительность?  UPD что-то нашел от Интела черт... там используются 4 таблицы из uint32_t[256] места в оперативке нет, во флеше тоже... придется побайтно считать
|
|
|
|
|
 |
Ответов
|
Mar 3 2015, 07:54
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(SM @ Mar 2 2015, 19:13)  Для CRC-32 такие конструкции категорически не выгодны, Существует куча других циклических контрольных сумм, 16- и 8-битных. Серега, ты можешь объяснить саму методику, как получаются такие формулы? В хозяйстве обязательно сгодится! Скажем, на примере полинома 0xA001 (modbus), обработка младшим битом вперед.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Mar 3 2015, 09:08
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(SM @ Mar 3 2015, 10:11)  Это что значит? Новый бит данных задвигается со старшего разряда сдвигом вправо, Да. Потихоньку начал сам разбираться с примером из приложенного мной выше примера применения: Код // обсчет одного байта "в лоб": void crc::ccitt:calculate(uint8_t byte) { uint_fast8_t Counter = 8; uint_fast16_t Tmp = Current; Tmp ^= byte; do { if (Tmp & (1<<0)) { Tmp >>= 1; Tmp ^= POLYNOME; } else Tmp >>= 1; } while(--Counter); Current = Tmp; }
результат для байта с одним установленным битом: /* 0x01 -> 0x1189 0x02 -> 0x2312 0x04 -> 0x4624 0x08 -> 0x8C48 0x10 -> 0x1081 0x20 -> 0x2102 0x40 -> 0x4204 0x80 -> 0x8408 // то же в двоичном виде: 0: 0000 0001 -> 0001 0001 1000 1001 1: 0000 0010 -> 0010 0011 0001 0010 2: 0000 0100 -> 0100 0110 0010 0100 3: 0000 1000 -> 1000 1100 0100 1000 4: 0001 0000 -> 0001 0000 1000 0001 5: 0010 0000 -> 0010 0001 0000 0010 6: 0100 0000 -> 0100 0010 0000 0100 7: 1000 0000 -> 1000 0100 0000 1000 // зависимость каждого бита результата от входных: ^^ y15 = x3 ^ x7 --+| y14 = x2 ^ x6 ---+ y13 = x1 ^ x5 y12 = x0 ^ x4 y11 = x3 ..... */ Пока с примером совпадает. В принципе уже можно написать такой вариант: Код тут была фигня Каким образом заполнена таблица 7-1 в примере понятно. Осталось понять, как эти выражения для каждого бита свернуть в общую формулу.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
Сообщений в этой теме
toweroff CRC32 Mar 1 2015, 21:16 VAI Вот 2 функции, одна "железная" для STM32... Mar 2 2015, 05:49 toweroff Спасибо!
У меня не STM и не старшие кортексы ... Mar 2 2015, 06:50 blackfin Цитата(toweroff @ Mar 2 2015, 09:50) Эта ... Mar 2 2015, 07:05  toweroff Цитата(blackfin @ Mar 2 2015, 10:05) Там,... Mar 2 2015, 07:32 ViKo А вы перешлите второй раз прошивку для верификации... Mar 2 2015, 08:14 toweroff Цитата(ViKo @ Mar 2 2015, 11:14) А вы пер... Mar 2 2015, 10:48 VAI Цитата(ViKo @ Mar 2 2015, 12:14) А вы пер... Mar 2 2015, 11:02  toweroff Цитата(VAI @ Mar 2 2015, 14:02) Запись же... Mar 2 2015, 11:20 adnega Типичный кусок кода для бестабличного вычисления:
... Mar 2 2015, 11:12 jcxz Цитата(adnega @ Mar 2 2015, 17:12) Типичн... Mar 2 2015, 11:38  toweroff Цитата(jcxz @ Mar 2 2015, 14:38) У нас бу... Mar 2 2015, 11:55  Сергей Борщ Цитата(jcxz @ Mar 2 2015, 13:38) Также мо... Mar 2 2015, 14:48   jcxz Цитата(Сергей Борщ @ Mar 2 2015, 20:48) Я... Mar 2 2015, 14:55    Сергей Борщ Цитата(jcxz @ Mar 2 2015, 16:55) Я как ра... Mar 2 2015, 16:16 ViKo Кусками или целиком - какая разница? Сначала запис... Mar 2 2015, 11:18 SM в общем, объясню на примере 0x8408:
1)
byte ^= cr... Mar 3 2015, 10:49 Сергей Борщ Такс. Я разобрался. 0x8408, сдвиг вправо. За время... Mar 3 2015, 12:24 SM Цитата(Сергей Борщ @ Mar 3 2015, 15:24) Т... Mar 3 2015, 12:50  Сергей Борщ Цитата(SM @ Mar 3 2015, 14:50) Короче, им... Mar 3 2015, 14:06   SM Цитата(Сергей Борщ @ Mar 3 2015, 17:06) Н... Mar 3 2015, 14:23    Сергей Борщ Цитата(SM @ Mar 3 2015, 16:23) То есть, 0... Mar 3 2015, 16:05 toweroff Подниму тему вот по какому вопросу
Когда пользова... Mar 11 2015, 18:34 SM Цитата(toweroff @ Mar 11 2015, 21:34) но ... Mar 11 2015, 18:49 toweroff Да суть-то не в этом - с нулем или константой срав... Mar 11 2015, 18:58 SM Цитата(toweroff @ Mar 11 2015, 21:58) Есл... Mar 11 2015, 19:04  toweroff Цитата(SM @ Mar 11 2015, 22:04) Эту конст... Mar 11 2015, 19:32   SM Цитата(toweroff @ Mar 11 2015, 22:32) хмм... Mar 11 2015, 19:42 toweroff Так.
Не получается у меня, или я не так понял.
[... Mar 11 2015, 20:12 SM Цитата(toweroff @ Mar 11 2015, 23:12) рас... Mar 12 2015, 08:45 ViKo Пользуюсь аппаратным CRC32 в STM32, никаких перест... Mar 12 2015, 03:51 toweroff Цитата(ViKo @ Mar 12 2015, 06:51) Пользую... Mar 12 2015, 04:48 ViKo В аппаратном CRC STM32 перед началом расчета нужно... Mar 12 2015, 06:16 toweroff Вот о чем я и говорил - если не инвертировать, то ... Mar 12 2015, 09:58 SM Цитата(toweroff @ Mar 12 2015, 12:58) Вот... Mar 12 2015, 10:02 toweroff Просто может возникнуть необходимость проверить ... Mar 12 2015, 11:09
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|