Почему Windows показывает только около 3,5 ГБ из 4 ГБ ОЗУ?

Я недавно обновил ОЗУ своего компьютера до 4 ГБ. Моя 32-битная установка Windows показывает только 3574 МБ памяти. Как я могу заставить Windows использовать полный объем оперативной памяти?

9 ответов

Решение

Вы не можете:

Видишь, чувак, где мои 4 гигабайта оперативной памяти?

если вы хотите поместить память и устройства в 32-разрядный диапазон адресов: не все доступные 4 ГБ адресного пространства могут быть переданы в память.
Так что же на самом деле произойдет, если вы выйдете и купите 4 ГБ памяти для своего ПК?
В карте памяти есть дыра для ввода-вывода. (Сейчас это только 25% от общего адресного пространства, но это все еще большая дыра.) Таким образом, будут доступны 3 младших гигабайта вашей памяти, но есть проблема с последними 1 гигабайтами.

Единственное практическое решение - установить 64-битную операционную систему. В Windows Vista и более поздних версиях 32-разрядные и 64-разрядные лицензионные ключи являются взаимозаменяемыми. Если вы можете получить установочный носитель Windows для 64-разрядной версии операционной системы, вы можете переустановить его, используя свой оригинальный лицензионный ключ.

Во-первых, Windows XP (32-разрядная версия) поддерживает только 4 ГБ. Это относится не только к Windows XP. Вместо этого он применяется к 32-разрядным настольным системам Windows - 32-разрядным системам Linux с PAE, и многие 32-разрядные выпуски Windows Server поддерживают более 4 ГБ на связанную статью. Вы никогда не увидите более 4 ГБ, если используете 32-разрядную версию Windows XP. Тем не менее, я нашел более подробную причину, почему ваша система показывает меньше доступного оперативной памяти, чем то, что фактически установлено.

Из проблемы ОЗУ 3 ГБ, а не 4 ГБ (блог Microsoft MSDN):

Из-за архитектурного решения, принятого давно, если у вас установлено 4 ГБ физической ОЗУ, Windows может сообщать только часть физической 4 ГБ ОЗУ (в диапазоне от ~2,75 ГБ до 3,5 ГБ в зависимости от установленных устройств, чипсета материнской платы и BIOS).

Это происходит из-за "резервирования ввода-вывода с отображением в память". Эти резервирования перекрывают физическое адресное пространство и маскируют эти физические адреса, чтобы их нельзя было использовать для рабочей памяти. Это не зависит от ОС, работающей на машине.

Значительные куски адресного пространства ниже 4 ГБ (самый высокий адрес, доступный через 32-разрядный) зарезервированы для использования системным оборудованием:

  • BIOS - включая ACPI и поддержку устаревшего видео
  • Шина PCI, включая мосты и т. Д.
  • Поддержка PCI Express зарезервирует не менее 256 МБ, до 768 МБ в зависимости от установленной памяти видеокарты

Это означает, что типичная система может видеть между ~256 МБ и 1 ГБ адресного пространства ниже 4 ГБ, зарезервированных для аппаратного использования, к которому ОС не может получить доступ. Спецификации чипсета Intel довольно хорошо объясняют, какие диапазоны адресов зарезервированы по умолчанию, и в некоторых случаях говорят, что 1,5 ГБ всегда зарезервированы и, следовательно, недоступны для Windows.

Существует больше информации, если вы проверите источник. Однако вы можете воспользоваться всеми установленными 8 ГБ, если будете следовать этим инструкциям.

Если говорить из личного опыта, это не новая проблема. Я столкнулся с этой же проблемой несколько лет назад, когда создавал 32-битную систему Windows Vista на 4 ГБ, когда Vista была впервые выпущена. На форуме было множество сообщений на эту тему.

Читайте также Microsoft KB 929605 - Объем системной памяти, о которой сообщается в диалоговом окне "Сведения о системе" в Windows Vista, меньше ожидаемого, если установлено 4 ГБ ОЗУ.

Как говорили другие, это невозможно.

Объяснение:

Каждый кусок памяти имеет адрес. Операционная система указывает длину адреса. В старых операционных системах длина адреса составляет 32 бита, что позволяет использовать только 2 ^ 32 (4 294 967 296) адресов. Теперь, глядя на это число, может показаться, что ваша операционная система должна поддерживать 4 ГБ, но все другое аппаратное обеспечение (что особенно важно, видеопамять на вашей видеокарте), имеющее внутреннюю память, также отображается в этом адресном пространстве.

Как будто вы пытаетесь раздать 1 200000 шестизначных телефонных номеров.

Если вы используете 32-битную Windows XP, то это невозможно. Так как для использования дополнительной оперативной памяти недостаточно адресного пространства

Лучшим решением было бы перейти на 64-разрядную версию Windows, поскольку она поддерживает 4+ ГБ ОЗУ.

Старая материнская плата поддерживала только 4 ГБ физической памяти, современные поддерживают гораздо больше. Процессор Intel P4 всегда может адресовать более 4 ГБ (используя то, что называется расширением физического адреса или PAE)

Microstoft приняла "маркетинговое решение" не поддерживать физическое адресное пространство более 4 Гб в "клиентских" версиях всех 32-битных версий своих операционных систем, включая все от w2k до 32-битной Windows 8 (если вы посетите MS KB На страницах, которые вы заметите, 32-битные версии серверов могут поддерживать гораздо больше - до 128 Гб, я полагаю, с 32-битной версией Enterprise Edition, - именно поэтому "правильные" 32-битные ОС (Linux и т. д.) на одном и том же оборудовании всегда могут получить доступ ко ВСЕМ физическая оперативная память

(примечание: 32-битным пользователям Win7 настолько надоел этот "глупый" лимит, что они "взломали" Kernal, чтобы разрешить доступ к полной физической ОЗУ... разумеется, это нарушает вашу лицензию и фактически является незаконным в США (DCMA).)

Windows XP 32bit "резервирует" часть адресного пространства объемом 4 Гб для использования драйвером. Нет никаких причин, по которым вы не можете "адресовать" физическую ОЗУ за пределы 4 ГБ (используя PAE), однако многим ПОЛНЫМ ДРАЙВЕРАМ во времена Windows XP Pro не удалось этого сделать, и вы получите ошибку "BSOD" (современные драйверы используют PAE правильно, и в ТЕОРИИ нет причины, по которой им нужно больше, чем около 32 МБ пространства страниц "lo" (как "окна") в общей сложности, даже для поддержки графической карты 2 ГБ (2 ГБ будут находиться в пространстве "hi", т.е. выше 4 ГБ) отметка)

В XP SP2 MS почти утроила объем адресного пространства, "зарезервированного" для драйверов, чтобы устранить BSOD, и с тех пор так и было (MS не хочет "отлаживать" драйверы == они хотят продать вам 64-битную версию). ОС вместо). Фактическое оборудование практически не влияет на это "зарезервированное" пространство.

Итак, если у вас 4 ГБ или более физической ОЗУ, большинство XP Pro sp2+ увидит около 3,25 ГБ. Остальные МОГУТ получить доступ с помощью различных различных драйверов ОЗУ (не MS, конечно) = идите искать что-то, что использует "Невидимое адресное пространство" или "высокое пространство 4 ГБ" в XP Pro) . Использование "отсутствующего" 0,75 ГБ как части вашей "виртуальной памяти" может ускорить вашу систему...

Обратите внимание, что ключ /3G может разрешить 32-разрядным приложениям доступ к 3Gb в 32-разрядной ОС (если в заголовке.exe установлен флаг LargeAddressAware - в этом случае они могут получить доступ к 4 ГБ в 64-разрядной ОС), но в XP вам также нужно указать /USERVA, чтобы не выдавливать ОС из ОЗУ:-)

Это довольно сложный вопрос, поскольку для его разработки требуется несколько компонентов. Эти компоненты:

  • Центральное процессорное устройство
  • Блок контроллера памяти
  • BIOS / (U)EFI
  • Операционная система
  • заявка

Последний пункт не имеет отношения к проблеме напрямую, но я добавил его для полноты картины.

Короче говоря, все вышеперечисленные компоненты должны поддерживать более 4 ГБ памяти, чтобы добиться успеха.

Центральное процессорное устройство

Начнем с процессора. Но сначала важно отметить, что ЦП вообще не обладает магической способностью использовать какую-либо память. Вместо этого он мог просто получить доступ к любому адресу в пределах своего адресуемого пространства. Теперь вот идет вещь битности. 32-разрядный ЦП способен обращаться к адресам в диапазоне от 0 до 4 ГиБ. Этот диапазон, однако, должен учитывать не только доступную оперативную память, ПЗУ, SMRAM, таблицу переопределения графических адресов, но также и все необходимые операции ввода-вывода с отображением в памяти и многое другое, для чего может потребоваться существенная часть этого диапазона адресов. Как следствие, вполне возможно, что некоторые адреса памяти были скрыты этим использованием и, следовательно, недоступны для операций с оперативной памятью. Чтобы восстановить скрытую память, необходимо расширить доступное адресное пространство CPU. В случае 32-битного расширения физического адреса ЦП может помочь. Что позволяет адресовать до 64 ГиБ. 64-разрядный процессор, работающий в собственном 64-разрядном режиме, по умолчанию способен получить доступ к 16 EiB, что довольно много и не требует таких приемов. Но с другой стороны, 64-разрядному ЦП нецелесообразно использовать 64-разрядную адресацию, поэтому в действительности они все еще ограничены адресной шиной меньшим диапазоном, чем 16 EiB.

Блок контроллера памяти

Первоначально он находился в Северном мосту, но был перенесен в процессорную головку AMD, начиная с процессоров AMD64, и Intel с процессорами Nehalem. Даже если ЦП с PAE способен самостоятельно обращаться к 64 ГиБ, ему все равно нужен MCU для доступа к ОЗУ. Проще говоря: процессор, обращающийся к определенному адресу, получает ответ либо от устройства PCI, флэш-памяти BIOS или MCU, если запрашиваемый адрес находится в оперативной памяти, и так далее. Однако для MCU (будь то в северном мосту или в процессоре) нередко поддерживается гораздо меньше адресуемого пространства, чем 64 ГиБ, например, по маркетинговым причинам.

BIOS / (U)EFI

BIOS / (U)EFI также важны, так как их обязанность - конфигурировать аппаратные средства, прежде чем что-либо действительно сможет работать. Помимо прочего, они отвечают за отображение всего адресуемого пространства процессора с диапазонами памяти аппаратных устройств, шин, оперативной памяти и так далее. Интересно, что может случиться так, что вся оперативная память разделится на части и отобразится в нескольких доступных несмежных точках. Проблема с BIOS заключается в том, что его разработчики могут рассчитывать не более чем на 3 ГБ использования ОЗУ в своей системе, и, таким образом, BIOS не будет правильно отображать всю используемую память. Скорее всего, этого не произойдет с (U)EFI.

Операционная система

Операционная система также должна поддерживать адресацию более 4 ГБ памяти. Чтобы быть более конкретным, он должен настроить процессор для использования PAE. Некоторые 32-разрядные операционные системы прекрасно могут использовать PAE и получать доступ к более чем 4 ГиБ, другие имеют программный лимит на максимальный объем памяти, даже если они включают PAE для повышенной безопасности (например, Windows XP). И снова 64-разрядные ОС, естественно, не испытывают таких трудностей и обычно поддерживают более 4 ГБ памяти.

заявка

Последний пункт из другого мира, так как приложения обычно работают в виртуальном адресном пространстве, я добавил его для полноты картины. Тем не менее, для компиляции приложения требуется несколько дополнительных шагов, чтобы иметь возможность использовать больше памяти. По умолчанию 32-разрядное приложение может использовать только 2 ГБ памяти. Это же 32-разрядное приложение может адресовать до 4 ГБ памяти при условии, что ОС поддерживает это и поддерживает CPU PAE. Точнее говоря, он может использовать до 3 ГБ памяти, другой 1 ГБ может быть адресован как общие библиотеки и ядро ​​ОС, но недоступен для записи (в конечном итоге это зависит от архитектуры ОС, а не от самого приложения). Опять же, 64-битные приложения изначально поддерживают адресацию более 4 ГБ памяти и не имеют таких проблем.

Чтобы рассмотреть все это в перспективе, давайте рассмотрим несколько примеров.

Рассмотрим контроллер памяти Intel® 82945G. На сайте Intel говорится, что он не поддерживает PAE и ограничен 4 ГБ оперативной памяти. Давайте посмотрим пункт 9 System Address Map из таблицы. В нем много информации. Самое интересное Figure 9-3. Main Memory Address Range: и абзац 9.2 Main Memory Address Range (1 MB to TOLUD), который гласит:

Этот диапазон адресов простирается от 1 МБ до верхней части физической памяти, доступ к которой разрешен (G)MCH (как запрограммировано в регистре TOLUD). Все обращения к адресам в этом диапазоне перенаправляются (G) MCH в основную память, если они не попадают в опциональный TSEG, опциональное отверстие ISA или опциональную память VGA, украденную IGD. (G) MCH обеспечивает максимальное пространство декодирования адреса основной памяти 4 ГБ (2 ГБ для 82945GC/82945GZ /82945PL). (G) MCH не переназначает пространство памяти APIC или PCI Express. Это означает, что, поскольку объем физической памяти, заполненной в системе, достигает 4 ГБ (2 ГБ для 82945GC/82945GZ/82945PL), будет существующая физическая память, которая еще не адресуема и поэтому не может использоваться системой.

Как говорится, поскольку он не поддерживает PAE, он в конечном итоге не может переназначить PCI и все остальные MMIO выше 4 ГБ, поэтому часть памяти будет затенена и неиспользована. Это означает, что даже если он используется с процессором, поддерживающим 36-битную адресацию, память выше 4 ГБ все равно будет недоступна, а часть памяти, близкая к пределу 4 ГБ, также не будет использоваться.

И наоборот, давайте рассмотрим контроллер памяти Intel® 82955X, который связан с предыдущим, но он настроен на поддержку 8 ГБ в отличие от предыдущего! Абзац таблицы 2.1 Host Interface Signals предполагает, что он использует 36-битную адресную шину для процессора, что является хорошим признаком. Параграф 7 System Address Map имеет дальнейшие идеи. сравнить Figure 7-1. System Address Ranges к тому, что мы видели раньше: Это ясно говорит о том, что он способен использовать более 4 ГБ ОЗУ при условии, что он используется с процессором, также способным к 36-битной адресации. Стоит также отметить этот пункт 7 System Address Map говорится, что MCH supports 64 GB of addressable memory space, Однако дополнительно уточняется, что максимально используемая оперативная память ограничена 8 ГБ. Это еще раз заявляет о разнице между адресуемой и используемой, как я пытался передать в разделе ЦП.

В заключение я хотел бы отметить, что два связанных чипсета на самом деле имеют огромную разницу в обработке памяти.

Давайте рассмотрим процессор Intel® Pentium® Extreme Edition 840. Он поддерживает 64-битный набор инструкций, но не поддерживает PAE. Это означает, что при работе в 32-разрядном режиме он не сможет использовать более 4 ГБ ОЗУ (пожалуйста, исправьте меня, если я ошибаюсь в этом предположении). Давайте посмотрим на таблицу и таблицу Table 4-3. Signal Description, Несмотря на то, что этот ЦП поддерживает 64-разрядную архитектуру, он по-прежнему ограничен шириной 36-разрядной адресной шины, что ограничивает его доступным диапазоном адресов от 0 до 64 ГиБ.

Теперь давайте рассмотрим более свежий процессор. Например, процессор Intel® Core™ i7-7700. Рекламируется для поддержки до 64 ГБ оперативной памяти. Теперь давайте проверим таблицу данных этого. Параграф 2.3 System Address Map убеждает нас, что адресный диапазон этого ЦП составляет от 0 до 512 ГиБ из-за 39-битной адресной шины. Обратите внимание, что это все еще далеко от теоретического диапазона 16 EiB для 64-битного процессора. Удивительно, но это дополнительно поясняет, что этот процессор поддерживает максимум до 32 ГиБ оперативной памяти (в отличие от 64 ГБ на веб-сайте). Здесь также есть интересное изображение Figure 2-2. System Address Range Example: Он хорошо иллюстрирует проблему с теневым копированием памяти устройствами PCI и т. Д. Кроме того, он предлагает способ преодоления этой проблемы путем сопоставления диапазона от реального ОЗУ до верхнего диапазона адресов в пределах диапазона адресации ЦП. Таким образом восстанавливая эту скрытую память для использования. Обратите внимание, что это переназначение выполняется BIOS / (U)EFI после аппаратной инициализации, и именно по этой причине я включил BIOS / (U)EFI в список выше.

Я взял в качестве примера продукты Intel, но то же самое относится и к AMD.

Теперь давайте обсудим, как задействованы операционные системы. Ядро Linux включает полную поддержку режима PAE, начиная с версии 2.3.23, и вполне возможно иметь более 4 ГБ памяти, используемой с ядром Linux в 32-разрядной системе. Однако следует помнить о неопределенной проблеме с 32-битным ядром Linux в системе с более чем 4 ГБ ОЗУ на некотором оборудовании (по моему опыту это имеет отношение к сбоям TLB). В любом случае, в Википедии есть хорошая информация о поддержке PAE. Интересно, что Windows XP ограничена 4 ГБ, тогда как Windows Server 2003 Enterprise/Datacenter SP2 может заполнять до 64 ГБ. То же самое для других пар Windows Desktop-Server.

Как вы можете видеть, существует множество комбинаций среди перечисленных компонентов, и в некоторых случаях замена процессора или ОС может помочь. Гораздо сложнее иметь дело с BIOS / (U)EFI или MCU, поскольку первый является проприетарным и встроенным в систему и не может быть легко изменен, последний встроен в ЦП или припаян на плате.

Если вы хотите использовать полные 4 ГБ, единственным вариантом является обновление до 64-битной операционной системы:

  • Windox XP 64
  • Windows Vista 64
  • Linux
  • Max OS / X (хорошо, для этого вам может понадобиться новый ПК)

Обычная Windows XP - только 32-битная, и это ограничивает память до 3,5 ГБ макс. Проверьте ссылку, размещенную VonC для деталей об этой теме.

Если вы используете интегрированную графику, вы можете отказаться от нее, и это будет означать, что система сможет использовать больше оперативной памяти вашей системы.

Но лучшее решение, безусловно, получить ОС x64.

Нет причин не слишком в любом случае. Большинство программ работают в x64 с XP/Vista/7, имеющим слой эмуляции x86. Это просто драйверы, которые могут быть проблемой.

Он показывает 3574 МБ оперативной памяти, потому что именно столько оперативной памяти БЕСПЛАТНО и доступно для использования компьютером в любое время. Эта цифра представляет собой ОЗУ, к которому у вашего компьютера есть полный доступ, поскольку программы и настройки, предварительно установленные на ПК, используют установленный объем ОЗУ, который в вашем случае составляет 426 МБ. Мой 6-ГБ 64-битный ПК показывает 5,8 ГБ доступной оперативной памяти вместо полных 6 ГБ. Лучше всего было бы посмотреть на обновление вашего ПК

Другие вопросы по тегам