aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/hle/service/service.cpp
diff options
context:
space:
mode:
authorGravatar bunnei <ericbunnie@gmail.com>2014-04-13 00:38:48 -0400
committerGravatar bunnei <ericbunnie@gmail.com>2014-04-13 00:38:48 -0400
commit5ea4679630d6776837114252476dd445f377322d (patch)
tree3dc3dd3084669edd83637c344866264dd1120632 /src/core/hle/service/service.cpp
parent67f6e414702cbb83a53392e1cca229875a186cea (diff)
added some very initial command parsing for SRV Sync
Diffstat (limited to 'src/core/hle/service/service.cpp')
-rw-r--r--src/core/hle/service/service.cpp36
1 files changed, 31 insertions, 5 deletions
diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp
index 3434b6db..556dfc8a 100644
--- a/src/core/hle/service/service.cpp
+++ b/src/core/hle/service/service.cpp
@@ -5,15 +5,16 @@
#include "common/common.h"
#include "common/log.h"
+#include "core/hle/hle.h"
#include "core/hle/service/service.h"
-////////////////////////////////////////////////////////////////////////////////////////////////////
-// Namespace Service
-
namespace Service {
Manager* g_manager = NULL; ///< Service manager
+////////////////////////////////////////////////////////////////////////////////////////////////////
+// Service Manager class
+
Manager::Manager() {
}
@@ -62,7 +63,11 @@ Interface* Manager::FetchFromPortName(std::string port_name) {
return FetchFromUID(itr->second);
}
+////////////////////////////////////////////////////////////////////////////////////////////////////
+// Interface to "SRV" service
+
class Interface_SRV : public Interface {
+
public:
Interface_SRV() {
@@ -71,6 +76,12 @@ public:
~Interface_SRV() {
}
+ enum {
+ CMD_OFFSET = 0x80,
+ CMD_HEADER_INIT = 0x10002, ///< Command header to initialize SRV service
+ CMD_HEADER_GET_HANDLE = 0x50100, ///< Command header to get handle of other services
+ };
+
/**
* Gets the string name used by CTROS for a service
* @return String name of service
@@ -92,12 +103,27 @@ public:
* @return Return result of svcSendSyncRequest passed back to user app
*/
Syscall::Result Sync() {
- ERROR_LOG(HLE, "Unimplemented function Interface_SRV::Sync");
+ u32 header = 0;
+ HLE::Read<u32>(header, (HLE::CMD_BUFFER_ADDR + CMD_OFFSET));
+
+ switch (header) {
+ case CMD_HEADER_INIT:
+ NOTICE_LOG(HLE, "Interface_SRV::Sync - Initialize");
+ break;
+
+ case CMD_HEADER_GET_HANDLE:
+ NOTICE_LOG(HLE, "Interface_SRV::Sync - GetHandle, port: %s", HLE::GetCharPointer(HLE::CMD_BUFFER_ADDR + CMD_OFFSET + 4));
+ break;
+ }
+
return 0;
}
-
+
};
+////////////////////////////////////////////////////////////////////////////////////////////////////
+// Module interface
+
/// Initialize ServiceManager
void Init() {
g_manager = new Manager;