From 2e5ded70c26c831c587f3e7574df11a84864ef22 Mon Sep 17 00:00:00 2001 From: Waldemar Brodkorb Date: Mon, 27 Apr 2020 12:37:25 +0200 Subject: add riscv macros from glibc --- test/tls/tls-macros-riscv.h | 48 +++++++++++++++++++++++++++++++++++++++++++++ test/tls/tls-macros.h | 4 ++++ 2 files changed, 52 insertions(+) create mode 100644 test/tls/tls-macros-riscv.h diff --git a/test/tls/tls-macros-riscv.h b/test/tls/tls-macros-riscv.h new file mode 100644 index 0000000..d18f923 --- /dev/null +++ b/test/tls/tls-macros-riscv.h @@ -0,0 +1,48 @@ +/* Macros to support TLS testing in times of missing compiler support. + Copyright (C) 2017-2020 Free Software Foundation, Inc. + + This file is part of the GNU C Library. + + The GNU C Library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library. If not, see + . */ + + +#include +#include +#include +#include "dl-tls.h" + +#define TLS_GD(x) \ + ({ void *__result; \ + asm ("la.tls.gd %0, " #x "\n\t" \ + : "=r" (__result)); \ + __tls_get_addr (__result); }) + +#define TLS_LD(x) TLS_GD(x) + +#define TLS_IE(x) \ + ({ void *__result; \ + asm ("la.tls.ie %0, " #x "\n\t" \ + "add %0, %0, tp\n\t" \ + : "=r" (__result)); \ + __result; }) + +#define TLS_LE(x) \ + ({ void *__result; \ + asm ("lui %0, %%tprel_hi(" #x ")\n\t" \ + "add %0, %0, tp, %%tprel_add(" #x ")\n\t" \ + "addi %0, %0, %%tprel_lo(" #x ")\n\t" \ + : "=r" (__result)); \ + __result; }) + diff --git a/test/tls/tls-macros.h b/test/tls/tls-macros.h index 50a8b07..d46f407 100644 --- a/test/tls/tls-macros.h +++ b/test/tls/tls-macros.h @@ -68,6 +68,10 @@ #include #endif +#ifdef __riscv__ +#include +#endif + #ifdef __sh__ #include #endif -- cgit v1.2.3