From 76f3d08d26cbfd7dace2c0ea4f756f0e45c7a2ad Mon Sep 17 00:00:00 2001 From: Takanori Watanabe Date: Thu, 10 Apr 2008 18:38:31 +0000 Subject: [PATCH] Don't break identity mapping set up for ACPI resume path. With this change, BSP processor context seems to be recovered. --- sys/i386/i386/mp_machdep.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/sys/i386/i386/mp_machdep.c b/sys/i386/i386/mp_machdep.c index b472f055c748..a18d6a1b3677 100644 --- a/sys/i386/i386/mp_machdep.c +++ b/sys/i386/i386/mp_machdep.c @@ -718,6 +718,8 @@ assign_cpu_ids(void) /* * start each AP in our list */ +/* Lowest 1MB is already mapped: don't touch*/ +#define TMPMAP_START 1 static int start_all_aps(void) { @@ -742,8 +744,9 @@ start_all_aps(void) /* set up temporary P==V mapping for AP boot */ /* XXX this is a hack, we should boot the AP on its own stack/PTD */ + kptbase = (uintptr_t)(void *)KPTphys; - for (i = 0; i < NKPT; i++) + for (i = TMPMAP_START; i < NKPT; i++) PTD[i] = (pd_entry_t)(PG_V | PG_RW | ((kptbase + i * PAGE_SIZE) & PG_FRAME)); invltlb(); @@ -793,7 +796,7 @@ start_all_aps(void) #endif /* Undo V==P hack from above */ - for (i = 0; i < NKPT; i++) + for (i = TMPMAP_START; i < NKPT; i++) PTD[i] = 0; pmap_invalidate_range(kernel_pmap, 0, NKPT * NBPDR - 1);