2018-01-13 19:04:19 +01:00
|
|
|
/* 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 <array>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <unicorn/unicorn.h>
|
|
|
|
|
|
|
|
#include "common/common_types.h"
|
|
|
|
|
2018-08-11 12:39:53 +02:00
|
|
|
#include "A32/testenv.h"
|
|
|
|
|
|
|
|
class A32Unicorn final {
|
2018-01-13 19:04:19 +01:00
|
|
|
public:
|
2018-08-11 12:39:53 +02:00
|
|
|
static constexpr size_t num_gprs = 16;
|
|
|
|
using RegisterArray = std::array<u32, num_gprs>;
|
2018-07-13 19:41:19 +02:00
|
|
|
using RegisterPtrArray = std::array<RegisterArray::pointer, num_gprs>;
|
|
|
|
using RegisterConstPtrArray = std::array<RegisterArray::const_pointer, num_gprs>;
|
|
|
|
|
2018-08-11 12:39:53 +02:00
|
|
|
static constexpr size_t num_ext_regs = 64;
|
|
|
|
using ExtRegArray = std::array<u32, num_ext_regs>;
|
2018-07-13 19:41:19 +02:00
|
|
|
|
2018-08-11 12:39:53 +02:00
|
|
|
explicit A32Unicorn(ArmTestEnv& testenv);
|
|
|
|
~A32Unicorn();
|
2018-01-13 19:04:19 +01:00
|
|
|
|
|
|
|
void Run();
|
|
|
|
|
2018-07-13 19:41:19 +02:00
|
|
|
RegisterArray GetRegisters() const;
|
|
|
|
void SetRegisters(const RegisterArray& value);
|
2018-01-13 19:04:19 +01:00
|
|
|
|
2018-08-11 12:39:53 +02:00
|
|
|
ExtRegArray GetExtRegs() const;
|
|
|
|
void SetExtRegs(const ExtRegArray& value);
|
2018-01-13 19:04:19 +01:00
|
|
|
|
2018-08-11 12:39:53 +02:00
|
|
|
u32 GetPC() const;
|
2018-01-13 19:04:19 +01:00
|
|
|
|
2018-08-11 12:39:53 +02:00
|
|
|
u32 GetFpscr() const;
|
|
|
|
void SetFpscr(u32 value);
|
2018-07-24 17:06:55 +02:00
|
|
|
|
2018-08-11 12:39:53 +02:00
|
|
|
u32 GetCpsr() const;
|
|
|
|
void SetCpsr(u32 value);
|
2018-01-13 19:04:19 +01:00
|
|
|
|
|
|
|
void ClearPageCache();
|
|
|
|
|
|
|
|
void DumpMemoryInformation();
|
|
|
|
|
|
|
|
private:
|
|
|
|
static void InterruptHook(uc_engine* uc, u32 interrupt, void* user_data);
|
2018-08-11 12:39:53 +02:00
|
|
|
static bool UnmappedMemoryHook(uc_engine* uc, uc_mem_type type, u32 addr, int size, u64 value, void* user_data);
|
|
|
|
static bool MemoryWriteHook(uc_engine* uc, uc_mem_type type, u32 addr, int size, u64 value, void* user_data);
|
2018-01-13 19:04:19 +01:00
|
|
|
|
|
|
|
struct Page {
|
2018-08-11 12:39:53 +02:00
|
|
|
u32 address;
|
2018-01-13 19:04:19 +01:00
|
|
|
std::array<u8, 4096> data;
|
|
|
|
};
|
|
|
|
|
2018-08-11 12:39:53 +02:00
|
|
|
ArmTestEnv& testenv;
|
2018-01-13 19:04:19 +01:00
|
|
|
uc_engine* uc{};
|
|
|
|
uc_hook intr_hook{};
|
|
|
|
uc_hook mem_invalid_hook{};
|
2018-01-26 00:56:57 +01:00
|
|
|
uc_hook mem_write_prot_hook{};
|
2018-01-13 19:04:19 +01:00
|
|
|
|
2018-01-13 19:30:02 +01:00
|
|
|
std::vector<std::unique_ptr<Page>> pages;
|
2018-01-13 19:04:19 +01:00
|
|
|
};
|