2012-11-01 16:19:01 +01: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 23:01:49 +01:00
|
|
|
// the Free Software Foundation, version 2.0 or later versions.
|
2012-11-01 16:19:01 +01: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/.
|
|
|
|
|
2013-04-13 01:13:28 -07:00
|
|
|
#include "Core/Config.h"
|
|
|
|
#include "Core/HLE/HLE.h"
|
|
|
|
#include "Core/MIPS/MIPS.h"
|
|
|
|
#include "Core/MIPS/MIPSCodeUtils.h"
|
|
|
|
#include "Core/MIPS/MIPSInt.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2013-03-10 23:52:11 -07:00
|
|
|
#include "Common/LogManager.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
#include "../FileSystems/FileSystem.h"
|
|
|
|
#include "../FileSystems/MetaFileSystem.h"
|
|
|
|
#include "../PSPLoaders.h"
|
|
|
|
#include "../../Core/CoreTiming.h"
|
2012-12-27 11:28:12 -08:00
|
|
|
#include "../../Core/SaveState.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
#include "../../Core/System.h"
|
2012-12-21 14:10:57 -08:00
|
|
|
#include "../../GPU/GPUInterface.h"
|
|
|
|
#include "../../GPU/GPUState.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
#include "__sceAudio.h"
|
2013-02-01 08:31:51 -08:00
|
|
|
#include "sceAtrac.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
#include "sceAudio.h"
|
2012-12-02 15:44:23 -08:00
|
|
|
#include "sceCtrl.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
#include "sceDisplay.h"
|
2012-12-27 23:00:04 -08:00
|
|
|
#include "sceFont.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
#include "sceGe.h"
|
|
|
|
#include "sceIo.h"
|
|
|
|
#include "sceKernel.h"
|
|
|
|
#include "sceKernelAlarm.h"
|
|
|
|
#include "sceKernelInterrupt.h"
|
|
|
|
#include "sceKernelThread.h"
|
|
|
|
#include "sceKernelMemory.h"
|
|
|
|
#include "sceKernelMutex.h"
|
|
|
|
#include "sceKernelMbx.h"
|
|
|
|
#include "sceKernelMsgPipe.h"
|
|
|
|
#include "sceKernelInterrupt.h"
|
|
|
|
#include "sceKernelSemaphore.h"
|
|
|
|
#include "sceKernelEventFlag.h"
|
|
|
|
#include "sceKernelVTimer.h"
|
|
|
|
#include "sceKernelTime.h"
|
2012-11-13 18:05:26 +01:00
|
|
|
#include "sceMpeg.h"
|
2013-03-25 00:07:30 +01:00
|
|
|
#include "sceNet.h"
|
2012-11-10 10:15:11 +01:00
|
|
|
#include "scePower.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
#include "sceUtility.h"
|
|
|
|
#include "sceUmd.h"
|
2012-12-06 15:24:25 +00:00
|
|
|
#include "sceSsl.h"
|
2012-12-17 21:45:32 +01:00
|
|
|
#include "sceSas.h"
|
2012-12-24 10:44:40 -08:00
|
|
|
#include "scePsmf.h"
|
2012-12-23 22:47:52 -08:00
|
|
|
#include "sceImpose.h"
|
|
|
|
#include "sceUsb.h"
|
2013-02-24 19:27:37 +02:00
|
|
|
#include "scePspNpDrm_user.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2012-11-18 13:04:49 +01:00
|
|
|
#include "../Util/PPGeDraw.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
17: [MIPS32 R4K 00000000 ]: Loader: Type: 1 Vaddr: 00000000 Filesz: 2856816 Memsz: 2856816
|
|
|
|
18: [MIPS32 R4K 00000000 ]: Loader: Loadable Segment Copied to 0898dab0, size 002b9770
|
|
|
|
19: [MIPS32 R4K 00000000 ]: Loader: Type: 1 Vaddr: 002b9770 Filesz: 14964 Memsz: 733156
|
|
|
|
20: [MIPS32 R4K 00000000 ]: Loader: Loadable Segment Copied to 08c47220, size 000b2fe4
|
|
|
|
*/
|
|
|
|
|
|
|
|
static bool kernelRunning = false;
|
2012-12-27 14:21:39 -08:00
|
|
|
KernelObjectPool kernelObjects;
|
2013-01-10 23:42:46 +01:00
|
|
|
KernelStats kernelStats;
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
void __KernelInit()
|
|
|
|
{
|
|
|
|
if (kernelRunning)
|
|
|
|
{
|
|
|
|
ERROR_LOG(HLE, "Can't init kernel when kernel is running");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-01-02 01:09:44 -08:00
|
|
|
__KernelTimeInit();
|
2012-12-27 15:56:46 -08:00
|
|
|
__InterruptsInit();
|
2012-11-01 16:19:01 +01:00
|
|
|
__KernelMemoryInit();
|
|
|
|
__KernelThreadingInit();
|
2012-12-23 21:27:26 -08:00
|
|
|
__KernelAlarmInit();
|
2013-03-01 15:55:58 +01:00
|
|
|
__KernelVTimerInit();
|
2012-12-23 21:27:26 -08:00
|
|
|
__KernelEventFlagInit();
|
|
|
|
__KernelMbxInit();
|
2012-12-27 15:56:46 -08:00
|
|
|
__KernelMutexInit();
|
|
|
|
__KernelSemaInit();
|
2012-11-01 16:19:01 +01:00
|
|
|
__IoInit();
|
|
|
|
__AudioInit();
|
2012-12-17 21:45:32 +01:00
|
|
|
__SasInit();
|
2013-02-01 08:31:51 -08:00
|
|
|
__AtracInit();
|
2012-11-01 16:19:01 +01:00
|
|
|
__DisplayInit();
|
|
|
|
__GeInit();
|
2012-11-10 10:15:11 +01:00
|
|
|
__PowerInit();
|
2012-11-01 16:19:01 +01:00
|
|
|
__UtilityInit();
|
|
|
|
__UmdInit();
|
2012-11-13 18:05:26 +01:00
|
|
|
__MpegInit(PSP_CoreParameter().useMediaEngine);
|
2012-12-24 10:44:40 -08:00
|
|
|
__PsmfInit();
|
2012-12-02 15:44:23 -08:00
|
|
|
__CtrlInit();
|
2012-12-06 15:24:25 +00:00
|
|
|
__SslInit();
|
2012-12-23 22:47:52 -08:00
|
|
|
__ImposeInit();
|
|
|
|
__UsbInit();
|
2012-12-27 23:00:04 -08:00
|
|
|
__FontInit();
|
2013-03-25 00:07:30 +01:00
|
|
|
__NetInit();
|
2013-03-04 23:34:17 +01:00
|
|
|
|
2013-01-02 21:00:10 +01:00
|
|
|
SaveState::Init(); // Must be after IO, as it may create a directory
|
2012-12-09 20:49:16 +00:00
|
|
|
|
2012-11-18 13:04:49 +01:00
|
|
|
// "Internal" PSP libraries
|
|
|
|
__PPGeInit();
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
kernelRunning = true;
|
|
|
|
INFO_LOG(HLE, "Kernel initialized.");
|
|
|
|
}
|
|
|
|
|
|
|
|
void __KernelShutdown()
|
|
|
|
{
|
|
|
|
if (!kernelRunning)
|
|
|
|
{
|
|
|
|
ERROR_LOG(HLE, "Can't shut down kernel - not running");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
kernelObjects.List();
|
|
|
|
INFO_LOG(HLE, "Shutting down kernel - %i kernel objects alive", kernelObjects.GetCount());
|
2013-03-11 00:18:59 -07:00
|
|
|
hleCurrentThreadName = NULL;
|
2012-11-01 16:19:01 +01:00
|
|
|
kernelObjects.Clear();
|
|
|
|
|
2013-03-25 00:07:30 +01:00
|
|
|
__NetShutdown();
|
2013-02-22 20:05:07 +01:00
|
|
|
__FontShutdown();
|
|
|
|
|
2012-11-13 18:05:26 +01:00
|
|
|
__MpegShutdown();
|
2012-12-24 10:44:40 -08:00
|
|
|
__PsmfShutdown();
|
2012-11-18 13:04:49 +01:00
|
|
|
__PPGeShutdown();
|
2012-12-09 20:49:16 +00:00
|
|
|
|
2012-12-24 01:41:15 -08:00
|
|
|
__CtrlShutdown();
|
|
|
|
__UtilityShutdown();
|
2012-11-01 16:19:01 +01:00
|
|
|
__GeShutdown();
|
2012-12-17 21:45:32 +01:00
|
|
|
__SasShutdown();
|
2012-12-25 15:28:34 +01:00
|
|
|
__DisplayShutdown();
|
2013-02-01 08:31:51 -08:00
|
|
|
__AtracShutdown();
|
2012-11-01 16:19:01 +01:00
|
|
|
__AudioShutdown();
|
|
|
|
__IoShutdown();
|
2012-12-23 11:19:55 +01:00
|
|
|
__KernelMutexShutdown();
|
2012-11-01 16:19:01 +01:00
|
|
|
__KernelThreadingShutdown();
|
|
|
|
__KernelMemoryShutdown();
|
2012-12-27 15:56:46 -08:00
|
|
|
__InterruptsShutdown();
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
CoreTiming::ClearPendingEvents();
|
|
|
|
CoreTiming::UnregisterAllEvents();
|
|
|
|
|
|
|
|
kernelRunning = false;
|
|
|
|
}
|
|
|
|
|
2012-12-26 20:15:31 -08:00
|
|
|
void __KernelDoState(PointerWrap &p)
|
|
|
|
{
|
2013-04-13 01:13:28 -07:00
|
|
|
std::string git_version = PPSSPP_GIT_VERSION;
|
|
|
|
p.Do(git_version);
|
|
|
|
if (git_version != PPSSPP_GIT_VERSION)
|
2013-04-13 01:39:17 -07:00
|
|
|
{
|
|
|
|
p.SetError(p.ERROR_WARNING);
|
2013-04-13 01:13:28 -07:00
|
|
|
WARN_LOG(HLE, "Warning: this savestate was generated by a different version of PPSSPP. It may not load properly.");
|
2013-04-13 01:39:17 -07:00
|
|
|
}
|
2013-04-13 01:13:28 -07:00
|
|
|
|
2012-12-27 14:21:39 -08:00
|
|
|
p.Do(kernelRunning);
|
2012-12-26 20:15:31 -08:00
|
|
|
kernelObjects.DoState(p);
|
|
|
|
p.DoMarker("KernelObjects");
|
2012-12-27 14:21:39 -08:00
|
|
|
|
2012-12-27 15:56:46 -08:00
|
|
|
__InterruptsDoState(p);
|
2013-02-08 08:10:20 -08:00
|
|
|
// Memory needs to be after kernel objects, which may free kernel memory.
|
2012-12-27 15:56:46 -08:00
|
|
|
__KernelMemoryDoState(p);
|
2012-12-27 19:30:36 -08:00
|
|
|
__KernelThreadingDoState(p);
|
2012-12-27 14:21:39 -08:00
|
|
|
__KernelAlarmDoState(p);
|
2013-03-02 17:16:46 +01:00
|
|
|
__KernelVTimerDoState(p);
|
2012-12-27 14:21:39 -08:00
|
|
|
__KernelEventFlagDoState(p);
|
|
|
|
__KernelMbxDoState(p);
|
|
|
|
__KernelModuleDoState(p);
|
|
|
|
__KernelMutexDoState(p);
|
|
|
|
__KernelSemaDoState(p);
|
2013-01-02 01:09:44 -08:00
|
|
|
__KernelTimeDoState(p);
|
2012-12-27 23:00:04 -08:00
|
|
|
|
2013-02-01 08:31:51 -08:00
|
|
|
__AtracDoState(p);
|
2012-12-28 00:05:54 -08:00
|
|
|
__AudioDoState(p);
|
2012-12-27 23:00:04 -08:00
|
|
|
__CtrlDoState(p);
|
2012-12-28 02:22:39 -08:00
|
|
|
__DisplayDoState(p);
|
2012-12-27 23:00:04 -08:00
|
|
|
__FontDoState(p);
|
2012-12-28 02:22:39 -08:00
|
|
|
__GeDoState(p);
|
2012-12-27 23:00:04 -08:00
|
|
|
__ImposeDoState(p);
|
2012-12-28 13:36:37 -08:00
|
|
|
__IoDoState(p);
|
2012-12-28 23:29:24 -08:00
|
|
|
__MpegDoState(p);
|
2013-04-09 02:18:09 -07:00
|
|
|
__NetDoState(p);
|
2012-12-27 23:00:04 -08:00
|
|
|
__PowerDoState(p);
|
2012-12-28 23:29:24 -08:00
|
|
|
__PsmfDoState(p);
|
2013-01-20 16:16:57 +08:00
|
|
|
__PsmfPlayerDoState(p);
|
2012-12-28 00:05:54 -08:00
|
|
|
__SasDoState(p);
|
2012-12-27 23:00:04 -08:00
|
|
|
__SslDoState(p);
|
|
|
|
__UmdDoState(p);
|
2012-12-28 13:36:37 -08:00
|
|
|
__UtilityDoState(p);
|
2012-12-27 23:00:04 -08:00
|
|
|
__UsbDoState(p);
|
|
|
|
|
|
|
|
__PPGeDoState(p);
|
2012-12-27 19:30:36 -08:00
|
|
|
|
|
|
|
__InterruptsDoStateLate(p);
|
|
|
|
__KernelThreadingDoStateLate(p);
|
2012-12-26 20:15:31 -08:00
|
|
|
}
|
|
|
|
|
2012-11-06 22:03:25 +01:00
|
|
|
bool __KernelIsRunning() {
|
|
|
|
return kernelRunning;
|
|
|
|
}
|
|
|
|
|
2012-11-01 16:19:01 +01:00
|
|
|
void sceKernelExitGame()
|
|
|
|
{
|
|
|
|
INFO_LOG(HLE,"sceKernelExitGame");
|
2012-12-29 19:36:03 -08:00
|
|
|
if (!PSP_CoreParameter().headLess)
|
2012-11-01 16:19:01 +01:00
|
|
|
PanicAlert("Game exited");
|
2012-12-29 19:36:03 -08:00
|
|
|
__KernelSwitchOffThread("game exited");
|
2012-11-01 16:19:01 +01:00
|
|
|
Core_Stop();
|
|
|
|
}
|
|
|
|
|
2012-11-08 16:28:45 +01:00
|
|
|
void sceKernelExitGameWithStatus()
|
|
|
|
{
|
|
|
|
INFO_LOG(HLE,"sceKernelExitGameWithStatus");
|
2012-12-29 19:36:03 -08:00
|
|
|
if (!PSP_CoreParameter().headLess)
|
2012-11-08 16:28:45 +01:00
|
|
|
PanicAlert("Game exited (with status)");
|
2012-12-29 19:36:03 -08:00
|
|
|
__KernelSwitchOffThread("game exited");
|
2012-11-08 16:28:45 +01:00
|
|
|
Core_Stop();
|
|
|
|
}
|
|
|
|
|
2012-11-12 00:25:14 +00:00
|
|
|
u32 sceKernelRegisterExitCallback(u32 cbId)
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
2012-11-12 00:04:57 +01:00
|
|
|
DEBUG_LOG(HLE,"NOP sceKernelRegisterExitCallback(%i)", cbId);
|
2012-11-12 00:25:14 +00:00
|
|
|
return 0;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
|
|
|
|
2013-01-31 11:14:03 +08:00
|
|
|
|
|
|
|
u32 sceKernelDevkitVersion()
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
2013-01-31 11:14:03 +08:00
|
|
|
int firmwareVersion = 150;
|
|
|
|
int major = firmwareVersion / 100;
|
|
|
|
int minor = (firmwareVersion / 10) % 10;
|
|
|
|
int revision = firmwareVersion % 10;
|
|
|
|
int devkitVersion = (major << 24) | (minor << 16) | (revision << 8) | 0x10;
|
|
|
|
DEBUG_LOG(HLE,"sceKernelDevkitVersion (%i) ", devkitVersion);
|
|
|
|
return devkitVersion;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
|
|
|
|
2013-01-01 22:22:08 -03:00
|
|
|
u32 sceKernelRegisterKprintfHandler()
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
|
|
|
ERROR_LOG(HLE,"UNIMPL sceKernelRegisterKprintfHandler()");
|
2013-01-01 22:22:08 -03:00
|
|
|
return 0;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
|
|
|
void sceKernelRegisterDefaultExceptionHandler()
|
|
|
|
{
|
|
|
|
ERROR_LOG(HLE,"UNIMPL sceKernelRegisterDefaultExceptionHandler()");
|
|
|
|
RETURN(0);
|
|
|
|
}
|
|
|
|
|
2013-01-01 22:22:08 -03:00
|
|
|
void sceKernelSetGPO(u32 ledAddr)
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
|
|
|
// Sets debug LEDs.
|
2013-01-01 22:22:08 -03:00
|
|
|
DEBUG_LOG(HLE,"sceKernelSetGPO(%02x)", ledAddr);
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
|
|
|
|
2013-01-01 22:22:08 -03:00
|
|
|
u32 sceKernelGetGPI()
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
|
|
|
// Always returns 0 on production systems.
|
2012-11-06 19:22:14 +01:00
|
|
|
DEBUG_LOG(HLE,"0=sceKernelGetGPI()");
|
2013-01-01 22:22:08 -03:00
|
|
|
return 0;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
|
|
|
|
2013-01-22 20:28:05 +01:00
|
|
|
// #define LOG_CACHE
|
|
|
|
|
|
|
|
// Don't even log these by default, they're spammy and we probably won't
|
|
|
|
// need to emulate them. Useful for invalidating cached textures though,
|
|
|
|
// and in the future display lists (although hashing takes care of those
|
|
|
|
// for now).
|
2013-01-02 00:54:23 -08:00
|
|
|
int sceKernelDcacheInvalidateRange(u32 addr, int size)
|
2012-12-21 10:18:52 +01:00
|
|
|
{
|
2013-01-22 20:28:05 +01:00
|
|
|
#ifdef LOG_CACHE
|
|
|
|
NOTICE_LOG(HLE,"sceKernelDcacheInvalidateRange(%08x, %i)", addr, size);
|
|
|
|
#endif
|
2013-01-05 15:30:31 -08:00
|
|
|
if (size < 0 || (int) addr + size < 0)
|
|
|
|
return SCE_KERNEL_ERROR_ILLEGAL_ADDR;
|
|
|
|
|
|
|
|
if (size > 0)
|
|
|
|
{
|
|
|
|
if ((addr % 64) != 0 || (size % 64) != 0)
|
|
|
|
return SCE_KERNEL_ERROR_CACHE_ALIGNMENT;
|
|
|
|
|
|
|
|
if (addr != 0)
|
|
|
|
gpu->InvalidateCache(addr, size);
|
2013-01-04 00:32:18 +01:00
|
|
|
}
|
2013-01-02 00:54:23 -08:00
|
|
|
return 0;
|
2012-12-21 10:18:52 +01:00
|
|
|
}
|
2013-03-16 09:38:50 +01:00
|
|
|
|
|
|
|
int sceKernelIcacheInvalidateRange(u32 addr, int size) {
|
|
|
|
DEBUG_LOG(HLE,"sceKernelIcacheInvalidateRange(%08x, %i)", addr, size);
|
|
|
|
// TODO: Make the JIT hash and compare the touched blocks.
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-01-02 00:54:23 -08:00
|
|
|
int sceKernelDcacheWritebackAll()
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
2013-01-22 20:28:05 +01:00
|
|
|
#ifdef LOG_CACHE
|
|
|
|
NOTICE_LOG(HLE,"sceKernelDcacheWritebackAll()");
|
|
|
|
#endif
|
2013-01-04 00:32:18 +01:00
|
|
|
// Some games seem to use this a lot, it doesn't make sense
|
2013-01-02 23:21:02 -08:00
|
|
|
// to zap the whole texture cache.
|
|
|
|
gpu->InvalidateCacheHint(0, -1);
|
2013-01-02 00:54:23 -08:00
|
|
|
return 0;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
2013-03-16 09:38:50 +01:00
|
|
|
|
2013-01-02 00:54:23 -08:00
|
|
|
int sceKernelDcacheWritebackRange(u32 addr, int size)
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
2013-01-22 20:28:05 +01:00
|
|
|
#ifdef LOG_CACHE
|
|
|
|
NOTICE_LOG(HLE,"sceKernelDcacheWritebackRange(%08x, %i)", addr, size);
|
|
|
|
#endif
|
2013-01-05 15:30:31 -08:00
|
|
|
if (size < 0)
|
|
|
|
return SCE_KERNEL_ERROR_INVALID_SIZE;
|
|
|
|
|
2013-01-04 00:32:18 +01:00
|
|
|
if (size > 0 && addr != 0) {
|
|
|
|
gpu->InvalidateCache(addr, size);
|
|
|
|
}
|
2013-01-02 00:54:23 -08:00
|
|
|
return 0;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
2013-01-02 00:54:23 -08:00
|
|
|
int sceKernelDcacheWritebackInvalidateRange(u32 addr, int size)
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
2013-01-22 20:28:05 +01:00
|
|
|
#ifdef LOG_CACHE
|
|
|
|
NOTICE_LOG(HLE,"sceKernelDcacheInvalidateRange(%08x, %i)", addr, size);
|
|
|
|
#endif
|
2013-01-05 15:30:31 -08:00
|
|
|
if (size < 0)
|
|
|
|
return SCE_KERNEL_ERROR_INVALID_SIZE;
|
|
|
|
|
2013-01-04 00:32:18 +01:00
|
|
|
if (size > 0 && addr != 0) {
|
|
|
|
gpu->InvalidateCache(addr, size);
|
|
|
|
}
|
2013-01-02 00:54:23 -08:00
|
|
|
return 0;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
2013-01-02 00:54:23 -08:00
|
|
|
int sceKernelDcacheWritebackInvalidateAll()
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
2013-01-22 20:28:05 +01:00
|
|
|
#ifdef LOG_CACHE
|
|
|
|
NOTICE_LOG(HLE,"sceKernelDcacheInvalidateAll()");
|
|
|
|
#endif
|
2013-01-06 12:27:01 +01:00
|
|
|
gpu->InvalidateCacheHint(0, -1);
|
2013-01-02 00:54:23 -08:00
|
|
|
return 0;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
|
|
|
|
2013-01-22 20:28:05 +01:00
|
|
|
|
|
|
|
u32 sceKernelIcacheInvalidateAll()
|
|
|
|
{
|
|
|
|
#ifdef LOG_CACHE
|
|
|
|
NOTICE_LOG(CPU, "Icache invalidated - should clear JIT someday");
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
u32 sceKernelIcacheClearAll()
|
|
|
|
{
|
|
|
|
#ifdef LOG_CACHE
|
|
|
|
NOTICE_LOG(CPU, "Icache cleared - should clear JIT someday");
|
|
|
|
#endif
|
|
|
|
DEBUG_LOG(CPU, "Icache cleared - should clear JIT someday");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-11-01 16:19:01 +01:00
|
|
|
KernelObjectPool::KernelObjectPool()
|
|
|
|
{
|
|
|
|
memset(occupied, 0, sizeof(bool)*maxCount);
|
2013-03-31 22:29:44 -07:00
|
|
|
nextID = 16;
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
|
|
|
|
2012-11-04 13:28:52 +01:00
|
|
|
SceUID KernelObjectPool::Create(KernelObject *obj, int rangeBottom, int rangeTop)
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
2012-11-04 13:28:52 +01:00
|
|
|
if (rangeTop > maxCount)
|
|
|
|
rangeTop = maxCount;
|
2013-03-31 22:29:44 -07:00
|
|
|
if (nextID >= rangeBottom && nextID < rangeTop)
|
|
|
|
rangeBottom = nextID++;
|
|
|
|
|
2012-11-04 13:28:52 +01:00
|
|
|
for (int i = rangeBottom; i < rangeTop; i++)
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
|
|
|
if (!occupied[i])
|
|
|
|
{
|
2012-11-04 13:28:52 +01:00
|
|
|
occupied[i] = true;
|
2012-11-01 16:19:01 +01:00
|
|
|
pool[i] = obj;
|
|
|
|
pool[i]->uid = i + handleOffset;
|
|
|
|
return i + handleOffset;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_dbg_assert_(HLE, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool KernelObjectPool::IsValid(SceUID handle)
|
|
|
|
{
|
|
|
|
int index = handle - handleOffset;
|
|
|
|
if (index < 0)
|
|
|
|
return false;
|
|
|
|
if (index >= maxCount)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
return occupied[index];
|
|
|
|
}
|
|
|
|
|
|
|
|
void KernelObjectPool::Clear()
|
|
|
|
{
|
|
|
|
for (int i=0; i<maxCount; i++)
|
|
|
|
{
|
|
|
|
//brutally clear everything, no validation
|
|
|
|
if (occupied[i])
|
|
|
|
delete pool[i];
|
|
|
|
occupied[i]=false;
|
|
|
|
}
|
|
|
|
memset(pool, 0, sizeof(KernelObject*)*maxCount);
|
|
|
|
}
|
2012-11-06 15:46:21 +01:00
|
|
|
|
2012-11-01 16:19:01 +01:00
|
|
|
KernelObject *&KernelObjectPool::operator [](SceUID handle)
|
|
|
|
{
|
|
|
|
_dbg_assert_msg_(HLE, IsValid(handle), "GRABBING UNALLOCED KERNEL OBJ");
|
|
|
|
return pool[handle - handleOffset];
|
|
|
|
}
|
|
|
|
|
|
|
|
void KernelObjectPool::List()
|
|
|
|
{
|
2012-11-06 15:46:21 +01:00
|
|
|
for (int i = 0; i < maxCount; i++)
|
2012-11-01 16:19:01 +01:00
|
|
|
{
|
|
|
|
if (occupied[i])
|
|
|
|
{
|
|
|
|
char buffer[256];
|
|
|
|
if (pool[i])
|
|
|
|
{
|
|
|
|
pool[i]->GetQuickInfo(buffer,256);
|
2012-12-21 16:07:42 -08:00
|
|
|
INFO_LOG(HLE, "KO %i: %s \"%s\": %s", i + handleOffset, pool[i]->GetTypeName(), pool[i]->GetName(), buffer);
|
2012-11-01 16:19:01 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
strcpy(buffer,"WTF? Zero Pointer");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-11-06 15:46:21 +01:00
|
|
|
|
2012-11-01 16:19:01 +01:00
|
|
|
int KernelObjectPool::GetCount()
|
|
|
|
{
|
|
|
|
int count = 0;
|
|
|
|
for (int i=0; i<maxCount; i++)
|
|
|
|
{
|
|
|
|
if (occupied[i])
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
return count;
|
|
|
|
}
|
|
|
|
|
2012-12-26 20:15:31 -08:00
|
|
|
void KernelObjectPool::DoState(PointerWrap &p)
|
|
|
|
{
|
|
|
|
int _maxCount = maxCount;
|
|
|
|
p.Do(_maxCount);
|
2012-12-26 22:45:19 -08:00
|
|
|
|
|
|
|
if (_maxCount != maxCount)
|
2013-04-13 01:39:17 -07:00
|
|
|
{
|
|
|
|
p.SetError(p.ERROR_FAILURE);
|
2012-12-26 22:45:19 -08:00
|
|
|
ERROR_LOG(HLE, "Unable to load state: different kernel object storage.");
|
2013-04-13 01:39:17 -07:00
|
|
|
return;
|
|
|
|
}
|
2012-12-26 22:45:19 -08:00
|
|
|
|
2012-12-27 15:56:46 -08:00
|
|
|
if (p.mode == p.MODE_READ)
|
2013-03-10 23:52:11 -07:00
|
|
|
{
|
|
|
|
hleCurrentThreadName = NULL;
|
2012-12-27 15:56:46 -08:00
|
|
|
kernelObjects.Clear();
|
2013-03-10 23:52:11 -07:00
|
|
|
}
|
2012-12-27 15:56:46 -08:00
|
|
|
|
2013-03-31 22:29:44 -07:00
|
|
|
p.Do(nextID);
|
2012-12-26 20:15:31 -08:00
|
|
|
p.DoArray(occupied, maxCount);
|
|
|
|
for (int i = 0; i < maxCount; ++i)
|
|
|
|
{
|
|
|
|
if (!occupied[i])
|
|
|
|
continue;
|
|
|
|
|
2012-12-26 22:45:19 -08:00
|
|
|
int type;
|
|
|
|
if (p.mode == p.MODE_READ)
|
2012-12-26 20:15:31 -08:00
|
|
|
{
|
2012-12-26 22:45:19 -08:00
|
|
|
p.Do(type);
|
|
|
|
pool[i] = CreateByIDType(type);
|
2012-12-28 03:54:16 -08:00
|
|
|
pool[i]->uid = i + handleOffset;
|
2012-12-26 22:50:45 -08:00
|
|
|
|
|
|
|
// Already logged an error.
|
|
|
|
if (pool[i] == NULL)
|
|
|
|
return;
|
2012-12-26 20:15:31 -08:00
|
|
|
}
|
2012-12-26 22:45:19 -08:00
|
|
|
else
|
|
|
|
{
|
|
|
|
type = pool[i]->GetIDType();
|
|
|
|
p.Do(type);
|
|
|
|
}
|
|
|
|
pool[i]->DoState(p);
|
2012-12-26 20:15:31 -08:00
|
|
|
}
|
|
|
|
p.DoMarker("KernelObjectPool");
|
|
|
|
}
|
|
|
|
|
2012-12-26 22:45:19 -08:00
|
|
|
KernelObject *KernelObjectPool::CreateByIDType(int type)
|
|
|
|
{
|
|
|
|
// Used for save states. This is ugly, but what other way is there?
|
|
|
|
switch (type)
|
|
|
|
{
|
|
|
|
case SCE_KERNEL_TMID_Alarm:
|
|
|
|
return __KernelAlarmObject();
|
|
|
|
case SCE_KERNEL_TMID_EventFlag:
|
|
|
|
return __KernelEventFlagObject();
|
|
|
|
case SCE_KERNEL_TMID_Mbox:
|
|
|
|
return __KernelMbxObject();
|
|
|
|
case SCE_KERNEL_TMID_Fpl:
|
|
|
|
return __KernelMemoryFPLObject();
|
|
|
|
case SCE_KERNEL_TMID_Vpl:
|
|
|
|
return __KernelMemoryVPLObject();
|
|
|
|
case PPSSPP_KERNEL_TMID_PMB:
|
|
|
|
return __KernelMemoryPMBObject();
|
|
|
|
case PPSSPP_KERNEL_TMID_Module:
|
|
|
|
return __KernelModuleObject();
|
|
|
|
case SCE_KERNEL_TMID_Mpipe:
|
|
|
|
return __KernelMsgPipeObject();
|
|
|
|
case SCE_KERNEL_TMID_Mutex:
|
|
|
|
return __KernelMutexObject();
|
|
|
|
case SCE_KERNEL_TMID_LwMutex:
|
|
|
|
return __KernelLwMutexObject();
|
|
|
|
case SCE_KERNEL_TMID_Semaphore:
|
|
|
|
return __KernelSemaphoreObject();
|
|
|
|
case SCE_KERNEL_TMID_Callback:
|
|
|
|
return __KernelCallbackObject();
|
|
|
|
case SCE_KERNEL_TMID_Thread:
|
|
|
|
return __KernelThreadObject();
|
|
|
|
case SCE_KERNEL_TMID_VTimer:
|
|
|
|
return __KernelVTimerObject();
|
|
|
|
case PPSSPP_KERNEL_TMID_File:
|
|
|
|
return __KernelFileNodeObject();
|
|
|
|
case PPSSPP_KERNEL_TMID_DirList:
|
|
|
|
return __KernelDirListingObject();
|
|
|
|
|
|
|
|
default:
|
|
|
|
ERROR_LOG(COMMON, "Unable to load state: could not find object type %d.", type);
|
2012-12-26 22:50:45 -08:00
|
|
|
return NULL;
|
2012-12-26 22:45:19 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-11-09 17:51:45 +01:00
|
|
|
struct SystemStatus {
|
|
|
|
SceSize size;
|
|
|
|
SceUInt status;
|
|
|
|
SceUInt clockPart1;
|
|
|
|
SceUInt clockPart2;
|
|
|
|
SceUInt perfcounter1;
|
|
|
|
SceUInt perfcounter2;
|
|
|
|
SceUInt perfcounter3;
|
|
|
|
};
|
|
|
|
|
2013-03-04 22:15:39 +01:00
|
|
|
int sceKernelReferSystemStatus(u32 statusPtr) {
|
2012-11-09 17:51:45 +01:00
|
|
|
DEBUG_LOG(HLE, "sceKernelReferSystemStatus(%08x)", statusPtr);
|
|
|
|
if (Memory::IsValidAddress(statusPtr)) {
|
|
|
|
SystemStatus status;
|
|
|
|
memset(&status, 0, sizeof(SystemStatus));
|
|
|
|
status.size = sizeof(SystemStatus);
|
2013-03-04 22:15:39 +01:00
|
|
|
// TODO: Fill in the struct!
|
2012-11-09 17:51:45 +01:00
|
|
|
Memory::WriteStruct(statusPtr, &status);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-03-04 23:39:59 +01:00
|
|
|
struct DebugProfilerRegs {
|
|
|
|
u32 enable;
|
|
|
|
u32 systemck;
|
|
|
|
u32 cpuck;
|
|
|
|
u32 internal;
|
|
|
|
u32 memory;
|
|
|
|
u32 copz;
|
|
|
|
u32 vfpu;
|
|
|
|
u32 sleep;
|
|
|
|
u32 bus_access;
|
|
|
|
u32 uncached_load;
|
|
|
|
u32 uncached_store;
|
|
|
|
u32 cached_load;
|
|
|
|
u32 cached_store;
|
|
|
|
u32 i_miss;
|
|
|
|
u32 d_miss;
|
|
|
|
u32 d_writeback;
|
|
|
|
u32 cop0_inst;
|
|
|
|
u32 fpu_inst;
|
|
|
|
u32 vfpu_inst;
|
|
|
|
u32 local_bus;
|
|
|
|
};
|
|
|
|
|
2013-03-05 00:20:11 +01:00
|
|
|
u32 sceKernelReferThreadProfiler(u32 statusPtr) {
|
2013-03-04 23:39:59 +01:00
|
|
|
ERROR_LOG(HLE, "FAKE sceKernelReferThreadProfiler()");
|
|
|
|
|
2013-03-05 00:20:11 +01:00
|
|
|
// Can we confirm that the struct above is the right struct?
|
|
|
|
// If so, re-enable this code.
|
|
|
|
//DebugProfilerRegs regs;
|
|
|
|
//memset(®s, 0, sizeof(regs));
|
|
|
|
// TODO: fill the struct.
|
|
|
|
//if (Memory::IsValidAddress(statusPtr)) {
|
|
|
|
// Memory::WriteStruct(statusPtr, ®s);
|
|
|
|
//}
|
2013-03-04 22:15:39 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int sceKernelReferGlobalProfiler(u32 statusPtr) {
|
|
|
|
DEBUG_LOG(HLE, "UNIMPL sceKernelReferGlobalProfiler(%08x)", statusPtr);
|
2012-11-12 00:04:57 +01:00
|
|
|
// Ignore for now
|
|
|
|
return 0;
|
|
|
|
}
|
2012-11-09 17:51:45 +01:00
|
|
|
|
2012-11-01 16:19:01 +01:00
|
|
|
const HLEFunction ThreadManForUser[] =
|
|
|
|
{
|
2013-02-24 22:50:48 -08:00
|
|
|
{0x55C20A00,&WrapI_CUUU<sceKernelCreateEventFlag>, "sceKernelCreateEventFlag"},
|
|
|
|
{0x812346E4,&WrapU_IU<sceKernelClearEventFlag>, "sceKernelClearEventFlag"},
|
|
|
|
{0xEF9E4C70,&WrapU_I<sceKernelDeleteEventFlag>, "sceKernelDeleteEventFlag"},
|
|
|
|
{0x1fb15a32,&WrapU_IU<sceKernelSetEventFlag>, "sceKernelSetEventFlag"},
|
|
|
|
{0x402FCF22,&WrapI_IUUUU<sceKernelWaitEventFlag>, "sceKernelWaitEventFlag"},
|
|
|
|
{0x328C546A,&WrapI_IUUUU<sceKernelWaitEventFlagCB>, "sceKernelWaitEventFlagCB"},
|
|
|
|
{0x30FD48F0,&WrapI_IUUUU<sceKernelPollEventFlag>, "sceKernelPollEventFlag"},
|
|
|
|
{0xCD203292,&WrapU_IUU<sceKernelCancelEventFlag>, "sceKernelCancelEventFlag"},
|
|
|
|
{0xA66B0120,&WrapU_IU<sceKernelReferEventFlagStatus>, "sceKernelReferEventFlagStatus"},
|
|
|
|
|
|
|
|
{0x8FFDF9A2,&WrapI_IIU<sceKernelCancelSema>, "sceKernelCancelSema"},
|
|
|
|
{0xD6DA4BA1,&WrapI_CUIIU<sceKernelCreateSema>, "sceKernelCreateSema"},
|
|
|
|
{0x28b6489c,&WrapI_I<sceKernelDeleteSema>, "sceKernelDeleteSema"},
|
|
|
|
{0x58b1f937,&WrapI_II<sceKernelPollSema>, "sceKernelPollSema"},
|
|
|
|
{0xBC6FEBC5,&WrapI_IU<sceKernelReferSemaStatus>, "sceKernelReferSemaStatus"},
|
|
|
|
{0x3F53E640,&WrapI_II<sceKernelSignalSema>, "sceKernelSignalSema"},
|
2013-03-24 23:30:32 -07:00
|
|
|
{0x4E3A1105,&WrapI_IIU<sceKernelWaitSema>, "sceKernelWaitSema", HLE_NOT_DISPATCH_SUSPENDED},
|
|
|
|
{0x6d212bac,&WrapI_IIU<sceKernelWaitSemaCB>, "sceKernelWaitSemaCB", HLE_NOT_DISPATCH_SUSPENDED},
|
2013-02-24 22:50:48 -08:00
|
|
|
|
|
|
|
{0x60107536,&WrapI_U<sceKernelDeleteLwMutex>, "sceKernelDeleteLwMutex"},
|
|
|
|
{0x19CFF145,&WrapI_UCUIU<sceKernelCreateLwMutex>, "sceKernelCreateLwMutex"},
|
|
|
|
{0x4C145944,&WrapI_IU<sceKernelReferLwMutexStatusByID>, "sceKernelReferLwMutexStatusByID"},
|
|
|
|
// NOTE: LockLwMutex, UnlockLwMutex, and ReferLwMutexStatus are in Kernel_Library, see sceKernelInterrupt.cpp.
|
2013-04-14 11:03:23 -07:00
|
|
|
// The below should not be called directly.
|
|
|
|
//{0x71040D5C,0, "_sceKernelTryLockLwMutex"},
|
|
|
|
//{0x7CFF8CF3,0, "_sceKernelLockLwMutex"},
|
|
|
|
//{0x31327F19,0, "_sceKernelLockLwMutexCB"},
|
|
|
|
//{0xBEED3A47,0, "_sceKernelUnlockLwMutex"},
|
2013-02-24 22:50:48 -08:00
|
|
|
|
|
|
|
{0xf8170fbe,&WrapI_I<sceKernelDeleteMutex>, "sceKernelDeleteMutex"},
|
2013-03-25 00:07:44 -07:00
|
|
|
{0xB011B11F,&WrapI_IIU<sceKernelLockMutex>, "sceKernelLockMutex", HLE_NOT_DISPATCH_SUSPENDED},
|
|
|
|
{0x5bf4dd27,&WrapI_IIU<sceKernelLockMutexCB>, "sceKernelLockMutexCB", HLE_NOT_DISPATCH_SUSPENDED},
|
2013-02-24 22:50:48 -08:00
|
|
|
{0x6b30100f,&WrapI_II<sceKernelUnlockMutex>, "sceKernelUnlockMutex"},
|
|
|
|
{0xb7d098c6,&WrapI_CUIU<sceKernelCreateMutex>, "sceKernelCreateMutex"},
|
|
|
|
{0x0DDCD2C9,&WrapI_II<sceKernelTryLockMutex>, "sceKernelTryLockMutex"},
|
|
|
|
{0xA9C2CB9A,&WrapI_IU<sceKernelReferMutexStatus>, "sceKernelReferMutexStatus"},
|
2013-04-14 11:03:23 -07:00
|
|
|
{0x87D9223C,0, "sceKernelCancelMutex"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2012-11-12 00:04:57 +01:00
|
|
|
{0xFCCFAD26,sceKernelCancelWakeupThread,"sceKernelCancelWakeupThread"},
|
2013-04-14 11:03:23 -07:00
|
|
|
{0x1AF94D03,0,"sceKernelDonateWakeupThread"},
|
2012-11-05 10:05:09 +01:00
|
|
|
{0xea748e31,sceKernelChangeCurrentThreadAttr,"sceKernelChangeCurrentThreadAttr"},
|
|
|
|
{0x71bc9871,sceKernelChangeThreadPriority,"sceKernelChangeThreadPriority"},
|
2012-12-09 00:29:10 -08:00
|
|
|
{0x446D8DE6,WrapI_CUUIUU<sceKernelCreateThread>,"sceKernelCreateThread"},
|
|
|
|
{0x9fa03cd3,WrapI_I<sceKernelDeleteThread>,"sceKernelDeleteThread"},
|
2013-01-05 23:24:05 +01:00
|
|
|
{0xBD123D9E,sceKernelDelaySysClockThread,"sceKernelDelaySysClockThread"},
|
|
|
|
{0x1181E963,sceKernelDelaySysClockThreadCB,"sceKernelDelaySysClockThreadCB"},
|
2013-03-06 07:40:34 -08:00
|
|
|
{0xceadeb47,WrapI_U<sceKernelDelayThread>,"sceKernelDelayThread"},
|
|
|
|
{0x68da9e36,WrapI_U<sceKernelDelayThreadCB>,"sceKernelDelayThreadCB"},
|
2013-04-09 23:16:23 -07:00
|
|
|
{0xaa73c935,WrapV_I<sceKernelExitThread>,"sceKernelExitThread"},
|
|
|
|
{0x809ce29b,WrapV_I<sceKernelExitDeleteThread>,"sceKernelExitDeleteThread"},
|
2012-11-06 16:20:13 +01:00
|
|
|
{0x94aa61ee,sceKernelGetThreadCurrentPriority,"sceKernelGetThreadCurrentPriority"},
|
2013-04-09 23:16:23 -07:00
|
|
|
{0x293b45b8,WrapI_V<sceKernelGetThreadId>,"sceKernelGetThreadId"},
|
2012-11-05 10:05:09 +01:00
|
|
|
{0x3B183E26,sceKernelGetThreadExitStatus,"sceKernelGetThreadExitStatus"},
|
|
|
|
{0x52089CA1,sceKernelGetThreadStackFreeSize,"sceKernelGetThreadStackFreeSize"},
|
2013-01-05 23:06:28 +01:00
|
|
|
{0xFFC36A14,WrapU_UU<sceKernelReferThreadRunStatus>,"sceKernelReferThreadRunStatus"},
|
|
|
|
{0x17c1684e,WrapU_UU<sceKernelReferThreadStatus>,"sceKernelReferThreadStatus"},
|
2013-01-07 19:44:39 -08:00
|
|
|
{0x2C34E053,WrapI_I<sceKernelReleaseWaitThread>,"sceKernelReleaseWaitThread"},
|
2012-11-05 10:05:09 +01:00
|
|
|
{0x75156e8f,sceKernelResumeThread,"sceKernelResumeThread"},
|
2012-11-06 19:22:14 +01:00
|
|
|
{0x3ad58b8c,&WrapU_V<sceKernelSuspendDispatchThread>,"sceKernelSuspendDispatchThread"},
|
|
|
|
{0x27e22ec2,&WrapU_U<sceKernelResumeDispatchThread>,"sceKernelResumeDispatchThread"},
|
2013-02-09 02:17:19 -08:00
|
|
|
{0x912354a7,&WrapI_I<sceKernelRotateThreadReadyQueue>,"sceKernelRotateThreadReadyQueue"},
|
2012-11-05 10:05:09 +01:00
|
|
|
{0x9ACE131E,sceKernelSleepThread,"sceKernelSleepThread"},
|
|
|
|
{0x82826f70,sceKernelSleepThreadCB,"sceKernelSleepThreadCB"},
|
2012-12-09 00:29:10 -08:00
|
|
|
{0xF475845D,&WrapI_IUU<sceKernelStartThread>,"sceKernelStartThread"},
|
2012-11-05 10:05:09 +01:00
|
|
|
{0x9944f31f,sceKernelSuspendThread,"sceKernelSuspendThread"},
|
2013-03-02 14:58:58 -08:00
|
|
|
{0x616403ba,WrapI_I<sceKernelTerminateThread>,"sceKernelTerminateThread"},
|
2012-12-09 00:29:10 -08:00
|
|
|
{0x383f7bcc,WrapI_I<sceKernelTerminateDeleteThread>,"sceKernelTerminateDeleteThread"},
|
2013-01-07 10:02:11 -08:00
|
|
|
{0x840E8133,WrapI_IU<sceKernelWaitThreadEndCB>,"sceKernelWaitThreadEndCB"},
|
2013-03-23 14:41:13 +01:00
|
|
|
{0xd13bde95,WrapI_V<sceKernelCheckThreadStack>,"sceKernelCheckThreadStack"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2012-12-17 22:20:32 +01:00
|
|
|
{0x94416130,WrapU_UUUU<sceKernelGetThreadmanIdList>,"sceKernelGetThreadmanIdList"},
|
|
|
|
{0x57CF62DD,WrapU_U<sceKernelGetThreadmanIdType>,"sceKernelGetThreadmanIdType"},
|
2013-02-04 02:53:38 +08:00
|
|
|
{0xBC80EC7C,WrapU_UUUU<sceKernelExtendThreadStack>, "sceKernelExtendThreadStack"},
|
2013-04-14 11:03:23 -07:00
|
|
|
// NOTE: Takes a UID from sceKernelMemory's AllocMemoryBlock and seems thread stack related.
|
|
|
|
//{0x28BFD974,0,"ThreadManForUser_28BFD974"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2013-02-03 16:33:01 +01:00
|
|
|
{0x82BC5777,WrapU64_V<sceKernelGetSystemTimeWide>,"sceKernelGetSystemTimeWide"},
|
2013-02-02 20:42:16 -08:00
|
|
|
{0xdb738f35,WrapI_U<sceKernelGetSystemTime>,"sceKernelGetSystemTime"},
|
2013-02-03 16:33:01 +01:00
|
|
|
{0x369ed59d,WrapU_V<sceKernelGetSystemTimeLow>,"sceKernelGetSystemTimeLow"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2013-03-04 22:15:39 +01:00
|
|
|
{0x8218B4DD,WrapI_U<sceKernelReferGlobalProfiler>,"sceKernelReferGlobalProfiler"},
|
|
|
|
{0x627E6F3A,WrapI_U<sceKernelReferSystemStatus>,"sceKernelReferSystemStatus"},
|
2013-03-05 00:20:11 +01:00
|
|
|
{0x64D4540E,WrapU_U<sceKernelReferThreadProfiler>,"sceKernelReferThreadProfiler"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
//Fifa Street 2 uses alarms
|
2012-12-18 23:47:57 -08:00
|
|
|
{0x6652b8ca,WrapI_UUU<sceKernelSetAlarm>,"sceKernelSetAlarm"},
|
|
|
|
{0xB2C25152,WrapI_UUU<sceKernelSetSysClockAlarm>,"sceKernelSetSysClockAlarm"},
|
|
|
|
{0x7e65b999,WrapI_I<sceKernelCancelAlarm>,"sceKernelCancelAlarm"},
|
|
|
|
{0xDAA3F564,WrapI_IU<sceKernelReferAlarmStatus>,"sceKernelReferAlarmStatus"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2013-02-02 20:42:16 -08:00
|
|
|
{0xba6b92e2,WrapI_UUU<sceKernelSysClock2USec>,"sceKernelSysClock2USec"},
|
2013-02-03 22:14:19 +01:00
|
|
|
{0x110dec9a,WrapI_UU<sceKernelUSec2SysClock>,"sceKernelUSec2SysClock"},
|
|
|
|
{0xC8CD158C,WrapU64_U<sceKernelUSec2SysClockWide>,"sceKernelUSec2SysClockWide"},
|
2013-02-03 16:33:01 +01:00
|
|
|
{0xE1619D7C,WrapI_UUUU<sceKernelSysClock2USecWide>,"sceKernelSysClock2USecWide"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2013-01-07 10:02:11 -08:00
|
|
|
{0x278C0DF5,WrapI_IU<sceKernelWaitThreadEnd>,"sceKernelWaitThreadEnd"},
|
2012-11-05 10:05:09 +01:00
|
|
|
{0xd59ead2f,sceKernelWakeupThread,"sceKernelWakeupThread"}, //AI Go, audio?
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
{0x0C106E53,0,"sceKernelRegisterThreadEventHandler"},
|
|
|
|
{0x72F3C145,0,"sceKernelReleaseThreadEventHandler"},
|
|
|
|
{0x369EEB6B,0,"sceKernelReferThreadEventHandlerStatus"},
|
|
|
|
|
2012-11-07 15:44:48 +01:00
|
|
|
{0x349d6d6c,sceKernelCheckCallback,"sceKernelCheckCallback"},
|
2012-11-05 10:05:09 +01:00
|
|
|
{0xE81CAF8F,sceKernelCreateCallback,"sceKernelCreateCallback"},
|
|
|
|
{0xEDBA5844,sceKernelDeleteCallback,"sceKernelDeleteCallback"},
|
|
|
|
{0xC11BA8C4,sceKernelNotifyCallback,"sceKernelNotifyCallback"},
|
|
|
|
{0xBA4051D6,sceKernelCancelCallback,"sceKernelCancelCallback"},
|
|
|
|
{0x2A3D44FF,sceKernelGetCallbackCount,"sceKernelGetCallbackCount"},
|
|
|
|
{0x730ED8BC,sceKernelReferCallbackStatus,"sceKernelReferCallbackStatus"},
|
|
|
|
|
2012-12-15 18:06:55 -08:00
|
|
|
{0x8125221D,&WrapI_CUU<sceKernelCreateMbx>,"sceKernelCreateMbx"},
|
2012-11-08 14:24:51 +01:00
|
|
|
{0x86255ADA,&WrapI_I<sceKernelDeleteMbx>,"sceKernelDeleteMbx"},
|
2012-12-16 18:40:47 -08:00
|
|
|
{0xE9B3061E,&WrapI_IU<sceKernelSendMbx>,"sceKernelSendMbx"},
|
|
|
|
{0x18260574,&WrapI_IUU<sceKernelReceiveMbx>,"sceKernelReceiveMbx"},
|
|
|
|
{0xF3986382,&WrapI_IUU<sceKernelReceiveMbxCB>,"sceKernelReceiveMbxCB"},
|
2012-11-08 14:24:51 +01:00
|
|
|
{0x0D81716A,&WrapI_IU<sceKernelPollMbx>,"sceKernelPollMbx"},
|
|
|
|
{0x87D4DD36,&WrapI_IU<sceKernelCancelReceiveMbx>,"sceKernelCancelReceiveMbx"},
|
|
|
|
{0xA8E8C846,&WrapI_IU<sceKernelReferMbxStatus>,"sceKernelReferMbxStatus"},
|
2012-11-05 10:05:09 +01:00
|
|
|
|
|
|
|
{0x7C0DC2A0,sceKernelCreateMsgPipe,"sceKernelCreateMsgPipe"},
|
|
|
|
{0xF0B7DA1C,sceKernelDeleteMsgPipe,"sceKernelDeleteMsgPipe"},
|
|
|
|
{0x876DBFAD,sceKernelSendMsgPipe,"sceKernelSendMsgPipe"},
|
|
|
|
{0x7C41F2C2,sceKernelSendMsgPipeCB,"sceKernelSendMsgPipeCB"},
|
|
|
|
{0x884C9F90,sceKernelTrySendMsgPipe,"sceKernelTrySendMsgPipe"},
|
|
|
|
{0x74829B76,sceKernelReceiveMsgPipe,"sceKernelReceiveMsgPipe"},
|
|
|
|
{0xFBFA697D,sceKernelReceiveMsgPipeCB,"sceKernelReceiveMsgPipeCB"},
|
|
|
|
{0xDF52098F,sceKernelTryReceiveMsgPipe,"sceKernelTryReceiveMsgPipe"},
|
|
|
|
{0x349B864D,sceKernelCancelMsgPipe,"sceKernelCancelMsgPipe"},
|
|
|
|
{0x33BE4024,sceKernelReferMsgPipeStatus,"sceKernelReferMsgPipeStatus"},
|
|
|
|
|
2012-12-30 18:19:00 -08:00
|
|
|
{0x56C039B5,WrapI_CIUUU<sceKernelCreateVpl>,"sceKernelCreateVpl"},
|
2013-01-17 22:05:46 -08:00
|
|
|
{0x89B3D48C,WrapI_I<sceKernelDeleteVpl>,"sceKernelDeleteVpl"},
|
2013-01-15 22:13:11 -08:00
|
|
|
{0xBED27435,WrapI_IUUU<sceKernelAllocateVpl>,"sceKernelAllocateVpl"},
|
|
|
|
{0xEC0A693F,WrapI_IUUU<sceKernelAllocateVplCB>,"sceKernelAllocateVplCB"},
|
|
|
|
{0xAF36D708,WrapI_IUU<sceKernelTryAllocateVpl>,"sceKernelTryAllocateVpl"},
|
2013-01-16 00:47:06 -08:00
|
|
|
{0xB736E9FF,WrapI_IU<sceKernelFreeVpl>,"sceKernelFreeVpl"},
|
2013-01-17 22:05:46 -08:00
|
|
|
{0x1D371B8A,WrapI_IU<sceKernelCancelVpl>,"sceKernelCancelVpl"},
|
|
|
|
{0x39810265,WrapI_IU<sceKernelReferVplStatus>,"sceKernelReferVplStatus"},
|
2012-11-05 10:05:09 +01:00
|
|
|
|
|
|
|
{0xC07BB470,sceKernelCreateFpl,"sceKernelCreateFpl"},
|
|
|
|
{0xED1410E0,sceKernelDeleteFpl,"sceKernelDeleteFpl"},
|
|
|
|
{0xD979E9BF,sceKernelAllocateFpl,"sceKernelAllocateFpl"},
|
|
|
|
{0xE7282CB6,sceKernelAllocateFplCB,"sceKernelAllocateFplCB"},
|
|
|
|
{0x623AE665,sceKernelTryAllocateFpl,"sceKernelTryAllocateFpl"},
|
|
|
|
{0xF6414A71,sceKernelFreeFpl,"sceKernelFreeFpl"},
|
|
|
|
{0xA8AA591F,sceKernelCancelFpl,"sceKernelCancelFpl"},
|
|
|
|
{0xD8199E4C,sceKernelReferFplStatus,"sceKernelReferFplStatus"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2012-12-30 21:30:33 +01:00
|
|
|
{0x20fff560,WrapU_CU<sceKernelCreateVTimer>,"sceKernelCreateVTimer"},
|
|
|
|
{0x328F9E52,WrapU_U<sceKernelDeleteVTimer>,"sceKernelDeleteVTimer"},
|
|
|
|
{0xc68d9437,WrapU_U<sceKernelStartVTimer>,"sceKernelStartVTimer"},
|
|
|
|
{0xD0AEEE87,WrapU_U<sceKernelStopVTimer>,"sceKernelStopVTimer"},
|
|
|
|
{0xD2D615EF,WrapU_U<sceKernelCancelVTimerHandler>,"sceKernelCancelVTimerHandler"},
|
|
|
|
{0xB3A59970,WrapU_UU<sceKernelGetVTimerBase>,"sceKernelGetVTimerBase"},
|
|
|
|
{0xB7C18B77,WrapU64_U<sceKernelGetVTimerBaseWide>,"sceKernelGetVTimerBaseWide"},
|
|
|
|
{0x034A921F,WrapU_UU<sceKernelGetVTimerTime>,"sceKernelGetVTimerTime"},
|
|
|
|
{0xC0B3FFD2,WrapU64_U<sceKernelGetVTimerTimeWide>,"sceKernelGetVTimerTimeWide"},
|
|
|
|
{0x5F32BEAA,WrapU_UU<sceKernelReferVTimerStatus>,"sceKernelReferVTimerStatus"},
|
|
|
|
{0x542AD630,WrapU_UU<sceKernelSetVTimerTime>,"sceKernelSetVTimerTime"},
|
|
|
|
{0xFB6425C3,WrapU_UU64<sceKernelSetVTimerTimeWide>,"sceKernelSetVTimerTimeWide"},
|
|
|
|
{0xd8b299ae,WrapU_UUUU<sceKernelSetVTimerHandler>,"sceKernelSetVTimerHandler"},
|
|
|
|
{0x53B00E9A,WrapU_UU64UU<sceKernelSetVTimerHandlerWide>,"sceKernelSetVTimerHandlerWide"},
|
|
|
|
|
2013-04-07 20:57:53 -07:00
|
|
|
{0x8daff657,WrapI_CUUUUU<ThreadManForUser_8DAFF657>,"ThreadManForUser_8DAFF657"},
|
|
|
|
{0x32bf938e,WrapI_I<ThreadManForUser_32BF938E>,"ThreadManForUser_32BF938E"},
|
|
|
|
|
2012-11-07 15:44:48 +01:00
|
|
|
// Not sure if these should be hooked up. See below.
|
2012-11-01 16:19:01 +01:00
|
|
|
{0x0E927AED, _sceKernelReturnFromTimerHandler, "_sceKernelReturnFromTimerHandler"},
|
2013-04-09 23:16:23 -07:00
|
|
|
{0x532A522E, WrapV_I<_sceKernelExitThread>,"_sceKernelExitThread"},
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2012-11-06 16:20:13 +01:00
|
|
|
|
2012-11-01 16:19:01 +01:00
|
|
|
// Shouldn't hook this up. No games should import this function manually and call it.
|
|
|
|
// {0x6E9EA350, _sceKernelReturnFromCallback,"_sceKernelReturnFromCallback"},
|
|
|
|
};
|
|
|
|
|
|
|
|
void Register_ThreadManForUser()
|
|
|
|
{
|
|
|
|
RegisterModule("ThreadManForUser", ARRAY_SIZE(ThreadManForUser), ThreadManForUser);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const HLEFunction LoadExecForUser[] =
|
|
|
|
{
|
2012-11-12 00:25:14 +00:00
|
|
|
{0x05572A5F,&WrapV_V<sceKernelExitGame>, "sceKernelExitGame"}, //()
|
|
|
|
{0x4AC57943,&WrapU_U<sceKernelRegisterExitCallback>,"sceKernelRegisterExitCallback"},
|
|
|
|
{0xBD2F1094,&WrapI_CU<sceKernelLoadExec>,"sceKernelLoadExec"},
|
|
|
|
{0x2AC9954B,&WrapV_V<sceKernelExitGameWithStatus>,"sceKernelExitGameWithStatus"},
|
2012-11-01 16:19:01 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
void Register_LoadExecForUser()
|
|
|
|
{
|
|
|
|
RegisterModule("LoadExecForUser", ARRAY_SIZE(LoadExecForUser), LoadExecForUser);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const HLEFunction ExceptionManagerForKernel[] =
|
|
|
|
{
|
|
|
|
{0x3FB264FC, 0, "sceKernelRegisterExceptionHandler"},
|
|
|
|
{0x5A837AD4, 0, "sceKernelRegisterPriorityExceptionHandler"},
|
|
|
|
{0x565C0B0E, sceKernelRegisterDefaultExceptionHandler, "sceKernelRegisterDefaultExceptionHandler"},
|
|
|
|
{0x1AA6CFFA, 0, "sceKernelReleaseExceptionHandler"},
|
|
|
|
{0xDF83875E, 0, "sceKernelGetActiveDefaultExceptionHandler"},
|
|
|
|
{0x291FF031, 0, "sceKernelReleaseDefaultExceptionHandler"},
|
|
|
|
{0x15ADC862, 0, "sceKernelRegisterNmiHandler"},
|
|
|
|
{0xB15357C9, 0, "sceKernelReleaseNmiHandler"},
|
|
|
|
};
|
|
|
|
|
|
|
|
void Register_ExceptionManagerForKernel()
|
|
|
|
{
|
|
|
|
RegisterModule("ExceptionManagerForKernel", ARRAY_SIZE(ExceptionManagerForKernel), ExceptionManagerForKernel);
|
|
|
|
}
|