diff options
| author | 2018-09-02 11:58:58 -0400 | |
|---|---|---|
| committer | 2018-09-02 12:35:30 -0400 | |
| commit | 1242c1ec0aab88d91b0bb4faf6200e4f20e4bdc2 (patch) | |
| tree | f540b9cbc6db29bb5d41668f7efa8fc5c4e44469 /src/core/hle/service | |
| parent | Merge pull request #1213 from DarkLordZach/octopath-fs (diff) | |
| download | yuzu-1242c1ec0aab88d91b0bb4faf6200e4f20e4bdc2.tar.gz yuzu-1242c1ec0aab88d91b0bb4faf6200e4f20e4bdc2.tar.xz yuzu-1242c1ec0aab88d91b0bb4faf6200e4f20e4bdc2.zip | |
service: Migrate global named port map to the KernelCore class
Now that we have a class representing the kernel in some capacity, we
now have a place to put the named port map, so we move it over and get
rid of another piece of global state within the core.
Diffstat (limited to 'src/core/hle/service')
| -rw-r--r-- | src/core/hle/service/service.cpp | 9 | ||||
| -rw-r--r-- | src/core/hle/service/service.h | 7 |
2 files changed, 2 insertions, 14 deletions
diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp index 8fb907072..9d804652e 100644 --- a/src/core/hle/service/service.cpp +++ b/src/core/hle/service/service.cpp | |||
| @@ -12,6 +12,7 @@ | |||
| 12 | #include "core/hle/ipc_helpers.h" | 12 | #include "core/hle/ipc_helpers.h" |
| 13 | #include "core/hle/kernel/client_port.h" | 13 | #include "core/hle/kernel/client_port.h" |
| 14 | #include "core/hle/kernel/handle_table.h" | 14 | #include "core/hle/kernel/handle_table.h" |
| 15 | #include "core/hle/kernel/kernel.h" | ||
| 15 | #include "core/hle/kernel/process.h" | 16 | #include "core/hle/kernel/process.h" |
| 16 | #include "core/hle/kernel/server_port.h" | 17 | #include "core/hle/kernel/server_port.h" |
| 17 | #include "core/hle/kernel/thread.h" | 18 | #include "core/hle/kernel/thread.h" |
| @@ -114,7 +115,7 @@ void ServiceFrameworkBase::InstallAsNamedPort() { | |||
| 114 | std::tie(server_port, client_port) = | 115 | std::tie(server_port, client_port) = |
| 115 | ServerPort::CreatePortPair(kernel, max_sessions, service_name); | 116 | ServerPort::CreatePortPair(kernel, max_sessions, service_name); |
| 116 | server_port->SetHleHandler(shared_from_this()); | 117 | server_port->SetHleHandler(shared_from_this()); |
| 117 | AddNamedPort(service_name, std::move(client_port)); | 118 | kernel.AddNamedPort(service_name, std::move(client_port)); |
| 118 | } | 119 | } |
| 119 | 120 | ||
| 120 | Kernel::SharedPtr<Kernel::ClientPort> ServiceFrameworkBase::CreatePort() { | 121 | Kernel::SharedPtr<Kernel::ClientPort> ServiceFrameworkBase::CreatePort() { |
| @@ -197,11 +198,6 @@ ResultCode ServiceFrameworkBase::HandleSyncRequest(Kernel::HLERequestContext& co | |||
| 197 | //////////////////////////////////////////////////////////////////////////////////////////////////// | 198 | //////////////////////////////////////////////////////////////////////////////////////////////////// |
| 198 | // Module interface | 199 | // Module interface |
| 199 | 200 | ||
| 200 | // TODO(yuriks): Move to kernel | ||
| 201 | void AddNamedPort(std::string name, SharedPtr<ClientPort> port) { | ||
| 202 | g_kernel_named_ports.emplace(std::move(name), std::move(port)); | ||
| 203 | } | ||
| 204 | |||
| 205 | /// Initialize ServiceManager | 201 | /// Initialize ServiceManager |
| 206 | void Init(std::shared_ptr<SM::ServiceManager>& sm, const FileSys::VirtualFilesystem& rfs) { | 202 | void Init(std::shared_ptr<SM::ServiceManager>& sm, const FileSys::VirtualFilesystem& rfs) { |
| 207 | // NVFlinger needs to be accessed by several services like Vi and AppletOE so we instantiate it | 203 | // NVFlinger needs to be accessed by several services like Vi and AppletOE so we instantiate it |
| @@ -264,7 +260,6 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm, const FileSys::VirtualFilesys | |||
| 264 | 260 | ||
| 265 | /// Shutdown ServiceManager | 261 | /// Shutdown ServiceManager |
| 266 | void Shutdown() { | 262 | void Shutdown() { |
| 267 | g_kernel_named_ports.clear(); | ||
| 268 | LOG_DEBUG(Service, "shutdown OK"); | 263 | LOG_DEBUG(Service, "shutdown OK"); |
| 269 | } | 264 | } |
| 270 | } // namespace Service | 265 | } // namespace Service |
diff --git a/src/core/hle/service/service.h b/src/core/hle/service/service.h index cd9c74f3d..7a051523e 100644 --- a/src/core/hle/service/service.h +++ b/src/core/hle/service/service.h | |||
| @@ -6,7 +6,6 @@ | |||
| 6 | 6 | ||
| 7 | #include <cstddef> | 7 | #include <cstddef> |
| 8 | #include <string> | 8 | #include <string> |
| 9 | #include <unordered_map> | ||
| 10 | #include <boost/container/flat_map.hpp> | 9 | #include <boost/container/flat_map.hpp> |
| 11 | #include "common/common_types.h" | 10 | #include "common/common_types.h" |
| 12 | #include "core/hle/kernel/hle_ipc.h" | 11 | #include "core/hle/kernel/hle_ipc.h" |
| @@ -187,10 +186,4 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm, | |||
| 187 | /// Shutdown ServiceManager | 186 | /// Shutdown ServiceManager |
| 188 | void Shutdown(); | 187 | void Shutdown(); |
| 189 | 188 | ||
| 190 | /// Map of named ports managed by the kernel, which can be retrieved using the ConnectToPort SVC. | ||
| 191 | extern std::unordered_map<std::string, Kernel::SharedPtr<Kernel::ClientPort>> g_kernel_named_ports; | ||
| 192 | |||
| 193 | /// Adds a port to the named port table | ||
| 194 | void AddNamedPort(std::string name, Kernel::SharedPtr<Kernel::ClientPort> port); | ||
| 195 | |||
| 196 | } // namespace Service | 189 | } // namespace Service |