예제 #1
0
bool BPLRelInstr::exp(asmjit::X86Assembler& a, MemoryMapper& m) {
	auto Set = a.newLabel();

	a.bt(REG_S, S_NEGATIVE);
	a.jc(Set);
	a.mov(asmjit::x86::di, this->next + this->target);
	a.jmp((uint64_t)&jit_and_jump);
	a.bind(Set);
	a.mov(asmjit::x86::di, this->next);
	a.jmp((uint64_t)&jit_and_jump);
	return false;
}
예제 #2
0
bool BEQRelInstr::exp(asmjit::X86Assembler& a, MemoryMapper& m) {
	auto NotSet = a.newLabel();

	a.bt(REG_S, S_ZERO);
	a.jnc(NotSet);
	a.mov(asmjit::x86::di, this->next + this->target);
	a.jmp((uint64_t)&jit_and_jump);
	a.bind(NotSet);
	a.mov(asmjit::x86::di, this->next);
	a.jmp((uint64_t)&jit_and_jump);
	return false;
}
예제 #3
0
bool LDAAbsXInstr::exp(asmjit::X86Assembler& a, MemoryMapper& m) {
	auto temp = asmjit::x86::rax;
	a.mov(temp, this->base);
	a.add(temp, REG_X);
	auto tmpPtr = asmjit::x86::byte_ptr(temp);

	{
		auto NotZero = a.newLabel();
		auto Exit = a.newLabel();
		a.cmp(tmpPtr, 0);
		a.jne(NotZero);
		// Value was 0
		a.bts(REG_S, S_ZERO);
		a.jmp(Exit);

		// Value was not 0
		a.bind(NotZero);
		a.btr(REG_S, S_ZERO);
		//No jmp required, just fall though

		a.bind(Exit);
	}

	a.mov(REG_A, tmpPtr);
	return true;
}
예제 #4
0
bool RTS::exp(asmjit::X86Assembler& a, MemoryMapper& m) {
	// Use rbx because that's safe during a call
	virtual_pop(a, m, asmjit::x86::bl);
	a.shl(asmjit::x86::bx, 8);
	virtual_pop(a, m, asmjit::x86::dl);
	a.or_(asmjit::x86::bx, asmjit::x86::dx);
	a.mov(asmjit::x86::rdi, asmjit::x86::rbx);
	a.jmp((uint64_t)&jit_and_jump);
	return false;
}
예제 #5
0
bool JSRAbsInstr::exp(asmjit::X86Assembler& a, MemoryMapper& m) {
	// Push the virtual PC to the stack
	// @COMPLETENESS: This order is likely wrong!
	virtual_push(a, m, static_cast<uint8_t>(next & 0xFF));
	virtual_push(a, m, static_cast<uint8_t>(next >> 8));

	a.mov(asmjit::x86::di, this->target);
	a.jmp((uint64_t)&jit_and_jump);
	return false;
}
예제 #6
0
bool BITZeroP::exp(asmjit::X86Assembler& a, MemoryMapper& m) {
	m.emitLoad(a, operand, asmjit::x86::al);
	// @COMPLETENESS: We should check and set the S_ flags here before the and
	a.push(asmjit::x86::rax);

	a.and_(asmjit::x86::al, REG_A);
	auto Zero = a.newLabel();
	auto Exit = a.newLabel();
	a.jz(Zero);

	//Not zero
	a.btr(REG_S, S_ZERO);
	a.jmp(Exit);
	a.bind(Zero);
	a.bts(REG_S, S_ZERO);
	a.bind(Exit);

	a.pop(asmjit::x86::rax);

	{
		a.btr(REG_S, S_OVERFLOW);
		a.bt(asmjit::x86::al, 6);
		auto End = a.newLabel();
		a.jnc(End);
		a.bts(REG_S, S_OVERFLOW);
		a.bind(End);
	}

	{
		a.btr(REG_S, S_NEGATIVE);
		a.bt(asmjit::x86::al, 7);
		auto End = a.newLabel();
		a.jnc(End);
		a.bts(REG_S, S_NEGATIVE);
		a.bind(End);
	}
	return true;
}
예제 #7
0
bool JMPAbsInstr::exp(asmjit::X86Assembler& a, MemoryMapper& m) {
	a.mov(asmjit::x86::di, this->m_target);
	a.jmp((uint64_t)&jit_and_jump);
	return false;
}