Intel 80386 (также известный как i386 или просто 386) — 32-битный x86-совместимый процессор третьего поколения фирмы Intel выпущенный 17 октября 1985 года. Данный процессор был первым 32-разрядным процессором для IBM PC-совместимых ПК. Применялся, преимущественно, в настольных ПК и портативных ПК (ноутбуки и лэптопы).
Оглавление документа
- Описание
- 32 бита
- Страничное преобразование
- Улучшенная поддержка многозадачности и защиты
- Виртуальный режим
- Аппаратная отладка
- Пошаговое выполнение
- Точки прерывания
- Ловушка переключения задачи
- Другие изменения
- Регистры
- Набор инструкции
- Сопроцессор
- Модели
- 386DX
- 386SX
- 386SL
- 386EX
- Компьютеры на базе процессора Intel 80386
- 🔍 Видео
Видео:Как работает компьютер? Шины адреса, управления и данных. Дешифрация. Взгляд изнутри!Скачать
Описание
Процессор i386 полностью совместим со своими предшественниками — процессорами 80 86–802 86. Он выполняет программы, предназначенные для них без необходимости модификации кода и перекомпиляции (или с минимальными модификациями) и делает это более эффективно:
- затрачивает на выполнение меньшее число тактов синхронизации
- имеет более высокие тактовые частоты, за счет использования новых технологий
- имеет увеличенный, по сравнению с предыдущими процессорами буфер предвыборки команд — 16 байт (которых хватает примерно на пять команд); буфер предвыборки обеспечивает меньшее количество обращений за командами и исключает лишние обращения в память в коротких циклах и выполнении строковых команд
- первым из процессоров x86 имеет встроенную кэш-память, обеспечивающую меньшее количество обращений в память при последовательном чтении и данных, а также обращении к одним и тем же данным
Вместе с тем i386 является серьезной переработкой процессора 80286. По некоторым оценкам, ни до, ни после i386, архитектура процессоров x86 ни разу не переделывались столь кардинально. Современные операционные системы называют аппаратную платформу PC-совместимых компьютеров никак не иначе как «i386», потому что не способны работать на процессорах ниже этого.
Изобретение процессоров Intel 80386 и Intel 80286 было большим шагом в улучшении архитектуры и производительности процессоров фирмы Intel, сейчас эти процессоры морально устарели и в основном используются в контроллерах, а так же в бытовой технике.
Основные изменения:
32 бита
Вся архитектура x86 была расширена до 32 бит — все регистры (за исключением сегментных) стали 32-битными, получив в названии префикс «E» (EAX, EBX, EIP, EFLAGS и т. п.), с сохранением полного набора команд для работы с ними. В том числе:
- регистр флагов, получивший множество новых флагов для управления многозадачностью
- регистр управления процессором MSW процессора 80286, названный в i386 «CR0»
32-битной стала и адресация в защищенном режиме (с возможностью создания 16-битных сегментов, для совместимости с 80286). Она позволила, впервые со времени появления 8086 забыть о сегментации, а точнее ограничении размера сегмента 64 килобайтами (ограничение 16-битного адреса), которое давно перестало устраивать программистов.
До появления i386 программы и операционные системы использовали несколько головоломных моделей организации памяти (крохотная — tiny, малая — small, большая — large, огромная — huge), различающихся по организации в памяти сегментов кода стека и данных. 32-битный адрес позволил использовать вместо них одну простую плоскую модель (англ. flat) — 32-битный вариант крохотной модели, в которой все сегменты задачи находятся в одном и том же месте адресного пространства памяти. Плоская модель обеспечивает размер такого «общего» сегмента до 4 гигабайт, которых хватает для любой мыслимой задачи.
Плоская модель имеет и недостатки:
- в ней появляются проблемы перемещаемости машинного кода, которые ранее легко обходились сегментацией, обеспечение перемещаемости легло на плечи операционных систем, с новыми форматами дискового образа программы.
- плоская модель, практически, сводит на нет управление памятью в защищенном режиме (ограничение доступа и поддержка виртуальной памяти), которое до i386 могло выполняться только на уровне сегментации. Только появление новой модели управления памятью — страничного преобразования, обеспечило плоской модели ее сегодняшнюю популярность.
Плоская модель вошла в обиход столь широко, что современные программисты, зачастую, и не подозревают что программы обращаются в память через сегменты.
Страничное преобразование
В i386 был введен новый механизм управления памятью — адресное пространство, к которому обращается процессор за данными и кодом, в котором располагаются сегменты (названное линейным адресным пространством) может не соответствовать реальной физической памяти. Физическая память (включая буферы внешних устройств, например видеобуфер) может быть отображена в линейное адресное пространство произвольным образом — каждая страница (размером 4 килобайта) линейного пространства может быть переадресована на любую страницу физической памяти через каталог страниц, располагающийся в оперативной памяти (адрес каталога страниц определяется значением нового регистра управления «CR3»).
Читайте также: Размерность шин рено сандеро степвей 2019
Как и сегменты, страницы линейного адресного пространства могут быть объявлены неприсутствующими (обращение к таким страницам вызывает обработчик страничного нарушения операционной системы). Неприсутствующие страницы, в первую очередь, используются, для организации виртуальной памяти — обработчик страничного нарушения осуществляет свопинг страниц памяти с внешними запоминающими устройствами. Также, неприсутствующие страницы используются в плоской модели памяти (где размер сегмента обычно имеет размер от 2 до 4 гигабайт, даже если у компьютера не имеется столько физической памяти) для маркировки страниц сегмента, в которые операционная система не выделила памяти. В этом случае, страничное нарушение, обычно, завершает задачу или начинает ее отладку.
Через страничное преобразование i386 может адресовать до 4 Гбайт физической памяти и до 64 Тбайт виртуальной памяти.
Улучшенная поддержка многозадачности и защиты
Поддержка многозадачности в процессорах x86 обозначает аппаратную поддержку «прозрачного» переключения с одной обычной программы (задачи) на другую. При переключении процессор сохраняет свое состояние (включая адрес следующей команды, селекторы сегментов) в сегменте состояния (TSS; сегмент памяти, с селектором из регистра TR) одной задачи, после чего восстанавливает состояние другой задачи из ее сегмента состояния (селектор сегмента состояния новой задачи загружается из дескриптора ее сегмента кода).
Переключение между задачами обычно осуществляется:
- прерыванием таймера; время, на которое настроен таймер, называется квантом времени для задачи
- системным вызовом (вызовом функции операционной системы)
- исключением — например, при попытке выполнить недопустимую команду или обращении к неприсутствующей памяти
- отладкой
В i386 механизмы защиты и многозадачности были значительно расширены и улучшены. В зависимости от характера нарушений, они могут тихо игнорироваться (например, некоторые биты регистра EFLAGS нельзя изменить загрузкой флагов из стека), вызывать обработчик исключения (операционной системы). Серьезные ошибки на уровне операционной системы (или в реальном режиме) могут привести процессор в режим аварийного останова (например, при нарушении в обработчике двойного нарушения), из которого можно выйти только аппаратным сбросом (англ. reset) процессора.
Например, i386 поддерживает ограничение доступа к портам ввода-вывода и флагу запрещения прерываний через:
- назначение необходимого уровня привилегий для выполнения таких команд (двухбитным полем IOPL регистра флагов)
- разрешением задаче выборочного доступа к портам ввода-вывода через битовую карту в сегменте состояния задачи
Попытка исполнения неразрешенной команды ввода-вывода, приводит к исключению, обработчик которого (принадлежащий операционной системе) может завершить задачу по ошибке, игнорировать (возобновить выполнение со следующей команды) или эмулировать ввод-вывод.
Кроме всего многозадачность i386 полностью поддерживает все новые возможности — для 32-битных задач сегмент состояния содержит все 32-битные и необходимые новые регистры (например, регистр CR3 с адресом каталога страниц для этой задачи).
Виртуальный режим
В процессоре i386 компания Intel учла необходимость лучшей поддержки реального режима, потому что программное обеспечение времени его появления не было готово полностью работать в защищенном режиме. Поэтому, например, в i386, возможно переключение из защищенного режима обратно в реальный (при разработке 80286 считалось, что это не потребуется, поэтому на компьютерах с процессором 80286 возврат в реальный режим осуществляется схемно — через сброс процессора).
В качестве дополнительной поддержки реального режима, i386 позволяет задаче (или нескольким задачам) защищенного работать в виртуальном режиме — режиме эмуляции режима реального адреса (таким образом в переключении в реальный режим уже нет необходимости). Виртуальный режим предназначается для одновременного выполнения программы реального режима (например, программы DOS) под операционной системой защищенного режима.
Выполнение в виртуальном режиме практически идентично реальному, за несколькими исключениями, обусловленными тем, что виртуальная задача выполняется в защищенном режиме:
- виртуальная задача не может выполнять привилегированные команды, потому что имеет наинизший уровень привилегий
- все прерывания и исключения обрабатываются операционной системой защищенного режима (которая, впрочем, может инициировать обработчик прерывания виртуальной задачи)
вместе с тем, в задаче виртуального режима можно использовать:
- страничное преобразование, например, для:
- расширения памяти, путем включения страниц в неиспользуемое адресное пространство
- эмуляциии расширений с переключением банков (например, EMS-памяти)
- виртуальной развертки или свертки буферов внешних устройств (видеопамять, аппаратная EMS-память)
Читайте также: Давление в шинах зимой r14 тойота
Например, начиная с версий 4.01 — 5.0, при использовании менеджера памяти EMM386 (и его аналогов других разработчиков) операционная система MS-DOS работает как задача в виртуальном режиме. EMM386, в этом случае является подобием операционной системы защищенного режима (передавая большинство системных событий ядру MS-DOS в виртуальной задаче).
Режим виртуального 8086 поддерживается и в последующих 32-битных процессорах x86, вплоть до режима совместимости в x 86–64 .
Аппаратная отладка
Как и в предыдущих процессорах (начиная с 8086), отладка в i386 осуществляется вызовом отладочного прерывания, обработчик которого передает управление программе-отладчику. В предыдущих процессорах отладка могла быть вызвана двумя событиями:
- пошаговое выполнение
- программные точки останова
в i386 отладку также могут начать:
- аппаратные точки останова
- ловушка переключения задачи
Пошаговое выполнение
Пошаговое выполнение или трассивка (вызов отладочного прерывания после выполнения каждой команды при установленном флаге TF) в i386 осталось таким же как и в предыдущих процессорах, работая во всех новых режимах (32-битной адресации и режиме виртуальной задачи).
Точки прерывания
Точка прерывания (англ. breakpoint) — прекращение выполнения программы по достижении определенной команды.
В ранних процессорах x86 для организации точки останова, было необходимо заменить первый байт команды на команду вызова отладочного прерывания (int 3), вызов прерывания возвращал управление отладчику, который возвращал исходное значение первого байта команды. Кроме всего, точки останова такого рода было невозможно устанавливать в ПЗУ. i386 поддерживает такие точки останова для совместимости.
Точки прерывания i386 определяются адресом в регистрах отладки. Обработчик отладки вызывается, если адрес следующей команды совпадает с адресом в регистре. В связи с тем, что такие точки прерывания не требуют записи в память, они могут использоваться для отладки программ в ПЗУ. i386 позволяет одновременно устанавливать до четырех точек прерывания.
Точки прерывания i386, также могут быть установлены на обращение (чтение или запись) к переменной по заданному адресу в памяти. Процессор вызывает обработчик отладки при обращении команды к памяти по заданному адресу.
Ловушка переключения задачи
Отладочное прерывание может быть вызвано при переключении на задачу (для этого в сегменте состояния задачи предусмотрен специальный бит).
Другие изменения
Линии данных и адресов в процессоре 80386, как и в процессоре 80286, не мультиплексируются: имеется 32 линий данных и 32 независимых от них линии адреса.
Регистры
В составе микропроцессора имеются 8 32-битных регистров общего назначения (EAX, EBX, ECX, EDX, ESI, EDI, EBP, ESP). Младшая, 16-битная, половина каждого из этих регистров соответствует регистрам AX, BX, CX, DX, SI, DI, BP, SP в предыдущих процессорах семейства x86. Как и раньше возможна адресация младших и старших 8-битных половин, младшей 16-битной половины 32-разрядных регистров данных (AL и AH, BL и BH, CL и CH, DL и DH). Регистр указатель команды и регистр флагов также стали 32-битными (EIP и EFLAGS соответственно), причем в регистре флагов добавлены новая группа флажков. К 4-м 16-битным сегментным регистрам (ES, CS, SS, DS) прибавились ещё 2 16-битных регистра (FS и GS). Добавлены несколько новых групп регистров (каждый регистр размером 32 бит): 3 регистра управления (CR0 (MSW), CR2, CR3), 8 регистров отладки (DR0, DR1, DR2, DR3, DR6, DR7), 2 тестовых регистра (TR6, TR7).
Набор инструкции
Набор инструкций i386 был расширен, в основном, за счет добавления 32-битных вариантов существующих инструкций (образованных 32-битными префиксами), включая те у которых 32-битные варианты имеют другие мнемоники (pushad/popad, pushfd/popfd, cwd*/cdq, movsd/cmpsd/scasd/lodsd/insd/outsd, iretd), а также команды mov для новых регистров. Другие новые инструкции:
- установка байта по условию (set*)
- команды переходов (jmp, j*) с относительным 16-битным смещением
- команды загрузки полного адреса для новых сегментных регистров (lfs, lgs)
Средняя длина инструкций составляет 3,2 байта.
Сопроцессор
Специально для микропроцессоров Intel 80386 были разработаны математические сопроцессоры 387SX и 387DX, объединяемые единым наименованием 80387. Эти сопроцессоры совместимы с процессорами 386SX и 386DX соответственно; так, сопроцессор 387DX возможно подключить к 32-разрядной шине процессора. В остальном, обе модели аналогичны математическому сопроцессору 80287, который также можно использовать вместе с процессором 80386.
Читайте также: Обмен шин в кирове
Видео:Intel 80386 i386Скачать
Модели
С 1985 года было выпущено множество модификаций процессора i386, отличающихся между собой производительностью, потребляемой мощностью, разъёмами и корпусами и прочими характеристиками.
386DX
Первый процессор семейства 386 выпущен 17 октября 1985 года и имел тактовую частоту 16МГц. После выпуска процессоров 386SX процессоры этой серии получили индекс ‘’DX’’ — ‘’D’’ouble-word e’’X’’ternal, что указывало на его 32-разрядную внешнюю шину. Процессор позиционировался как производительное решение для настольных систем. Производился процессор по CHMOS IV технологии и потреблял 400 мА, что значительно меньше, чем Intel 8086. 16 февраля 1987 года анонсирована модель с частотой 20МГц; 4 апреля 1988 года с частотой 25МГц и 10 апреля 1989 года с частотой 33МГц. Процессор выпускался в корпусах PQFP-132 (такие процессоры имели литеру «NG» в начале названия, например, NG80386DX25) или в керамическом PGA-132 (такие процессоры имели литеру «A» в начале названия, например, A80386DX25)
Первые процессоры 386DX имели ошибку, которая, иногда, приводила к неверным результатам при работе с 32-разрядными числами в таких программах, как OS/2 2.x, UNIX/386, или Windows в расширенном режиме. Ошибка приводила к тому, что система зависала. Вследствие некоторых проблем, в том числе из-за отсутствия 32-битных операционных систем устранить ошибку удалось лишь в апреле 1987 года. Уже вышедшие процессоры прошли проверку, в результате которой процессоры не имеющие ошибку были промаркированы двойным символом «сигма» и/или одним символом «IV».
386SX
Первая модель этого семейства была представлена 16 июня 1988 года и имела частоту 16 МГц, позже были представлены и более быстрые модели: 20МГц (25 января 1989 года), 25МГц и 33МГц (оба процессора представлены 26 октября 1992 года). Процессоры позиционировались как решения для настольных ПК начального уровня и портативных ПК. Семейство SX отличалось от семейства DX тем, что у него разрядность внешней шины данных составляла 16 бит, а разрядность внешней шины адреса 24 бит. В результате чего процессор мог адресовать только 16Мбайт физической памяти, что делало его совместимым со старыми процессорами (Intel 80286). С другой стороны, процессор 386SX мог выполнять все программы, написанные для 386DX, и наоборот. Это сделало его популярным для изготовления «Турбо-плат», например, Cumulus 386SX, Intel In Board ? или Orchid Tiny Turbo.
В рамках серии SX были выпущены процессоры с маркировками 80386SXTA, 80386SXSA, 80386SXLP, которые представляли собой встраиваемые (embedded) процессоры (серия SXSA), процессоры низкого потребления (Low Power), а так же использовались в других целях.
386SL
Первая модель этого семейства была представлена 15 октября 1990 года и имела частоту 20 МГц, позже была представлена модель 25МГц (30 сентября 1991 года). Процессоры позиционировались как первые микропроцессоры специально предназначенные для портативных ПК. Семейство SL отличалось от семейства DX тем, что имел в кристалле также контроллеры оперативной памяти, кэш-памяти до 64Кбайт и шины.
386EX
Представляет собой модификацию процессора 386SX. Процессор предназначался для встраиваемых приложений с высокой интеграцией и малой потребляемой мощностью. Ключевые особенности этого процессора — низкое энергопотребление, пониженное напряжение питания, расположенные на кристалле контроллер прерываний, микросхема выбора чипа, счётчики и таймеры, логика тестирования JTAG. Эта серия процессоров имела несколько модификаций: EXSA, EXTA, EXTB, EXTC. Максимальный ток потребляемый процессорами составляет 320мА для процессоров серии EXTC и 140мА для процессоров серии EXTB.
Использовался на борту различных орбитальных спутников и микроспутников и в NASA-овском проекте Flight Linux ?.
Видео:HAND386: новый (недо)компьютер на базе 80386-го процессора. Краткий обзор ПО и железаСкачать
Компьютеры на базе процессора Intel 80386
На основе микропроцессоров 80386 фирмой IBM были созданы персональные компьютеры IBM AT 386 (семейство PC) и IBM PS/ 2–80 (семейство PS/2). В первом применялась ОС PC-DOS, а во втором — OS/2.
- Свежие записи
- Нужно ли менять пружины при замене амортизаторов
- Скрипят амортизаторы на машине что делать
- Из чего состоит стойка амортизатора передняя
- Чем стянуть пружину амортизатора без стяжек
- Для чего нужны амортизаторы в автомобиле
🔍 Видео
Архитектура x86. Уверены, что знаете свой домашний компьютер?Скачать
Частота процессора или частота системной шины?Скачать
Очень важные параметры видеокарты, на которые редко обращают внимание при покупке!Скачать
Все о маркировках процессоров INTEL COREСкачать
х64 или х86? Как узнать разрядность процессора и архитектуру windows?Скачать
Гнать или не гнать? BSEL мод Intel Celeron M530Скачать
Внутри CPU: Intel 8086Скачать
Настоящая ЭВМ 80386 SX Чиним, заводим, тестим Ретро раритетСкачать
Взаимозаменяемость процессоров ИнтелСкачать
Разгон отечественного процессора М1821ВМ85А Intel 80C85Скачать
Центральный процессор: Intel 2013 г. HaswellСкачать
На что способны 32 и 64-битные мобильные процессорыСкачать
Из-за чего производители чипов урезают свои процессоры?Скачать
Как разогнать процессор и память? Гоним по шине и множителю.Скачать
Влияние шин PCI-e и внутренней шины видеокарты на производительностьСкачать
Что такое i3, i5, i7, i9? В чем разница? Как выбрать процессор?Скачать
#эволюция - процессоры Intel / Часть 1Скачать