From f8ab2079cda8fc89f576b3b78a23a9c62891d74d Mon Sep 17 00:00:00 2001
From: Russ Cox <rsc@x40.(none)>
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;
 };
 
-- 
GitLab