Длинный режим - Long mode

в x86-64 компьютерная архитектура, длинный режим это режим, в котором 64-битный Операционная система может получить доступ к 64-битной инструкции и регистры. 64-битные программы запускаются в подрежиме, называемом 64-битным режимом, а 32-битные программы и 16-битные программы. защищенный режим программы выполняются в подрежиме, называемом режимом совместимости. Реальный режим или же виртуальный режим 8086 программы не могут быть изначально запущены в долгом режиме.

Обзор

Процессор x86-64 действует идентично IA-32 процессор при работе в реальном режиме или защищенном режиме, которые поддерживаются подрежимами, когда процессор нет в длительном режиме.

Немного в CPUID Поле расширенных атрибутов сообщает программам в реальном или защищенном режиме, может ли процессор перейти в длительный режим, что позволяет программе обнаруживать процессор x86-64. Это похоже на бит атрибутов CPUID, который Intel IA-64 процессоры позволяют программам определять, работают ли они в режиме эмуляции IA-32.

На компьютере под управлением устаревшей версии BIOS, BIOS и загрузчик работает в Реальный режим, затем ядро ​​64-битной операционной системы проверяет и переключает ЦП в длинный режим, а затем запускает новый режим ядра потоки, выполняющие 64-битный код. С работающим компьютером UEFI, прошивка UEFI (кроме CSM и устаревших Дополнительное ПЗУ ), UEFI загрузчик а ядро ​​операционной системы UEFI все работает в длинном режиме.

Ограничения памяти

Хотя размеры регистров увеличились до 64 бит по сравнению с предыдущим архитектура x86, адресация памяти еще не увеличен до полных 64 бит. В настоящее время нецелесообразно оснащать компьютеры достаточным объемом памяти, чтобы требовать полные 64 бита. Пока это остается так, загружайте / сохраняйте единицы, тайник теги MMU и TLB можно упростить без потери полезной памяти. Несмотря на это ограничение, программное обеспечение программируется с использованием полной 64-разрядной версии. указатели, и, следовательно, сможет использовать все более крупные адресные пространства по мере того, как они будут поддерживаться будущими процессорами и операционными системами.

Текущие ограничения

Первые процессоры, реализующие архитектуру x86-64, а именно AMD Athlon 64 / Opteron (K8) CPU с 48-битной виртуальный[1]:129–130 и 40-битный физическая адресация.[1]:4

Виртуальное адресное пространство этих процессоров разделено на две 47-битные области, одна из которых начинается с наименьшего возможного адреса, а другая простирается вниз от наибольшего. Попытка использовать адреса, выходящие за пределы этого диапазона, вызовет общая ошибка защиты.

Предел физической адресации ограничивает количество установленных баран может быть доступен с компьютера. На ccNUMA мультипроцессор system (Opteron) сюда входит память, которая установлена ​​на удаленных узлах, поскольку процессоры могут напрямую адресовать (и кэшировать) всю память, независимо от того, находится она на домашнем узле или удаленном. 1Туберкулез ограничение (40 бит) для физической памяти для K8 огромно по стандартам типичных персональных компьютеров, но могло быть ограничением для использования в суперкомпьютерах. Следовательно, K10 (или "10ч") микроархитектура реализует 48-битные физические адреса и поэтому может адресовать до 256Туберкулез оперативной памяти.[2]

При необходимости микроархитектуру можно шаг за шагом расширять без побочных эффектов со стороны программного обеспечения и одновременно снижать затраты на ее реализацию. Для будущего расширения архитектура поддерживает расширение виртуального адресного пространства до 64 бит и адресацию физической памяти до 52 бит (ограничено таблица страниц формат записи).[3] Это позволит процессору обращаться к 264 байтов (16 эксабайты ) виртуального адресного пространства и 252 байта (4 петабайты ) физического адресного пространства.

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

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

  1. ^ а б "Руководство программиста по архитектуре AMD64, том 2: Системное программирование" (PDF). 2016. Получено 2015-04-09.
  2. ^ «Руководство разработчика BIOS и ядра (BKDG) для процессоров AMD семейства 10h» (PDF). п. 30. Получено 2015-04-09. Физическое адресное пространство увеличено до 48 бит.
  3. ^ AMD 2016 г., п. 24: «Архитектура AMD64 расширяет эту поддержку, позволяя преобразовывать 64-битные виртуальные адреса в 52-битные физические адреса, хотя реализации процессоров могут поддерживать меньшие пространства виртуальных адресов и физических адресов».

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