mirror of
https://github.com/azahar-emu/dynarmic
synced 2025-11-10 09:00:00 +01:00
43 lines
1.4 KiB
C++
43 lines
1.4 KiB
C++
/* This file is part of the dynarmic project.
|
|
* Copyright (c) 2018 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 <functional>
|
|
|
|
#include "common/common_types.h"
|
|
|
|
namespace Dynarmic {
|
|
|
|
namespace IR {
|
|
class Block;
|
|
} // namespace IR
|
|
|
|
namespace A64 {
|
|
|
|
class LocationDescriptor;
|
|
|
|
using MemoryReadCodeFuncType = std::function<u32(u64 vaddr)>;
|
|
|
|
/**
|
|
* This function translates instructions in memory into our intermediate representation.
|
|
* @param descriptor The starting location of the basic block. Includes information like PC, FPCR state, &c.
|
|
* @param memory_read_code The function we should use to read emulated memory.
|
|
* @return A translated basic block in the intermediate representation.
|
|
*/
|
|
IR::Block Translate(LocationDescriptor descriptor, MemoryReadCodeFuncType memory_read_code);
|
|
|
|
/**
|
|
* This function translates a single provided instruction into our intermediate representation.
|
|
* @param block The block to append the IR for the instruction to.
|
|
* @param descriptor The location of the instruction. Includes information like PC, FPCR state, &c.
|
|
* @param instruction The instruction to translate.
|
|
* @return The translated instruction translated to the intermediate representation.
|
|
*/
|
|
bool TranslateSingleInstruction(IR::Block& block, LocationDescriptor descriptor, u32 instruction);
|
|
|
|
} // namespace A64
|
|
} // namespace Dynarmic
|