Перенести флаг - Carry flag

В компьютерные процессоры то нести флаг (обычно обозначается как Флаг C) является одиночным кусочек в системе регистр статуса / flag регистр, используемый для указания, когда арифметика нести или заем был получен из наиболее значимый арифметико-логическое устройство (ALU) битовая позиция. Флаг переноса позволяет добавлять / вычитать числа, превышающие ширину одного ALU, путем переноса (добавления) двоичной цифры из частичного сложения / вычитания в младший бит положение более значимого слова. Он также используется для расширения битовые сдвиги и вращается аналогичным образом на многих процессорах (иногда через специальный Икс флаг). Для операций вычитания используются два (противоположных) соглашения, поскольку большинство машин устанавливают флаг переноса при заимствовании, в то время как некоторые машины (такие как 6502 и ПОС ) вместо этого сбрасывайте флаг переноса при заимствовании (и наоборот).

Использует

Флаг переноса зависит от результата большинства арифметических (и обычно нескольких побитовых) инструкций, а также используется в качестве входных данных для многих из них. Некоторые из этих инструкций имеют две формы, которые либо читают, либо игнорируют перенос. В языки ассемблера эти инструкции представлены мнемоника Такие как ДОБАВИТЬ / ПОДПИСАТЬСЯ, АЦП / SBC (ДОБАВИТЬ / ПОДПИСАТЬ включая перенос), SHL / SHR (битовые сдвиги ), ROL / ROR (бит вращается), RCR / RCL (вращение через перенос) и т. д.[1] Использование флага переноса таким образом позволяетслово операции сложения, вычитания, сдвига и поворота.

Примером является то, что произойдет, если сложить 255 и 255, используя 8 бит регистры. Результат должен быть 510, что является 9-битным значением. 111111110 в двоичном формате. 8 младших значащих битов, всегда хранящихся в регистре, будут 11111110 двоичный (254 десятичных), но поскольку есть перенос бита 7 (восемь битов), перенос устанавливается, указывая, что результат требует 9 бит. Действительный 9-битный результат - это соединение флага переноса с результатом.

Для x86 ALU размером 8 бит, 8-битная интерпретация дополнения до двух, операция сложения 11111111 + 11111111 приводит к 111111110, Carry_Flag набор, Знак_Флаг набор, и Overflow_Flag Чисто.

Если 11111111 представляет собой дополненное до двух целое число со знаком −1 (ДОБАВИТЬ al, -1), то интерпретация результата такова: 11111110 потому что Overflow_Flag ясно, и Carry_Flag игнорируется. Знак результата отрицательный, потому что Знак_Флаг установлен. 11111110 является дополнением до двух целого числа со знаком −2.

Если 11111111 представляет собой целое двоичное число без знака 255 (ДОБАВИТЬ al, 255), то интерпретация результата, что Carry_Flag нельзя игнорировать. В Overflow_Flag и Знак_Флаг игнорируются.

Другим примером может быть 8-битный регистр с битовым шаблоном 01010101 и установлен флаг переноса; если мы выполним повернуть влево через перенос инструкция, результат будет 10101011 с очищенным флагом переноса, потому что самый старший бит (бит 7) был повернут в перенос, а перенос был повернут в младший бит (бит 0).

Первые микропроцессоры Intel 4004 и Intel 8008 были конкретные инструкции для явной установки, а также сброса флага переноса. Однако позднее Intel 8080Z80 ) не содержал явного кода операции переноса сброса, так как это можно было сделать так же быстро с помощью одной из побитовых инструкций AND, OR или XOR (которые не используют флаг переноса).

Флаг переноса также часто используется после инструкций сравнения, которые обычно реализуются с помощью операций вычитания, чтобы позволить принять решение о том, какое из двух сравниваемых значений ниже (или больше или равно) другому. Инструкции перехода, которые проверяют флаг переноса, часто представлены мнемоника Такие как BCC и БКС для перехода, если перенос ясен, или перехода, если перенос установлен соответственно. При использовании таким образом флаг переноса обеспечивает механизм для сравнения значений как целых чисел без знака. Это в отличие от флаг переполнения который предоставляет механизм для сравнения значений как целочисленных значений со знаком.

Против. заимствовать флаг

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

Первый использует бит как флаг заимствования, устанавливая его, если а<б при вычислении аб, и заимствование должно быть выполнено. Если аб, бит сброшен. А вычесть с заимствованием (SBB) инструкция вычислит абC = а−(б+C), а вычитание без заимствования (SUB) действует так, как если бы бит заимствования был очищен. В 8080, Z80, 8051, x86[1] и 68 тыс. семьи (среди прочих) используют бит заимствования.

Второй использует идентичность, которая -Икс = нет (Икс) +1 и вычисляет аб в качестве а+ не (б) +1. Флаг переноса устанавливается в соответствии с этим дополнением, и вычесть с переносом вычисляет а+ не (б)+C, а вычитание без переноса действует так, как если бы бит переноса был установлен. В результате бит переноса устанавливается, если аб, и ясно, если а<б. В Система / 360,[2] 6502, MSP430, РУКА и PowerPC процессоры используют это соглашение. 6502 - особенно известный пример, поскольку в нем нет вычитания. без Операция переноса, поэтому программисты должны убедиться, что флаг переноса установлен перед каждой операцией вычитания, когда заимствование не требуется.

Сводка различных вариантов использования флага переноса при вычитании
Нести или
одолжить немного
Вычесть без
носить / брать в долг
Вычесть
с заимствованием
Вычесть
с переноской
C = 0аб
= а + не (б) + 1
аб0
= а + не (б) + 1
а + не (б) + 0
= аб1
C = 1аб1
= а + не (б) + 0
а + не (б) + 1
= аб0

Чаще всего первая альтернатива называется «вычитанием с заимствованием», а вторая - «вычитанием с переносом». Однако есть исключения в обоих направлениях; то VAX, NS320xx, и Atmel AVR архитектуры используют соглашение о битах заимствования, но называют их абC операция «вычесть с переносом» (SBWC, SUBC и SBC). В PA-RISC и PICmicro архитектуры используют соглашение о битах переноса, но называют их а+ не (б)+C операция «вычесть с займом» (SUBB и SUBWFB).

В ST6 / ST7 8-битные микроконтроллеры, пожалуй, самые запутанные. Хотя у них нет какой-либо инструкции «вычитание с переносом», у них есть бит переноса, который устанавливается инструкцией вычитания, и соглашение зависит от модели процессора. Процессор ST60 использует соглашение «переноса», а процессоры ST62 и ST63 - соглашение «заимствования».[3]

Смотрите также

Рекомендации

  1. ^ а б «Руководство разработчика программного обеспечения для архитектуры Intel, Том 2: Справочное руководство по набору инструкций» (PDF). Получено 2007-10-25.
  2. ^ Принципы работы IBM System / 360 (PDF). п. 28. Форма IBM A22-6821-0.
  3. ^ "Руководство по программированию семейства ST6" (PDF). Редакция 2.0. STMicroelectronics. Октябрь 2004. с. 42. Получено 2017-02-28.

внешняя ссылка