From f8ab2079cda8fc89f576b3b78a23a9c62891d74d Mon Sep 17 00:00:00 2001 From: Russ Cox Date: Wed, 2 Sep 2009 07:59:24 -0700 Subject: [PATCH] fix TLS again; still not quite but a lot better. --- proc.c | 5 +++-- proc.h | 5 ++++- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/proc.c b/proc.c index 91a5801..e83e0f7 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 10760f8..f20f67e 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; };