From b9e03cbaed8c0d7804b72bb15a7aa5e0083cc1a6 Mon Sep 17 00:00:00 2001
From: Jeremy Soller <jeremy@system76.com>
Date: Sun, 14 Apr 2019 19:09:10 -0600
Subject: [PATCH] Implement __tls_get_addr

---
 src/header/dl-tls/mod.rs | 17 ++++++++++++++---
 1 file changed, 14 insertions(+), 3 deletions(-)

diff --git a/src/header/dl-tls/mod.rs b/src/header/dl-tls/mod.rs
index b61cc4ce..63a00fc7 100644
--- a/src/header/dl-tls/mod.rs
+++ b/src/header/dl-tls/mod.rs
@@ -10,7 +10,18 @@ pub struct dl_tls_index {
 }
 
 #[no_mangle]
-pub extern "C" fn __tls_get_addr(ti: *mut dl_tls_index) -> *mut c_void {
-    //TODO: Figure out how to implement this
-    unimplemented!();
+pub unsafe extern "C" fn __tls_get_addr(ti: *mut dl_tls_index) -> *mut c_void {
+    trace!("__tls_get_addr({:p}: {:#x}, {:#x})", ti, (*ti).ti_module, (*ti).ti_offset);
+    if let Some(tcb) = Tcb::current() {
+        if let Some(tls) = tcb.tls() {
+            if let Some(masters) = tcb.masters() {
+                if let Some(master) = masters.get((*ti).ti_module as usize) {
+                    let addr = tls.as_mut_ptr().add(master.offset + (*ti).ti_offset as usize);
+                    trace!("__tls_get_addr({:p}: {:#x}, {:#x}) = {:p}", ti, (*ti).ti_module, (*ti).ti_offset, addr);
+                    return addr as *mut c_void;
+                }
+            }
+        }
+    }
+    panic!("__tls_get_addr({:p}: {:#x}, {:#x}) failed", ti, (*ti).ti_module, (*ti).ti_offset);
 }
-- 
GitLab