Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: ассемблер MSP430
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > MSP430
andreyaa
При выполнении вычитания команда SUB ( двухбайтная) не всегда выставляет значение N
регистре статуса SR при отрицательном результат.
Пример R11=8046h
R12=0045h
SUB R11,R12

Помогите разобраться
rumit2000
Цитата(andreyaa @ Apr 19 2007, 09:00) *
При выполнении вычитания команда SUB ( двухбайтная) не всегда выставляет значение N
регистре статуса SR при отрицательном результат.
Пример R11=8046h
R12=0045h
SUB R11,R12

Помогите разобраться


тугометнация об ентой команде говорит

N: Set if result is negative, reset if positive

а каким образом Вы наблюдаете "не всегда выставляет значение N", нет ли варианта, что ошибка в методе наблюдения за N?
rezident
andreyaa, на caxapa.ru вы задавали точно такой же вопрос и получили точно такой же ответ. Сколько раз и на скольких форумах вам нужно еще продублировать, чтобы до вас дошел смысл ответов? wink.gif
Calculator
Цитата
Пример R11=8046h
R12=0045h
SUB R11,R12

Команда предполагает использование знаковых переменных. 8046h=-32698, 45h=69
тогда SUB R11,R12 означает 69-(-32698) = 32767 = 7FFFh. Число положительное, поэтому N выставляться не должен
rumit2000
Цитата(Calculator @ Apr 19 2007, 14:46) *
... Число положительное, поэтому N выставляться не должен


Думаю, что всё-таки неверная методика детектирования N, т.к. "не всегда выставляет значение N", может означать что иногда всё-таки выставляет smile.gif
Илья Литвиненко
Цитата(rumit2000 @ Apr 19 2007, 17:50) *
Думаю, что всё-таки неверная методика детектирования N, т.к. "не всегда выставляет значение N", может означать что иногда всё-таки выставляет smile.gif



Ответ неверный. Автор вопроса упустил из вида флаг V, отвечающий за переполнение. Такое ощущение, что на асме никто не пишет, либо пишет и помалкивает.

Переполнение происходит в 2 случаях:
если результат положительный при вычитании, когда оба операнда отрицательные.

если результат отрицательный при сложении, когда оба операнда положительные.

Так что после сложения/вычитания смотрим флаг V, а затем флаг N.

Удачи!
Calculator
Цитата(Илья Литвиненко @ May 10 2007, 12:03) *
Ответ неверный. Автор вопроса упустил из вида флаг V, отвечающий за переполнение. Такое ощущение, что на асме никто не пишет, либо пишет и помалкивает.

Переполнение происходит в 2 случаях:
если результат положительный при вычитании, когда оба операнда отрицательные.

если результат отрицательный при сложении, когда оба операнда положительные.

Так что после сложения/вычитания смотрим флаг V, а затем флаг N.

Удачи!

Могу только повторить, что для исходного вопроса из положительного числа вычитается отрицательное и в результате получается положительное число. Без переполнения. Не выставляются ни N, ни V
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.