mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-01 15:58:50 +00:00
ef836b9932
Add documention for the x86 'mtrr' command. Signed-off-by: Simon Glass <sjg@chromium.org> Reviewed-by: Bin Meng <bmeng.cn@gmail.com> Suggested-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
151 lines
5.8 KiB
ReStructuredText
151 lines
5.8 KiB
ReStructuredText
.. SPDX-License-Identifier: GPL-2.0+:
|
|
|
|
mtrr command
|
|
============
|
|
|
|
Synopis
|
|
-------
|
|
|
|
mtrr [list]
|
|
mtrr set <reg> <type> <start> <size>
|
|
mtrr disable <reg>
|
|
mtrr enable
|
|
|
|
|
|
Description
|
|
-----------
|
|
|
|
The *mtrr* command is used to dump the Memory Type Range Registers (MTRRs) on
|
|
an x86 machine. These register control cache behaviour in selected memory
|
|
ranges.
|
|
|
|
Note that the number of registers can vary between CPUs.
|
|
|
|
|
|
mtrr [list]
|
|
~~~~~~~~~~~
|
|
|
|
List the MTRRs. The table shows the following information:
|
|
|
|
Reg
|
|
Register number (the first is register 0)
|
|
|
|
Valid
|
|
Shows Y if the register is valid (has bit 11 set), N if not
|
|
|
|
Write-type
|
|
Shows the behaviour when writing to the memory region. The types are
|
|
abbreviated to fit a reasonable line length. Valid types shown below.
|
|
|
|
====== ============== ====================================================
|
|
Value Type Meaning
|
|
====== ============== ====================================================
|
|
0 Uncacheable Skip cache and write directly to memory
|
|
1 Combine Multiple writes can be combined into one transaction
|
|
4 Through Update cache and also write to memory
|
|
5 Protect Writes are prohibited
|
|
6 Back Update cache but don't write to memory
|
|
====== ============== ====================================================
|
|
|
|
Base
|
|
Base memory address from which the register controls behaviour
|
|
|
|
Mask
|
|
Mask value, which also indicates the size
|
|
|
|
Size
|
|
Length of memory region within which the register controls behaviour
|
|
|
|
|
|
mtrr set
|
|
~~~~~~~~
|
|
|
|
This sets the value of a particular MTRR. Parameters are:
|
|
|
|
reg
|
|
Register number to set, with 0 being the first
|
|
|
|
type
|
|
Access type to set. See Write-type above for valid types. This uses the name
|
|
rather than its numeric value.
|
|
|
|
start
|
|
Base memory address from which the register should control behaviour
|
|
|
|
size
|
|
Length of memory region within which the register controls behaviour
|
|
|
|
|
|
mtrr disable
|
|
~~~~~~~~~~~~
|
|
|
|
This disables a particular register, by clearing its `valid` bit (11).
|
|
|
|
|
|
mtrr enable
|
|
~~~~~~~~~~~
|
|
|
|
This enables a particular register, by setting its `valid` bit (11).
|
|
|
|
|
|
Example
|
|
-------
|
|
|
|
This shows disabling and enabling an MTRR, as well as setting its type::
|
|
|
|
=> mtrr
|
|
CPU 0:
|
|
Reg Valid Write-type Base || Mask || Size ||
|
|
0 Y Back 0000000000000000 0000000f80000000 0000000080000000
|
|
1 Y Back 0000000080000000 0000000fe0000000 0000000020000000
|
|
2 Y Back 00000000a0000000 0000000ff0000000 0000000010000000
|
|
3 Y Uncacheable 00000000ad000000 0000000fff000000 0000000001000000
|
|
4 Y Uncacheable 00000000ae000000 0000000ffe000000 0000000002000000
|
|
5 Y Combine 00000000d0000000 0000000ff0000000 0000000010000000
|
|
6 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
7 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
8 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
9 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
=> mtrr d 5
|
|
=> mtrr
|
|
CPU 0:
|
|
Reg Valid Write-type Base || Mask || Size ||
|
|
0 Y Back 0000000000000000 0000000f80000000 0000000080000000
|
|
1 Y Back 0000000080000000 0000000fe0000000 0000000020000000
|
|
2 Y Back 00000000a0000000 0000000ff0000000 0000000010000000
|
|
3 Y Uncacheable 00000000ad000000 0000000fff000000 0000000001000000
|
|
4 Y Uncacheable 00000000ae000000 0000000ffe000000 0000000002000000
|
|
5 N Combine 00000000d0000000 0000000ff0000000 0000000010000000
|
|
6 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
7 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
8 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
9 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
=> mtrr e 5
|
|
=> mtrr
|
|
CPU 0:
|
|
Reg Valid Write-type Base || Mask || Size ||
|
|
0 Y Back 0000000000000000 0000000f80000000 0000000080000000
|
|
1 Y Back 0000000080000000 0000000fe0000000 0000000020000000
|
|
2 Y Back 00000000a0000000 0000000ff0000000 0000000010000000
|
|
3 Y Uncacheable 00000000ad000000 0000000fff000000 0000000001000000
|
|
4 Y Uncacheable 00000000ae000000 0000000ffe000000 0000000002000000
|
|
5 Y Combine 00000000d0000000 0000000ff0000000 0000000010000000
|
|
6 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
7 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
8 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
9 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
=> mtrr set 5 Uncacheable d0000000 10000000
|
|
=> mtrr
|
|
CPU 0:
|
|
Reg Valid Write-type Base || Mask || Size ||
|
|
0 Y Back 0000000000000000 0000000f80000000 0000000080000000
|
|
1 Y Back 0000000080000000 0000000fe0000000 0000000020000000
|
|
2 Y Back 00000000a0000000 0000000ff0000000 0000000010000000
|
|
3 Y Uncacheable 00000000ad000000 0000000fff000000 0000000001000000
|
|
4 Y Uncacheable 00000000ae000000 0000000ffe000000 0000000002000000
|
|
5 Y Uncacheable 00000000d0000000 0000000ff0000000 0000000010000000
|
|
6 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
7 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
8 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
9 N Uncacheable 0000000000000000 0000000000000000 0000001000000000
|
|
=>
|