Misplaced Pages

3 GB barrier: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editNext edit →Content deleted Content addedVisualWikitext
Revision as of 05:27, 15 July 2016 editJeh (talk | contribs)Extended confirmed users, Pending changes reviewers19,611 editsm Address remapping: fmt - missing apostrophe, so we had run-on italics← Previous edit Revision as of 14:19, 16 July 2016 edit undo115.188.27.154 (talk) 32 bit processors can address 4GB RAM maximum and the CPU is the only part of the system which can access RAM. Windows uses virtual addressing translated to physical addresses by the CPU TLB.Tag: section blankingNext edit →
Line 7: Line 7:


The barrier is caused by a set of interactions between several components, including the operating system. The barrier is caused by a set of interactions between several components, including the operating system.

==Physical address limits==

It is a common misconception{{according to whom|date=November 2014}} that 32-bit processors and operating systems
are limited to 4&nbsp;GB (2<sup>32</sup> bytes) of RAM,<ref>{{cite web
|url=http://www.pcmag.com/article2/0,2817,2354768,00.asp
|title=Windows 7: The 64-Bit Question
|publisher=PCMag
|author=Matthew Murray
|date=2009-10-27
|accessdate=2010-06-07
|quote=A 32-bit system is limited to utilizing 4GB of RAM (2<sup>32</sup> addresses)
}}</ref><ref name="Wired64BitQuestion">{{cite web|url=http://www.wired.com/science/discoveries/news/2002/07/53998 |title=AMD Answers the 64-Bit Question |publisher=Wired |author=Andy Patrizio |quote=32-bit processors like Intel's Pentium III/IV and AMD's Athlon have a memory limit of 4 GB per CPU. Any more memory can't be addressed. |date=2002-07-22 |accessdate=2015-12-09 |deadurl=yes |archiveurl=https://web.archive.org/web/20081216165055/http://www.wired.com/science/discoveries/news/2002/07/53998 |archivedate=December 16, 2008 }}</ref> as were the original ] and other early IA-32 CPUs. Since the 1995 ],<ref name="shanley-ppro">{{cite book
|title=Pentium Pro and Pentium II System Architecture
|edition=Second
|last=Shanley |first=Tom
|isbn=0-201-30973-4
|series=PC System Architecture Series
|year=1998
|publisher=Addison-Wesley
|page=445}}
</ref> almost all modern x86 processors can in fact already address up to 64&nbsp;GB (2<sup>36</sup> bytes) RAM via ] (PAE). PAE is a modification of the ] address translation scheme. It allows virtual or linear addresses to be translated to ] physical addresses, instead of the 32-bit addresses available without PAE.<ref>{{cite web
|url=http://download.intel.com/design/archives/processors/pro/docs/24269001.pdf
|work=Pentium Pro Family Developer’s Manual
|title=Volume 1: Specifications
|year=1996
|publisher=Intel Corporation
|format=pdf
|pages=3–15
|quote=The Pentium Pro processor physical address space is 2<sup>36</sup> bytes or 64-Gigabytes (64 Gbyte).}}
</ref> The CPU pinouts likewise provide 36 bits of physical address lines to the motherboard.
<ref>{{cite web
|url=http://download.intel.com/design/archives/processors/pro/docs/24269001.pdf
|work=Pentium Pro Family Developer’s Manual
|title=Volume 1: Specifications
|year=1996
|publisher=Intel Corporation
|format=pdf
|page=15-5
|quote=Pin #: C1; Signal Name: A35#}}
</ref>

Many x86 operating systems, including any version of Linux with a PAE ] and some versions of ] and ], support the use of PAE to address up to 64 GB of RAM on an x86 system.<ref name="MSWindowsRAMLimits">{{cite web
|url=http://msdn.microsoft.com/en-us/library/aa366778(VS.85).aspx
|title=Memory Limits for Windows Releases
|author=Microsoft Corporation
|date=2008-08-22
|accessdate=2010-06-07
|quote=Windows Server 2008 Enterprise; Limit in 32-bit Windows: 64 GB
}}</ref><ref>{{cite web
|url=https://help.ubuntu.com/community/EnablingPAE
|title=Enabling PAE
|work=Ubuntu Documentation
|date=2010-05-19
|accessdate=2010-06-07
|quote=Physical Address Extension is a technology which allows 32 bit operating systems to use up to 64 Gb of memory (RAM)... PAE is supported on the majority of computers today and it is an easy procedure to enable it in Ubuntu, if it is not already.
}}</ref><ref>{{cite web
|url=http://docs.fedoraproject.org/release-notes/f8/en_US/sn-Kernel.html
|work=Fedora Documentation
|title=Linux Kernel
|date=2010-05-18
|accessdate=2010-06-07
|quote=Fedora 8 includes the following kernel builds: ... The kernel-PAE, for use in 32-bit x86 systems with more than 4GB of RAM, or with CPUs that have an NX (No eXecute) feature.
}}</ref>

Use of PAE to address RAM above the 4 GB point allows use of more than 3 GB.{{clarify|date=November 2014}} There are, however, factors that limit this ability, and lead to the "3 GB barrier" under certain circumstances, even though the processor fully supports PAE. These are described in the following sections.


==Chipset and other motherboard issues== ==Chipset and other motherboard issues==

Revision as of 14:19, 16 July 2016

This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these messages)
This article may lend undue weight to certain ideas, incidents, or controversies. Please help improve it by rewriting it in a balanced fashion that contextualizes different points of view. (October 2012) (Learn how and when to remove this message)
This article possibly contains original research. Please improve it by verifying the claims made and adding inline citations. Statements consisting only of original research should be removed. (October 2012) (Learn how and when to remove this message)
(Learn how and when to remove this message)

In computing, the 3 GB barrier is a limitation of some 32-bit operating systems running on x86 microprocessors. It prevents the operating systems from using more than about 3 GB (3 × 1024 bytes) of main memory (RAM). The exact barrier varies by motherboard and I/O device configuration, particularly the size of video RAM; it may be in the range of 2.75 GB to 3.5 GB. The barrier is not present with a 64-bit processor and 64-bit operating system, or with certain x86 hardware and an operating system such as Linux or certain versions of Windows Server and Mac OS that fully support physical address extension (PAE) mode on x86.

The barrier is caused by a set of interactions between several components, including the operating system.

Chipset and other motherboard issues

Although, as noted above, most x86 processors from the Pentium Pro onward do support physical addresses up to 64 GB, the rest of the motherboard must participate in allowing RAM above the 4GB point to be addressed by the CPU. Chipsets and motherboards allowing more than 4 GB of RAM with x86 processors do exist, but in the past, most of those intended for other than the high-end server market supported only 4 GB of RAM.

This, however, is not sufficient to explain the "3 GB barrier" that appears even when running some x86 versions of Microsoft Windows on platforms that do support more than 4 GB of RAM.

Memory mapped I/O and disabled RAM

Modern personal computers are built around a set of standards that depend on, among other things, the characteristics of the original PCI bus. The original PCI bus supported 32-bit physical addresses and 32-bit wide data transfers. PCI (and PCI Express, and AGP) devices present at least some, if not all, of their host control interfaces via a set of memory-mapped I/O locations (MMIO). The address space in which these MMIO locations appear is the same address space as that used by RAM, and while RAM can exist and be addressable above the 4 GB point, these MMIO locations decoded by I/O devices cannot be. They are limited by PCI bus specifications to addresses of 0xFFFFFFFF (2−1) and below. With 4 GB or more of RAM installed, and with RAM occupying a contiguous range of addresses starting at 0, some of the MMIO locations will overlap with RAM addresses. On machines with large amounts of video memory, MMIO locations have been found to occupy as much as 1.8 GB of the 32-bit address space.

The BIOS and chipset are responsible for detecting these address conflicts and disabling access to the RAM at those locations. Due to the way bus address ranges are determined on the PCI bus, this disabling is often at a relatively large granularity, resulting in relatively large amounts of RAM being disabled.

Address remapping

x86 chipsets that support more than 4 GB of RAM typically also support memory remapping (referred to in some BIOS setup screens as "memory hole remapping"). In this scheme, the BIOS detects the memory address conflict and in effect relocates the interfering RAM so that it may be addressed by the processor at a new physical address that does not conflict with MMIO. On the Intel side, this support once was limited to server chipsets; however, newer desktop chipsets like the Intel 955X and 965 and later support it as well. On the AMD side, the AMD K8 and later processors' built-in memory controller supported it from the beginning.

As the new physical addresses are above the 4 GB point, addressing this RAM does require that the operating system be able to use physical addresses larger than 2. This capability is provided by PAE. Note that there is not necessarily a requirement for the operating system to support more than 4 GB total of RAM, as the total RAM might be only 4 GB; it is just that a portion of it appears to the CPU at addresses in the range from 4 GB and up.

This form of the 3 GB barrier affects one generation of MacBooks, lasting 1 year (Core2Duo (Merom) – Nov 2006 to Oct 2007): the prior generation was limited to 2 GB, while later generations (Nov 2007–Oct 2009) allowed 4 GB by supporting PAE and memory hole remapping, and subsequent generations (late 2009 onwards) use 64-bit processors and support over 4 GB.

Windows version dependencies

Main article: Physical Address Extension § Operating system support

In Microsoft's "non-server", or "client", x86 editions of Microsoft Windows: Windows XP, Windows Vista, Windows 7, Windows 8, and Windows 8.1, the 32-bit (x86) versions of these are able to operate x86 processors in PAE mode, and do so by default as long as the CPU present supports the NX bit. Nevertheless, these operating systems do not permit addressing of physical memory above the 4 GB address boundary. This is not an architectural limit; it is a limit imposed by Microsoft via license enforcement routines as a workaround for device driver compatibility issues that were discovered during testing.

Thus, the "3 GB barrier" under x86 Windows "client" operating systems can therefore arise in two slightly different scenarios. In both, RAM near the 4 GB point conflicts with memory-mapped I/O space. Either the BIOS simply disables the conflicting RAM; or, the BIOS remaps the conflicting RAM to physical addresses above the 4 GB point, but x86 Windows client editions refuse to use physical addresses higher than that, even though they are running with PAE enabled. The conflicting RAM is therefore unavailable to the operating system whether it is remapped or not.

See also

References

  1. MSDN. "Memory Limits for Windows Releases". Microsoft. Retrieved 28 December 2013.
  2. Russinovich, Mark. "Pushing the Limits of Windows: Physical Memory". Technet. Microsoft. Retrieved 28 December 2013.
  3. Intel Corporation (February 2005). "Intel Chipset 4 GB System Memory Support" (pdf). Pentium Pro Family Developer’s Manual. p. 7. In uni-processor based systems for mobile, desktop, workstation, and entry level servers, chipsets may be limited to 4 GB of maximum memory. In today's dual processor Intel server chipsets and workstations, maximum system memory size can be upwards of 16 GB.
  4. ^ Mark Russinovich (2008-07-21). "Pushing the Limits of Windows: Physical Memory". Archived from the original on 9 June 2010. Retrieved 2010-06-07. Windows XP SP2 also enabled Physical Address Extensions (PAE) support by default on hardware that implements no-execute memory because its required for Data Execution Prevention (DEP), but that also enables support for more than 4GB of memory. {{cite web}}: Unknown parameter |deadurl= ignored (|url-status= suggested) (help)
  5. Intel Corporation (February 2005). "Intel Chipset 4 GB System Memory Support" (pdf). In platforms populated with physical memory sizes approaching 4 GB and greater, onboard system resource requirements will likely not allow the operating system to take advantage of all physical memory populated due to PCI specification requirements and other memory mapped IO resources. Portions of physical memory may overlap with the memory space dedicated to other subsystems and become unavailable to the operating system.
  6. Intel Corporation (February 2005). "Intel Chipset 4 GB System Memory Support" (pdf). Pentium Pro Family Developer’s Manual. p. 8.
  7. ^ Intel Corporation (February 2005). "Intel Chipset 4 GB System Memory Support" (pdf). Pentium Pro Family Developer’s Manual. p. 13,14. In order to use remapping, the operating system must be able to address ranges higher than 4 GB of memory
  8. "Understanding Intel Mac RAM".
  9. Mark Russinovich (2008-07-21). "Pushing the Limits of Windows: Physical Memory". Archived from the original on 9 June 2010. Retrieved 2010-06-07. The problematic client driver ecosystem led to the decision for client SKUs to ignore physical memory that resides above 4GB, even though they can theoretically address it. 4GB is the licensed limit for 32-bit client SKUs. {{cite web}}: Unknown parameter |deadurl= ignored (|url-status= suggested) (help)

External links

Categories: