[an error occurred while processing this directive]
Разбираюсь с аппаратным умножителем на Меге (+)
(«Телесистемы»: Конференция «Микроконтроллеры и их применение»)

миниатюрный аудио-видеорекордер mAVR

Отправлено vinogradov aleksei 20 октября 2006 г. 16:39

Изучаю документ AVR201 от ATMEL. Процедура знакового умножения. На входе два 16-битовых числа в доп. коде (первое число в r23:r22, второе в r21:r20), на выходе 32-битный результат:

main_program:
ldi r23,high(392)
ldi r22,low(392)

ldi r21,high(34567)
ldi r20,low(34567)
rcall mul_s_16_16_32

mul_s_16_16_32:
clr r2
muls r23,r21
movw r19:r18, r1:r0
mul r22,r20
movw r17:r16, r1:r0
mulsu r23,r20
sbc r19,r2
add r17,r0
adc r18,r1
adc r19,r2
mulsu r21,r22
sbc r19,r2
add r17,r0
adc r18,r1
adc r19,r2
ret

Все работает, но я никак не могу понять назначения команд "sbc r19,r2". Т.е. если команда mulsu дает отрицательное число, то из r19 нужно вычесть единицу. А зачем ?

Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа
Имя (обязательно): 
Пароль: 
E-mail: 

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 
URL изображения: 


Rambler's Top100 Рейтинг@Mail.ru
Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание