diff --git a/proc.c b/proc.c index 91a58010c603e4b07092420c978ae9d3acb4d61b..e83e0f7ca3bb21e049965e78b7acff6d25e45b00 100644 --- a/proc.c +++ b/proc.c @@ -70,12 +70,13 @@ ksegment(void) c = &cpus[cpunum()]; c->gdt[SEG_KCODE] = SEG(STA_X|STA_R, 0, 0x100000 + 64*1024-1, 0); c->gdt[SEG_KDATA] = SEG(STA_W, 0, 0xffffffff, 0); - c->gdt[SEG_KCPU] = SEG(STA_W, (uint)(&c->tls+1), 0xffffffff, 0); + c->gdt[SEG_KCPU] = SEG(STA_W, &c->tlsstruct, 0xffffffff, 0); lgdt(c->gdt, sizeof(c->gdt)); loadfsgs(SEG_KCPU << 3); - // Initialize cpu-local variables. + // Initialize cpu-local storage. c->tlsstruct = &c->tlsstruct; + asm volatile(""); // Do not let gcc reorder across this line. cpu = c; proc = 0; } diff --git a/proc.h b/proc.h index 10760f826f1018783925f6f8a2fbf5218e432a58..f20f67ec25cd70a764b6b0aa71e653b30de190e6 100644 --- a/proc.h +++ b/proc.h @@ -58,7 +58,10 @@ struct cpu { volatile uint booted; // Has the CPU started? int ncli; // Depth of pushcli nesting. int intena; // Were interrupts enabled before pushcli? - void *tls[2]; + + // "Thread"-local storage variables + struct cpu *cpu; + struct proc *proc; void *tlsstruct; };