00001 /* 00002 * Copyright (c) 2007 Pavel Jancik 00003 * Copyright (c) 2007 Michal Kebrt 00004 * All rights reserved. 00005 * 00006 * Redistribution and use in source and binary forms, with or without 00007 * modification, are permitted provided that the following conditions 00008 * are met: 00009 * 00010 * - Redistributions of source code must retain the above copyright 00011 * notice, this list of conditions and the following disclaimer. 00012 * - Redistributions in binary form must reproduce the above copyright 00013 * notice, this list of conditions and the following disclaimer in the 00014 * documentation and/or other materials provided with the distribution. 00015 * - The name of the author may not be used to endorse or promote products 00016 * derived from this software without specific prior written permission. 00017 * 00018 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 00019 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 00020 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 00021 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 00022 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 00023 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 00024 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 00025 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 00026 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 00027 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00028 */ 00029 00036 #ifndef LIBC_arm32_TLS_H_ 00037 #define LIBC_arm32_TLS_H_ 00038 00039 #include <sys/types.h> 00040 00041 #define CONFIG_TLS_VARIANT_1 00042 00044 #define ARM_TP_OFFSET (-8) 00045 00050 typedef struct { 00052 void *fibril_data; 00053 } tcb_t; 00054 00055 00060 static inline void __tcb_set(tcb_t *tcb) 00061 { 00062 void *tls = (void *) tcb; 00063 tls += sizeof(tcb_t) + ARM_TP_OFFSET; 00064 asm volatile ( 00065 "mov r9, %0" 00066 : 00067 : "r" (tls) 00068 ); 00069 } 00070 00071 00077 static inline tcb_t *__tcb_get(void) 00078 { 00079 void *ret; 00080 asm volatile ( 00081 "mov %0, r9" 00082 : "=r"(ret) 00083 ); 00084 return (tcb_t *) (ret - ARM_TP_OFFSET - sizeof(tcb_t)); 00085 } 00086 00087 00094 extern uintptr_t __aeabi_read_tp(void); 00095 00096 #endif 00097