mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-30 10:45:40 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			144 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #define TLS_LE(x) \
 | |
|   ({ int *__l; void *__tp;						      \
 | |
|      asm ("stc gbr,%1\n\t"						      \
 | |
| 	  "mov.l 1f,%0\n\t"						      \
 | |
| 	  "bra 2f\n\t"							      \
 | |
| 	  " add %1,%0\n\t"						      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "1: .long " #x "@tpoff\n\t"					      \
 | |
| 	  "2:"								      \
 | |
| 	  : "=r" (__l), "=r" (__tp));					      \
 | |
|      __l; })
 | |
| 
 | |
| #ifdef PIC
 | |
| # define TLS_IE(x) \
 | |
|   ({ int *__l; void *__tp;						      \
 | |
|      register void *__gp __asm__("r12");				      \
 | |
|      asm ("mov.l 1f,r0\n\t"						      \
 | |
| 	  "stc gbr,%1\n\t"						      \
 | |
| 	  "mov.l @(r0,r12),%0\n\t"					      \
 | |
| 	  "bra 2f\n\t"							      \
 | |
| 	  " add %1,%0\n\t"						      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "1: .long " #x "@gottpoff\n\t"				      \
 | |
| 	  "2:"								      \
 | |
| 	  : "=r" (__l), "=r" (__tp) : "r" (__gp) : "r0");		      \
 | |
|      __l; })
 | |
| #else
 | |
| # define TLS_IE(x) \
 | |
|   ({ int *__l; void *__tp;						      \
 | |
|      asm ("mov.l r12,@-r15\n\t"						      \
 | |
| 	  "mova 0f,r0\n\t"						      \
 | |
| 	  "mov.l 0f,r12\n\t"						      \
 | |
| 	  "add r0,r12\n\t"						      \
 | |
| 	  "mov.l 1f,r0\n\t"						      \
 | |
| 	  "stc gbr,%1\n\t"						      \
 | |
| 	  "mov.l @(r0,r12),%0\n\t"					      \
 | |
| 	  "bra 2f\n\t"							      \
 | |
| 	  " add %1,%0\n\t"						      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "1: .long " #x "@gottpoff\n\t"				      \
 | |
| 	  "0: .long _GLOBAL_OFFSET_TABLE_\n\t"				      \
 | |
| 	  "2: mov.l @r15+,r12"						      \
 | |
| 	  : "=r" (__l), "=r" (__tp) : : "r0");				      \
 | |
|      __l; })
 | |
| #endif
 | |
| 
 | |
| #ifdef PIC
 | |
| # define TLS_LD(x) \
 | |
|   ({ int *__l;								      \
 | |
|      register void *__gp __asm__("r12");				      \
 | |
|      asm ("mov.l 1f,r4\n\t"						      \
 | |
| 	  "mova 2f,r0\n\t"						      \
 | |
| 	  "mov.l 2f,r1\n\t"						      \
 | |
| 	  "add r0,r1\n\t"						      \
 | |
| 	  "jsr @r1\n\t"							      \
 | |
| 	  " add r12,r4\n\t"						      \
 | |
| 	  "bra 4f\n\t"							      \
 | |
| 	  " nop\n\t"							      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "1: .long " #x "@tlsldm\n\t"					      \
 | |
| 	  "2: .long __tls_get_addr@plt\n\t"				      \
 | |
| 	  "4: mov.l 3f,%0\n\t"						      \
 | |
| 	  "bra 5f\n\t"							      \
 | |
| 	  " add r0,%0\n\t"						      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "3: .long " #x "@dtpoff\n\t"					      \
 | |
| 	  "5:"								      \
 | |
| 	  : "=r" (__l) : "r" (__gp) : "r0", "r1", "r2", "r3", "r4", "r5",     \
 | |
| 				      "r6", "r7", "pr", "t");		      \
 | |
|      __l; })
 | |
| #else
 | |
| # define TLS_LD(x) \
 | |
|   ({ int *__l;								      \
 | |
|      asm ("mov.l r12,@-r15\n\t"						      \
 | |
| 	  "mova 0f,r0\n\t"						      \
 | |
| 	  "mov.l 0f,r12\n\t"						      \
 | |
| 	  "add r0,r12\n\t"						      \
 | |
| 	  "mov.l 1f,r4\n\t"						      \
 | |
| 	  "mova 2f,r0\n\t"						      \
 | |
| 	  "mov.l 2f,r1\n\t"						      \
 | |
| 	  "add r0,r1\n\t"						      \
 | |
| 	  "jsr @r1\n\t"							      \
 | |
| 	  " add r12,r4\n\t"						      \
 | |
| 	  "bra 4f\n\t"							      \
 | |
| 	  " nop\n\t"							      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "1: .long " #x "@tlsldm\n\t"					      \
 | |
| 	  "2: .long __tls_get_addr@plt\n\t"				      \
 | |
| 	  "0: .long _GLOBAL_OFFSET_TABLE_\n\t"				      \
 | |
| 	  "4: mov.l 3f,%0\n\t"						      \
 | |
| 	  "bra 5f\n\t"							      \
 | |
| 	  " add r0,%0\n\t"						      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "3: .long " #x "@dtpoff\n\t"					      \
 | |
| 	  "5: mov.l @r15+,r12"						      \
 | |
| 	  : "=r" (__l) : : "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",    \
 | |
| 			   "pr", "t");					      \
 | |
|      __l; })
 | |
| #endif
 | |
| 
 | |
| #ifdef PIC
 | |
| # define TLS_GD(x) \
 | |
|   ({ int *__l;								      \
 | |
|      register void *__gp __asm__("r12");				      \
 | |
|      asm ("mov.l 1f,r4\n\t"						      \
 | |
| 	  "mova 2f,r0\n\t"						      \
 | |
| 	  "mov.l 2f,r1\n\t"						      \
 | |
| 	  "add r0,r1\n\t"						      \
 | |
| 	  "jsr @r1\n\t"							      \
 | |
| 	  " add r12,r4\n\t"						      \
 | |
| 	  "bra 3f\n\t"							      \
 | |
| 	  " mov r0,%0\n\t"						      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "1: .long " #x "@tlsgd\n\t"					      \
 | |
| 	  "2: .long __tls_get_addr@plt\n\t"				      \
 | |
| 	  "3:"								      \
 | |
| 	  : "=r" (__l) : "r" (__gp) : "r0", "r1", "r2", "r3", "r4", "r5",     \
 | |
| 				      "r6", "r7", "pr", "t");		      \
 | |
|      __l; })
 | |
| #else
 | |
| # define TLS_GD(x) \
 | |
|   ({ int *__l;								      \
 | |
|      asm ("mov.l r12,@-r15\n\t"						      \
 | |
| 	  "mova 0f,r0\n\t"						      \
 | |
| 	  "mov.l 0f,r12\n\t"						      \
 | |
| 	  "add r0,r12\n\t"						      \
 | |
| 	  "mov.l 1f,r4\n\t"						      \
 | |
| 	  "mova 2f,r0\n\t"						      \
 | |
| 	  "mov.l 2f,r1\n\t"						      \
 | |
| 	  "add r0,r1\n\t"						      \
 | |
| 	  "jsr @r1\n\t"							      \
 | |
| 	  " add r12,r4\n\t"						      \
 | |
| 	  "bra 3f\n\t"							      \
 | |
| 	  " mov r0,%0\n\t"						      \
 | |
| 	  ".align 2\n\t"						      \
 | |
| 	  "1: .long " #x "@tlsgd\n\t"					      \
 | |
| 	  "2: .long __tls_get_addr@plt\n\t"				      \
 | |
| 	  "0: .long _GLOBAL_OFFSET_TABLE_\n\t"				      \
 | |
| 	  "3: mov.l @r15+,r12"						      \
 | |
| 	  : "=r" (__l) : : "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",    \
 | |
| 			   "pr", "t");					      \
 | |
|      __l; })
 | |
| #endif
 |