dynarmic/src/frontend/A64/ir_emitter.h

94 lines
3.4 KiB
C
Raw Normal View History

2018-01-06 21:15:25 +00: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 <initializer_list>
#include <optional>
2018-02-11 22:53:46 +00:00
#include <dynarmic/A64/config.h>
2018-01-06 21:15:25 +00:00
#include "common/common_types.h"
#include "frontend/A64/location_descriptor.h"
#include "frontend/A64/types.h"
#include "frontend/ir/ir_emitter.h"
#include "frontend/ir/value.h"
namespace Dynarmic::A64 {
2018-01-06 21:15:25 +00:00
/**
* Convenience class to construct a basic block of the intermediate representation.
* `block` is the resulting block.
* The user of this class updates `current_location` as appropriate.
*/
class IREmitter : public IR::IREmitter {
public:
2018-02-11 22:53:46 +00:00
explicit IREmitter(IR::Block& block) : IR::IREmitter(block) {}
explicit IREmitter(IR::Block& block, LocationDescriptor descriptor) : IR::IREmitter(block), current_location(descriptor) {}
2018-01-06 21:15:25 +00:00
std::optional<LocationDescriptor> current_location;
2018-01-06 21:15:25 +00:00
u64 PC() const;
u64 AlignPC(size_t alignment) const;
2018-01-06 21:15:25 +00:00
2018-01-07 16:33:02 +00:00
void SetCheckBit(const IR::U1& value);
2018-01-07 11:31:20 +00:00
IR::U1 GetCFlag();
void SetNZCV(const IR::NZCV& nzcv);
2018-07-24 19:04:40 +01:00
void OrQC(const IR::U1& value);
2018-01-07 11:31:20 +00:00
2018-01-08 22:03:03 +00:00
void CallSupervisor(u32 imm);
void ExceptionRaised(Exception exception);
2018-02-11 22:53:46 +00:00
void DataCacheOperationRaised(DataCacheOperation op, const IR::U64& value);
2018-02-11 23:27:28 +00:00
void DataSynchronizationBarrier();
void DataMemoryBarrier();
void InstructionSynchronizationBarrier();
2018-08-16 09:58:34 +01:00
IR::U32 GetCNTFRQ();
IR::U64 GetCNTPCT(); // TODO: Ensure sub-basic-block cycle counts are updated before this.
2018-02-20 16:44:13 +00:00
IR::U32 GetCTR();
2018-02-12 00:06:44 +00:00
IR::U32 GetDCZID();
IR::U64 GetTPIDR();
2018-02-12 00:06:44 +00:00
IR::U64 GetTPIDRRO();
2018-08-16 09:58:34 +01:00
void SetTPIDR(const IR::U64& value);
2018-01-08 22:03:03 +00:00
void ClearExclusive();
void SetExclusive(const IR::U64& vaddr, size_t byte_size);
2018-01-10 01:13:23 +00:00
IR::U8 ReadMemory8(const IR::U64& vaddr);
IR::U16 ReadMemory16(const IR::U64& vaddr);
IR::U32 ReadMemory32(const IR::U64& vaddr);
IR::U64 ReadMemory64(const IR::U64& vaddr);
IR::U128 ReadMemory128(const IR::U64& vaddr);
2018-01-10 01:13:23 +00:00
void WriteMemory8(const IR::U64& vaddr, const IR::U8& value);
void WriteMemory16(const IR::U64& vaddr, const IR::U16& value);
void WriteMemory32(const IR::U64& vaddr, const IR::U32& value);
void WriteMemory64(const IR::U64& vaddr, const IR::U64& value);
void WriteMemory128(const IR::U64& vaddr, const IR::U128& value);
IR::U32 ExclusiveWriteMemory8(const IR::U64& vaddr, const IR::U8& value);
IR::U32 ExclusiveWriteMemory16(const IR::U64& vaddr, const IR::U16& value);
IR::U32 ExclusiveWriteMemory32(const IR::U64& vaddr, const IR::U32& value);
IR::U32 ExclusiveWriteMemory64(const IR::U64& vaddr, const IR::U64& value);
IR::U32 ExclusiveWriteMemory128(const IR::U64& vaddr, const IR::U128& value);
2018-01-10 01:13:23 +00:00
2018-01-06 21:15:25 +00:00
IR::U32 GetW(Reg source_reg);
IR::U64 GetX(Reg source_reg);
IR::U128 GetS(Vec source_vec);
2018-01-21 17:45:43 +00:00
IR::U128 GetD(Vec source_vec);
IR::U128 GetQ(Vec source_vec);
2018-01-07 11:31:20 +00:00
IR::U64 GetSP();
IR::U32 GetFPCR();
IR::U32 GetFPSR();
2018-01-06 21:15:25 +00:00
void SetW(Reg dest_reg, const IR::U32& value);
void SetX(Reg dest_reg, const IR::U64& value);
void SetS(Vec dest_vec, const IR::U128& value);
2018-01-21 17:45:43 +00:00
void SetD(Vec dest_vec, const IR::U128& value);
void SetQ(Vec dest_vec, const IR::U128& value);
2018-01-07 11:31:20 +00:00
void SetSP(const IR::U64& value);
void SetFPCR(const IR::U32& value);
void SetFPSR(const IR::U32& value);
2018-01-07 13:56:32 +00:00
void SetPC(const IR::U64& value);
2018-01-06 21:15:25 +00:00
};
} // namespace Dynarmic::A64