2014-04-12 00:44:21 +02:00
|
|
|
// Copyright 2014 Citra Emulator Project
|
2014-12-17 06:38:14 +01:00
|
|
|
// Licensed under GPLv2 or any later version
|
2014-11-19 09:49:13 +01:00
|
|
|
// Refer to the license.txt file included.
|
2014-04-12 00:44:21 +02:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "common/common_types.h"
|
|
|
|
|
2014-05-16 00:25:56 +02:00
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
2014-05-19 00:12:29 +02:00
|
|
|
// SVC types
|
2014-05-16 00:25:56 +02:00
|
|
|
|
2014-05-16 02:17:30 +02:00
|
|
|
struct MemoryInfo {
|
|
|
|
u32 base_address;
|
|
|
|
u32 size;
|
|
|
|
u32 permission;
|
|
|
|
u32 state;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct PageInfo {
|
|
|
|
u32 flags;
|
|
|
|
};
|
|
|
|
|
2014-05-16 00:25:56 +02:00
|
|
|
struct ThreadContext {
|
|
|
|
u32 cpu_registers[13];
|
|
|
|
u32 sp;
|
|
|
|
u32 lr;
|
|
|
|
u32 pc;
|
|
|
|
u32 cpsr;
|
|
|
|
u32 fpu_registers[32];
|
|
|
|
u32 fpscr;
|
|
|
|
u32 fpexc;
|
2014-06-05 06:20:11 +02:00
|
|
|
|
|
|
|
// These are not part of native ThreadContext, but needed by emu
|
|
|
|
u32 reg_15;
|
|
|
|
u32 mode;
|
2014-05-16 00:25:56 +02:00
|
|
|
};
|
|
|
|
|
2014-05-19 00:12:29 +02:00
|
|
|
enum ResetType {
|
|
|
|
RESETTYPE_ONESHOT,
|
|
|
|
RESETTYPE_STICKY,
|
|
|
|
RESETTYPE_PULSE,
|
|
|
|
RESETTYPE_MAX_BIT = (1u << 31),
|
|
|
|
};
|
|
|
|
|
2014-05-30 00:52:57 +02:00
|
|
|
enum ArbitrationType {
|
|
|
|
ARBITRATIONTYPE_SIGNAL,
|
|
|
|
ARBITRATIONTYPE_WAIT_IF_LESS_THAN,
|
|
|
|
ARBITRATIONTYPE_DECREMENT_AND_WAIT_IF_LESS_THAN,
|
|
|
|
ARBITRATIONTYPE_WAIT_IF_LESS_THAN_WITH_TIMEOUT,
|
|
|
|
ARBITRATIONTYPE_DECREMENT_AND_WAIT_IF_LESS_THAN_WITH_TIMEOUT,
|
|
|
|
ARBITRATIONTYPE_MAX_BIT = (1u << 31)
|
|
|
|
};
|
|
|
|
|
2014-04-12 00:44:21 +02:00
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
2014-05-21 00:28:38 +02:00
|
|
|
// Namespace SVC
|
2014-04-12 00:44:21 +02:00
|
|
|
|
2014-05-21 00:28:38 +02:00
|
|
|
namespace SVC {
|
2014-04-12 00:44:21 +02:00
|
|
|
|
|
|
|
void Register();
|
|
|
|
|
|
|
|
} // namespace
|