seabios-convert-value-of-be16_to_cpu-to-u64-before-s.patch: be16_to_cpu(scsi_lun->lun[i]) is 16 bits and left shifting by more than 16 will have undefined behaviour. convert it to u64 before shifting. seabios-do-not-give-back-high-ram.patch: fix bug of Oracle 6 and 7 series virtual machines using the high ram returned by sebios. seabios-drop-yield-in-smp_setup.patch: Fix SeaBIOS stuck problem becuase SeaBIOS open hardware interrupt by invoking yield(). That's dangerous and unnecessary. Let's drop it, and make the processing of setup smp more security in SeaBIOS. seabios-fix-memory-leak-when-pci-check.patch: fix code memory leak when pci check failed free busses memory when pci_bios_check_devices function returns error in pci_setup() seabios-increase-the-seabios-high-mem-zone-size.patch: In terms of version and specification, under the maximum configuration specification of the number of vcpus, virtio blocks and other features, there exists bottleneck in seabios high_mem_zone, which results in the memory application failure and causes the vm to fail to start. Increase BUILD_MAX_HIGHTABLE to 512k. seabios-increase-the-seabios-minibiostable.patch: Increase the BUILD_MIN_BIOSTABLE to 4096; support 25 virtio-blk(data) + 1 virtio-scsi(sys) + 1 virtio-net Increase the BUILD_MIN_BIOSTABLE to 5120; support 18 virtio-scsi while vm starts with IDE boot disk Signed-off-by: jiangdongxu <jiangdongxu1@huawei.com>
40 lines
1.4 KiB
Diff
40 lines
1.4 KiB
Diff
From 1a8defda890d6fe3efe2238cff1ef2ae6ca8928c Mon Sep 17 00:00:00 2001
|
|
From: jiangdongxu <jiangdongxu1@huawei.com>
|
|
Date: Fri, 11 Feb 2022 16:31:25 +0800
|
|
Subject: [PATCH 4/6] seabios: drop yield() in smp_setup()
|
|
|
|
Fix SeaBIOS stuck problem becuase SeaBIOS open hardware interrupt
|
|
by invoking yield(). That's dangerous and unnecessary. Let's drop
|
|
it, and make the processing of setup smp more security in SeaBIOS.
|
|
|
|
Signed-off-by: liuxiangdong <liuxiangdong5@huawei.com>
|
|
Signed-off-by: jiangdongxu <jiangdongxu1@huawei.com>
|
|
---
|
|
roms/seabios/src/fw/smp.c | 3 ++-
|
|
1 file changed, 2 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/roms/seabios/src/fw/smp.c b/roms/seabios/src/fw/smp.c
|
|
index 46d1da1784..e5e407be0c 100644
|
|
--- a/roms/seabios/src/fw/smp.c
|
|
+++ b/roms/seabios/src/fw/smp.c
|
|
@@ -149,6 +149,7 @@ smp_scan(void)
|
|
|
|
// Wait for other CPUs to process the SIPI.
|
|
u16 expected_cpus_count = qemu_get_present_cpus_count();
|
|
+ dprintf(1,"expected_cpus_count=%d\n", expected_cpus_count);
|
|
while (expected_cpus_count != CountCPUs)
|
|
asm volatile(
|
|
// Release lock and allow other processors to use the stack.
|
|
@@ -160,7 +161,7 @@ smp_scan(void)
|
|
" jc 1b\n"
|
|
: "+m" (SMPLock), "+m" (SMPStack)
|
|
: : "cc", "memory");
|
|
- yield();
|
|
+ dprintf(1, "finish smp\n");
|
|
|
|
// Restore memory.
|
|
*(u64*)BUILD_AP_BOOT_ADDR = old;
|
|
--
|
|
2.27.0
|
|
|