diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/citra_qt/debugger/wait_tree.cpp | 1 | ||||
| -rw-r--r-- | src/core/hle/kernel/client_port.cpp | 1 | ||||
| -rw-r--r-- | src/core/hle/kernel/client_port.h | 32 | ||||
| -rw-r--r-- | src/core/hle/kernel/client_session.cpp | 3 | ||||
| -rw-r--r-- | src/core/hle/kernel/client_session.h | 17 | ||||
| -rw-r--r-- | src/core/hle/kernel/kernel.h | 34 | ||||
| -rw-r--r-- | src/core/hle/kernel/server_session.cpp | 1 | ||||
| -rw-r--r-- | src/core/hle/kernel/server_session.h | 9 | ||||
| -rw-r--r-- | src/core/hle/service/fs/archive.cpp | 8 | ||||
| -rw-r--r-- | src/core/hle/service/service.h | 50 | ||||
| -rw-r--r-- | src/core/hle/service/srv.cpp | 3 |
11 files changed, 76 insertions, 83 deletions
diff --git a/src/citra_qt/debugger/wait_tree.cpp b/src/citra_qt/debugger/wait_tree.cpp index be5a51e52..51e70fae3 100644 --- a/src/citra_qt/debugger/wait_tree.cpp +++ b/src/citra_qt/debugger/wait_tree.cpp | |||
| @@ -8,7 +8,6 @@ | |||
| 8 | #include "core/hle/kernel/event.h" | 8 | #include "core/hle/kernel/event.h" |
| 9 | #include "core/hle/kernel/mutex.h" | 9 | #include "core/hle/kernel/mutex.h" |
| 10 | #include "core/hle/kernel/semaphore.h" | 10 | #include "core/hle/kernel/semaphore.h" |
| 11 | #include "core/hle/kernel/session.h" | ||
| 12 | #include "core/hle/kernel/thread.h" | 11 | #include "core/hle/kernel/thread.h" |
| 13 | #include "core/hle/kernel/timer.h" | 12 | #include "core/hle/kernel/timer.h" |
| 14 | 13 | ||
diff --git a/src/core/hle/kernel/client_port.cpp b/src/core/hle/kernel/client_port.cpp index de67688c9..5ee7679eb 100644 --- a/src/core/hle/kernel/client_port.cpp +++ b/src/core/hle/kernel/client_port.cpp | |||
| @@ -7,7 +7,6 @@ | |||
| 7 | #include "core/hle/kernel/kernel.h" | 7 | #include "core/hle/kernel/kernel.h" |
| 8 | #include "core/hle/kernel/server_port.h" | 8 | #include "core/hle/kernel/server_port.h" |
| 9 | #include "core/hle/kernel/server_session.h" | 9 | #include "core/hle/kernel/server_session.h" |
| 10 | #include "core/hle/service/service.h" | ||
| 11 | 10 | ||
| 12 | namespace Kernel { | 11 | namespace Kernel { |
| 13 | 12 | ||
diff --git a/src/core/hle/kernel/client_port.h b/src/core/hle/kernel/client_port.h index 7a53c93b8..4848cb4c4 100644 --- a/src/core/hle/kernel/client_port.h +++ b/src/core/hle/kernel/client_port.h | |||
| @@ -5,14 +5,9 @@ | |||
| 5 | #pragma once | 5 | #pragma once |
| 6 | 6 | ||
| 7 | #include <string> | 7 | #include <string> |
| 8 | #include <memory> | ||
| 9 | #include "common/common_types.h" | 8 | #include "common/common_types.h" |
| 10 | #include "core/hle/kernel/kernel.h" | 9 | #include "core/hle/kernel/kernel.h" |
| 11 | 10 | ||
| 12 | namespace Service { | ||
| 13 | class Interface; | ||
| 14 | } | ||
| 15 | |||
| 16 | namespace Kernel { | 11 | namespace Kernel { |
| 17 | 12 | ||
| 18 | class ServerPort; | 13 | class ServerPort; |
| @@ -21,6 +16,17 @@ class ServerSession; | |||
| 21 | class ClientPort final : public Object { | 16 | class ClientPort final : public Object { |
| 22 | public: | 17 | public: |
| 23 | friend class ServerPort; | 18 | friend class ServerPort; |
| 19 | std::string GetTypeName() const override { | ||
| 20 | return "ClientPort"; | ||
| 21 | } | ||
| 22 | std::string GetName() const override { | ||
| 23 | return name; | ||
| 24 | } | ||
| 25 | |||
| 26 | static const HandleType HANDLE_TYPE = HandleType::ClientPort; | ||
| 27 | HandleType GetHandleType() const override { | ||
| 28 | return HANDLE_TYPE; | ||
| 29 | } | ||
| 24 | 30 | ||
| 25 | /** | 31 | /** |
| 26 | * Adds the specified server session to the queue of pending sessions of the associated ServerPort | 32 | * Adds the specified server session to the queue of pending sessions of the associated ServerPort |
| @@ -28,18 +34,10 @@ public: | |||
| 28 | */ | 34 | */ |
| 29 | void AddWaitingSession(SharedPtr<ServerSession> server_session); | 35 | void AddWaitingSession(SharedPtr<ServerSession> server_session); |
| 30 | 36 | ||
| 31 | std::string GetTypeName() const override { return "ClientPort"; } | 37 | SharedPtr<ServerPort> server_port; ///< ServerPort associated with this client port. |
| 32 | std::string GetName() const override { return name; } | 38 | u32 max_sessions; ///< Maximum number of simultaneous sessions the port can have |
| 33 | 39 | u32 active_sessions; ///< Number of currently open sessions to this port | |
| 34 | static const HandleType HANDLE_TYPE = HandleType::ClientPort; | 40 | std::string name; ///< Name of client port (optional) |
| 35 | HandleType GetHandleType() const override { | ||
| 36 | return HANDLE_TYPE; | ||
| 37 | } | ||
| 38 | |||
| 39 | SharedPtr<ServerPort> server_port; ///< ServerPort associated with this client port. | ||
| 40 | u32 max_sessions; ///< Maximum number of simultaneous sessions the port can have | ||
| 41 | u32 active_sessions; ///< Number of currently open sessions to this port | ||
| 42 | std::string name; ///< Name of client port (optional) | ||
| 43 | private: | 41 | private: |
| 44 | ClientPort(); | 42 | ClientPort(); |
| 45 | ~ClientPort() override; | 43 | ~ClientPort() override; |
diff --git a/src/core/hle/kernel/client_session.cpp b/src/core/hle/kernel/client_session.cpp index 31ea8045a..c8be29b0a 100644 --- a/src/core/hle/kernel/client_session.cpp +++ b/src/core/hle/kernel/client_session.cpp | |||
| @@ -4,11 +4,8 @@ | |||
| 4 | 4 | ||
| 5 | #include "common/assert.h" | 5 | #include "common/assert.h" |
| 6 | 6 | ||
| 7 | #include "core/hle/kernel/client_port.h" | ||
| 8 | #include "core/hle/kernel/client_session.h" | 7 | #include "core/hle/kernel/client_session.h" |
| 9 | #include "core/hle/kernel/server_session.h" | 8 | #include "core/hle/kernel/server_session.h" |
| 10 | #include "core/hle/kernel/kernel.h" | ||
| 11 | #include "core/hle/service/service.h" | ||
| 12 | 9 | ||
| 13 | namespace Kernel { | 10 | namespace Kernel { |
| 14 | 11 | ||
diff --git a/src/core/hle/kernel/client_session.h b/src/core/hle/kernel/client_session.h index a951ea4d6..e34528301 100644 --- a/src/core/hle/kernel/client_session.h +++ b/src/core/hle/kernel/client_session.h | |||
| @@ -11,13 +11,8 @@ | |||
| 11 | 11 | ||
| 12 | #include "core/hle/kernel/kernel.h" | 12 | #include "core/hle/kernel/kernel.h" |
| 13 | 13 | ||
| 14 | namespace Service { | ||
| 15 | class Interface; | ||
| 16 | } | ||
| 17 | |||
| 18 | namespace Kernel { | 14 | namespace Kernel { |
| 19 | 15 | ||
| 20 | class ClientPort; | ||
| 21 | class ServerSession; | 16 | class ServerSession; |
| 22 | 17 | ||
| 23 | class ClientSession final : public Object { | 18 | class ClientSession final : public Object { |
| @@ -30,11 +25,17 @@ public: | |||
| 30 | */ | 25 | */ |
| 31 | static ResultVal<SharedPtr<ClientSession>> Create(SharedPtr<ServerSession> server_session, std::string name = "Unknown"); | 26 | static ResultVal<SharedPtr<ClientSession>> Create(SharedPtr<ServerSession> server_session, std::string name = "Unknown"); |
| 32 | 27 | ||
| 33 | std::string GetTypeName() const override { return "ClientSession"; } | 28 | std::string GetTypeName() const override { |
| 34 | std::string GetName() const override { return name; } | 29 | return "ClientSession"; |
| 30 | } | ||
| 31 | std::string GetName() const override { | ||
| 32 | return name; | ||
| 33 | } | ||
| 35 | 34 | ||
| 36 | static const HandleType HANDLE_TYPE = HandleType::ClientSession; | 35 | static const HandleType HANDLE_TYPE = HandleType::ClientSession; |
| 37 | HandleType GetHandleType() const override { return HANDLE_TYPE; } | 36 | HandleType GetHandleType() const override { |
| 37 | return HANDLE_TYPE; | ||
| 38 | } | ||
| 38 | 39 | ||
| 39 | /** | 40 | /** |
| 40 | * Handle a SyncRequest from the emulated application. | 41 | * Handle a SyncRequest from the emulated application. |
diff --git a/src/core/hle/kernel/kernel.h b/src/core/hle/kernel/kernel.h index 4bd505b5d..9808d375b 100644 --- a/src/core/hle/kernel/kernel.h +++ b/src/core/hle/kernel/kernel.h | |||
| @@ -31,24 +31,22 @@ enum KernelHandle : Handle { | |||
| 31 | }; | 31 | }; |
| 32 | 32 | ||
| 33 | enum class HandleType : u32 { | 33 | enum class HandleType : u32 { |
| 34 | Unknown = 0, | 34 | Unknown, |
| 35 | 35 | Event, | |
| 36 | 36 | Mutex, | |
| 37 | Event = 3, | 37 | SharedMemory, |
| 38 | Mutex = 4, | 38 | Redirection, |
| 39 | SharedMemory = 5, | 39 | Thread, |
| 40 | Redirection = 6, | 40 | Process, |
| 41 | Thread = 7, | 41 | AddressArbiter, |
| 42 | Process = 8, | 42 | Semaphore, |
| 43 | AddressArbiter = 9, | 43 | Timer, |
| 44 | Semaphore = 10, | 44 | ResourceLimit, |
| 45 | Timer = 11, | 45 | CodeSet, |
| 46 | ResourceLimit = 12, | 46 | ClientPort, |
| 47 | CodeSet = 13, | 47 | ServerPort, |
| 48 | ClientPort = 14, | 48 | ClientSession, |
| 49 | ServerPort = 15, | 49 | ServerSession, |
| 50 | ClientSession = 16, | ||
| 51 | ServerSession = 17, | ||
| 52 | }; | 50 | }; |
| 53 | 51 | ||
| 54 | enum { | 52 | enum { |
diff --git a/src/core/hle/kernel/server_session.cpp b/src/core/hle/kernel/server_session.cpp index 200a7b815..006d67e65 100644 --- a/src/core/hle/kernel/server_session.cpp +++ b/src/core/hle/kernel/server_session.cpp | |||
| @@ -4,7 +4,6 @@ | |||
| 4 | 4 | ||
| 5 | #include <tuple> | 5 | #include <tuple> |
| 6 | 6 | ||
| 7 | #include "core/hle/kernel/client_port.h" | ||
| 8 | #include "core/hle/kernel/client_session.h" | 7 | #include "core/hle/kernel/client_session.h" |
| 9 | #include "core/hle/kernel/server_session.h" | 8 | #include "core/hle/kernel/server_session.h" |
| 10 | #include "core/hle/kernel/thread.h" | 9 | #include "core/hle/kernel/thread.h" |
diff --git a/src/core/hle/kernel/server_session.h b/src/core/hle/kernel/server_session.h index 86fe641c0..70661e9af 100644 --- a/src/core/hle/kernel/server_session.h +++ b/src/core/hle/kernel/server_session.h | |||
| @@ -16,7 +16,6 @@ | |||
| 16 | namespace Kernel { | 16 | namespace Kernel { |
| 17 | 17 | ||
| 18 | class ClientSession; | 18 | class ClientSession; |
| 19 | class ClientPort; | ||
| 20 | 19 | ||
| 21 | /** | 20 | /** |
| 22 | * Kernel object representing the server endpoint of an IPC session. Sessions are the basic CTR-OS | 21 | * Kernel object representing the server endpoint of an IPC session. Sessions are the basic CTR-OS |
| @@ -44,10 +43,14 @@ public: | |||
| 44 | */ | 43 | */ |
| 45 | static ResultVal<SharedPtr<ServerSession>> Create(std::string name = "Unknown", std::shared_ptr<Service::SessionRequestHandler> hle_handler = nullptr); | 44 | static ResultVal<SharedPtr<ServerSession>> Create(std::string name = "Unknown", std::shared_ptr<Service::SessionRequestHandler> hle_handler = nullptr); |
| 46 | 45 | ||
| 47 | std::string GetTypeName() const override { return "ServerSession"; } | 46 | std::string GetTypeName() const override { |
| 47 | return "ServerSession"; | ||
| 48 | } | ||
| 48 | 49 | ||
| 49 | static const HandleType HANDLE_TYPE = HandleType::ServerSession; | 50 | static const HandleType HANDLE_TYPE = HandleType::ServerSession; |
| 50 | HandleType GetHandleType() const override { return HANDLE_TYPE; } | 51 | HandleType GetHandleType() const override { |
| 52 | return HANDLE_TYPE; | ||
| 53 | } | ||
| 51 | 54 | ||
| 52 | /** | 55 | /** |
| 53 | * Creates a pair of ServerSession and an associated ClientSession. | 56 | * Creates a pair of ServerSession and an associated ClientSession. |
diff --git a/src/core/hle/service/fs/archive.cpp b/src/core/hle/service/fs/archive.cpp index e40483c72..a9f457726 100644 --- a/src/core/hle/service/fs/archive.cpp +++ b/src/core/hle/service/fs/archive.cpp | |||
| @@ -25,9 +25,9 @@ | |||
| 25 | #include "core/hle/hle.h" | 25 | #include "core/hle/hle.h" |
| 26 | #include "core/hle/kernel/client_session.h" | 26 | #include "core/hle/kernel/client_session.h" |
| 27 | #include "core/hle/result.h" | 27 | #include "core/hle/result.h" |
| 28 | #include "core/hle/service/service.h" | ||
| 29 | #include "core/hle/service/fs/archive.h" | 28 | #include "core/hle/service/fs/archive.h" |
| 30 | #include "core/hle/service/fs/fs_user.h" | 29 | #include "core/hle/service/fs/fs_user.h" |
| 30 | #include "core/hle/service/service.h" | ||
| 31 | #include "core/memory.h" | 31 | #include "core/memory.h" |
| 32 | 32 | ||
| 33 | // Specializes std::hash for ArchiveIdCode, so that we can use it in std::unordered_map. | 33 | // Specializes std::hash for ArchiveIdCode, so that we can use it in std::unordered_map. |
| @@ -97,6 +97,7 @@ ResultCode File::HandleSyncRequest(Kernel::SharedPtr<Kernel::ServerSession> serv | |||
| 97 | u32* cmd_buff = Kernel::GetCommandBuffer(); | 97 | u32* cmd_buff = Kernel::GetCommandBuffer(); |
| 98 | FileCommand cmd = static_cast<FileCommand>(cmd_buff[0]); | 98 | FileCommand cmd = static_cast<FileCommand>(cmd_buff[0]); |
| 99 | switch (cmd) { | 99 | switch (cmd) { |
| 100 | |||
| 100 | // Read from file... | 101 | // Read from file... |
| 101 | case FileCommand::Read: { | 102 | case FileCommand::Read: { |
| 102 | u64 offset = cmd_buff[1] | ((u64)cmd_buff[2]) << 32; | 103 | u64 offset = cmd_buff[1] | ((u64)cmd_buff[2]) << 32; |
| @@ -170,8 +171,7 @@ ResultCode File::HandleSyncRequest(Kernel::SharedPtr<Kernel::ServerSession> serv | |||
| 170 | break; | 171 | break; |
| 171 | } | 172 | } |
| 172 | 173 | ||
| 173 | case FileCommand::OpenLinkFile: | 174 | case FileCommand::OpenLinkFile: { |
| 174 | { | ||
| 175 | LOG_WARNING(Service_FS, "(STUBBED) File command OpenLinkFile %s", GetName().c_str()); | 175 | LOG_WARNING(Service_FS, "(STUBBED) File command OpenLinkFile %s", GetName().c_str()); |
| 176 | auto sessions = Kernel::ServerSession::CreateSessionPair(GetName(), shared_from_this()); | 176 | auto sessions = Kernel::ServerSession::CreateSessionPair(GetName(), shared_from_this()); |
| 177 | cmd_buff[3] = Kernel::g_handle_table.Create(std::get<Kernel::SharedPtr<Kernel::ClientSession>>(sessions)).ValueOr(INVALID_HANDLE); | 177 | cmd_buff[3] = Kernel::g_handle_table.Create(std::get<Kernel::SharedPtr<Kernel::ClientSession>>(sessions)).ValueOr(INVALID_HANDLE); |
| @@ -195,7 +195,7 @@ ResultCode File::HandleSyncRequest(Kernel::SharedPtr<Kernel::ServerSession> serv | |||
| 195 | LOG_ERROR(Service_FS, "Unknown command=0x%08X!", cmd); | 195 | LOG_ERROR(Service_FS, "Unknown command=0x%08X!", cmd); |
| 196 | ResultCode error = UnimplementedFunction(ErrorModule::FS); | 196 | ResultCode error = UnimplementedFunction(ErrorModule::FS); |
| 197 | cmd_buff[1] = error.raw; // TODO(Link Mauve): use the correct error code for that. | 197 | cmd_buff[1] = error.raw; // TODO(Link Mauve): use the correct error code for that. |
| 198 | return RESULT_SUCCESS; | 198 | return error; |
| 199 | } | 199 | } |
| 200 | cmd_buff[1] = RESULT_SUCCESS.raw; // No error | 200 | cmd_buff[1] = RESULT_SUCCESS.raw; // No error |
| 201 | return RESULT_SUCCESS; | 201 | return RESULT_SUCCESS; |
diff --git a/src/core/hle/service/service.h b/src/core/hle/service/service.h index dd268f39c..931512339 100644 --- a/src/core/hle/service/service.h +++ b/src/core/hle/service/service.h | |||
| @@ -50,23 +50,23 @@ enum DescriptorType : u32 { | |||
| 50 | }; | 50 | }; |
| 51 | 51 | ||
| 52 | /** | 52 | /** |
| 53 | * @brief Creates a command header to be used for IPC | 53 | * @brief Creates a command header to be used for IPC |
| 54 | * @param command_id ID of the command to create a header for. | 54 | * @param command_id ID of the command to create a header for. |
| 55 | * @param normal_params Size of the normal parameters in words. Up to 63. | 55 | * @param normal_params Size of the normal parameters in words. Up to 63. |
| 56 | * @param translate_params_size Size of the translate parameters in words. Up to 63. | 56 | * @param translate_params_size Size of the translate parameters in words. Up to 63. |
| 57 | * @return The created IPC header. | 57 | * @return The created IPC header. |
| 58 | * | 58 | * |
| 59 | * Normal parameters are sent directly to the process while the translate parameters might go | 59 | * Normal parameters are sent directly to the process while the translate parameters might go |
| 60 | * through modifications and checks by the kernel. | 60 | * through modifications and checks by the kernel. |
| 61 | * The translate parameters are described by headers generated with the IPC::*Desc functions. | 61 | * The translate parameters are described by headers generated with the IPC::*Desc functions. |
| 62 | * | 62 | * |
| 63 | * @note While #normal_params is equivalent to the number of normal parameters, | 63 | * @note While #normal_params is equivalent to the number of normal parameters, |
| 64 | * #translate_params_size includes the size occupied by the translate parameters headers. | 64 | * #translate_params_size includes the size occupied by the translate parameters headers. |
| 65 | */ | 65 | */ |
| 66 | constexpr u32 MakeHeader(u16 command_id, unsigned int normal_params, | 66 | constexpr u32 MakeHeader(u16 command_id, unsigned int normal_params, |
| 67 | unsigned int translate_params_size) { | 67 | unsigned int translate_params_size) { |
| 68 | return (u32(command_id) << 16) | ((u32(normal_params) & 0x3F) << 6) | | 68 | return (u32(command_id) << 16) | ((u32(normal_params) & 0x3F) << 6) | |
| 69 | (u32(translate_params_size) & 0x3F); | 69 | (u32(translate_params_size) & 0x3F); |
| 70 | } | 70 | } |
| 71 | 71 | ||
| 72 | union Header { | 72 | union Header { |
| @@ -77,7 +77,7 @@ union Header { | |||
| 77 | }; | 77 | }; |
| 78 | 78 | ||
| 79 | inline Header ParseHeader(u32 header) { | 79 | inline Header ParseHeader(u32 header) { |
| 80 | return{ header }; | 80 | return {header}; |
| 81 | } | 81 | } |
| 82 | 82 | ||
| 83 | constexpr u32 MoveHandleDesc(u32 num_handles = 1) { | 83 | constexpr u32 MoveHandleDesc(u32 num_handles = 1) { |
| @@ -111,19 +111,19 @@ union StaticBufferDescInfo { | |||
| 111 | }; | 111 | }; |
| 112 | 112 | ||
| 113 | inline StaticBufferDescInfo ParseStaticBufferDesc(const u32 desc) { | 113 | inline StaticBufferDescInfo ParseStaticBufferDesc(const u32 desc) { |
| 114 | return{ desc }; | 114 | return {desc}; |
| 115 | } | 115 | } |
| 116 | 116 | ||
| 117 | /** | 117 | /** |
| 118 | * @brief Creates a header describing a buffer to be sent over PXI. | 118 | * @brief Creates a header describing a buffer to be sent over PXI. |
| 119 | * @param size Size of the buffer. Max 0x00FFFFFF. | 119 | * @param size Size of the buffer. Max 0x00FFFFFF. |
| 120 | * @param buffer_id The Id of the buffer. Max 0xF. | 120 | * @param buffer_id The Id of the buffer. Max 0xF. |
| 121 | * @param is_read_only true if the buffer is read-only. If false, the buffer is considered to have | 121 | * @param is_read_only true if the buffer is read-only. If false, the buffer is considered to have |
| 122 | * read-write access. | 122 | * read-write access. |
| 123 | * @return The created PXI buffer header. | 123 | * @return The created PXI buffer header. |
| 124 | * | 124 | * |
| 125 | * The next value is a phys-address of a table located in the BASE memregion. | 125 | * The next value is a phys-address of a table located in the BASE memregion. |
| 126 | */ | 126 | */ |
| 127 | inline u32 PXIBufferDesc(u32 size, unsigned buffer_id, bool is_read_only) { | 127 | inline u32 PXIBufferDesc(u32 size, unsigned buffer_id, bool is_read_only) { |
| 128 | u32 type = PXIBuffer; | 128 | u32 type = PXIBuffer; |
| 129 | if (is_read_only) | 129 | if (is_read_only) |
diff --git a/src/core/hle/service/srv.cpp b/src/core/hle/service/srv.cpp index 6731afc22..d228e3523 100644 --- a/src/core/hle/service/srv.cpp +++ b/src/core/hle/service/srv.cpp | |||
| @@ -6,11 +6,10 @@ | |||
| 6 | 6 | ||
| 7 | #include "common/common_types.h" | 7 | #include "common/common_types.h" |
| 8 | #include "common/logging/log.h" | 8 | #include "common/logging/log.h" |
| 9 | #include "core/hle/service/srv.h" | ||
| 10 | #include "core/hle/kernel/client_session.h" | 9 | #include "core/hle/kernel/client_session.h" |
| 10 | #include "core/hle/kernel/server_session.h" | ||
| 11 | #include "core/hle/kernel/event.h" | 11 | #include "core/hle/kernel/event.h" |
| 12 | #include "core/hle/service/srv.h" | 12 | #include "core/hle/service/srv.h" |
| 13 | #include "core/hle/kernel/server_session.h" | ||
| 14 | 13 | ||
| 15 | //////////////////////////////////////////////////////////////////////////////////////////////////// | 14 | //////////////////////////////////////////////////////////////////////////////////////////////////// |
| 16 | // Namespace SRV | 15 | // Namespace SRV |