The original address: manybutfinite.com/post/mother…
Note: This article was published on April, 2008.some of the content may be out of date
In order to make the reading smooth, some revisions and additions were made in the process of translation. Minor changes will not be marked separately, only large additions will be marked
I plan to write a series of articles on the internal knowledge of computers by explaining the operation mode of modern system kernel, taking Linux, Windows system and Intel chip as examples, hoping to provide some help to those who like this kind of knowledge but have no experience of programmers and enthusiasts. The first blog will describe modern Intel-based motherboards, explaining how the CPU accesses memory and system memory mapping.
Let’s start with what makes up a modern Intel computer. The following diagram shows the main components on the motherboard:
Schematic of a modern motherboard. “Chipset” consists of the north bridge and the south bridge.
As far as the CPU is concerned, it doesn’t really know what it’s connected to: the CPU communicates with the outside world through pins, but it doesn’t really care about what’s going on in the outside world, and it certainly doesn’t care where it’s mounted: A CPU might be on the motherboard of a real computer, but it might also be in an oven, in a router, in a brain implant, or on a CPU testing platform. No matter where it is installed, the CPU communicates with the outside world in three main ways: memory address space, I/O address space, and interrupt. In this blog, we’ll focus only on how the CPU communicates with memory via the motherboard.
On the motherboard, the CPU is accessed through a forward bus connected to the Northbridge: all read and write operations to the memory need to pass through this bus. The CPU uses some pins to transmit the physical addresses of the memory it wants to read or write to, and others to transmit the values it wants to write to or read from those addresses. The Intel Core 2 QX6600 CPU, for example, has 33 pins for transmitting physical memory addresses (access to 2^33 memory addresses) and 64 pins for receiving or sending data (data is transmitted in a 64-bit wide path). 64-bit wide paths are also called 8-byte chunks. As a result, the CPU can physically address 64GB of memory (2^33 * 8bit), although most chipsets at this point only support up to 8GB of memory.
We often think that “memory” refers to RAM when a program is running through a “memory address” — but this is not the case — although the vast majority of read and write requests from the CPU to a physical memory address are routed through the Northbridge to the RAM module, other than that, There are also physical memory addresses used to communicate between various devices on the motherboard: this communication method is called memory-mapped I/O, which allows the CPU to use some devices on the motherboard as memory, using the same way as accessing memory to access these devices. Such devices include graphics cards, most PCI cards (such as SCSI card scanners), and flash memory for the BIOS.
:
The physical memory address refers to a value in the memory address space. Memory address space is an abstract concept, which refers to the collection of all memory addresses accessible to the CPU. Some of these addresses may correspond to devices on the motherboard, while others may not have corresponding devices. So, if the address space is large, we can artificially specify that certain segments of the address space can correspond to certain devices, and then when the CPU gives the address it wants to visit, we can determine which device that address corresponds to based on the range of the address value.
In the following memory layout diagram, access to physical addresses from 0 to 640 KB is to RAM because the address space is mapped to RAM. Access to the 960KB to 1MB physical address will access the BIOS flash memory, because this address space is mapped to the System BIOS
Most of this address space is allocated to RAM, and the rest can be allocated to non-RAM devices. The mapping between physical memory addresses and non-RAM devices is called “memory-mapped I/O”.
When Northbridge receives a physical Memory access request, northbridge needs to decide where to route the request (for example, the Memory address may exist in RAM or graphics card). The route uses Memory map to select the device to which the access request will go. Memory address mapping will save each physical memory address area to the device map: most addresses are mapped to RAM, but when the requested address was not mapped to RAM, memory mapping chipset will be requested the address of the corresponding service equipment told chipset, let chipset know which device can go to access the address. It is this memory address mapping mechanism outside of the RAM module that causes the classic hole problem between 640KB and 1MB of PC memory. As computer RAM continues to expand, a new problem arises when the RAM address exceeds 3GB: Larger holes were created in the address space reserved for graphics cards and PCI devices. This is why 32-bit operating systems have problems with less than 4GB of available memory when using 4GB of memory (support.microsoft.com/zh-cn/topic…)
The following figure shows a typical memory map for the first 4GB physical memory address on an Intel PC:
The layout of the first 4GB of memory in an Intel computer. The actual address and range depend on the motherboard used by the computer and the devices in the computer. But on most Core2 computers it should look pretty much the same. All of the brown areas are mapped out of RAM. Note that the above addresses are physical addresses used in the motherboard bus. Addresses inside the CPU (for example, in our own running programs) are logical addresses that have to be translated by the CPU into physical addresses before they can be placed on the bus to access the device.
In Linux, you can view the current memory mapping using the /proc/iomem file
The following image shows the contents of the /proc/iomem file on the translator’s computer. Those of you who are diligent can get a calculator out and see how far you can match the following addresses
If you don’t work hard, I’ll work hard for you
Address 9f000, pointing to 636 KB
Address a0000, pointing to 640KB
Address f0000, pointing to 960KB
Address 100000, pointing to 1024th KB
This part is basically the same as the diagram above
The rules for converting logical addresses to physical addresses are complex and depend on the CPU’s current operating mode (real mode, 32-bit protected mode, 64-bit protected mode). Regardless of the conversion mechanism, the CPU operating mode determines how much memory the CPU can access. For example, if the CPU is running in 32-bit mode, it can only address 4GB of memory (though there is an exception called “physical address extension,” which we’ll leave out for now).
However, because the 1GB of physical address at the top is mapped to the motherboard device, the ACTUAL memory that the CPU can access efficiently is only about 3GB (sometimes less than 3GB — one of my Windows Vista machines had only 2.4GB of available memory). If the CPU was running in real mode (which was the only mode supported by early Intel cpus), the CPU could access only 1MB of physical RAM. Some cpus running in 64-bit mode can physically address 64GB of RAM (although only a few chipsets support 64GB of RAM). In 64-bit mode, the CPU can access other devices on the motherboard using physical addresses outside the total memory space supported by the system — the physical memory addresses of these devices can be arranged outside the physical address space of all RAM. The method is called reclaiming Memory and requires a chipset and CPU to claiming memory.
That’s all you need to understand your next blog post. The next blog post will describe the entire process from powering up to the upcoming jump to the kernel by bootloader. If you like these, I strongly recommend you read Intel Manuals. Intel Manuals has been written quite well and accurately. Here’s part of it:
- Datasheet for Intel G35 Chipset documents a representative chipset for Core 2 processors. This is the main source for this post.
- Datasheet for Intel Core 2 Quad-Core Q6000 Sequence is a processor datasheet. It documents each pin in the processor There aren’t that many actually, and after you group them there’s really not a lot to it. though some bits are arcane.
- The Intel Software Developer’s Manuals are outstanding. Far from Arcane, Manuals are Manuals. They explain beautifully all sorts of things about the architecture. Volumes 1 and 3A have the good stuff (Don’t be put Off by the name, the “volumes” are small and you can read The Weekend.
- Padraig Brady suggested that I link to Ulrich Drepper’s excellent paper on memory. It’s great stuff. I was waiting to link to it in a post about memory, but the more the merrier.
\