]> git.proxmox.com Git - mirror_edk2.git/commitdiff
OvmfPkg/IndustryStandard: add MCH_DEFAULT_SMBASE* register macros
authorLaszlo Ersek <lersek@redhat.com>
Fri, 20 Sep 2019 11:05:58 +0000 (13:05 +0200)
committermergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
Wed, 5 Feb 2020 12:59:32 +0000 (12:59 +0000)
In Intel datasheet 316966-002 (the "q35 spec"), Table 5-1 "DRAM Controller
Register Address Map (D0:F0)" leaves the byte register at config space
offset 0x9C unused.

On QEMU's Q35 board, for detecting the "SMRAM at default SMBASE" feature,
firmware is expected to write MCH_DEFAULT_SMBASE_QUERY (0xFF) to offset
MCH_DEFAULT_SMBASE_CTL (0x9C), and read back the register. If the value is
MCH_DEFAULT_SMBASE_IN_RAM (0x01), then the feature is available, and the
range mentioned below is open (accessible to code running outside of SMM).

Then, once firmware writes MCH_DEFAULT_SMBASE_LCK (0x02) to the register,
the MCH_DEFAULT_SMBASE_SIZE (128KB) range at 0x3_0000 (SMM_DEFAULT_SMBASE)
gets closed and locked down, and the register becomes read-only. The area
is reopened, and the register becomes read/write, at platform reset.

Add the above-listed macros to "Q35MchIch9.h".

(There are some other unused offsets in Table 5-1; for example we had
scavenged 0x50 for implementing the extended TSEG feature. 0x9C is the
first byte-wide register standing in isolation after 0x50.)

Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Cc: Jordan Justen <jordan.l.justen@intel.com>
Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=1512
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
Reviewed-by: Jiewen Yao <jiewen.yao@intel.com>
Message-Id: <20200129214412.2361-4-lersek@redhat.com>
Reviewed-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
OvmfPkg/Include/IndustryStandard/Q35MchIch9.h

index 80379c223a1cf4a2af1bd8e32c0c42f408727033..cb705fee92ca91770bb8d953cea538effb7f830a 100644 (file)
 #define MCH_PAM5                  0x95\r
 #define MCH_PAM6                  0x96\r
 \r
+#define MCH_DEFAULT_SMBASE_CTL    0x9C\r
+#define MCH_DEFAULT_SMBASE_QUERY    0xFF\r
+#define MCH_DEFAULT_SMBASE_IN_RAM   0x01\r
+#define MCH_DEFAULT_SMBASE_LCK      0x02\r
+#define MCH_DEFAULT_SMBASE_SIZE     SIZE_128KB\r
+\r
 #define MCH_SMRAM                 0x9D\r
 #define MCH_SMRAM_D_LCK             BIT4\r
 #define MCH_SMRAM_G_SMRAME          BIT3\r