| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-21 13:40:28 +01:00
										 |  |  | #include <string>
 | 
					
						
							|  |  |  | #include "common/assert.h"
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | #include "core/hle/kernel/kernel.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-10 18:35:37 -05:00
										 |  |  | #include "core/hle/kernel/thread.h"
 | 
					
						
							| 
									
										
										
										
											2015-06-21 13:40:28 +01:00
										 |  |  | #include "core/hle/result.h"
 | 
					
						
							| 
									
										
										
										
											2016-11-30 22:50:13 -05:00
										 |  |  | #include "core/hle/service/service.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-12 22:38:29 -03:00
										 |  |  | #include "core/memory.h"
 | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Kernel { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  | class ClientSession; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |  * Kernel object representing the server endpoint of an IPC session. Sessions are the basic CTR-OS | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  |  * primitive for communication between different processes, and are used to implement service calls | 
					
						
							|  |  |  |  * to the various system services. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * To make a service call, the client must write the command header and parameters to the buffer | 
					
						
							|  |  |  |  * located at offset 0x80 of the TLS (Thread-Local Storage) area, then execute a SendSyncRequest | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |  * SVC call with its ClientSession handle. The kernel will read the command header, using it to marshall | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  |  * the parameters to the process at the server endpoint of the session. After the server replies to | 
					
						
							|  |  |  |  * the request, the response is marshalled back to the caller's TLS buffer and control is | 
					
						
							|  |  |  |  * transferred back to it. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  | class ServerSession : public WaitObject { | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |     ServerSession(); | 
					
						
							|  |  |  |     ~ServerSession() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2016-11-30 22:50:13 -05:00
										 |  |  |      * Creates a server session. The server session can have an optional HLE handler, | 
					
						
							|  |  |  |      * which will be invoked to handle the IPC requests that this session receives. | 
					
						
							|  |  |  |      * @param name Optional name of the server session. | 
					
						
							|  |  |  |      * @param hle_handler Optional HLE handler for this server session. | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |      * @return The created server session | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-11-30 22:50:13 -05:00
										 |  |  |     static ResultVal<SharedPtr<ServerSession>> Create(std::string name = "Unknown", std::shared_ptr<Service::SessionRequestHandler> hle_handler = nullptr); | 
					
						
							| 
									
										
										
										
											2015-01-31 22:56:59 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-30 23:28:31 -05:00
										 |  |  |     std::string GetTypeName() const override { | 
					
						
							|  |  |  |         return "ServerSession"; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |     static const HandleType HANDLE_TYPE = HandleType::ServerSession; | 
					
						
							| 
									
										
										
										
											2016-11-30 23:28:31 -05:00
										 |  |  |     HandleType GetHandleType() const override { | 
					
						
							|  |  |  |         return HANDLE_TYPE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Creates a pair of ServerSession and an associated ClientSession. | 
					
						
							|  |  |  |      * @param name Optional name of the ports | 
					
						
							|  |  |  |      * @return The created session tuple | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-11-30 22:50:13 -05:00
										 |  |  |     static std::tuple<SharedPtr<ServerSession>, SharedPtr<ClientSession>> CreateSessionPair(const std::string& name = "Unknown", std::shared_ptr<Service::SessionRequestHandler> hle_handler = nullptr); | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |      * Handle a sync request from the emulated application. | 
					
						
							|  |  |  |      * Only HLE services should override this function. | 
					
						
							|  |  |  |      * @returns ResultCode from the operation. | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |     virtual ResultCode HandleSyncRequest(); | 
					
						
							| 
									
										
										
										
											2015-01-18 20:40:53 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |     bool ShouldWait() override; | 
					
						
							| 
									
										
										
										
											2015-01-20 17:41:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |     void Acquire() override; | 
					
						
							| 
									
										
										
										
											2015-01-20 17:41:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-14 18:03:30 -05:00
										 |  |  |     std::string name; ///< The name of this session (optional)
 | 
					
						
							|  |  |  |     bool signaled;    ///< Whether there's new data available to this ServerSession
 | 
					
						
							| 
									
										
										
										
											2016-11-30 22:50:13 -05:00
										 |  |  |     std::shared_ptr<Service::SessionRequestHandler> hle_handler; ///< This session's HLE request handler (optional)
 | 
					
						
							| 
									
										
										
										
											2014-12-14 03:30:11 -02:00
										 |  |  | }; | 
					
						
							|  |  |  | } |