dynarmic/src/frontend/ir/ir_emitter.h

127 lines
5.4 KiB
C
Raw Normal View History

2016-07-01 15:01:06 +02:00
/* This file is part of the dynarmic project.
* Copyright (c) 2016 MerryMage
* This software may be used and distributed according to the terms of the GNU
* General Public License version 2 or any later version.
*/
#pragma once
#include "frontend/arm_types.h"
#include "frontend/ir/ir.h"
#include "frontend/ir/opcodes.h"
2016-07-01 15:01:06 +02:00
namespace Dynarmic {
namespace Arm {
class IREmitter {
public:
explicit IREmitter(LocationDescriptor descriptor) : block(descriptor), current_location(descriptor) {}
IR::Block block;
LocationDescriptor current_location;
2016-07-01 15:01:06 +02:00
struct ResultAndCarry {
2016-07-23 00:55:00 +02:00
IR::Value result;
IR::Value carry;
2016-07-01 15:01:06 +02:00
};
struct ResultAndCarryAndOverflow {
2016-07-23 00:55:00 +02:00
IR::Value result;
IR::Value carry;
IR::Value overflow;
};
2016-07-01 15:01:06 +02:00
void Unimplemented();
u32 PC();
u32 AlignPC(size_t alignment);
2016-07-01 15:01:06 +02:00
2016-07-23 00:55:00 +02:00
IR::Value Imm1(bool value);
IR::Value Imm8(u8 value);
IR::Value Imm32(u32 value);
IR::Value GetRegister(Reg source_reg);
IR::Value GetExtendedRegister(ExtReg source_reg);
2016-07-23 00:55:00 +02:00
void SetRegister(const Reg dest_reg, const IR::Value& value);
void SetExtendedRegister(const ExtReg dest_reg, const IR::Value& value);
2016-07-23 00:55:00 +02:00
void ALUWritePC(const IR::Value& value);
void BranchWritePC(const IR::Value& value);
void BXWritePC(const IR::Value& value);
void LoadWritePC(const IR::Value& value);
void CallSupervisor(const IR::Value& value);
IR::Value GetCFlag();
void SetNFlag(const IR::Value& value);
void SetZFlag(const IR::Value& value);
void SetCFlag(const IR::Value& value);
void SetVFlag(const IR::Value& value);
IR::Value Pack2x32To1x64(const IR::Value& lo, const IR::Value& hi);
IR::Value LeastSignificantWord(const IR::Value& value);
ResultAndCarry MostSignificantWord(const IR::Value& value);
2016-07-23 00:55:00 +02:00
IR::Value LeastSignificantHalf(const IR::Value& value);
IR::Value LeastSignificantByte(const IR::Value& value);
IR::Value MostSignificantBit(const IR::Value& value);
IR::Value IsZero(const IR::Value& value);
IR::Value IsZero64(const IR::Value& value);
2016-07-23 00:55:00 +02:00
ResultAndCarry LogicalShiftLeft(const IR::Value& value_in, const IR::Value& shift_amount, const IR::Value& carry_in);
ResultAndCarry LogicalShiftRight(const IR::Value& value_in, const IR::Value& shift_amount, const IR::Value& carry_in);
ResultAndCarry ArithmeticShiftRight(const IR::Value& value_in, const IR::Value& shift_amount, const IR::Value& carry_in);
ResultAndCarry RotateRight(const IR::Value& value_in, const IR::Value& shift_amount, const IR::Value& carry_in);
ResultAndCarry RotateRightExtended(const IR::Value& value_in, const IR::Value& carry_in);
2016-07-23 00:55:00 +02:00
ResultAndCarryAndOverflow AddWithCarry(const IR::Value& a, const IR::Value& b, const IR::Value& carry_in);
IR::Value Add(const IR::Value& a, const IR::Value& b);
IR::Value Add64(const IR::Value& a, const IR::Value& b);
2016-07-23 00:55:00 +02:00
ResultAndCarryAndOverflow SubWithCarry(const IR::Value& a, const IR::Value& b, const IR::Value& carry_in);
IR::Value Sub(const IR::Value& a, const IR::Value& b);
2016-08-06 07:09:47 +02:00
IR::Value Sub64(const IR::Value& a, const IR::Value& b);
IR::Value Mul(const IR::Value& a, const IR::Value& b);
IR::Value Mul64(const IR::Value& a, const IR::Value& b);
2016-07-23 00:55:00 +02:00
IR::Value And(const IR::Value& a, const IR::Value& b);
IR::Value Eor(const IR::Value& a, const IR::Value& b);
IR::Value Or(const IR::Value& a, const IR::Value& b);
IR::Value Not(const IR::Value& a);
IR::Value SignExtendWordToLong(const IR::Value& a);
2016-07-23 00:55:00 +02:00
IR::Value SignExtendHalfToWord(const IR::Value& a);
IR::Value SignExtendByteToWord(const IR::Value& a);
IR::Value ZeroExtendWordToLong(const IR::Value& a);
2016-07-23 00:55:00 +02:00
IR::Value ZeroExtendHalfToWord(const IR::Value& a);
IR::Value ZeroExtendByteToWord(const IR::Value& a);
IR::Value ByteReverseWord(const IR::Value& a);
IR::Value ByteReverseHalf(const IR::Value& a);
IR::Value ByteReverseDual(const IR::Value& a);
2016-08-07 02:27:18 +02:00
IR::Value FPAbs32(const IR::Value& a);
IR::Value FPAbs64(const IR::Value& a);
2016-08-06 18:21:29 +02:00
IR::Value FPAdd32(const IR::Value& a, const IR::Value& b, bool fpscr_controlled);
IR::Value FPAdd64(const IR::Value& a, const IR::Value& b, bool fpscr_controlled);
2016-08-07 11:56:12 +02:00
IR::Value FPDiv32(const IR::Value& a, const IR::Value& b, bool fpscr_controlled);
IR::Value FPDiv64(const IR::Value& a, const IR::Value& b, bool fpscr_controlled);
2016-08-07 11:21:14 +02:00
IR::Value FPMul32(const IR::Value& a, const IR::Value& b, bool fpscr_controlled);
IR::Value FPMul64(const IR::Value& a, const IR::Value& b, bool fpscr_controlled);
2016-08-07 11:56:12 +02:00
IR::Value FPNeg32(const IR::Value& a);
IR::Value FPNeg64(const IR::Value& a);
2016-08-07 02:41:25 +02:00
IR::Value FPSub32(const IR::Value& a, const IR::Value& b, bool fpscr_controlled);
IR::Value FPSub64(const IR::Value& a, const IR::Value& b, bool fpscr_controlled);
2016-08-06 18:21:29 +02:00
2016-07-23 00:55:00 +02:00
IR::Value ReadMemory8(const IR::Value& vaddr);
IR::Value ReadMemory16(const IR::Value& vaddr);
IR::Value ReadMemory32(const IR::Value& vaddr);
IR::Value ReadMemory64(const IR::Value& vaddr);
void WriteMemory8(const IR::Value& vaddr, const IR::Value& value);
void WriteMemory16(const IR::Value& vaddr, const IR::Value& value);
void WriteMemory32(const IR::Value& vaddr, const IR::Value& value);
void WriteMemory64(const IR::Value& vaddr, const IR::Value& value);
void Breakpoint();
2016-07-07 11:53:09 +02:00
void SetTerm(const IR::Terminal& terminal);
2016-07-01 15:01:06 +02:00
private:
2016-07-23 00:55:00 +02:00
IR::Value Inst(IR::Opcode op, std::initializer_list<IR::Value> args);
2016-07-01 15:01:06 +02:00
};
} // namespace Arm
} // namespace Dynarmic