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/.
|
|
|
|
|
2013-04-22 06:35:57 +00:00
|
|
|
#include <set>
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
#include "HLE.h"
|
|
|
|
#include "../MIPS/MIPS.h"
|
2013-03-09 20:53:53 +00:00
|
|
|
#include "Core/Reporting.h"
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
#include "sceKernel.h"
|
|
|
|
#include "sceKernelThread.h"
|
|
|
|
#include "sceUtility.h"
|
|
|
|
|
2012-11-18 12:04:49 +00:00
|
|
|
#include "sceCtrl.h"
|
|
|
|
#include "../Util/PPGeDraw.h"
|
2012-12-10 12:08:54 +00:00
|
|
|
#include "../Dialog/PSPSaveDialog.h"
|
|
|
|
#include "../Dialog/PSPMsgDialog.h"
|
|
|
|
#include "../Dialog/PSPPlaceholderDialog.h"
|
2012-12-15 16:42:38 +00:00
|
|
|
#include "../Dialog/PSPOskDialog.h"
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-03-08 06:25:07 +00:00
|
|
|
const int SCE_ERROR_MODULE_BAD_ID = 0x80111101;
|
2013-04-22 06:35:57 +00:00
|
|
|
const int SCE_ERROR_MODULE_ALREADY_LOADED = 0x80111102;
|
|
|
|
const int SCE_ERROR_MODULE_NOT_LOADED = 0x80111103;
|
2013-03-09 20:53:53 +00:00
|
|
|
const int SCE_ERROR_AV_MODULE_BAD_ID = 0x80110F01;
|
2013-03-08 06:25:07 +00:00
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
enum UtilityDialogType {
|
|
|
|
UTILITY_DIALOG_NONE,
|
|
|
|
UTILITY_DIALOG_SAVEDATA,
|
|
|
|
UTILITY_DIALOG_MSG,
|
|
|
|
UTILITY_DIALOG_OSK,
|
|
|
|
UTILITY_DIALOG_NET,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Only a single dialog is allowed at a time.
|
|
|
|
static UtilityDialogType currentDialogType;
|
|
|
|
static bool currentDialogActive;
|
|
|
|
static PSPSaveDialog saveDialog;
|
|
|
|
static PSPMsgDialog msgDialog;
|
|
|
|
static PSPOskDialog oskDialog;
|
|
|
|
static PSPPlaceholderDialog netDialog;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-04-22 06:35:57 +00:00
|
|
|
static std::set<int> currentlyLoadedModules;
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
void __UtilityInit()
|
2012-12-24 09:41:15 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
currentDialogType = UTILITY_DIALOG_NONE;
|
|
|
|
currentDialogActive = false;
|
2012-12-24 09:41:15 +00:00
|
|
|
SavedataParam::Init();
|
2013-04-22 06:35:57 +00:00
|
|
|
currentlyLoadedModules.clear();
|
2012-12-24 09:41:15 +00:00
|
|
|
}
|
|
|
|
|
2012-12-28 21:36:37 +00:00
|
|
|
void __UtilityDoState(PointerWrap &p)
|
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
p.Do(currentDialogType);
|
|
|
|
p.Do(currentDialogActive);
|
2012-12-28 21:36:37 +00:00
|
|
|
saveDialog.DoState(p);
|
|
|
|
msgDialog.DoState(p);
|
|
|
|
oskDialog.DoState(p);
|
|
|
|
netDialog.DoState(p);
|
2013-04-22 06:35:57 +00:00
|
|
|
p.Do(currentlyLoadedModules);
|
2012-12-28 21:36:37 +00:00
|
|
|
p.DoMarker("sceUtility");
|
|
|
|
}
|
|
|
|
|
2012-12-24 09:41:15 +00:00
|
|
|
void __UtilityShutdown()
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2012-12-24 06:47:52 +00:00
|
|
|
saveDialog.Shutdown();
|
|
|
|
msgDialog.Shutdown();
|
|
|
|
oskDialog.Shutdown();
|
|
|
|
netDialog.Shutdown();
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-11-22 20:46:22 +00:00
|
|
|
int sceUtilitySavedataInitStart(u32 paramAddr)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogActive && currentDialogType != UTILITY_DIALOG_SAVEDATA)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilitySavedataInitStart(%08x): wrong dialog type", paramAddr);
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
currentDialogType = UTILITY_DIALOG_SAVEDATA;
|
|
|
|
currentDialogActive = true;
|
|
|
|
|
2012-12-19 20:23:52 +00:00
|
|
|
DEBUG_LOG(HLE,"sceUtilitySavedataInitStart(%08x)", paramAddr);
|
2012-12-25 02:37:28 +00:00
|
|
|
return saveDialog.Init(paramAddr);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-11-22 20:46:22 +00:00
|
|
|
int sceUtilitySavedataShutdownStart()
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_SAVEDATA)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilitySavedataShutdownStart(): wrong dialog type");
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
currentDialogActive = false;
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
DEBUG_LOG(HLE,"sceUtilitySavedataShutdownStart()");
|
2012-12-25 02:37:28 +00:00
|
|
|
return saveDialog.Shutdown();
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-11-22 20:46:22 +00:00
|
|
|
int sceUtilitySavedataGetStatus()
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_SAVEDATA)
|
|
|
|
{
|
2013-04-11 02:14:43 +00:00
|
|
|
DEBUG_LOG(HLE, "sceUtilitySavedataGetStatus(): wrong dialog type");
|
2013-03-18 02:01:58 +00:00
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
|
2013-03-18 00:49:37 +00:00
|
|
|
int status = saveDialog.GetStatus();
|
2013-03-18 02:01:58 +00:00
|
|
|
DEBUG_LOG(HLE, "%08x=sceUtilitySavedataGetStatus()", status);
|
2013-03-18 00:49:37 +00:00
|
|
|
return status;
|
2012-12-08 22:39:47 +00:00
|
|
|
}
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
int sceUtilitySavedataUpdate(int animSpeed)
|
2012-12-08 22:39:47 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_SAVEDATA)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilitySavedataUpdate(): wrong dialog type");
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
DEBUG_LOG(HLE,"sceUtilitySavedataUpdate(%d)", animSpeed);
|
2013-03-18 04:39:06 +00:00
|
|
|
int result = saveDialog.Update();
|
|
|
|
if (result >= 0)
|
|
|
|
return hleDelayResult(result, "savedata update", 300);
|
|
|
|
return result;
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
2012-11-22 20:46:22 +00:00
|
|
|
|
2013-01-20 06:05:01 +00:00
|
|
|
#define PSP_AV_MODULE_AVCODEC 0
|
|
|
|
#define PSP_AV_MODULE_SASCORE 1
|
|
|
|
#define PSP_AV_MODULE_ATRAC3PLUS 2 // Requires PSP_AV_MODULE_AVCODEC loading first
|
|
|
|
#define PSP_AV_MODULE_MPEGBASE 3 // Requires PSP_AV_MODULE_AVCODEC loading first
|
|
|
|
#define PSP_AV_MODULE_MP3 4
|
|
|
|
#define PSP_AV_MODULE_VAUDIO 5
|
|
|
|
#define PSP_AV_MODULE_AAC 6
|
|
|
|
#define PSP_AV_MODULE_G729 7
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2012-12-31 12:43:38 +00:00
|
|
|
u32 sceUtilityLoadAvModule(u32 module)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-09 20:53:53 +00:00
|
|
|
if (module > 7)
|
|
|
|
{
|
2013-03-26 07:54:00 +00:00
|
|
|
ERROR_LOG_REPORT(HLE, "sceUtilityLoadAvModule(%i): invalid module id", module);
|
2013-03-09 20:53:53 +00:00
|
|
|
return SCE_ERROR_AV_MODULE_BAD_ID;
|
|
|
|
}
|
|
|
|
|
2012-11-22 20:46:22 +00:00
|
|
|
DEBUG_LOG(HLE,"sceUtilityLoadAvModule(%i)", module);
|
2013-03-09 20:53:53 +00:00
|
|
|
return hleDelayResult(0, "utility av module loaded", 25000);
|
2012-12-31 12:43:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
u32 sceUtilityUnloadAvModule(u32 module)
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"sceUtilityUnloadAvModule(%i)", module);
|
2013-03-09 20:53:53 +00:00
|
|
|
return hleDelayResult(0, "utility av module unloaded", 800);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-12-31 12:43:38 +00:00
|
|
|
u32 sceUtilityLoadModule(u32 module)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-08 06:25:07 +00:00
|
|
|
// TODO: Not all modules between 0x100 and 0x601 are valid.
|
|
|
|
if (module < 0x100 || module > 0x601)
|
|
|
|
{
|
2013-03-26 07:54:00 +00:00
|
|
|
ERROR_LOG_REPORT(HLE, "sceUtilityLoadModule(%i): invalid module id", module);
|
2013-03-08 06:25:07 +00:00
|
|
|
return SCE_ERROR_MODULE_BAD_ID;
|
|
|
|
}
|
|
|
|
|
2013-04-22 06:35:57 +00:00
|
|
|
if (currentlyLoadedModules.find(module) != currentlyLoadedModules.end())
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE, "sceUtilityLoadModule(%i): already loaded", module);
|
|
|
|
return SCE_ERROR_MODULE_ALREADY_LOADED;
|
|
|
|
}
|
|
|
|
currentlyLoadedModules.insert(module);
|
|
|
|
|
2013-03-08 06:25:07 +00:00
|
|
|
DEBUG_LOG(HLE, "sceUtilityLoadModule(%i)", module);
|
|
|
|
// TODO: Each module has its own timing, technically, but this is a low-end.
|
|
|
|
// Note: Some modules have dependencies, but they still resched.
|
|
|
|
if (module == 0x3FF)
|
2013-03-09 19:37:57 +00:00
|
|
|
return hleDelayResult(0, "utility module loaded", 130);
|
2013-03-08 06:25:07 +00:00
|
|
|
else
|
2013-03-09 19:37:57 +00:00
|
|
|
return hleDelayResult(0, "utility module loaded", 25000);
|
2012-12-31 12:43:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
u32 sceUtilityUnloadModule(u32 module)
|
|
|
|
{
|
2013-03-08 06:25:07 +00:00
|
|
|
// TODO: Not all modules between 0x100 and 0x601 are valid.
|
|
|
|
if (module < 0x100 || module > 0x601)
|
|
|
|
{
|
2013-03-26 07:54:00 +00:00
|
|
|
ERROR_LOG_REPORT(HLE, "sceUtilityUnloadModule(%i): invalid module id", module);
|
2013-03-08 06:25:07 +00:00
|
|
|
return SCE_ERROR_MODULE_BAD_ID;
|
|
|
|
}
|
|
|
|
|
2013-04-22 06:35:57 +00:00
|
|
|
if (currentlyLoadedModules.find(module) == currentlyLoadedModules.end())
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilityLoadModule(%i): not yet loaded", module);
|
|
|
|
return SCE_ERROR_MODULE_NOT_LOADED;
|
|
|
|
}
|
|
|
|
currentlyLoadedModules.erase(module);
|
|
|
|
|
2013-03-08 06:25:07 +00:00
|
|
|
DEBUG_LOG(HLE, "sceUtilityUnloadModule(%i)", module);
|
|
|
|
// TODO: Each module has its own timing, technically, but this is a low-end.
|
|
|
|
// Note: If not loaded, it should not reschedule actually...
|
|
|
|
if (module == 0x3FF)
|
2013-03-09 19:37:57 +00:00
|
|
|
return hleDelayResult(0, "utility module unloaded", 110);
|
2013-03-08 06:25:07 +00:00
|
|
|
else
|
2013-03-09 19:37:57 +00:00
|
|
|
return hleDelayResult(0, "utility module unloaded", 400);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
int sceUtilityMsgDialogInitStart(u32 structAddr)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogActive && currentDialogType != UTILITY_DIALOG_MSG)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilityMsgDialogInitStart(%08x): wrong dialog type", structAddr);
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
currentDialogType = UTILITY_DIALOG_MSG;
|
|
|
|
currentDialogActive = true;
|
|
|
|
|
|
|
|
DEBUG_LOG(HLE, "sceUtilityMsgDialogInitStart(%08x)", structAddr);
|
2012-12-25 02:37:28 +00:00
|
|
|
return msgDialog.Init(structAddr);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
int sceUtilityMsgDialogShutdownStart()
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_MSG)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilityMsgDialogShutdownStart(): wrong dialog type");
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
currentDialogActive = false;
|
|
|
|
|
|
|
|
DEBUG_LOG(HLE, "sceUtilityMsgDialogShutdownStart()");
|
2012-12-25 02:37:28 +00:00
|
|
|
return msgDialog.Shutdown();
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
int sceUtilityMsgDialogUpdate(int animSpeed)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_MSG)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilityMsgDialogUpdate(): wrong dialog type");
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
|
2012-11-18 23:29:41 +00:00
|
|
|
DEBUG_LOG(HLE,"sceUtilityMsgDialogUpdate(%i)", animSpeed);
|
2012-12-25 02:37:28 +00:00
|
|
|
return msgDialog.Update();
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
int sceUtilityMsgDialogGetStatus()
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_MSG)
|
|
|
|
{
|
2013-04-11 02:14:43 +00:00
|
|
|
DEBUG_LOG(HLE, "sceUtilityMsgDialogGetStatus(): wrong dialog type");
|
2013-03-18 02:01:58 +00:00
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
|
|
|
|
int status = msgDialog.GetStatus();
|
|
|
|
DEBUG_LOG(HLE, "%08x=sceUtilityMsgDialogGetStatus()", status);
|
|
|
|
return status;
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2013-03-31 05:54:00 +00:00
|
|
|
int sceUtilityMsgDialogAbort()
|
|
|
|
{
|
|
|
|
if (currentDialogType != UTILITY_DIALOG_MSG)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilityMsgDialogShutdownStart(): wrong dialog type");
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
currentDialogActive = false;
|
|
|
|
|
|
|
|
DEBUG_LOG(HLE, "sceUtilityMsgDialogAbort()");
|
|
|
|
return msgDialog.Abort();
|
|
|
|
}
|
|
|
|
|
2012-11-18 12:04:49 +00:00
|
|
|
|
|
|
|
// On screen keyboard
|
|
|
|
|
2012-12-15 16:42:38 +00:00
|
|
|
int sceUtilityOskInitStart(u32 oskPtr)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogActive && currentDialogType != UTILITY_DIALOG_OSK)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilityOskInitStart(%08x): wrong dialog type", oskPtr);
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
currentDialogType = UTILITY_DIALOG_OSK;
|
|
|
|
currentDialogActive = true;
|
|
|
|
|
|
|
|
DEBUG_LOG(HLE, "sceUtilityOskInitStart(%08x)", oskPtr);
|
2012-12-15 16:42:38 +00:00
|
|
|
return oskDialog.Init(oskPtr);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-12-10 12:08:54 +00:00
|
|
|
int sceUtilityOskShutdownStart()
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_OSK)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilityOskShutdownStart(): wrong dialog type");
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
currentDialogActive = false;
|
|
|
|
|
|
|
|
DEBUG_LOG(HLE, "sceUtilityOskShutdownStart()");
|
2012-12-25 02:37:28 +00:00
|
|
|
return oskDialog.Shutdown();
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
int sceUtilityOskUpdate(int animSpeed)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_OSK)
|
|
|
|
{
|
|
|
|
WARN_LOG(HLE, "sceUtilityMsgDialogUpdate(): wrong dialog type");
|
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
|
|
|
|
DEBUG_LOG(HLE, "sceUtilityOskUpdate(%i)", animSpeed);
|
2012-12-25 02:37:28 +00:00
|
|
|
return oskDialog.Update();
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-12-10 12:08:54 +00:00
|
|
|
int sceUtilityOskGetStatus()
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
if (currentDialogType != UTILITY_DIALOG_OSK)
|
|
|
|
{
|
2013-04-11 02:14:43 +00:00
|
|
|
DEBUG_LOG(HLE, "sceUtilityOskGetStatus(): wrong dialog type");
|
2013-03-18 02:01:58 +00:00
|
|
|
return SCE_ERROR_UTILITY_WRONG_TYPE;
|
|
|
|
}
|
|
|
|
|
2012-12-25 14:28:34 +00:00
|
|
|
int status = oskDialog.GetStatus();
|
2013-03-18 02:01:58 +00:00
|
|
|
|
2012-12-15 17:13:58 +00:00
|
|
|
// Seems that 4 is the cancelled status for OSK?
|
|
|
|
if (status == 4)
|
2012-12-15 16:42:38 +00:00
|
|
|
{
|
2012-12-15 17:13:58 +00:00
|
|
|
status = 5;
|
2012-12-15 16:42:38 +00:00
|
|
|
}
|
2013-03-18 02:01:58 +00:00
|
|
|
|
|
|
|
DEBUG_LOG(HLE, "%08x=sceUtilityOskGetStatus()", status);
|
2012-12-15 17:13:58 +00:00
|
|
|
return status;
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
int sceUtilityNetconfInitStart(u32 structAddr)
|
2012-11-06 18:22:14 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
ERROR_LOG(HLE, "UNIMPL sceUtilityNetconfInitStart(%08x)", structAddr);
|
2012-12-25 02:37:28 +00:00
|
|
|
return netDialog.Init();
|
2012-11-06 18:22:14 +00:00
|
|
|
}
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
int sceUtilityNetconfShutdownStart(unsigned int unknown)
|
2012-11-06 18:22:14 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
ERROR_LOG(HLE, "UNIMPL sceUtilityNetconfShutdownStart(%i)", unknown);
|
2012-12-25 02:37:28 +00:00
|
|
|
return netDialog.Shutdown();
|
2012-11-06 18:22:14 +00:00
|
|
|
}
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
int sceUtilityNetconfUpdate(int animSpeed)
|
2012-11-06 18:22:14 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
ERROR_LOG(HLE, "UNIMPL sceUtilityNetconfUpdate(%i)", animSpeed);
|
2012-12-25 02:37:28 +00:00
|
|
|
return netDialog.Update();
|
2012-11-06 18:22:14 +00:00
|
|
|
}
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
int sceUtilityNetconfGetStatus()
|
2012-11-06 18:22:14 +00:00
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
ERROR_LOG(HLE, "UNIMPL sceUtilityNetconfGetStatus()");
|
2012-12-10 12:08:54 +00:00
|
|
|
return netDialog.GetStatus();
|
2012-11-06 18:22:14 +00:00
|
|
|
}
|
|
|
|
|
2012-12-08 22:39:47 +00:00
|
|
|
int sceUtilityScreenshotGetStatus()
|
|
|
|
{
|
|
|
|
u32 retval = 0;//__UtilityGetStatus();
|
2013-03-18 02:01:58 +00:00
|
|
|
ERROR_LOG(HLE, "UNIMPL %i=sceUtilityScreenshotGetStatus()", retval);
|
2012-12-08 22:39:47 +00:00
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
2012-12-19 00:05:45 +00:00
|
|
|
void sceUtilityGamedataInstallInitStart(u32 unkown)
|
|
|
|
{
|
2013-03-18 02:01:58 +00:00
|
|
|
ERROR_LOG(HLE, "UNIMPL sceUtilityGamedataInstallInitStart(%i)", unkown);
|
2012-12-19 00:05:45 +00:00
|
|
|
}
|
|
|
|
|
2012-12-08 22:39:47 +00:00
|
|
|
int sceUtilityGamedataInstallGetStatus()
|
|
|
|
{
|
|
|
|
u32 retval = 0;//__UtilityGetStatus();
|
2013-03-18 02:01:58 +00:00
|
|
|
ERROR_LOG(HLE, "UNIMPL %i=sceUtilityGamedataInstallGetStatus()", retval);
|
2012-12-08 22:39:47 +00:00
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
2012-12-12 21:08:55 +00:00
|
|
|
//TODO: should save to config file
|
|
|
|
u32 sceUtilitySetSystemParamString(u32 id, u32 strPtr)
|
|
|
|
{
|
2013-04-20 16:01:03 +00:00
|
|
|
WARN_LOG(HLE, "sceUtilitySetSystemParamString(%i, %08x)", id, strPtr);
|
2012-12-12 21:08:55 +00:00
|
|
|
return 0;
|
|
|
|
}
|
2012-11-14 23:04:40 +00:00
|
|
|
|
2013-04-20 16:30:46 +00:00
|
|
|
u32 sceUtilityGetSystemParamString(u32 id, u32 destaddr, int destSize)
|
2012-11-14 23:04:40 +00:00
|
|
|
{
|
2013-04-20 16:30:46 +00:00
|
|
|
DEBUG_LOG(HLE, "sceUtilityGetSystemParamString(%i, %08x, %i)", id, destaddr, destSize);
|
2012-11-14 23:04:40 +00:00
|
|
|
char *buf = (char *)Memory::GetPointer(destaddr);
|
|
|
|
switch (id) {
|
2012-11-22 20:46:22 +00:00
|
|
|
case PSP_SYSTEMPARAM_ID_STRING_NICKNAME:
|
2013-04-20 16:30:46 +00:00
|
|
|
// If there's not enough space for the string and null terminator, fail.
|
|
|
|
if (destSize <= (int)g_Config.sNickName.length())
|
|
|
|
return PSP_SYSTEMPARAM_RETVAL_STRING_TOO_LONG;
|
|
|
|
strncpy(buf, g_Config.sNickName.c_str(), destSize);
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
2012-11-14 23:04:40 +00:00
|
|
|
|
2012-11-22 20:46:22 +00:00
|
|
|
default:
|
|
|
|
return PSP_SYSTEMPARAM_RETVAL_FAIL;
|
2012-11-14 23:04:40 +00:00
|
|
|
}
|
2012-11-06 18:22:14 +00:00
|
|
|
|
2012-11-14 23:04:40 +00:00
|
|
|
return 0;
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-11-14 23:04:40 +00:00
|
|
|
u32 sceUtilityGetSystemParamInt(u32 id, u32 destaddr)
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"sceUtilityGetSystemParamInt(%i, %08x)", id,destaddr);
|
2012-11-27 09:18:36 +00:00
|
|
|
u32 param = 0;
|
2012-11-14 23:04:40 +00:00
|
|
|
switch (id) {
|
2012-11-22 20:46:22 +00:00
|
|
|
case PSP_SYSTEMPARAM_ID_INT_ADHOC_CHANNEL:
|
2013-04-19 18:59:24 +00:00
|
|
|
param = g_Config.iWlanAdhocChannel;
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
|
|
|
case PSP_SYSTEMPARAM_ID_INT_WLAN_POWERSAVE:
|
2013-04-19 18:59:24 +00:00
|
|
|
param = g_Config.bWlanPowerSave?PSP_SYSTEMPARAM_WLAN_POWERSAVE_ON:PSP_SYSTEMPARAM_WLAN_POWERSAVE_OFF;
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
|
|
|
case PSP_SYSTEMPARAM_ID_INT_DATE_FORMAT:
|
2013-04-19 18:59:24 +00:00
|
|
|
param = g_Config.iDateFormat;
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
|
|
|
case PSP_SYSTEMPARAM_ID_INT_TIME_FORMAT:
|
2013-04-19 18:59:24 +00:00
|
|
|
param = g_Config.itimeformat?PSP_SYSTEMPARAM_TIME_FORMAT_12HR:PSP_SYSTEMPARAM_TIME_FORMAT_24HR;
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
|
|
|
case PSP_SYSTEMPARAM_ID_INT_TIMEZONE:
|
2013-04-19 18:59:24 +00:00
|
|
|
param = g_Config.iTimeZone;
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
|
|
|
case PSP_SYSTEMPARAM_ID_INT_DAYLIGHTSAVINGS:
|
2013-04-19 18:59:24 +00:00
|
|
|
param = g_Config.bDayLightSavings?PSP_SYSTEMPARAM_DAYLIGHTSAVINGS_SAVING:PSP_SYSTEMPARAM_DAYLIGHTSAVINGS_STD;
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
|
|
|
case PSP_SYSTEMPARAM_ID_INT_LANGUAGE:
|
2013-01-20 09:50:05 +00:00
|
|
|
param = g_Config.ilanguage;
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
2013-01-20 06:05:01 +00:00
|
|
|
case PSP_SYSTEMPARAM_ID_INT_BUTTON_PREFERENCE:
|
2013-04-19 18:59:24 +00:00
|
|
|
param = g_Config.bButtonPreference?PSP_SYSTEMPARAM_BUTTON_CROSS:PSP_SYSTEMPARAM_BUTTON_CIRCLE;
|
2012-11-22 20:46:22 +00:00
|
|
|
break;
|
2013-02-01 17:06:37 +00:00
|
|
|
case PSP_SYSTEMPARAM_ID_INT_LOCK_PARENTAL_LEVEL:
|
2013-04-20 16:01:03 +00:00
|
|
|
param = g_Config.iLockParentalLevel;
|
2013-02-01 17:06:37 +00:00
|
|
|
break;
|
2012-11-22 20:46:22 +00:00
|
|
|
default:
|
|
|
|
return PSP_SYSTEMPARAM_RETVAL_FAIL;
|
2012-11-14 23:04:40 +00:00
|
|
|
}
|
|
|
|
|
2012-11-27 09:18:36 +00:00
|
|
|
Memory::Write_U32(param, destaddr);
|
|
|
|
|
2012-11-14 23:04:40 +00:00
|
|
|
return 0;
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2012-11-06 17:56:56 +00:00
|
|
|
u32 sceUtilityLoadNetModule(u32 module)
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"FAKE: sceUtilityLoadNetModule(%i)", module);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-12-12 21:08:55 +00:00
|
|
|
u32 sceUtilityUnloadNetModule(u32 module)
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"FAKE: sceUtilityUnloadNetModule(%i)", module);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-12-19 00:05:45 +00:00
|
|
|
void sceUtilityInstallInitStart(u32 unknown)
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"FAKE sceUtilityInstallInitStart()");
|
|
|
|
}
|
|
|
|
|
2013-04-29 03:40:09 +00:00
|
|
|
int sceUtilityStoreCheckoutShutdownStart()
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"UNIMPL sceUtilityStoreCheckoutShutdownStart()");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int sceUtilityStoreCheckoutInitStart(u32 paramsPtr)
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"UNIMPL sceUtilityStoreCheckoutInitStart(%d)", paramsPtr);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int sceUtilityStoreCheckoutUpdate(int drawSpeed)
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"UNIMPL sceUtilityStoreCheckoutUpdate(%d)", drawSpeed);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int sceUtilityStoreCheckoutGetStatus()
|
|
|
|
{
|
|
|
|
DEBUG_LOG(HLE,"UNIMPL sceUtilityStoreCheckoutGetStatus()");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
const HLEFunction sceUtility[] =
|
|
|
|
{
|
2012-11-06 17:56:56 +00:00
|
|
|
{0x1579a159, &WrapU_U<sceUtilityLoadNetModule>, "sceUtilityLoadNetModule"},
|
2013-03-18 02:01:58 +00:00
|
|
|
{0x64d50c56, &WrapU_U<sceUtilityUnloadNetModule>, "sceUtilityUnloadNetModule"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
|
|
|
|
2012-12-25 02:37:28 +00:00
|
|
|
{0xf88155f6, &WrapI_U<sceUtilityNetconfShutdownStart>, "sceUtilityNetconfShutdownStart"},
|
|
|
|
{0x4db1e739, &WrapI_U<sceUtilityNetconfInitStart>, "sceUtilityNetconfInitStart"},
|
|
|
|
{0x91e70e35, &WrapI_I<sceUtilityNetconfUpdate>, "sceUtilityNetconfUpdate"},
|
|
|
|
{0x6332aa39, &WrapI_V<sceUtilityNetconfGetStatus>, "sceUtilityNetconfGetStatus"},
|
2013-03-18 02:01:58 +00:00
|
|
|
{0x5eee6548, 0, "sceUtilityCheckNetParam"},
|
|
|
|
{0x434d4b3a, 0, "sceUtilityGetNetParam"},
|
2012-12-12 21:37:58 +00:00
|
|
|
{0x4FED24D8, 0, "sceUtilityGetNetParamLatestID"},
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
{0x67af3428, &WrapI_V<sceUtilityMsgDialogShutdownStart>, "sceUtilityMsgDialogShutdownStart"},
|
|
|
|
{0x2ad8e239, &WrapI_U<sceUtilityMsgDialogInitStart>, "sceUtilityMsgDialogInitStart"},
|
|
|
|
{0x95fc253b, &WrapI_I<sceUtilityMsgDialogUpdate>, "sceUtilityMsgDialogUpdate"},
|
|
|
|
{0x9a1c91d7, &WrapI_V<sceUtilityMsgDialogGetStatus>, "sceUtilityMsgDialogGetStatus"},
|
2013-03-31 05:54:00 +00:00
|
|
|
{0x4928bd96, &WrapI_V<sceUtilityMsgDialogAbort>, "sceUtilityMsgDialogAbort"},
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
{0x9790b33c, &WrapI_V<sceUtilitySavedataShutdownStart>, "sceUtilitySavedataShutdownStart"},
|
|
|
|
{0x50c4cd57, &WrapI_U<sceUtilitySavedataInitStart>, "sceUtilitySavedataInitStart"},
|
|
|
|
{0xd4b95ffb, &WrapI_I<sceUtilitySavedataUpdate>, "sceUtilitySavedataUpdate"},
|
2012-11-22 20:46:22 +00:00
|
|
|
{0x8874dbe0, &WrapI_V<sceUtilitySavedataGetStatus>, "sceUtilitySavedataGetStatus"},
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2012-12-10 12:08:54 +00:00
|
|
|
{0x3dfaeba9, &WrapI_V<sceUtilityOskShutdownStart>, "sceUtilityOskShutdownStart"},
|
|
|
|
{0xf6269b82, &WrapI_U<sceUtilityOskInitStart>, "sceUtilityOskInitStart"},
|
2013-03-18 02:01:58 +00:00
|
|
|
{0x4b85c861, &WrapI_I<sceUtilityOskUpdate>, "sceUtilityOskUpdate"},
|
2012-12-10 12:08:54 +00:00
|
|
|
{0xf3f76017, &WrapI_V<sceUtilityOskGetStatus>, "sceUtilityOskGetStatus"},
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2012-12-12 21:08:55 +00:00
|
|
|
{0x41e30674, &WrapU_UU<sceUtilitySetSystemParamString>, "sceUtilitySetSystemParamString"},
|
|
|
|
{0x45c18506, 0, "sceUtilitySetSystemParamInt"},
|
2013-04-20 16:30:46 +00:00
|
|
|
{0x34b78343, &WrapU_UUI<sceUtilityGetSystemParamString>, "sceUtilityGetSystemParamString"},
|
2012-11-14 23:04:40 +00:00
|
|
|
{0xA5DA2406, &WrapU_UU<sceUtilityGetSystemParamInt>, "sceUtilityGetSystemParamInt"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
{0xc492f751, 0, "sceUtilityGameSharingInitStart"},
|
|
|
|
{0xefc6f80f, 0, "sceUtilityGameSharingShutdownStart"},
|
|
|
|
{0x7853182d, 0, "sceUtilityGameSharingUpdate"},
|
|
|
|
{0x946963f3, 0, "sceUtilityGameSharingGetStatus"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
{0x2995d020, 0, "sceUtility_2995d020"},
|
|
|
|
{0xb62a4061, 0, "sceUtility_b62a4061"},
|
|
|
|
{0xed0fad38, 0, "sceUtility_ed0fad38"},
|
|
|
|
{0x88bc7406, 0, "sceUtility_88bc7406"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
{0xbda7d894, 0, "sceUtilityHtmlViewerGetStatus"},
|
|
|
|
{0xcdc3aa41, 0, "sceUtilityHtmlViewerInitStart"},
|
|
|
|
{0xf5ce1134, 0, "sceUtilityHtmlViewerShutdownStart"},
|
|
|
|
{0x05afb9e4, 0, "sceUtilityHtmlViewerUpdate"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
2013-03-18 02:01:58 +00:00
|
|
|
{0xc629af26, &WrapU_U<sceUtilityLoadAvModule>, "sceUtilityLoadAvModule"},
|
2012-12-31 12:43:38 +00:00
|
|
|
{0xf7d8d092, &WrapU_U<sceUtilityUnloadAvModule>, "sceUtilityUnloadAvModule"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
2012-12-31 12:43:38 +00:00
|
|
|
{0x2a2b3de0, &WrapU_U<sceUtilityLoadModule>, "sceUtilityLoadModule"},
|
|
|
|
{0xe49bfe92, &WrapU_U<sceUtilityUnloadModule>, "sceUtilityUnloadModule"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
2012-11-06 16:05:51 +00:00
|
|
|
{0x0251B134, 0, "sceUtilityScreenshotInitStart"},
|
|
|
|
{0xF9E0008C, 0, "sceUtilityScreenshotShutdownStart"},
|
|
|
|
{0xAB083EA9, 0, "sceUtilityScreenshotUpdate"},
|
2012-12-08 22:39:47 +00:00
|
|
|
{0xD81957B7, &WrapI_V<sceUtilityScreenshotGetStatus>, "sceUtilityScreenshotGetStatus"},
|
2012-11-06 16:05:51 +00:00
|
|
|
{0x86A03A27, 0, "sceUtilityScreenshotContStart"},
|
2012-11-07 14:44:48 +00:00
|
|
|
|
|
|
|
{0x0D5BC6D2, 0, "sceUtilityLoadUsbModule"},
|
|
|
|
{0xF64910F0, 0, "sceUtilityUnloadUsbModule"},
|
|
|
|
|
2012-12-19 00:05:45 +00:00
|
|
|
{0x24AC31EB, &WrapV_U<sceUtilityGamedataInstallInitStart>, "sceUtilityGamedataInstallInitStart"},
|
2012-11-22 20:46:22 +00:00
|
|
|
{0x32E32DCB, 0, "sceUtilityGamedataInstallShutdownStart"},
|
|
|
|
{0x4AECD179, 0, "sceUtilityGamedataInstallUpdate"},
|
2012-12-08 22:39:47 +00:00
|
|
|
{0xB57E95D9, &WrapI_V<sceUtilityGamedataInstallGetStatus>, "sceUtilityGamedataInstallGetStatus"},
|
2013-03-31 05:54:00 +00:00
|
|
|
{0x180F7B62, 0, "sceUtilityGamedataInstallAbort"},
|
2012-11-27 10:40:30 +00:00
|
|
|
|
|
|
|
{0x16D02AF0, 0, "sceUtilityNpSigninInitStart"},
|
|
|
|
{0xE19C97D6, 0, "sceUtilityNpSigninShutdownStart"},
|
|
|
|
{0xF3FBC572, 0, "sceUtilityNpSigninUpdate"},
|
|
|
|
{0x86ABDB1B, 0, "sceUtilityNpSigninGetStatus"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
2012-12-19 00:05:45 +00:00
|
|
|
{0x1281DA8E, &WrapV_U<sceUtilityInstallInitStart>, "sceUtilityInstallInitStart"},
|
2012-12-12 21:08:55 +00:00
|
|
|
{0x5EF1C24A, 0, "sceUtilityInstallShutdownStart"},
|
|
|
|
{0xA03D29BA, 0, "sceUtilityInstallUpdate"},
|
2013-03-18 02:01:58 +00:00
|
|
|
{0xC4700FA3, 0, "sceUtilityInstallGetStatus"},
|
2012-12-12 21:08:55 +00:00
|
|
|
|
2013-04-29 03:40:09 +00:00
|
|
|
{0x54A5C62F, &WrapI_V<sceUtilityStoreCheckoutShutdownStart>, "sceUtilityStoreCheckoutShutdownStart"},
|
|
|
|
{0xDA97F1AA, &WrapI_U<sceUtilityStoreCheckoutInitStart>, "sceUtilityStoreCheckoutInitStart"},
|
|
|
|
{0xB8592D5F, &WrapI_I<sceUtilityStoreCheckoutUpdate>, "sceUtilityStoreCheckoutUpdate"},
|
|
|
|
{0x3AAD51DC, &WrapI_V<sceUtilityStoreCheckoutGetStatus>, "sceUtilityStoreCheckoutGetStatus"},
|
2012-11-01 15:19:01 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
void Register_sceUtility()
|
|
|
|
{
|
|
|
|
RegisterModule("sceUtility", ARRAY_SIZE(sceUtility), sceUtility);
|
|
|
|
}
|