| 
									
										
										
										
											2010-01-05 21:47:36 -05:00
										 |  |  | #include "master.hpp"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  | namespace factor { | 
					
						
							| 
									
										
										
										
											2010-01-05 21:47:36 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  | void factor_vm::c_to_factor(cell quot) { | 
					
						
							| 
									
										
										
										
											2016-08-21 10:26:04 -04:00
										 |  |  |   // First time this is called, wrap the c-to-factor sub-primitive inside
 | 
					
						
							|  |  |  |   // of a callback stub, which saves and restores non-volatile registers
 | 
					
						
							|  |  |  |   // per platform ABI conventions, so that the Factor compiler can treat
 | 
					
						
							|  |  |  |   // all registers as volatile
 | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  |   if (!c_to_factor_func) { | 
					
						
							|  |  |  |     tagged<word> c_to_factor_word(special_objects[C_TO_FACTOR_WORD]); | 
					
						
							|  |  |  |     code_block* c_to_factor_block = callbacks->add(c_to_factor_word.value(), 0); | 
					
						
							| 
									
										
										
										
											2015-01-07 05:51:19 -05:00
										 |  |  |     cell func = c_to_factor_block->entry_point(); | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  |     CODE_TO_FUNCTION_POINTER_CALLBACK(this, func); | 
					
						
							|  |  |  |     c_to_factor_func = (c_to_factor_func_type) func; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   c_to_factor_func(quot); | 
					
						
							| 
									
										
										
										
											2010-01-05 21:47:36 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-05 06:59:54 -05:00
										 |  |  | void factor_vm::unwind_native_frames(cell quot, cell to) { | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  |   tagged<word> entry_point_word(special_objects[UNWIND_NATIVE_FRAMES_WORD]); | 
					
						
							| 
									
										
										
										
											2015-01-07 05:51:19 -05:00
										 |  |  |   cell func = entry_point_word->entry_point; | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  |   CODE_TO_FUNCTION_POINTER(func); | 
					
						
							|  |  |  |   ((unwind_native_frames_func_type) func)(quot, to); | 
					
						
							| 
									
										
										
										
											2010-01-05 23:55:20 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  | cell factor_vm::get_fpu_state() { | 
					
						
							|  |  |  |   tagged<word> entry_point_word(special_objects[GET_FPU_STATE_WORD]); | 
					
						
							| 
									
										
										
										
											2015-01-07 05:51:19 -05:00
										 |  |  |   cell func = entry_point_word->entry_point; | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  |   CODE_TO_FUNCTION_POINTER(func); | 
					
						
							|  |  |  |   return ((get_fpu_state_func_type) func)(); | 
					
						
							| 
									
										
										
										
											2010-09-01 23:46:39 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  | void factor_vm::set_fpu_state(cell state) { | 
					
						
							|  |  |  |   tagged<word> entry_point_word(special_objects[SET_FPU_STATE_WORD]); | 
					
						
							| 
									
										
										
										
											2015-01-07 05:51:19 -05:00
										 |  |  |   cell func = entry_point_word->entry_point; | 
					
						
							| 
									
										
										
										
											2013-05-11 21:58:23 -04:00
										 |  |  |   CODE_TO_FUNCTION_POINTER(func); | 
					
						
							|  |  |  |   ((set_fpu_state_func_type) func)(state); | 
					
						
							| 
									
										
										
										
											2010-09-01 23:46:39 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-05 21:47:36 -05:00
										 |  |  | } |