| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | #include "master.hpp"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace factor | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-08 14:06:00 -05:00
										 |  |  | void safepoint_state::enqueue_safepoint(factor_vm *parent) volatile | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | { | 
					
						
							|  |  |  | 	parent->code->guard_safepoint(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-08 14:06:00 -05:00
										 |  |  | void safepoint_state::enqueue_fep(factor_vm *parent) volatile | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (parent->fep_p) | 
					
						
							|  |  |  | 		fatal_error("Low-level debugger interrupted", 0); | 
					
						
							|  |  |  | 	atomic::store(&fep_p, true); | 
					
						
							| 
									
										
										
										
											2011-11-08 14:06:00 -05:00
										 |  |  | 	enqueue_safepoint(parent); | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-08 14:06:00 -05:00
										 |  |  | void safepoint_state::enqueue_samples(factor_vm *parent, cell samples, cell pc, bool foreign_thread_p) volatile | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (atomic::load(&parent->sampling_profiler_p)) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-11-07 21:53:07 -05:00
										 |  |  | 		atomic::fetch_add(&sample_counts.sample_count, samples); | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | 		if (foreign_thread_p) | 
					
						
							| 
									
										
										
										
											2011-11-07 21:53:07 -05:00
										 |  |  | 			atomic::fetch_add(&sample_counts.foreign_thread_sample_count, samples); | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | 		else { | 
					
						
							|  |  |  | 			if (atomic::load(&parent->current_gc_p)) | 
					
						
							|  |  |  | 				atomic::fetch_add(&sample_counts.gc_sample_count, samples); | 
					
						
							|  |  |  | 			if (atomic::load(&parent->current_jit_count) > 0) | 
					
						
							|  |  |  | 				atomic::fetch_add(&sample_counts.jit_sample_count, samples); | 
					
						
							|  |  |  | 			if (!parent->code->seg->in_segment_p(pc)) | 
					
						
							|  |  |  | 				atomic::fetch_add(&sample_counts.foreign_sample_count, samples); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-11-08 14:06:00 -05:00
										 |  |  | 		enqueue_safepoint(parent); | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-17 20:13:59 -05:00
										 |  |  | void safepoint_state::handle_safepoint(factor_vm *parent, cell pc) volatile | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | { | 
					
						
							|  |  |  | 	parent->code->unguard_safepoint(); | 
					
						
							| 
									
										
										
										
											2011-11-11 16:29:46 -05:00
										 |  |  | 	parent->faulting_p = false; | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (atomic::load(&fep_p)) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (atomic::load(&parent->sampling_profiler_p)) | 
					
						
							|  |  |  | 			parent->end_sampling_profiler(); | 
					
						
							|  |  |  | 		std::cout << "Interrupted\n"; | 
					
						
							|  |  |  | 		parent->factorbug(); | 
					
						
							|  |  |  | 		atomic::store(&fep_p, false); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (atomic::load(&parent->sampling_profiler_p)) | 
					
						
							| 
									
										
										
										
											2011-11-17 20:13:59 -05:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-11-17 23:42:30 -05:00
										 |  |  | 		FACTOR_ASSERT(parent->code->seg->in_segment_p(pc)); | 
					
						
							| 
									
										
										
										
											2011-11-17 20:13:59 -05:00
										 |  |  | 		code_block *block = parent->code->code_block_for_address(pc); | 
					
						
							|  |  |  | 		bool prolog_p = (cell)block->entry_point() == pc; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		parent->record_sample(prolog_p); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-11-07 15:51:49 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |