diff options
author | Ian Moffett <ian@osmora.org> | 2025-09-16 23:18:03 -0400 |
---|---|---|
committer | Ian Moffett <ian@osmora.org> | 2025-09-16 23:19:30 -0400 |
commit | 8ae23738c78f58bea882dba11080d7052453e71d (patch) | |
tree | 93268fc5e4f8ca1025f882795c5badc0a56ec181 /src/sys/arch/amd64/boot | |
parent | c5ada50b5e897683c2317591331fa94f3ec1a2b1 (diff) |
kern/amd64: cpu: Make GDT per-cpu to match TSS
Signed-off-by: Ian Moffett <ian@osmora.org>
Diffstat (limited to 'src/sys/arch/amd64/boot')
-rw-r--r-- | src/sys/arch/amd64/boot/boot_chip.c | 4 | ||||
-rw-r--r-- | src/sys/arch/amd64/boot/boot_gdt.c | 5 |
2 files changed, 3 insertions, 6 deletions
diff --git a/src/sys/arch/amd64/boot/boot_chip.c b/src/sys/arch/amd64/boot/boot_chip.c index 2ff122c..76753d5 100644 --- a/src/sys/arch/amd64/boot/boot_chip.c +++ b/src/sys/arch/amd64/boot/boot_chip.c @@ -61,8 +61,10 @@ static void init_tss(struct pcore *pcore) { struct tss_desc *desc; + struct mdcore *mdcore; - desc = (struct tss_desc *)&g_gdt_data[GDT_TSS_INDEX]; + mdcore = &pcore->md; + desc = (struct tss_desc *)&mdcore->gdt[GDT_TSS_INDEX]; write_tss(pcore, desc); tss_load(); } diff --git a/src/sys/arch/amd64/boot/boot_gdt.c b/src/sys/arch/amd64/boot/boot_gdt.c index 2c1ada6..64b3f2b 100644 --- a/src/sys/arch/amd64/boot/boot_gdt.c +++ b/src/sys/arch/amd64/boot/boot_gdt.c @@ -91,8 +91,3 @@ struct gdt_entry g_gdt_data[GDT_ENTRY_COUNT] = { /* Verify that the GDT is of the correct size */ __static_assert(sizeof(g_gdt_data) == (8 * GDT_ENTRY_COUNT)); - -const struct gdtr g_gdtr = { - .limit = sizeof(g_gdt_data) - 1, - .offset = (uintptr_t)&g_gdt_data[0] -}; |