ports@,
Just sent an email to tech@ about this, subject:
vmd(8): create a proper e820 bios memory map
https://marc.info/?l=openbsd-tech&m=167071344902372&w=2
In short, this nukes some old hacks we've been carrying to communicate
things like >4GB of memory to SeaBIOS via CMOS. It assumes vmd(8)
properly builds and conveys a bios e820 memory map via the fw_cfg api.
While nuking, I also ripped out the etc/screen-and-debug tweak as vmd
has been communicating that value (0) via fw_cfg for awhile now. There's
no need to patch that.
The below diff isn't ready to commit until the changes to vmm/vmd land
(assuming they do), but I wanted to share this for any testers and get
eyeballs on my approach.
btw, I'm not bumping the SeaBIOS version at all, just revision.
-dv
diff refs/heads/master refs/heads/seabios-e820
commit - 2e9128e724420d4d786f1537c31c67623878de0a
commit + e27c83b9ed21ac29efaa0a8b2d8238af95799b0c
blob - ba30a80601c23dfd2f64eaa489418518c1f75800
blob + 32d68c925aa891000fdf411899d58bbe3805f333
--- sysutils/firmware/vmm/Makefile
+++ sysutils/firmware/vmm/Makefile
@@ -17,7 +17,7 @@ REVISION= 0
FW_VER= 1.14.0
SB_VER= 20180715
DISTNAME= seabios-${FW_VER}
-REVISION= 0
+REVISION= 1
DISTFILES= ${DISTNAME}${EXTRACT_SUFX} \
sgabios-${SB_VER}{72f39d48bedf044e202fd51fecf3e2218fc2ae66}.tar.gz:0
blob - 2382176b2d3b8f3ca809985fa0cafc40423a3a79
blob + f81983fb071984dafe9a24ff6781244dbcd0086d
--- sysutils/firmware/vmm/patches/patch-src_fw_paravirt_c
+++ sysutils/firmware/vmm/patches/patch-src_fw_paravirt_c
@@ -1,11 +1,9 @@
- Don't use 'rep insb' to read IO ports, vmm does not support that yet.
-- Allow detection of >4GB RAM. Normally seabios only allows this with the
- QEMU config device which VMM does not have.
Index: src/fw/paravirt.c
--- src/fw/paravirt.c.orig
+++ src/fw/paravirt.c
-@@ -310,7 +310,9 @@ qemu_cfg_read(void *buf, int len)
+@@ -310,6 +310,8 @@ qemu_cfg_read(void *buf, int len)
if (qemu_cfg_dma_enabled()) {
qemu_cfg_dma_transfer(buf, len, QEMU_CFG_DMA_CTL_READ);
} else {
@@ -15,23 +13,3 @@ Index: src/fw/paravirt.c
+ *d++ = inb(PORT_QEMU_CFG_DATA);
}
}
-
-@@ -515,6 +517,18 @@ qemu_cfg_e820(void)
- e820_add(0xfffbc000, 4*4096, E820_RESERVED);
- }
-
-+ // Check for memory over 4Gig in cmos
-+ u64 high = ((rtc_read(CMOS_MEM_HIGHMEM_LOW) << 16)
-+ | ((u32)rtc_read(CMOS_MEM_HIGHMEM_MID) << 24)
-+ | ((u64)rtc_read(CMOS_MEM_HIGHMEM_HIGH) << 32));
-+ RamSizeOver4G = high;
-+ e820_add(0x100000000ull, high, E820_RAM);
-+ dprintf(1, "RamSizeOver4G: 0x%016llx [cmos]\n", RamSizeOver4G);
-+}
-+
-+void
-+vmm_check_high_mem(void)
-+{
- // Check for memory over 4Gig in cmos
- u64 high = ((rtc_read(CMOS_MEM_HIGHMEM_LOW) << 16)
- | ((u32)rtc_read(CMOS_MEM_HIGHMEM_MID) << 24)
blob - 06accf4cae866712fc782ccc6920e20184ee1957 (mode 644)
blob + /dev/null
--- sysutils/firmware/vmm/patches/patch-src_fw_paravirt_h
+++ /dev/null
@@ -1,12 +0,0 @@
-Allow detection of >4GB RAM. Normally seabios only allows this with the
-QEMU config device which VMM does not have.
-
-Index: src/fw/paravirt.h
---- src/fw/paravirt.h.orig
-+++ src/fw/paravirt.h
-@@ -75,4 +75,5 @@ int qemu_cfg_write_file(void *src, struct romfile_s *f
- int qemu_cfg_write_file_simple(void *src, u16 key, u32 offset, u32 len);
- u16 qemu_get_romfile_key(struct romfile_s *file);
-
-+void vmm_check_high_mem(void);
- #endif
blob - ac0a7376d85a599c2dba0703fdd0e499a9837bde
blob + 89b46991f85530edc0c2fb5c808c9c84a5ecdf5b
--- sysutils/firmware/vmm/patches/patch-src_optionroms_c
+++ sysutils/firmware/vmm/patches/patch-src_optionroms_c
@@ -1,25 +1,15 @@
- Needed for SGABIOS option ROM for VMM. Normally these are setup based on
the QEMU fw_cfg interface (or coreboot CBFS on hardware).
-- Turn off screen-and-debug to prevent double printing of chars.
Index: src/optionroms.c
--- src/optionroms.c.orig
+++ src/optionroms.c
@@ -387,7 +387,7 @@ optionrom_setup(void)
-
+
// All option roms found and deployed - now build BEV/BCV vectors.
-
+
- u32 pos = post_vga;
+ u32 pos = BUILD_BIOS_ADDR - BUILD_ROM_START;
while (pos < rom_get_last()) {
struct rom_header *rom = (void*)pos;
if (! is_valid_rom(rom)) {
-@@ -461,7 +461,7 @@ vgarom_setup(void)
- EnforceChecksum = romfile_loadint("etc/optionroms-checksum", 1);
- S3ResumeVga = romfile_loadint("etc/s3-resume-vga-init", CONFIG_QEMU);
- RunPCIroms = romfile_loadint("etc/pci-optionrom-exec", 2);
-- ScreenAndDebug = romfile_loadint("etc/screen-and-debug", 1);
-+ ScreenAndDebug = romfile_loadint("etc/screen-and-debug", 0);
-
- // Clear option rom memory
- memset((void*)BUILD_ROM_START, 0, rom_get_max() - BUILD_ROM_START);
blob - b95bf5b010beb1dcbe4f508992a42b8d386a523c (mode 644)
blob + /dev/null
--- sysutils/firmware/vmm/patches/patch-src_post_c
+++ /dev/null
@@ -1,14 +0,0 @@
-Allow detection of >4GB RAM. Normally seabios only allows this with the
-QEMU config device which VMM does not have.
-
-Index: src/post.c
---- src/post.c.orig
-+++ src/post.c
-@@ -106,6 +106,7 @@ interface_init(void)
-
- // Setup romfile items.
- qemu_cfg_init();
-+ vmm_check_high_mem();
- coreboot_cbfs_init();
- multiboot_init();
-