2012-11-01 15:19:01 +00:00
|
|
|
// Copyright (c) 2012- PPSSPP Project.
|
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
2012-11-04 22:01:49 +00:00
|
|
|
// the Free Software Foundation, version 2.0 or later versions.
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License 2.0 for more details.
|
|
|
|
|
|
|
|
// A copy of the GPL 2.0 should have been included with the program.
|
|
|
|
// If not, see http://www.gnu.org/licenses/
|
|
|
|
|
|
|
|
// Official git repository and contact information can be found at
|
|
|
|
// https://github.com/hrydgard/ppsspp and http://www.ppsspp.org/.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2020-07-15 10:38:05 +00:00
|
|
|
#include <string>
|
|
|
|
|
2013-03-31 06:55:48 +00:00
|
|
|
#include "Core/System.h"
|
2013-03-29 19:51:14 +00:00
|
|
|
#include "Core/CoreParameter.h"
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2015-12-31 15:59:40 +00:00
|
|
|
class GraphicsContext;
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
// called from emu thread
|
2023-08-10 14:33:02 +00:00
|
|
|
void UpdateRunLoop(GraphicsContext *ctx);
|
2017-12-15 11:40:38 +00:00
|
|
|
|
2022-11-08 20:59:08 +00:00
|
|
|
// Returns false when an UI exit state is detected.
|
|
|
|
bool Core_Run(GraphicsContext *ctx);
|
2012-11-01 15:19:01 +00:00
|
|
|
void Core_Stop();
|
2022-11-08 20:59:08 +00:00
|
|
|
|
2016-01-01 13:08:23 +00:00
|
|
|
// For platforms that don't call Core_Run
|
|
|
|
void Core_SetGraphicsContext(GraphicsContext *ctx);
|
2017-12-15 11:40:38 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
// called from gui
|
2021-10-23 23:56:15 +00:00
|
|
|
void Core_EnableStepping(bool step, const char *reason = nullptr, u32 relatedAddress = 0);
|
2020-07-04 18:57:05 +00:00
|
|
|
|
|
|
|
bool Core_NextFrame();
|
2012-11-01 15:19:01 +00:00
|
|
|
void Core_DoSingleStep();
|
2013-09-15 01:43:23 +00:00
|
|
|
void Core_UpdateSingleStep();
|
2018-04-30 01:08:41 +00:00
|
|
|
void Core_ProcessStepping();
|
2018-04-20 04:14:01 +00:00
|
|
|
// Changes every time we enter stepping.
|
|
|
|
int Core_GetSteppingCounter();
|
2021-10-24 00:22:09 +00:00
|
|
|
struct SteppingReason {
|
|
|
|
const char *reason = nullptr;
|
|
|
|
u32 relatedAddress = 0;
|
|
|
|
};
|
|
|
|
SteppingReason Core_GetSteppingReason();
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2018-04-22 15:33:22 +00:00
|
|
|
enum class CoreLifecycle {
|
|
|
|
STARTING,
|
|
|
|
// Note: includes failure cases. Guaranteed call after STARTING.
|
|
|
|
START_COMPLETE,
|
|
|
|
STOPPING,
|
|
|
|
// Guaranteed call after STOPPING.
|
|
|
|
STOPPED,
|
2018-05-06 17:40:02 +00:00
|
|
|
|
|
|
|
// Sometimes called for save states. Guaranteed sequence, and never during STARTING or STOPPING.
|
|
|
|
MEMORY_REINITING,
|
|
|
|
MEMORY_REINITED,
|
2018-04-22 15:33:22 +00:00
|
|
|
};
|
|
|
|
|
2018-06-11 21:54:42 +00:00
|
|
|
// Callback is called on the Emu thread.
|
2018-04-22 15:33:22 +00:00
|
|
|
typedef void (* CoreLifecycleFunc)(CoreLifecycle stage);
|
|
|
|
void Core_ListenLifecycle(CoreLifecycleFunc func);
|
|
|
|
void Core_NotifyLifecycle(CoreLifecycle stage);
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2018-06-11 21:54:42 +00:00
|
|
|
// Callback is executed on requesting thread.
|
|
|
|
typedef void (* CoreStopRequestFunc)();
|
|
|
|
void Core_ListenStopRequest(CoreStopRequestFunc callback);
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
bool Core_IsStepping();
|
|
|
|
|
2013-06-08 00:32:07 +00:00
|
|
|
bool Core_IsActive();
|
2013-02-23 20:59:40 +00:00
|
|
|
bool Core_IsInactive();
|
2018-04-30 01:08:41 +00:00
|
|
|
// Warning: these currently work only on Windows.
|
2013-02-23 20:59:40 +00:00
|
|
|
void Core_WaitInactive();
|
2013-02-23 21:21:28 +00:00
|
|
|
void Core_WaitInactive(int milliseconds);
|
2013-02-23 20:59:40 +00:00
|
|
|
|
2017-01-17 10:21:00 +00:00
|
|
|
bool UpdateScreenScale(int width, int height);
|
2014-06-29 11:11:06 +00:00
|
|
|
|
|
|
|
// Don't run the core when minimized etc.
|
|
|
|
void Core_NotifyWindowHidden(bool hidden);
|
2023-08-08 09:21:09 +00:00
|
|
|
bool Core_IsWindowHidden();
|
2016-07-25 00:04:06 +00:00
|
|
|
|
|
|
|
void Core_SetPowerSaving(bool mode);
|
|
|
|
bool Core_GetPowerSaving();
|
2020-07-04 18:30:05 +00:00
|
|
|
|
|
|
|
enum class MemoryExceptionType {
|
2020-07-05 09:40:58 +00:00
|
|
|
NONE,
|
2020-07-13 07:17:42 +00:00
|
|
|
UNKNOWN,
|
2020-07-04 18:30:05 +00:00
|
|
|
READ_WORD,
|
|
|
|
WRITE_WORD,
|
|
|
|
READ_BLOCK,
|
|
|
|
WRITE_BLOCK,
|
2022-08-21 20:24:10 +00:00
|
|
|
ALIGNMENT,
|
2020-07-04 18:30:05 +00:00
|
|
|
};
|
2020-07-13 04:59:08 +00:00
|
|
|
enum class ExecExceptionType {
|
|
|
|
JUMP,
|
|
|
|
THREAD,
|
|
|
|
};
|
2020-07-04 18:30:05 +00:00
|
|
|
|
2020-07-15 10:38:05 +00:00
|
|
|
// Separate one for without info, to avoid having to allocate a string
|
2023-01-01 18:22:41 +00:00
|
|
|
void Core_MemoryException(u32 address, u32 accessSize, u32 pc, MemoryExceptionType type);
|
2020-07-15 10:38:05 +00:00
|
|
|
|
2023-01-01 18:22:41 +00:00
|
|
|
void Core_MemoryExceptionInfo(u32 address, u32 accessSize, u32 pc, MemoryExceptionType type, std::string additionalInfo, bool forceReport);
|
2020-07-15 10:38:05 +00:00
|
|
|
|
2020-07-13 04:59:08 +00:00
|
|
|
void Core_ExecException(u32 address, u32 pc, ExecExceptionType type);
|
2022-08-21 21:09:52 +00:00
|
|
|
void Core_Break(u32 pc);
|
2021-08-09 06:15:27 +00:00
|
|
|
// Call when loading save states, etc.
|
|
|
|
void Core_ResetException();
|
2020-07-04 18:57:05 +00:00
|
|
|
|
2023-04-28 11:38:16 +00:00
|
|
|
enum class MIPSExceptionType {
|
2020-07-04 18:57:05 +00:00
|
|
|
NONE,
|
|
|
|
MEMORY,
|
|
|
|
BREAK,
|
2020-07-04 21:45:03 +00:00
|
|
|
BAD_EXEC_ADDR,
|
2020-07-04 18:57:05 +00:00
|
|
|
};
|
|
|
|
|
2023-04-28 11:38:16 +00:00
|
|
|
struct MIPSExceptionInfo {
|
|
|
|
MIPSExceptionType type;
|
2020-07-04 18:57:05 +00:00
|
|
|
std::string info;
|
2023-03-31 08:08:12 +00:00
|
|
|
std::string stackTrace; // if available.
|
2019-02-12 12:29:37 +00:00
|
|
|
|
|
|
|
// Memory exception info
|
|
|
|
MemoryExceptionType memory_type;
|
|
|
|
uint32_t pc;
|
|
|
|
uint32_t address;
|
2023-01-01 18:22:41 +00:00
|
|
|
uint32_t accessSize;
|
2022-08-21 21:09:52 +00:00
|
|
|
uint32_t ra = 0;
|
2020-07-13 04:59:08 +00:00
|
|
|
|
|
|
|
// Reuses pc and address from memory type, where address is the failed destination.
|
|
|
|
ExecExceptionType exec_type;
|
2020-07-04 18:57:05 +00:00
|
|
|
};
|
|
|
|
|
2023-04-28 11:38:16 +00:00
|
|
|
const MIPSExceptionInfo &Core_GetExceptionInfo();
|
2020-07-04 18:57:05 +00:00
|
|
|
|
2023-04-28 11:38:16 +00:00
|
|
|
const char *ExceptionTypeAsString(MIPSExceptionType type);
|
2019-02-12 12:29:37 +00:00
|
|
|
const char *MemoryExceptionTypeAsString(MemoryExceptionType type);
|
2020-07-13 04:59:08 +00:00
|
|
|
const char *ExecExceptionTypeAsString(ExecExceptionType type);
|