| 
									
										
										
										
											2009-05-02 05:04:19 -04:00
										 |  |  | #include <ucontext.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 22:24:31 -04:00
										 |  |  | namespace factor { | 
					
						
							| 
									
										
										
										
											2009-05-04 02:46:13 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 22:23:10 -04:00
										 |  |  | /* glibc lies about the contents of the fpstate the kernel provides, hiding the
 | 
					
						
							|  |  |  |    FXSR environment */ | 
					
						
							| 
									
										
										
										
											2009-09-14 13:30:10 -04:00
										 |  |  | struct _fpstate { | 
					
						
							| 
									
										
										
										
											2013-05-11 22:24:31 -04:00
										 |  |  |   /* Regular FPU environment */ | 
					
						
							|  |  |  |   unsigned long cw; | 
					
						
							|  |  |  |   unsigned long sw; | 
					
						
							|  |  |  |   unsigned long tag; | 
					
						
							|  |  |  |   unsigned long ipoff; | 
					
						
							|  |  |  |   unsigned long cssel; | 
					
						
							|  |  |  |   unsigned long dataoff; | 
					
						
							|  |  |  |   unsigned long datasel; | 
					
						
							|  |  |  |   struct _fpreg _st[8]; | 
					
						
							|  |  |  |   unsigned short status; | 
					
						
							|  |  |  |   unsigned short magic; /* 0xffff = regular FPU data only */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* FXSR FPU environment */ | 
					
						
							|  |  |  |   unsigned long _fxsr_env[6]; /* FXSR FPU env is ignored */ | 
					
						
							|  |  |  |   unsigned long mxcsr; | 
					
						
							|  |  |  |   unsigned long reserved; | 
					
						
							|  |  |  |   struct _fpxreg _fxsr_st[8]; /* FXSR FPU reg data is ignored */ | 
					
						
							|  |  |  |   struct _xmmreg _xmm[8]; | 
					
						
							|  |  |  |   unsigned long padding[56]; | 
					
						
							| 
									
										
										
										
											2009-09-14 13:30:10 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 22:24:31 -04:00
										 |  |  | #define X86_FXSR_MAGIC 0x0000
 | 
					
						
							| 
									
										
										
										
											2009-09-14 13:30:10 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 22:24:31 -04:00
										 |  |  | inline static unsigned int uap_fpu_status(void* uap) { | 
					
						
							|  |  |  |   ucontext_t* ucontext = (ucontext_t*)uap; | 
					
						
							|  |  |  |   struct _fpstate* fpregs = (struct _fpstate*)ucontext->uc_mcontext.fpregs; | 
					
						
							|  |  |  |   if (fpregs->magic == X86_FXSR_MAGIC) | 
					
						
							|  |  |  |     return fpregs->sw | fpregs->mxcsr; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return fpregs->sw; | 
					
						
							| 
									
										
										
										
											2009-09-14 00:37:28 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 22:24:31 -04:00
										 |  |  | inline static void uap_clear_fpu_status(void* uap) { | 
					
						
							|  |  |  |   ucontext_t* ucontext = (ucontext_t*)uap; | 
					
						
							|  |  |  |   struct _fpstate* fpregs = (struct _fpstate*)ucontext->uc_mcontext.fpregs; | 
					
						
							|  |  |  |   fpregs->sw = 0; | 
					
						
							|  |  |  |   if (fpregs->magic == X86_FXSR_MAGIC) | 
					
						
							|  |  |  |     fpregs->mxcsr &= 0xffffffc0; | 
					
						
							| 
									
										
										
										
											2009-09-14 00:37:28 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 22:24:31 -04:00
										 |  |  | #define UAP_STACK_POINTER(ucontext) \
 | 
					
						
							|  |  |  |   (((ucontext_t*)ucontext)->uc_mcontext.gregs[7]) | 
					
						
							|  |  |  | #define UAP_PROGRAM_COUNTER(ucontext) \
 | 
					
						
							|  |  |  |   (((ucontext_t*)ucontext)->uc_mcontext.gregs[14]) | 
					
						
							| 
									
										
										
										
											2013-05-13 00:53:47 -04:00
										 |  |  | #define UAP_SET_TOC_POINTER(uap, ptr) (void)0
 | 
					
						
							| 
									
										
										
										
											2009-10-22 06:22:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-13 00:53:47 -04:00
										 |  |  | #define CODE_TO_FUNCTION_POINTER(code) (void)0
 | 
					
						
							|  |  |  | #define CODE_TO_FUNCTION_POINTER_CALLBACK(vm, code) (void)0
 | 
					
						
							| 
									
										
										
										
											2011-05-20 18:11:50 -04:00
										 |  |  | #define FUNCTION_CODE_POINTER(ptr) ptr
 | 
					
						
							|  |  |  | #define FUNCTION_TOC_POINTER(ptr) ptr
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-04 02:46:13 -04:00
										 |  |  | } |