From baef8a666c137fae513a195c8abeb80e1806d7bd Mon Sep 17 00:00:00 2001 From: Jes Sorensen Date: Thu, 23 Jul 2009 17:03:43 +0200 Subject: [PATCH] QEMU BOCHS bios patches to use maxcpus value. Signed-off-by: Jes Sorensen Signed-off-by: Anthony Liguori --- .../bios-pq/0020-qemu-kvm-cfg-maxcpus.patch | 62 ++++++++++ pc-bios/bios-pq/0021-qemu-madt-maxcpus.patch | 117 ++++++++++++++++++ pc-bios/bios-pq/series | 2 + pc-bios/bios.bin | Bin 131072 -> 131072 bytes 4 files changed, 181 insertions(+) create mode 100644 pc-bios/bios-pq/0020-qemu-kvm-cfg-maxcpus.patch create mode 100644 pc-bios/bios-pq/0021-qemu-madt-maxcpus.patch diff --git a/pc-bios/bios-pq/0020-qemu-kvm-cfg-maxcpus.patch b/pc-bios/bios-pq/0020-qemu-kvm-cfg-maxcpus.patch new file mode 100644 index 0000000000..50e9b8c714 --- /dev/null +++ b/pc-bios/bios-pq/0020-qemu-kvm-cfg-maxcpus.patch @@ -0,0 +1,62 @@ +Read max_cpus variable from QEMU_CFG. If not provided, use value of +smp_cpus. + +Signed-off-by: Jes Sorensen + +diff --git a/bios/rombios.h b/bios/rombios.h +index 8ece2ee..dbf3bd3 100644 +--- a/bios/rombios.h ++++ b/bios/rombios.h +@@ -65,6 +65,7 @@ + #define QEMU_CFG_UUID 0x02 + #define QEMU_CFG_NUMA 0x0d + #define QEMU_CFG_BOOT_MENU 0x0e ++#define QEMU_CFG_MAX_CPUS 0x0f + #define QEMU_CFG_ARCH_LOCAL 0x8000 + #define QEMU_CFG_ACPI_TABLES (QEMU_CFG_ARCH_LOCAL + 0) + #define QEMU_CFG_SMBIOS_ENTRIES (QEMU_CFG_ARCH_LOCAL + 1) +diff --git a/bios/rombios32.c b/bios/rombios32.c +index 69e82b1..610fc1f 100644 +--- a/bios/rombios32.c ++++ b/bios/rombios32.c +@@ -436,6 +436,7 @@ void delay_ms(int n) + } + + uint16_t smp_cpus; ++uint16_t max_cpus; + uint32_t cpuid_signature; + uint32_t cpuid_features; + uint32_t cpuid_ext_features; +@@ -526,6 +527,19 @@ static uint16_t smbios_entries(void) + return cnt; + } + ++static uint16_t get_max_cpus(void) ++{ ++ uint16_t cnt; ++ ++ qemu_cfg_select(QEMU_CFG_MAX_CPUS); ++ qemu_cfg_read((uint8_t*)&cnt, sizeof(cnt)); ++ ++ if (!cnt) ++ cnt = smp_cpus; ++ ++ return cnt; ++} ++ + uint64_t qemu_cfg_get64 (void) + { + uint64_t ret; +@@ -2689,6 +2703,12 @@ void rombios32_init(uint32_t *s3_resume_vector, uint8_t *shutdown_flag) + + smp_probe(); + ++#ifdef BX_QEMU ++ max_cpus = get_max_cpus(); ++#else ++ max_cpus = smp_cpus; ++#endif ++ + find_bios_table_area(); + + if (*shutdown_flag == 0xfe) { diff --git a/pc-bios/bios-pq/0021-qemu-madt-maxcpus.patch b/pc-bios/bios-pq/0021-qemu-madt-maxcpus.patch new file mode 100644 index 0000000000..49a0fdd7a5 --- /dev/null +++ b/pc-bios/bios-pq/0021-qemu-madt-maxcpus.patch @@ -0,0 +1,117 @@ +Use max_cpus when building bios tables. + +Signed-off-by: Jes Sorensen + +diff --git a/bios/rombios32.c b/bios/rombios32.c +index e6bb164..3d15283 100644 +--- a/bios/rombios32.c ++++ b/bios/rombios32.c +@@ -1145,23 +1145,25 @@ static void mptable_init(void) + putle32(&q, 0); /* OEM table ptr */ + putle16(&q, 0); /* OEM table size */ + #ifdef BX_QEMU +- putle16(&q, smp_cpus + 17); /* entry count */ ++ putle16(&q, max_cpus + 17); /* entry count */ + #else +- putle16(&q, smp_cpus + 18); /* entry count */ ++ putle16(&q, max_cpus + 18); /* entry count */ + #endif + putle32(&q, 0xfee00000); /* local APIC addr */ + putle16(&q, 0); /* ext table length */ + putb(&q, 0); /* ext table checksum */ + putb(&q, 0); /* reserved */ + +- for(i = 0; i < smp_cpus; i++) { ++ for(i = 0; i < max_cpus; i++) { + putb(&q, 0); /* entry type = processor */ + putb(&q, i); /* APIC id */ + putb(&q, 0x11); /* local APIC version number */ + if (i == 0) + putb(&q, 3); /* cpu flags: enabled, bootstrap cpu */ +- else ++ else if (i < smp_cpus) + putb(&q, 1); /* cpu flags: enabled */ ++ else ++ putb(&q, 0); /* cpu flags: disabled */ + putb(&q, 0); /* cpu signature */ + putb(&q, 6); + putb(&q, 0); +@@ -1181,7 +1183,7 @@ static void mptable_init(void) + putstr(&q, "ISA "); + + /* ioapic */ +- ioapic_id = smp_cpus; ++ ioapic_id = max_cpus; + putb(&q, 2); /* entry type = I/O APIC */ + putb(&q, ioapic_id); /* apic ID */ + putb(&q, 0x11); /* I/O APIC version number */ +@@ -1581,7 +1583,7 @@ int acpi_build_processor_ssdt(uint8_t *ssdt) + { + uint8_t *ssdt_ptr = ssdt; + int i, length; +- int acpi_cpus = smp_cpus > 0xff ? 0xff : smp_cpus; ++ int acpi_cpus = max_cpus > 0xff ? 0xff : max_cpus; + + ssdt_ptr[9] = 0; // checksum; + ssdt_ptr += sizeof(struct acpi_table_header); +@@ -1713,7 +1715,7 @@ void acpi_bios_init(void) + addr = (addr + 7) & ~7; + srat_addr = addr; + srat_size = sizeof(*srat) + +- sizeof(struct srat_processor_affinity) * smp_cpus + ++ sizeof(struct srat_processor_affinity) * max_cpus + + sizeof(struct srat_memory_affinity) * (nb_numa_nodes + 2); + srat = (void *)(addr); + addr += srat_size; +@@ -1726,7 +1728,7 @@ void acpi_bios_init(void) + addr = (addr + 7) & ~7; + madt_addr = addr; + madt_size = sizeof(*madt) + +- sizeof(struct madt_processor_apic) * smp_cpus + ++ sizeof(struct madt_processor_apic) * max_cpus + + #ifdef BX_QEMU + sizeof(struct madt_io_apic) + sizeof(struct madt_int_override); + #else +@@ -1799,18 +1801,21 @@ void acpi_bios_init(void) + madt->local_apic_address = cpu_to_le32(0xfee00000); + madt->flags = cpu_to_le32(1); + apic = (void *)(madt + 1); +- for(i=0;itype = APIC_PROCESSOR; + apic->length = sizeof(*apic); + apic->processor_id = i; + apic->local_apic_id = i; +- apic->flags = cpu_to_le32(1); ++ if (i < smp_cpus) ++ apic->flags = cpu_to_le32(1); ++ else ++ apic->flags = 0; + apic++; + } + io_apic = (void *)apic; + io_apic->type = APIC_IO; + io_apic->length = sizeof(*io_apic); +- io_apic->io_apic_id = smp_cpus; ++ io_apic->io_apic_id = max_cpus; + io_apic->address = cpu_to_le32(0xfec00000); + io_apic->interrupt = cpu_to_le32(0); + #ifdef BX_QEMU +@@ -1844,7 +1849,7 @@ void acpi_bios_init(void) + srat->reserved1=1; + + core = (void*)(srat + 1); +- for (i = 0; i < smp_cpus; ++i) { ++ for (i = 0; i < max_cpus; ++i) { + core->type = SRAT_PROCESSOR; + core->length = sizeof(*core); + core->local_apic_id = i; +@@ -2603,7 +2608,7 @@ void smbios_init(void) + add_struct(0, p); + add_struct(1, p); + add_struct(3, p); +- for (cpu_num = 1; cpu_num <= smp_cpus; cpu_num++) ++ for (cpu_num = 1; cpu_num <= max_cpus; cpu_num++) + add_struct(4, p, cpu_num); + + /* Each 'memory device' covers up to 16GB of address space. */ diff --git a/pc-bios/bios-pq/series b/pc-bios/bios-pq/series index 695b148ad6..0422dec96e 100644 --- a/pc-bios/bios-pq/series +++ b/pc-bios/bios-pq/series @@ -17,3 +17,5 @@ 0017-bochs-bios-Move-QEMU_CFG-constants-to-rombios.h.patch 0018-bochs-bios-Make-boot-prompt-optional.patch 0019-bios-fix-multiple-calls.patch +0020-qemu-kvm-cfg-maxcpus.patch +0021-qemu-madt-maxcpus.patch diff --git a/pc-bios/bios.bin b/pc-bios/bios.bin index e4323c0504f8f4faf72d56e288c0d457b37bf442..dc7d3825ec59a33f065ea005014ffcf3a8b1b632 100644 GIT binary patch delta 2143 zcmYjSeN0nV6o0q0P-o#4Y?Ti|gu(`5uys?bf>5YV6lI$xench4G;U*yZtZjtr1*-y zmuF4&F6!dUf;bX&Guui4>%t!BTF`wEvPIE-bWUawoCwLpFYeBL1=$}xx#!&9x#zs! z`KZ&Wb~@E@M(NwsD2BQ45s0iu!)IG}AC6msD!+OiMIZ^UiMWM!dgm)2BD4?ZMkb>D zxFixM@c(Z@^egzj5(nxK;`&X%}sR3 z+Y-G&mF=SG+~6dZ3l0j_Mou!+Q&S7$WEk81uVV*z>p$?jUuVaQryNq(!yVh4T#mb^ zY(^Lxb-KwXAf)4-SlZ}2fXj4xYynTMcj!{kC-{!;4gD#a+EN5*)XOIY zoKEA_`uOAq&;v??l3|$8q-TT}yWNeMpfGIHzH;o+n~TaJEMw0#cG^6AiNYxHB@uoF zvxpr!z_+7vF6-ej-kcMqmmE#fpbkv6RQ(r{Kao$u1(BPfA zT_-yqk+@4pC{%K7TALX@E_d2RC`13WGLVbof7JRRLDA}j91+d&B2G-08+|pLwQSjg zHzZU7_*%lM>Rt*iJqJu!b*cCP;5}@mc%eZr9mqc8`R_9 zA3H)w&E?||X5;29n=ZMV;KWeyK)y^8B_cHNkdVIlgpe_w=zUi>ohTIre2>p0`t_6r zq3U43>Y_6orllN+=xzNRhnVaPQWQ_0aYb7rBx)$gf>Z>gxKb8 zbC=^!AfMW3j?eJLG#6_Jt&R$6ipj^T(pLd>C(~ytQuDEtz8;iBLp#Xd32pIDt_<#kHP6e0 zR4(tlS(wiEm7Fw?_i|oRnDX(o*+*e=&(F?<2>6fLDWHtbK3kn5I^=@C9j>9==+a+= zuuYMagX#%0ZH3ThaAlNyS}3LM{slVH7h~Zp+!$b6Vdy1u7hBr^2I%;jNBiO0al3`K zVSNQq6ABCyBCG7F`tZuBp4d4d-!(!)y+Z(D!DB3jJmy0%=EF9wYKU=69;=y6unw`! z)*&AZ7-Ora{nXF8?U@YMuB~~@Fj~gGpk|?^_{mvV03}MdMJ+E6xu4;?I-tMZI<>G; zzZ*P(KFxTSe|L)zXZ|SbazWmqz)eEx=+>!~95LMGod0z`ET#($K##ngf`w@Ega{+V~@odxgT+22cBo z5Yw_8e8M$DJhZt2vT;d{2l7swWi+8Xc(XCR`W(E?$8zn6lhoW}cCTLuh}NL7b5>PQ zc*3t!ifeEB zqGZ|KZcsy)$wQS|Fu}#S-=Vwz9fWloeGsD5cCxi!Kv-Nc*HTUW=(PPX!MQwb3&BV3 zzC|ipNOu38Cr}6gt_wd5HYTJ8P~TR#@E1fWe6$Y0Q(x-n^A+ri0Gs;*rcVR5kPYDB w59}*~HEonUeafwm2|0#*Xo}bQa>3O`Wb09w<~MKeL7q&tX@2e;GxN0dKk!feX8-^I delta 2079 zcmZ8i3rtgI6uy6H;i|=3pg_w@#DbH@q~O%5%u*;uHxMUgQ->O78jWlrTRYi;Qg*@I zn`@Wqzw8k=H|AU-F-BLyqi*a{wpQHc3^7x54(HUh6Sc|`!3THezdTHqv?u4B|NQ@X zedk=KlXg1kSfluTdK5)$w2J&TkN5VGL;kx8fw zuZqOUO<>H&*ANSvZ zOuNbgjIrO?$CYS6DglWri2<%u=3;@f;x+1=S;USjNtv=qow7-jZ4RoS#)^i+MAb<-Dav;Do0uWadI$b@TWayLxcBLUaK?0`*5UrR zO=vAPYPB;qf=kD3p}ftz0#|C|Q8~70t!N8ArcFls@M&!tdKLezT^qlZgjR+ijMrpN z0o*pcI$oD*1392HC@G2xPJ1Fr#(q~@76=s6{$4t6iZ?B-1GkiYu2HnPIg5g`M6e?A zD=5DO(E*DR!6ECTZ6+15+jYgSK>PrlshJK{-GPJ@)QD3P=AtjKHNgSdpGw%SCx*-c zk?lo%v6Ai4*i5PN-A{3PvJO`z9)dOuCsqP2)t%Msg#ZPs6JjK;g1tCHUl=WnM=fhu zyj5Qh#)JBbxFf{4oD-}~llDijIVmyz{PQy@zTTkWOAYj7wt8HXq>DZVC!irY2LHwT zlj5S?<8RBF^Y~nS`!dH9XA zs_1>>ffLZ+GXW^|uW7THEuaysbkP2fBn4EQM@qYa0I@gHeTrX};iI!RqHS1}VVL$h z*ePrQRUIzKsF9sB?IIMN>F76|bNopP3l@P=gYr9kDx-<11*wG)qB>iIE9O){IX;^+ zTXD4ri*we4kYw-yy<#wfzqCv}(8ZZvXvc8orUEh=wtzWSrdpXMK-iVEAkPaNB}tOs ztfBno7*MOdO3Y?uqZ#;kRwkPdv&xh6@@=f{|)A0r@w@MTGAA^V}ZOmr~p4=EcrZLaQ}Z~#lB%LWO{nCTJ1)*&3P{+UU$BV4in71W`n1MAx67VIv7<;Y zvR4%VK5o?$c*AdbOu05_{Fbp8&LWL(fk-@%zqEkdg^Q-1`VagO$n}E4+X&(KOAyt$ zlKA%_4ltpBH;8|NVZ5`T0Nurh3g$F;pw3(j*svnaK4kXz`G8;z8~bv0hxtd`D@tKq zm>=mGp*f2R7O~hY?a`6&gz7NUu1tb^sK<1nA-a9+=}qc!qNtEi&(qi6kgd*Y&3IjDUjlH$Q=H`dH)&l04?l{=XOgDl?nS73wjid4>CMc9?gz_Q5 zY>