72 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
namespace factor
 | 
						|
{
 | 
						|
 | 
						|
struct jit {
 | 
						|
	cell type;
 | 
						|
	gc_root<object> owner;
 | 
						|
	growable_byte_array code;
 | 
						|
	growable_byte_array relocation;
 | 
						|
	growable_array literals;
 | 
						|
	bool computing_offset_p;
 | 
						|
	fixnum position;
 | 
						|
	cell offset;
 | 
						|
	factorvm *myvm;
 | 
						|
 | 
						|
	jit(cell jit_type, cell owner, factorvm *vm);
 | 
						|
	void compute_position(cell offset);
 | 
						|
 | 
						|
	void emit_relocation(cell code_template);
 | 
						|
	void emit(cell code_template);
 | 
						|
 | 
						|
	void literal(cell literal) { literals.add(literal); }
 | 
						|
	void emit_with(cell code_template_, cell literal_);
 | 
						|
 | 
						|
	void push(cell literal) {
 | 
						|
		emit_with(myvm->userenv[JIT_PUSH_IMMEDIATE],literal);
 | 
						|
	}
 | 
						|
 | 
						|
	void word_jump(cell word) {
 | 
						|
		literal(tag_fixnum(xt_tail_pic_offset));
 | 
						|
		literal(word);
 | 
						|
		emit(myvm->userenv[JIT_WORD_JUMP]);
 | 
						|
	}
 | 
						|
 | 
						|
	void word_call(cell word) {
 | 
						|
		emit_with(myvm->userenv[JIT_WORD_CALL],word);
 | 
						|
	}
 | 
						|
 | 
						|
	void word_special(cell word) {
 | 
						|
		emit_with(myvm->userenv[JIT_WORD_SPECIAL],word);
 | 
						|
	}
 | 
						|
 | 
						|
	void emit_subprimitive(cell word_) {
 | 
						|
		gc_root<word> word(word_,myvm);
 | 
						|
		gc_root<array> code_template(word->subprimitive,myvm);
 | 
						|
		if(array_capacity(code_template.untagged()) > 1) literal(myvm->T);
 | 
						|
		emit(code_template.value());
 | 
						|
	}
 | 
						|
 | 
						|
	void emit_class_lookup(fixnum index, cell type);
 | 
						|
 | 
						|
	fixnum get_position() {
 | 
						|
		if(computing_offset_p)
 | 
						|
		{
 | 
						|
			/* If this is still on, emit() didn't clear it,
 | 
						|
			   so the offset was out of bounds */
 | 
						|
			return -1;
 | 
						|
		}
 | 
						|
		else
 | 
						|
			return position;
 | 
						|
	}
 | 
						|
 | 
						|
        void set_position(fixnum position_) {
 | 
						|
		if(computing_offset_p)
 | 
						|
			position = position_;
 | 
						|
	}
 | 
						|
 | 
						|
	
 | 
						|
	code_block *to_code_block();
 | 
						|
};
 | 
						|
 | 
						|
}
 |