Сборник по задачам и примерам Assembler




Прямой табличный алгоритм CRC16



Прямой табличный алгоритм CRC16

'Необходимость дополнения исходной строки завершающими нулевыми байтами представляет большое неудобство при реализации общей схемы табличного

алгоритма. Поэтому на практике используют другую схему вычисления CRC, не требующую завершения исходного сообщения нулевыми байтами. В этой схеме

очередной байт исходной строки объединяется операцией XOR со старшим байтом регистра, выдвинутым с левой стороны этого регистра. Полученное в результате объединения значение используется в качестве индекса для доступа к CRC-таб-лице. Извлекаемое из CRC-таблицы значение объединяется операцией XOR с содержимым регистра. Описанный алгоритм называют прямым табличным алгоритмом.

Рисунок 9.9. Схема вычислений CRC с использованием прямого табличного алгоритма

На схеме вычислений CRC с использованием прямого табличного алгоритма цифрами обозначена последовательность шагов вычисления CRC.

  • 1. Выдвижение старшего байта регистра АХ в байтовую ячейку.

    2. Выполнение операции XOR над выдвинутым на шаге 1 в байтовую ячейку старшим байтом регистра АХ и очередным байтом исходной строки.

    3. Полученное на шаге 2 значение используется в качестве индекса для доступа к элементу CRC-таблицы.

    4. Извлеченное из CRC-таблицы значение объединяется по XOR со значением в регистре АХ.

    5. Результат выполнения на шаге 4 операции XOR помещается обратно в регистр АХ.

  • После обработки последнего байта исходной строки регистр АХ содержит значение CRC. Программа вычисления CRC с использованием прямого табличного алгоритма приведена ниже.

    :prg09_04.asm - программа вычисления CRC с использованием прямого табличного алгоритма.

    .......... »

    .data

    ;исходная битовая последовательность в символах

    bit_string db "6476c8"

    1en_bi t_string=$-bi t_stri ng

    adr_bit_string dd bit_string

    tabl_16 dw 256 dup (0) iCRC-таблица

    Ien_tab1_16=$-tabl_16 adr_tabl_16 dd tabl_16

    polinom dw 1021h

    .code

    .-------------расчитываем CRC-таблицу---.....-------------

    les di.adr_tabl_16

    add di.len_tabl_16-2




    Содержание  Назад  Вперед