Adding support for MOXA ART SoC. Testing port of linux-2.6.32.60-moxart.
[linux-3.6.7-moxart.git] / arch / arm / include / asm / tls.h
blob73409e6c0251001b5b03f27ae811a523cc605f62
1 #ifndef __ASMARM_TLS_H
2 #define __ASMARM_TLS_H
4 #ifdef __ASSEMBLY__
5 .macro set_tls_none, tp, tmp1, tmp2
6 .endm
8 .macro set_tls_v6k, tp, tmp1, tmp2
9 mcr p15, 0, \tp, c13, c0, 3 @ set TLS register
10 mov \tmp1, #0
11 mcr p15, 0, \tmp1, c13, c0, 2 @ clear user r/w TLS register
12 .endm
14 .macro set_tls_v6, tp, tmp1, tmp2
15 ldr \tmp1, =elf_hwcap
16 ldr \tmp1, [\tmp1, #0]
17 mov \tmp2, #0xffff0fff
18 tst \tmp1, #HWCAP_TLS @ hardware TLS available?
19 mcrne p15, 0, \tp, c13, c0, 3 @ yes, set TLS register
20 movne \tmp1, #0
21 mcrne p15, 0, \tmp1, c13, c0, 2 @ clear user r/w TLS register
22 streq \tp, [\tmp2, #-15] @ set TLS value at 0xffff0ff0
23 .endm
25 .macro set_tls_software, tp, tmp1, tmp2
26 mov \tmp1, #0xffff0fff
27 str \tp, [\tmp1, #-15] @ set TLS value at 0xffff0ff0
28 .endm
29 #endif
31 #ifdef CONFIG_TLS_REG_EMUL
32 #define tls_emu 1
33 #define has_tls_reg 1
34 #define set_tls set_tls_none
35 #elif defined(CONFIG_CPU_V6)
36 #define tls_emu 0
37 #define has_tls_reg (elf_hwcap & HWCAP_TLS)
38 #define set_tls set_tls_v6
39 #elif defined(CONFIG_CPU_32v6K)
40 #define tls_emu 0
41 #define has_tls_reg 1
42 #define set_tls set_tls_v6k
43 #else
44 #define tls_emu 0
45 #define has_tls_reg 0
46 #define set_tls set_tls_software
47 #endif
49 #endif /* __ASMARM_TLS_H */