MUL - інструкція множення у мікроконтролерах, присутня, наприклад, у мікроконтролерах Atmega . Але не у всіх мікроконтролерах AVR є апаратна підтримка функцій множення. Наприклад, у мікроконтролерах Attiny команда MUL просто відсутня, тому вирішення цього завдання покладається на програмний код.
Основний момент, який необхідно враховувати при реалізації функції множення те, що для збереження результату множення знадобиться два регістри. В один з регістрів буде збережено молодший байт результату, а в другому регістр буде збережено старший байт результату.
Програмна реалізація MUL
Нижче наведено функцію множення, яка працює з 8-ми розрядними числами і на виході дає 16-розрядні числа.
;======= Программная функция умножения (реализует mul) ============================== ; r16 ; множимое ; r17 ; множитель ; r0 ; младший байт результата ; r1 ; старший байт результата ; r19 ; счетчик цикла ;----------------------------------------------------------------------------------- mpy8u_c: clr r1 ; очищаем регистр для сохранения старшего байта результата ldi r19,8 ; устанавливаем стартовое значение счетчика цикла lsr r17 ; сдвигаем множитель вправо m8u_1: brcc m8u_2 ; производим переход, если С = 0 add r1,r16 ; к старшему байту результата прибавляем множимое m8u_2: ror r1 ; старший байт результата сдвигаем вправо ror r0 ; младший байт результата сдвигаем вправо dec r19 ; производим декремент счетчика brne m8u_1 ; производим переход, если С != 0 ret
Примітка. У цій програмній функції використовуються арифметичні операції, контроль виконання яких доручається SREG - AVR Status register.
SREG - Реєстр стану AVR
- Біт 7 - Біт глобального включення переривань;
- Біт 6 - Біт копіювання та завантаження інструкцій;
- Біт 5 - Прапор перенесення. Виставляється після деяких арифметичних операцій;
- Біт 4 - Прапор знака числа;
- Біт 3 - Прапор доповнення до двох. Виставляється при переповненні регістрів;
- Біт 2 - Прапор негативного результату арифметичних чи логічних операцій;
- Біт 1 - Прапор нульового результату. Виставляється, якщо результат арифметичних чи логічних операцій дорівнює нулю.
- Біт 0 - Прапор перенесення. Вказує перенесення в арифметичних та логічних операціях.