citra-emu
/
citra-canary
Archived
1
0
Fork 0

added a stub for GetLockHandle

This commit is contained in:
bunnei 2014-04-13 22:59:16 -04:00
parent 9f4d677cdf
commit 18766b9e69
3 changed files with 44 additions and 9 deletions

View File

@ -4,17 +4,42 @@
#include "common/log.h" #include "common/log.h"
#include "core/hle/hle.h"
#include "core/hle/service/apt.h" #include "core/hle/service/apt.h"
namespace Service { namespace Service {
// Returns handle to APT Mutex. Not imlemented.
Syscall::Result APT::GetLockHandle() {
return 0x00000000;
}
/**
* Called when svcSendSyncRequest is called, loads command buffer and executes comand
* @return Return result of svcSendSyncRequest passed back to user app
*/
Syscall::Result APT::Sync() { Syscall::Result APT::Sync() {
NOTICE_LOG(HLE, "APT::Sync - Initialize"); Syscall::Result res = 0;
return 0; u32* cmd_buff = (u32*)HLE::GetPointer(HLE::CMD_BUFFER_ADDR + CMD_OFFSET);
switch(cmd_buff[0]) {
case CMD_HEADER_INIT:
NOTICE_LOG(OSHLE, "APT::Sync - Initialize");
break;
case CMD_HEADER_GET_LOCK_HANDLE:
NOTICE_LOG(OSHLE, "APT::Sync - GetLockHandle");
cmd_buff[5] = GetLockHandle();
break;
default:
ERROR_LOG(OSHLE, "APT::Sync - Unknown command 0x%08X", cmd_buff[0]);
res = -1;
break;
}
return res;
} }

View File

@ -64,7 +64,13 @@ public:
* Called when svcSendSyncRequest is called, loads command buffer and executes comand * Called when svcSendSyncRequest is called, loads command buffer and executes comand
* @return Return result of svcSendSyncRequest passed back to user app * @return Return result of svcSendSyncRequest passed back to user app
*/ */
virtual Syscall::Result Sync(); Syscall::Result Sync();
private:
Syscall::Result GetLockHandle();
}; };

View File

@ -104,9 +104,7 @@ public:
* @return Return result of svcSendSyncRequest passed back to user app * @return Return result of svcSendSyncRequest passed back to user app
*/ */
Syscall::Result Sync() { Syscall::Result Sync() {
u32 header = 0;
Syscall::Result res = 0; Syscall::Result res = 0;
u32* cmd_buff = (u32*)HLE::GetPointer(HLE::CMD_BUFFER_ADDR + CMD_OFFSET); u32* cmd_buff = (u32*)HLE::GetPointer(HLE::CMD_BUFFER_ADDR + CMD_OFFSET);
switch (cmd_buff[0]) { switch (cmd_buff[0]) {
@ -116,6 +114,7 @@ public:
break; break;
case CMD_HEADER_GET_HANDLE: case CMD_HEADER_GET_HANDLE:
{
const char* port_name = (const char*)&cmd_buff[1]; const char* port_name = (const char*)&cmd_buff[1];
Interface* service = g_manager->FetchFromPortName(port_name); Interface* service = g_manager->FetchFromPortName(port_name);
@ -128,7 +127,12 @@ public:
ERROR_LOG(OSHLE, "Service %s does not exist", port_name); ERROR_LOG(OSHLE, "Service %s does not exist", port_name);
res = -1; res = -1;
} }
break;
}
default:
ERROR_LOG(OSHLE, "SRV::Sync - Unknown command 0x%08X", cmd_buff[0]);
res = -1;
break; break;
} }