Слово (компьютерная архитектура)
Разрядность архитектуры компьютера |
---|
Кусочек |
Приложение |
с плавающей запятой Двоичная точность |
с плавающей запятой Десятичная точность |
Эта статья включает список общих ссылок , но в ней отсутствуют достаточные соответствующие встроенные цитаты . ( Июль 2023 г. ) |
В вычислениях слово — это естественная единица данных , используемая конкретной конструкцией процессора . Слово — это данные фиксированного размера , обрабатываемые как единица набором команд или аппаратными средствами процессора. Количество битов или цифр [а] в слове ( размер слова , ширина слова или длина слова ) является важной характеристикой любой конкретной конструкции процессора или архитектуры компьютера .
Размер слова отражается на многих аспектах структуры и работы компьютера; большинство регистров в процессоре обычно имеют размер слова, и самый большой объем данных, который может быть передан в рабочую память и из нее за одну операцию, - это слово во многих (не во всех) архитектурах. Максимально возможный размер адреса , используемый для обозначения места в памяти, обычно представляет собой аппаратное слово (здесь «аппаратное слово» означает полноразмерное естественное слово процессора, в отличие от любого другого используемого определения).
В документации для старых компьютеров с фиксированным размером слова обычно указываются размеры памяти в словах, а не в байтах или символах. В документации иногда правильно используются метрические префиксы , иногда с округлением, например, 65 килослов (кВт), что означает 65536 слов, а иногда используются неправильно, при этом килослов (кВт) означает 1024 слова (2 10 ) и мегаслова (MW), означающие 1 048 576 слов (2 20 ). Благодаря стандартизации 8-битных байтов и байтовой адресации указание размеров памяти в байтах, килобайтах и мегабайтах со степенью 1024, а не 1000 стало нормой, хотя некоторые используются IEC двоичные префиксы .
Некоторые из самых ранних компьютеров (а также некоторые современные) используют двоично-десятичные числа , а не простые двоичные числа , обычно имеющие размер слова 10 или 12 десятичных цифр, а некоторые ранние десятичные компьютеры вообще не имеют фиксированной длины слова. Ранние двоичные системы, как правило, использовали длину слова, кратную 6 битам, причем 36-битное слово было особенно распространено на мэйнфреймах . Внедрение ASCII привело к переходу к системам с длиной слова, кратной 8 битам, причем 16-битные машины были популярны в 1970-х годах до перехода на современные процессоры с 32 или 64 битами. [1] Конструкции специального назначения, такие как процессоры цифровых сигналов , могут иметь любую длину слова от 4 до 80 бит. [1]
Размер слова иногда может отличаться от ожидаемого из-за обратной совместимости с более ранними компьютерами. Если несколько совместимых вариантов или семейство процессоров имеют общую архитектуру и набор команд, но различаются размерами слов, их документация и программное обеспечение могут стать слишком сложными в нотации, чтобы учесть разницу (см. Семейства размеров ниже).
Использование слов
[ редактировать ]В зависимости от того, как организован компьютер, единицы размера слова могут использоваться для:
- Числа с фиксированной точкой
- Держатели для фиксированной точки , обычно целочисленных , числовых значений могут быть доступны в одном или нескольких различных размерах, но одним из доступных размеров почти всегда будет слово. Другие размеры, если таковые имеются, скорее всего, будут кратными или долями размера слова. Меньшие размеры обычно используются только для эффективного использования памяти; при загрузке в процессор их значения обычно помещаются в более крупный контейнер размером со слово.
- Числа с плавающей запятой
- Держателями числовых значений с плавающей запятой обычно являются слова или кратные им слова.
- Адреса
- Держатели адресов памяти должны иметь размер, способный выразить необходимый диапазон значений, но не быть чрезмерно большими, поэтому часто используемый размер - это слово, хотя он также может быть кратным или дробным размером слова.
- Регистры
- Регистры процессора имеют размер, соответствующий типу хранящихся в них данных, например целые числа, числа с плавающей запятой или адреса. Во многих компьютерных архитектурах используются регистры общего назначения , способные хранить данные в нескольких представлениях.
- Передача памяти-процессора
- Когда процессор считывает из подсистемы памяти регистр или записывает значение регистра в память, объем передаваемых данных часто равен слову. Исторически сложилось так, что это количество битов, которое можно было передать за один цикл, в некоторых средах также называлось катеной ( например, Bull GAMMA 60 ). [2] [3] В простых подсистемах памяти слово передается по шине данных памяти , ширина которой обычно равна слову или полуслову. В подсистемах памяти, использующих кэши , передача размером в слово осуществляется между процессором и первым уровнем кэша; на более низких уровнях иерархии памяти обычно используются более крупные передачи (которые кратны размеру слова).
- Единица разрешения адреса
- В данной архитектуре последовательные значения адреса почти [б] всегда обозначайте последовательные единицы памяти; эта единица является единицей разрешения адреса. В большинстве компьютеров единицей измерения является либо символ (например, байт), либо слово. (Некоторые компьютеры используют битовое разрешение.) Если единицей измерения является слово, то доступ к большему объему памяти можно получить, используя адрес заданного размера, за счет дополнительной сложности доступа к отдельным символам. С другой стороны, если единицей измерения является байт, то можно адресовать отдельные символы (т.е. выбирать их во время операции с памятью).
- Инструкции
- Машинные инструкции обычно имеют размер слова архитектуры, например, в RISC-архитектуре , или кратны размеру «char», который является его частью. Это естественный выбор, поскольку инструкции и данные обычно используют одну и ту же подсистему памяти. В гарвардских архитектурах размеры слов инструкций и данных не обязательно должны быть связаны, поскольку инструкции и данные хранятся в разной памяти; например, процессор электронного телефонного коммутатора 1ESS имеет 37-битные инструкции и 23-битные слова данных.
Выбор размера слова
[ редактировать ]При проектировании архитектуры компьютера выбор размера слова имеет существенное значение. Существуют конструктивные соображения, которые поощряют определенные размеры битовых групп для конкретных применений (например, для адресов), и эти соображения указывают на разные размеры для разных применений. Однако соображения экономии при проектировании настоятельно требуют использования одного размера или нескольких размеров, связанных кратными или дробными числами (дольными числами) с основным размером. Этот предпочтительный размер становится размером слова архитектуры.
символа В прошлом размер ( кодирование символов до переменного размера ) влиял на разрешение единицы измерения адреса и выбор размера слова. До середины 1960-х годов символы чаще всего хранились в шести битах; это позволяло использовать не более 64 символов, поэтому алфавит был ограничен прописными буквами. Поскольку с точки зрения времени и пространства эффективно иметь размер слова, кратный размеру символа, размеры слов в этот период обычно были кратны 6 битам (в двоичных машинах). В то время распространенным выбором было 36-битное слово , которое также является подходящим размером для числовых свойств формата с плавающей запятой.
После внедрения дизайна IBM System/360 , в котором используются восьмибитные символы и поддерживаются строчные буквы, стандартный размер символа (точнее, байта ) становится восемь бит. После этого размеры слов, естественно, кратны восьми битам, при этом обычно используются 16, 32 и 64 бита.
Архитектуры с переменным словом
[ редактировать ]Ранние конструкции машин включали в себя некоторые, в которых использовалось то, что часто называют переменной длиной слова . В этом типе организации операнд не имеет фиксированной длины. В зависимости от машины и инструкции длина может обозначаться полем счета, символом-разделителем или дополнительным битом, называемым, например, флагом или словесным знаком . Такие машины часто используют двоично-десятичные числа в виде 4-битных цифр или 6-битных символов для чисел. К этому классу машин относятся IBM 702 , IBM 705 , IBM 7080 , IBM 7010 , UNIVAC 1050 , IBM 1401 , IBM 1620 и RCA 301.
Большинство этих машин одновременно работают с одной единицей памяти, и поскольку каждая инструкция или данные имеют длину в несколько единиц, каждой инструкции требуется несколько циклов только для доступа к памяти. Из-за этого эти машины часто работают довольно медленно. Например, выборка инструкций на модели IBM 1620 Model I занимает 8 циклов (160 мкс) только для чтения 12 цифр инструкции (Модель II сократила это время до 6 циклов или 4 циклов, если команде не требовались оба поля адреса). . Выполнение инструкции занимает разное количество циклов, в зависимости от размера операндов.
Словесная, битовая и байтовая адресация
[ редактировать ]Модель памяти архитектуры сильно зависит от размера слова. В частности, в качестве слова часто выбиралось разрешение адреса памяти, то есть наименьшая единица, которую можно обозначить адресом. В этом подходе, машинном подходе с пословной адресацией , значения адресов, отличающиеся на единицу, обозначают соседние слова памяти. Это естественно для машин, которые почти всегда работают с единицами слов (или нескольких слов), и имеет то преимущество, что позволяет инструкциям использовать поля минимального размера для хранения адресов, что может позволить использовать меньший размер инструкций или большее разнообразие инструкций.
Когда обработка байтов должна составлять значительную часть рабочей нагрузки, обычно более выгодно использовать байт , а не слово, в качестве единицы разрешения адреса. Значения адреса, отличающиеся на единицу, обозначают соседние байты в памяти. Это позволяет напрямую обращаться к произвольному символу в строке символов. К слову все еще можно адресовать, но для используемого адреса требуется несколько больше битов, чем при альтернативном разрешении слов. Размер слова должен быть целым числом, кратным размеру символа в этой организации. Этот подход к адресации использовался в IBM 360 и с тех пор стал наиболее распространенным подходом в машинах.
Когда рабочая нагрузка включает обработку полей разного размера, может быть выгодно обратиться к биту. Машины с битовой адресацией могут иметь некоторые инструкции, использующие размер байта, определенный программистом, и другие инструкции, которые работают с фиксированными размерами данных. Например, на IBM 7030. [4] («Растянуть»), инструкция с плавающей запятой может адресовать только слова, тогда как инструкция целочисленной арифметики может указывать длину поля от 1 до 64 бит, размер байта от 1 до 8 бит и смещение аккумулятора от 0 до 127 бит.
В машине с байтовой адресацией и инструкциями «хранилище-хранилище» (SS) обычно имеются инструкции перемещения для копирования одного или нескольких байтов из одного произвольного места в другое. В байт-ориентированной ( с байтовой адресацией ) машине без инструкций SS перемещение одного байта из одного произвольного места в другое обычно происходит:
- ЗАГРУЗИТЬ исходный байт
- СОХРАНИТЬ результат обратно в целевой байт
Доступ к отдельным байтам на текстово-ориентированной машине можно получить одним из двух способов. Байтами можно манипулировать с помощью комбинации операций сдвига и маски в регистрах. Для перемещения одного байта из одного произвольного места в другое может потребоваться эквивалент следующего:
- ЗАГРУЗИТЬ слово, содержащее исходный байт
- СДВИГАЙТЕ исходное слово, чтобы выровнять нужный байт в правильном положении в целевом слове.
- И исходное слово с маской для обнуления всех битов, кроме нужных
- ЗАГРУЗИТЬ слово, содержащее целевой байт
- И целевое слово с маской для обнуления целевого байта
- ИЛИ регистры, содержащие исходное и целевое слова для вставки исходного байта
- СОХРАНИТЬ результат обратно в целевое местоположение
В качестве альтернативы многие машины, ориентированные на слова, реализуют операции с байтами с помощью инструкций, использующих специальные указатели на байты в регистрах или памяти. Например, указатель байта PDP-10 содержал размер байта в битах (что позволяло осуществлять доступ к байтам разного размера), битовую позицию байта в слове и адрес слова данных. Инструкции могут автоматически корректировать указатель на следующий байт, например, при операциях загрузки и внесения (сохранения).
Полномочия двух
[ редактировать ]Для хранения значений данных с разной степенью точности используются разные объемы памяти. Обычно используемые размеры обычно представляют собой степень кратной двум , кратную единице разрешения адреса (байт или слово), . Преобразование индекса элемента массива в смещение адреса памяти этого элемента требует только операции сдвига, а не умножения. В некоторых случаях это соотношение также позволяет избежать использования операций деления. В результате размеры слов большинства современных компьютеров (и размеров других операндов) в два раза превышают размер байта.
Размер семьи
[ редактировать ]Поскольку компьютерные конструкции стали более сложными, центральная важность размера одного слова для архитектуры уменьшилась. Хотя более мощное оборудование может использовать более широкий диапазон размеров данных, рыночные силы оказывают давление на сохранение обратной совместимости при одновременном расширении возможностей процессора. В результате то, что могло быть центральным размером слова в новом проекте, должно сосуществовать как альтернативный размер исходному размеру слова в обратно совместимом дизайне. Исходный размер слова остается доступным в будущих проектах, образуя основу семейства размеров.
В середине 1970-х годов компания DEC разработала VAX как 32-битного преемника 16-битного PDP-11 . Они использовали слово для обозначения 16-битной величины, а длинное слово — для 32-битной величины; эта терминология такая же, как терминология, используемая для PDP-11. В этом отличие от более ранних машин, где естественная единица адресации памяти называлась словом , а величина, равная половине слова, называлась полусловом . В соответствии с этой схемой четверное слово VAX имеет длину 64 бита. Они продолжили эту терминологию из 16-битных слов, 32-битных длинных слов и 64-битных четверных слов в 64-битной Alpha .
Другим примером является семейство x86 , в котором выпущены процессоры с тремя разными длинами слов (16-разрядными, позднее 32- и 64-разрядными), при этом слово продолжает обозначать 16-разрядную величину. Поскольку программное обеспечение обычно переносится с одной длины слова на другую, некоторые API и документация определяют или ссылаются на более старую (и, следовательно, более короткую) длину слова, чем полная длина слова на ЦП, для которого программное обеспечение может быть скомпилировано. Кроме того, подобно тому, как байты используются для небольших чисел во многих программах, более короткое слово (16 или 32 бита) может использоваться в контекстах, где диапазон более широкого слова не требуется (особенно там, где это может сэкономить значительное пространство стека или кэша). пространство памяти). Например, Windows API от Microsoft поддерживает языка программирования определение WORD как 16-битное, несмотря на то, что API может использоваться на 32- или 64-битном процессоре x86, где стандартный размер слова будет 32 или 64 бита соответственно. . Структуры данных, содержащие слова такого разного размера, относятся к ним как:
- СЛОВО (16 бит/2 байта)
- DWORD (32 бита/4 байта)
- QWORD (64 бита/8 байтов)
Аналогичное явление возникло в Intel x86 языке ассемблера : из-за поддержки различных размеров (и обратной совместимости) в наборе команд некоторые мнемоники инструкций имеют идентификаторы «d» или «q», обозначающие «двойной», «четверной». или «дабл-квадрат», которые соответствуют исходному 16-битному размеру слова архитектуры.
Примером другого размера слова является семейство IBM System/360 . В архитектуре System/360 , архитектуре System/370 и архитектуре System/390 имеются 8-битные байты , 16-битные полуслова , 32-битные слова и 64-битные двойные слова. z /Architecture , который является 64-битным членом этого семейства архитектур, продолжает ссылаться на 16-битные полуслова , 32-битные слова и 64-битные двойные слова, а также дополнительно имеет 128-битные четверные слова.
Как правило, новые процессоры должны использовать ту же длину слов данных и ширину виртуальных адресов, что и старый процессор, чтобы иметь двоичную совместимость с этим старым процессором.
Часто тщательно написанный исходный код, написанный с учетом совместимости исходного кода и переносимости программного обеспечения , можно перекомпилировать для работы на различных процессорах, даже с разной длиной слова данных или разной шириной адреса, или и тем, и другим.
Таблица размеров слов
[ редактировать ]ключ: бит: биты , c : символы, d: десятичные цифры , w : размер слова архитектуры, n : переменный размер, wm: словесный знак | |||||||
---|---|---|---|---|---|---|---|
Год | Компьютер архитектура | Слово размер В | Целое число размеры | Плавающий точка размеры | Инструкция размеры | Единица адрес разрешение | Чар размер |
1837 | Бэббидж Аналитическая машина | 50 дней | В | — | Для разных функций использовались пять разных карт, точный размер карт неизвестен. | В | — |
1941 | Цузе Z3 | 22 бит | — | В | 8 бит | В | — |
1942 | АВС | 50 бит | В | — | — | — | — |
1944 | Гарвард Марк I | 23 д. | В | — | 24 бит | — | — |
1946 (1948) {1953} | ЭНИАК (с панелью №16 [5] ) {с панелью № 26 [6] } | 10 дней | Вт , 2 Вт (В) {В} | — | — (2 д, 4 д, 6 д, 8 д) {2 д, 4 д, 6 д, 8 д} | — — {В} | — |
1948 | Манчестер Бэби | 32 бит | В | — | В | В | — |
1951 | УНИВАК I | 12 дней | В | — | 1 ⁄ 2 w | В | 1 день |
1952 | машина ИАС | 40 бит | В | — | 1 ⁄ 2 w | В | 5 бит |
1952 | Быстрый универсальный цифровой компьютер М-2 | 34 бит | В? | В | 34 бита = 4-битный код операции плюс 3×10-битный адрес. | 10 бит | — |
1952 | ИБМ 701 | 36 бит | 1 ⁄ 2 Вт , Вт | — | 1 ⁄ 2 w | 1 ⁄ 2 Вт , Вт | 6 бит |
1952 | УНИВАК 60 | н д | 1 д, ... 10 д | — | — | — | 2 д, 3 д |
1952 | АРРА I | 30 бит | В | — | В | В | 5 бит |
1953 | ИБМ 702 | н с | 0 с, ... 511 с | — | 5 с | с | 6 бит |
1953 | УНИВАК 120 | н д | 1 д, ... 10 д | — | — | — | 2 д, 3 д |
1953 | АРРА II | 30 бит | В | 22 Вт | 1 ⁄ 2 w | В | 5 бит |
1954 (1955) | ИБМ 650 (с IBM 653 ) | 10 дней | В | — (В) | В | В | 2 дня |
1954 | ИБМ 704 | 36 бит | В | В | В | В | 6 бит |
1954 | ИБМ 705 | н с | 0 с, ... 255 с | — | 5 с | с | 6 бит |
1954 | IBM НОРК | 16 дней | В | Вт , 2 Вт | В | В | — |
1956 | ИБМ 305 | н д | 1 д, ... 100 д | — | 10 дней | д | 1 день |
1956 | ЦЕЛЬ | 34 бит | В | В | 1 ⁄ 2 w | В | 5 бит, 6 бит |
1956 | ЛГП-30 | 31 бит | В | — | 16 бит | В | 6 бит |
1958 | УНИВАК II | 12 дней | В | — | 1 ⁄ 2 w | В | 1 день |
1958 | МУДРЕЦ | 32 бит | 1 ⁄ 2 w | — | В | В | 6 бит |
1958 | Автонетика Рекомп II | 40 бит | ш , 79 бит, 8 д, 15 д | 22 Вт | 1 ⁄ 2 w | 1 ⁄ 2 Вт , Вт | 5 бит |
1958 | ЗЕБРА | 33 бит | ш , 65 бит | 2 Вт | В | В | 5 бит |
1958 | Сетунь | 6 trit (~9.5 bits) [с] | до 6 попыток | до 3 попыток | 4 шага ? | ||
1958 | Электрологика X1 | 27 бит | В | 22 Вт | В | В | 5 бит, 6 бит |
1959 | ИБМ 1401 | н с | 1с, ... | — | 1 в, 2 в, 4 в, 5 в, 7 в, 8 в | с | 6 бит + WM |
1959 (подлежит уточнению) | ИБМ 1620 | н д | 2 д, ... | — (4 д, ... 102 д) | 12 дней | д | 2 дня |
1960 | ЛАРК | 12 дней | Вт , 2 Вт | Вт , 2 Вт | В | В | 2 дня |
1960 | ЦКД 1604 | 48 бит | В | В | 1 ⁄ 2 w | В | 6 бит |
1960 | ИБМ 1410 | н с | 1с, ... | — | 1 в, 2 в, 6 в, 7 в, 11 в, 12 в | с | 6 бит + WM |
1960 | ИБМ 7070 | 10 дней [д] | з , 1-9 д | В | В | ш , д | 2 дня |
1960 | ПДП-1 | 18 бит | В | — | В | В | 6 бит |
1960 | Эллиотт 803 | 39 бит | |||||
1961 | ИБМ 7030 (Потягиваться) | 64 бит | 1 бит, ... 64 бит, 1 д, ... 16 д | В | 1 ⁄ 2 Вт , Вт | бит (целое число), 1 ⁄ 2 ш (ветвь), w (плавающее) | 1 бит, ... 8 бит |
1961 | ИБМ 7080 | н с | 0 с, ... 255 с | — | 5 с | с | 6 бит |
1962 | ГЭ-6хх | 36 бит | Вт , 2 Вт | Вт , 2 Вт , 80 бит | В | В | 6 бит, 9 бит |
1962 | УНИВАК III | 25 бит | ш , 2д , 3д , 4д , 6д, 12д | — | В | В | 6 бит |
1962 | Автонетика Д-17Б Minuteman I Компьютер управления | 27 бит | 11 бит, 24 бита | — | 24 бит | В | — |
1962 | УНИВАК 1107 | 36 бит | 1 ⁄ 6 w , 1 ⁄ 3 w , 1 ⁄ 2 Вт , Вт | В | В | В | 6 бит |
1962 | ИБМ 7010 | н с | 1с, ... | — | 1 в, 2 в, 6 в, 7 в, 11 в, 12 в | с | 6б+шм |
1962 | ИБМ 7094 | 36 бит | В | Вт , 2 Вт | В | В | 6 бит |
1962 | СДС 9 серии | 24 бит | В | 22 Вт | В | В | |
1963 (1966) | Компьютер управления Аполлоном | 15 бит | В | — | Вт , 2 Вт | В | — |
1963 | Цифровой компьютер ракеты-носителя Сатурн | 26 бит | В | — | 13 бит | В | — |
1964/ 1966 | ПДП-6 / ПДП-10 | 36 бит | В | Вт , 2 Вт | В | В | 6 бит 7 бит (типично) 9 бит |
1964 | Титан | 48 бит | В | В | В | В | В |
1964 | КДЦ 6600 | 60 бит | В | В | 1 ⁄ 4 w , 1 ⁄ 2 w | В | 6 бит |
1964 | Автонетика Д-37С Minuteman II Компьютер управления | 27 бит | 11 бит, 24 бита | — | 24 бит | В | 4 бит, 5 бит |
1965 | Компьютер управления Gemini | 39 бит | 26 бит | — | 13 бит | 13 бит, 26 | -кусочек |
1965 | ИБМ 1130 | 16 бит | ш , 2ш | 2 Вт , 3 Вт | ш , 2ш | В | 8 бит |
1965 | IBM Система/360 | 32 бит | 1 ⁄ 2 ш , ш , 1 д, ... 16 д | Вт , 2 Вт | 1 ⁄ 2 ж , ш , 1 1 ⁄ 2 w | 8 бит | 8 бит |
1965 | УНИВАК 1108 | 36 бит | 1 ⁄ 6 w , 1 ⁄ 4 w , 1 ⁄ 3 w , 1 ⁄ 2 нед , ш , 2 нед | Вт , 2 Вт | В | В | 6 бит, 9 бит |
1965 | ПДП-8 | 12 бит | В | — | В | В | 8 бит |
1965 | Электрологика X8 | 27 бит | В | 22 Вт | В | В | 6 бит, 7 бит |
1966 | СДС Сигма 7 | 32 бит | 1 ⁄ 2 Вт , Вт | Вт , 2 Вт | В | 8 бит | 8 бит |
1969 | Четырехфазные системы AL1 | 8 бит | В | — | ? | ? | ? |
1970 | МП944 | 20 бит | В | — | ? | ? | ? |
1970 | ПДП-11 | 16 бит | В | 2 Вт , 4 Вт | Вт , 2 Вт , 3 Вт | 8 бит | 8 бит |
1971 | КДЦ СТАР-100 | 64 бит | 1 ⁄ 2 Вт , Вт | 1 ⁄ 2 Вт , Вт | 1 ⁄ 2 Вт , Вт | кусочек | 8 бит |
1971 | ТМС1802NC | 4 бита | В | — | ? | ? | — |
1971 | Интел 4004 | 4 бита | ш , д | — | 2 Вт , 4 Вт | В | — |
1972 | Интел 8008 | 8 бит | ш , 2 д | — | Вт , 2 Вт , 3 Вт | В | 8 бит |
1972 | Калкомп 900 | 9 бит | В | — | Вт , 2 Вт | В | 8 бит |
1974 | Интел 8080 | 8 бит | ш , 2 ж , 2 д | — | Вт , 2 Вт , 3 Вт | В | 8 бит |
1975 | ИЛЛИАК IV | 64 бит | В | В , 1 ⁄ 2 w | В | В | — |
1975 | Моторола 6800 | 8 бит | ш , 2 д | — | Вт , 2 Вт , 3 Вт | В | 8 бит |
1975 | МОС Тех. 6501 МОС Тех. 6502 | 8 бит | ш , 2 д | — | Вт , 2 Вт , 3 Вт | В | 8 бит |
1976 | Крей-1 | 64 бит | 24 бит, Вт | В | 1 ⁄ 4 w , 1 ⁄ 2 w | В | 8 бит |
1976 | Зилог Z80 | 8 бит | ш , 2 ж , 2 д | — | ш , 2 нед , 3 нед , 4 нед , 5 нед | В | 8 бит |
1978 (1980) | 16-битный x86 ( Intel 8086 ) (с плавающей точкой: Intel 8087 ) | 16 бит | 1 ⁄ 2 нед , ш , 2 д | — (2н , 4н , 5н , 17д) | 1 ⁄ дюйма дюйма , , ... 7 дюймов | 8 бит | 8 бит |
1978 | ВАКС | 32 бит | 1 ⁄ 4 w , 1 ⁄ 2 ш , ш , 1 д, ... 31 д, 1 бит, ... 32 бит | Вт , 2 Вт | 1 ⁄ 4 w , ... 14 1 ⁄ 4 w | 8 бит | 8 бит |
1979 (1984) | Моторола серии 68000 (с плавающей точкой) | 32 бит | 1 ⁄ 4 w , 1 ⁄ 2 нед , ш , 2 д | — ( ш , 2 ш , 2 1 ⁄ 2 w ) | 1 ⁄ 2 ж , ш , ... 7 1 ⁄ 2 w | 8 бит | 8 бит |
1985 | IA-32 ( Intel 80386 ) (с плавающей запятой) | 32 бит | 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт | — ( ш , 2 ш , 80 бит) | 8 бит, ... 120 бит 1 ⁄ 4 w ... 3 3 ⁄ 4 w | 8 бит | 8 бит |
1985 | ARMv1 | 32 бит | 1 ⁄ 4 дюйма , v | — | В | 8 бит | 8 бит |
1985 | МИПС I | 32 бит | 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт | Вт , 2 Вт | В | 8 бит | 8 бит |
1991 | Крей C90 | 64 бит | 32 бит, Вт | В | 1 ⁄ 4 w , 1 ⁄ 2 Вт , 48 бит | В | 8 бит |
1992 | Альфа | 64 бит | 8 бит, 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт | 1 ⁄ 2 Вт , Вт | 1 ⁄ 2 w | 8 бит | 8 бит |
1992 | PowerPC | 32 бит | 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт | Вт , 2 Вт | В | 8 бит | 8 бит |
1996 | ARMv4 (с большим пальцем ) | 32 бит | 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт | — | В ( 1 ⁄ 2 дюйма , дюйма ) | 8 бит | 8 бит |
2000 | IBM z/Архитектура | 64 бит [и] | 8 бит, 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт 1 д, ... 31 д | 1 ⁄ 2 нед , ш , 2 нед | 1 ⁄ 4 w , 1 ⁄ 2 w , 3 ⁄ 4 w | 8 бит | 8 бит, UTF-16 , UTF-32 |
2001 | ИА-64 | 64 бит | 8 бит, 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт | 1 ⁄ 2 Вт , Вт | 41 бит (в пакетах 128 бит) [7] | 8 бит | 8 бит |
2001 | ARMv6 (с ВФП) | 32 бит | 8 бит, 1 ⁄ 2 Вт , Вт | — (ж, 2ж) | 1 ⁄ 2 Вт , Вт | 8 бит | 8 бит |
2003 | х86-64 | 64 бит | 8 бит, 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт | 1 ⁄ 2 Вт , Вт , 80 бит | 8 бит, ... 120 бит | 8 бит | 8 бит |
2013 | ARMv8-A и ARMv9-A | 64 бит | 8 бит, 1 ⁄ 4 w , 1 ⁄ 2 Вт , Вт | 1 ⁄ 2 Вт , Вт | 1 ⁄ 2 w | 8 бит | 8 бит |
Год | Компьютер архитектура | Слово размер В | Целое число размеры | Плавающий точка размеры | Инструкция размеры | Единица адрес разрешение | Чар размер |
ключ: бит: биты , c : символы, d: десятичные цифры , w : размер слова архитектуры, n : переменный размер, wm: словесный знак |
См. также
[ редактировать ]Примечания
[ редактировать ]- ^ Многие ранние компьютеры были десятичными , а некоторые — троичными.
- ^ UNIVAC 1005 обращается к ядру, используя 5-битные коды Грея для строки и столбца.
- ^ Битовый эквивалент вычисляется путем взятия количества информационной энтропии, предоставляемой тритом, который равен . Это дает эквивалент примерно 9,51 бит для 6 тритов.
- ^ Знак трех государств
- ^ Хотя z/Architecture по своей сути является 64-битной архитектурой, термин «слово» по-прежнему относится к 32-битной величине. Однако в этой таблице размеры рассматриваются так, как если бы слово было 64-битным.
Ссылки
[ редактировать ]- ^ Перейти обратно: а б Биб, Нельсон ХФ (22 августа 2017 г.). «Глава I. Целочисленная арифметика». Справочник по математическим вычислениям - Программирование с использованием портативной библиотеки программного обеспечения MathCW (1-е изд.). Солт-Лейк-Сити, Юта, США: Springer International Publishing AG . п. 970. дои : 10.1007/978-3-319-64110-2 . ISBN 978-3-319-64109-6 . LCCN 2017947446 . S2CID 30244721 .
- ^ Дрейфус, Филипп (8 мая 1958 г.) [6 мая 1958 г.]. Написано в Лос-Анджелесе, Калифорния, США. Системный дизайн Gamma 60 (PDF) . Западная объединенная компьютерная конференция : Контрасты в компьютерах. ACM, Нью-Йорк, штат Нью-Йорк, США. стр. 130–133. IRE-ACM-AIEE '58 (вестерн). Архивировано (PDF) из оригинала 3 апреля 2017 г. Проверено 3 апреля 2017 г.
[...] Используется внутренний код данных: Количественные (числовые) данные кодируются 4-битным десятичным кодом; качественные (буквенно-цифровые) данные кодируются 6-битным буквенно-цифровым кодом. Внутренний код инструкции означает, что инструкции закодированы в прямом двоичном коде.
Что касается внутренней длины информации, то информационный квант называется « катеной » и состоит из 24 битов, представляющих либо 6 десятичных цифр, либо 4 буквенно-цифровых символа. Этот квант должен содержать разряды, кратные 4 и 6, чтобы представлять целое число десятичных или буквенно-цифровых символов. Двадцать четыре бита оказались хорошим компромиссом между минимальными 12 битами, которые привели бы к слишком низкому потоку передачи из базовой памяти параллельного считывания, и 36 битами или более, что было сочтено слишком большим квантом информации. Катену следует рассматривать как эквивалент символа в машинах с переменной длиной слова, но ее нельзя называть так, поскольку она может содержать несколько символов. Он передается последовательно в основную память и обратно.
Не желая называть «квант» словом, а набор символов буквой (слово — это слово, а квант — это нечто иное), было создано новое слово, и оно получило название «катена». Это английское слово, оно существует в Webster's , хотя его нет во французском языке. Вебстер определяет слово катена как «связная серия»; следовательно, 24-битный информационный элемент. В дальнейшем будет использоваться слово катена.
Таким образом, внутренний код определен. Каковы же коды внешних данных? Они зависят в первую очередь от используемого устройства обработки информации. Gamma 60 предназначен для обработки информации, относящейся к любой двоично-кодированной структуре. Таким образом, перфокарта с 80 столбцами рассматривается как 960-битный элемент информации; 12 строк, умноженные на 80 столбцов, равняются 960 возможным ударам; хранится в виде точного изображения в 960 магнитных сердечниках основной памяти с двумя столбцами карточек, занимающими одну катену. [...] - ^ Блаау, Геррит Энн ; Брукс-младший, Фредерик Филлипс ; Бухгольц, Вернер (1962). «4: Естественные единицы данных» (PDF) . В Бухгольце, Вернер (ред.). Планирование компьютерной системы – расширенный проект . McGraw-Hill Book Company, Inc. / The Maple Press Company, Йорк, Пенсильвания. стр. 39–40. LCCN 61-10466 . Архивировано (PDF) из оригинала 3 апреля 2017 г. Проверено 3 апреля 2017 г.
[...] Термины, используемые здесь для описания структуры, заданной конструкцией машины, помимо бита , перечислены ниже.
Байт обозначает группу битов, используемых для кодирования символа, или количество битов, передаваемых параллельно к блокам ввода-вывода и от них. термин, отличный от символа Здесь используется , поскольку данный символ может быть представлен в разных приложениях более чем одним кодом, а разные коды могут использовать разное количество битов (т. е. разные размеры байтов). При передаче ввода-вывода группировка битов может быть совершенно произвольной и не иметь никакого отношения к реальным символам. (Термин произошел от укуса , но был изменен во избежание случайной мутации на бит .)
Слово . состоит из количества битов данных, передаваемых параллельно из или в память за один цикл памяти Таким образом, размер слова определяется как структурное свойство памяти. (Термин катена был придуман для этой цели разработчиками компьютера Bull GAMMA 60 ).
Блок относится к количеству слов, передаваемых в или из блока ввода-вывода в ответ на одну команду ввода-вывода. Размер блока — структурное свойство блока ввода-вывода; оно могло быть исправлено в проекте или оставлено для изменения в программе. [...] - ^ «Формат» (PDF) . Справочное руководство 7030 Система обработки данных (PDF) . ИБМ. Август 1961. стр. 50–57 . Проверено 15 декабря 2021 г.
- ^ Клиппингер, Ричард Ф. [на немецком языке] (29 сентября 1948 г.). «Система логического кодирования, примененная к ENIAC (электронный числовой интегратор и компьютер)» . Абердинский полигон, Мэриленд, США: Лаборатории баллистических исследований . Отчет № 673; Проект № ТБ3-0007 Отдела исследований и разработок Управления боеприпасов . Проверено 05 апреля 2017 г.
- ^ Клиппингер, Ричард Ф. [на немецком языке] (29 сентября 1948 г.). «Система логического кодирования, примененная к ENIAC» . Абердинский полигон, Мэриленд, США: Лаборатории баллистических исследований . Раздел VIII: Модифицированный ENIAC . Проверено 05 апреля 2017 г.
- ^ «4. Форматы инструкций» (PDF) . Руководство разработчика программного обеспечения для архитектуры Intel Itanium . Том. 3: Справочник по набору инструкций Intel Itanium. п. 3:293 . Проверено 25 апреля 2022 г.
Три инструкции сгруппированы в 128-битные и выровненные контейнеры, называемые пакетами . Каждый пакет содержит три 41-битных слота инструкций и 5-битное поле шаблона.
- ^ Блаау, Геррит Энн ; Брукс-младший, Фредерик Филлипс (1997). Компьютерная архитектура: концепции и эволюция (1-е изд.). Аддисон-Уэсли . ISBN 0-201-10557-8 . (1213 страниц) (Примечание. Это однотомное издание. Эта работа также доступна в двухтомной версии.)
- ^ Ралстон, Энтони; Рейли, Эдвин Д. (1993). Энциклопедия информатики (3-е изд.). Ван Ностранд Рейнхольд . ISBN 0-442-27679-6 .