aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/boot/mkcpustr.c
diff options
context:
space:
mode:
authorH. Peter Anvin <hpa@zytor.com>2008-09-16 15:09:26 -0700
committerH. Peter Anvin <hpa@zytor.com>2008-09-16 15:09:26 -0700
commit97fc0555dae8f4d437c8672c14d7191962429be4 (patch)
tree7cef9de931b66e43751c6535e5fcfdbb8389f307 /arch/x86/boot/mkcpustr.c
parenta9853dd6d285c30a3ddeb3cce8c05e1678400bef (diff)
downloadkernel_samsung_espresso10-97fc0555dae8f4d437c8672c14d7191962429be4.zip
kernel_samsung_espresso10-97fc0555dae8f4d437c8672c14d7191962429be4.tar.gz
kernel_samsung_espresso10-97fc0555dae8f4d437c8672c14d7191962429be4.tar.bz2
x86 setup: handle more than 8 CPU flag words
Checkin e38e05a85828dac23540cd007df5f20985388afc added a 9th CPU flag word, but didn't adjust the boot code to match. This patch adds the necessary boot code support. Note: due to a typo in an #if statement, it didn't trigger the #error this was supposed to do. Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'arch/x86/boot/mkcpustr.c')
-rw-r--r--arch/x86/boot/mkcpustr.c38
1 files changed, 19 insertions, 19 deletions
diff --git a/arch/x86/boot/mkcpustr.c b/arch/x86/boot/mkcpustr.c
index 4589caa..8ef60f2 100644
--- a/arch/x86/boot/mkcpustr.c
+++ b/arch/x86/boot/mkcpustr.c
@@ -17,31 +17,31 @@
#include "../kernel/cpu/capflags.c"
-#if NCAPFLAGS > 8
-# error "Need to adjust the boot code handling of CPUID strings"
-#endif
-
int main(void)
{
- int i;
+ int i, j;
const char *str;
printf("static const char x86_cap_strs[] = \n");
- for (i = 0; i < NCAPINTS*32; i++) {
- str = x86_cap_flags[i];
-
- if (i == NCAPINTS*32-1) {
- /* The last entry must be unconditional; this
- also consumes the compiler-added null character */
- if (!str)
- str = "";
- printf("\t\"\\x%02x\"\"%s\"\n", i, str);
- } else if (str) {
- printf("#if REQUIRED_MASK%d & (1 << %d)\n"
- "\t\"\\x%02x\"\"%s\\0\"\n"
- "#endif\n",
- i >> 5, i & 31, i, str);
+ for (i = 0; i < NCAPINTS; i++) {
+ for (j = 0; j < 32; j++) {
+ str = x86_cap_flags[i*32+j];
+
+ if (i == NCAPINTS-1 && j == 31) {
+ /* The last entry must be unconditional; this
+ also consumes the compiler-added null
+ character */
+ if (!str)
+ str = "";
+ printf("\t\"\\x%02x\\x%02x\"\"%s\"\n",
+ i, j, str);
+ } else if (str) {
+ printf("#if REQUIRED_MASK%d & (1 << %d)\n"
+ "\t\"\\x%02x\\x%02x\"\"%s\\0\"\n"
+ "#endif\n",
+ i, j, i, j, str);
+ }
}
}
printf("\t;\n");