summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/server_session.cpp (follow)
Commit message (Collapse)AuthorAgeFilesLines
* hle: kernel: Recode implementation of KThread to be more accurate.bunnei2021-01-291-1/+1
|
* core: hle: kernel: Rename Thread to KThread.bunnei2021-01-291-3/+3
|
* core: hle: kernel: Update KSynchronizationObject.bunnei2021-01-111-21/+2
|
* hle: kernel: Move ServiceThread ownership to KernelCore.bunnei2020-12-291-3/+10
| | | | - Fixes a circular dependency which prevented threads from being released on shutdown.
* hle: kernel: service_thread: Add thread name and take weak_ptr of ServerSession.bunnei2020-12-291-1/+1
|
* hle: kernel: service_thread: Add parameter for thread pool size.bunnei2020-12-291-1/+1
|
* core: hle: server_session: Use separate threads for each service connection.bunnei2020-12-291-16/+4
|
* Merge pull request #5131 from bunnei/scheduler-rewritebunnei2020-12-211-2/+2
|\ | | | | Rewrite Kernel scheduler based on Atmosphere
| * hle: kernel: Migrate to KScopedSchedulerLock.bunnei2020-12-061-1/+1
| |
| * hle: kernel: Rewrite scheduler implementation based on Mesopshere.bunnei2020-12-061-1/+1
| |
* | core: Remove unnecessary enum casts in log callsLioncash2020-12-081-2/+1
|/ | | | | Follows the video core PR. fmt doesn't require casts for enum classes anymore, so we can remove quite a few casts.
* kernel: Remove all dependencies on the global system instanceLioncash2020-09-141-3/+3
| | | | | With this, the kernel finally doesn't depend directly on the global system instance anymore.
* core_timing: Make use of uintptr_t to represent user_dataLioncash2020-07-281-2/+4
| | | | Makes the interface future-proofed for supporting other platforms in the event we ever support platforms with differing pointer sizes. This way, we have a type in place that is always guaranteed to be able to represent a pointer exactly.
* core_timing: Make TimedCallback take std::chrono::nanosecondsLioncash2020-07-161-1/+1
| | | | Enforces our desired time units directly with a concrete type.
* core_timing: Make use of std::chrono with ScheduleEventLioncash2020-07-161-2/+2
|
* Clang Format.Fernando Sahmkow2020-06-271-1/+1
|
* SingleCore: Improve Cycle timing Behavior and replace mutex in global scheduler for spinlock.Fernando Sahmkow2020-06-271-1/+2
|
* SVC: Correct SendSyncRequest.Fernando Sahmkow2020-06-271-5/+10
|
* hle_ipc: Eliminate core memory globalsLioncash2020-05-031-2/+2
| | | | | We can just pass the required instances into the constructor of the request, eliminating all usages of the global system accessor.
* core: memory: Move to Core::Memory namespace.bunnei2020-04-171-2/+3
| | | | - helpful to disambiguate Kernel::Memory namespace.
* Core: Address FeedbackFernando Sahmkow2020-02-141-1/+1
|
* Kernel: Refactor synchronization to better match REFernando Sahmkow2020-02-111-0/+10
|
* Kernel: Change WaitObject to Synchronization object. In order to better reflect RE.Fernando Sahmkow2020-02-111-1/+1
|
* kernel: Implement a more accurate IPC dispatch.bunnei2019-11-281-74/+43
|
* core/memory: Migrate over GetPointer()Lioncash2019-11-271-1/+2
| | | | | With all of the interfaces ready for migration, it's trivial to migrate over GetPointer().
* core: Prepare various classes for memory read/write migrationLioncash2019-11-271-1/+2
| | | | | | | | | | Amends a few interfaces to be able to handle the migration over to the new Memory class by passing the class by reference as a function parameter where necessary. Notably, within the filesystem services, this eliminates two ReadBlock() calls by using the helper functions of HLERequestContext to do that for us.
* kernel: Fix reference management for client/server session.bunnei2019-11-261-9/+9
| | | | - Fixes shutdown crash and crash in Pokemon SwSh.
* kernel: Replace usage of boost::intrusive_ptr with std::shared_ptr for kernel objects. (#3154)bunnei2019-11-251-7/+8
| | | | | | * kernel: Replace usage of boost::intrusive_ptr with std::shared_ptr for kernel objects. - See https://github.com/citra-emu/citra/pull/4710 for details.
* HLE/IPC: HLEContext can memorize the client thread and use it for SleepClientThreadWeiyi Wang2019-05-181-1/+1
| | | | This reduces the boilerplate that services have to write out the current thread explicitly. Using current thread instead of client thread is also semantically incorrect, and will be a problem when we implement multicore (at which time there will be multiple current threads)
* kernel/server_session: Remove obsolete TODOsLioncash2019-04-101-7/+2
| | | | These are holdovers from Citra.
* kernel/server_session: Return a std::pair from CreateSessionPair()Lioncash2019-04-061-1/+1
| | | | | | Keeps the return type consistent with the function name. While we're at it, we can also reduce the amount of boilerplate involved with handling these by using structured bindings.
* kernel/wait_object: Make ShouldWait() take thread members by pointer-to-constLioncash2019-04-021-1/+1
| | | | | Given this is intended as a querying function, it doesn't make sense to allow the implementer to modify the state of the given thread.
* kernel/hle_ipc: Convert std::shared_ptr IPC header instances to std::optionalLioncash2019-03-081-31/+32
| | | | | | | | | There's no real need to use a shared lifetime here, since we don't actually expose them to anything else. This is also kind of an unnecessary use of the heap given the objects themselves are so small; small enough, in fact that changing over to optionals actually reduces the overall size of the HLERequestContext struct (818 bytes to 808 bytes).
* kernel/server_session: Make data members privateLioncash2019-03-061-0/+28
| | | | | Makes it much nicer to locally reason about server session behavior, as part of its functionality isn't placed around other classes.
* core/kernel: Remove unnecessary inclusionsLioncash2019-01-011-0/+1
| | | | Gets rid of a few unnecessary header dependencies in some source files.
* hle_ipc: Add member function for querying the existence of a domain headerLioncash2018-10-301-1/+1
| | | | Gets rid of the need to call the getter and then check for null.
* hle_ipc: Make GetDomainMessageHeader return a regular pointerLioncash2018-10-301-1/+1
| | | | | Nothing requires the shared owner ship here, so we can just return a plain pointer.
* kernel/process: Make the handle table per-processLioncash2018-10-201-2/+1
| | | | | | | | In the kernel, there isn't a singular handle table that everything gets tossed into or used, rather, each process gets its own handle table that it uses. This currently isn't an issue for us, since we only execute one process at the moment, but we may as well get this out of the way so it's not a headache later on.
* kernel/thread: Make all instance variables privateLioncash2018-10-041-2/+2
| | | | | | | | | | | | | | | | | | | | Many of the member variables of the thread class aren't even used outside of the class itself, so there's no need to make those variables public. This change follows in the steps of the previous changes that made other kernel types' members private. The main motivation behind this is that the Thread class will likely change in the future as emulation becomes more accurate, and letting random bits of the emulator access data members of the Thread class directly makes it a pain to shuffle around and/or modify internals. Having all data members public like this also makes it difficult to reason about certain bits of behavior without first verifying what parts of the core actually use them. Everything being public also generally follows the tendency for changes to be introduced in completely different translation units that would otherwise be better introduced as an addition to the Thread class' public interface.
* core/core: Replace includes with forward declarations where applicableLioncash2018-08-311-3/+3
| | | | | | | | | | | The follow-up to e2457418dae19b889b2ad85255bb95d4cd0e4bff, which replaces most of the includes in the core header with forward declarations. This makes it so that if any of the headers the core header was previously including change, then no one will need to rebuild the bulk of the core, due to core.h being quite a prevalent inclusion. This should make turnaround for changes much faster for developers.
* kernel: Eliminate kernel global stateLioncash2018-08-291-8/+9
| | | | | | | | | | | | | | | | | | | | | | As means to pave the way for getting rid of global state within core, This eliminates kernel global state by removing all globals. Instead this introduces a KernelCore class which acts as a kernel instance. This instance lives in the System class, which keeps its lifetime contained to the lifetime of the System class. This also forces the kernel types to actually interact with the main kernel instance itself instead of having transient kernel state placed all over several translation units, keeping everything together. It also has a nice consequence of making dependencies much more explicit. This also makes our initialization a tad bit more correct. Previously we were creating a kernel process before the actual kernel was initialized, which doesn't really make much sense. The KernelCore class itself follows the PImpl idiom, which allows keeping all the implementation details sealed away from everything else, which forces the use of the exposed API and allows us to avoid any unnecessary inclusions within the main kernel header.
* kernel/server_session: Add IsSession() member functionLioncash2018-08-151-1/+1
| | | | | | Allows querying the inverse of IsDomain() to make things more readable. This will likely also be usable in the event of implementing ConvertDomainToSession().
* server_session: Provide more useful information and don't crash on bad IPC request.bunnei2018-08-121-0/+8
|
* client_port: Make all data members privateLioncash2018-08-071-1/+1
| | | | | | | | These members don't need to be entirely exposed, we can instead expose an API to operate on them without directly needing to mutate them We can also guard against overflow/API misuse this way as well, given active_sessions is an unsigned value.
* kernel: Remove unnecessary includesLioncash2018-07-311-0/+2
| | | | | Removes unnecessary direct dependencies in some headers and also gets rid of indirect dependencies that were being relied on to be included.
* thread: Convert ThreadStatus into an enum classLioncash2018-07-201-2/+2
| | | | | Makes the thread status strongly typed, so implicit conversions can't happen. It also makes it easier to catch mistakes at compile time.
* core/memory, core/hle/kernel: Use std::move where applicableLioncash2018-07-191-1/+2
| | | | Avoids pointless copies
* Update clang formatJames Rowe2018-07-031-1/+1
|
* Rename logging macro back to LOG_*James Rowe2018-07-031-2/+2
|
* Merge pull request #431 from lioncash/fmtbunnei2018-05-021-1/+1
|\ | | | | general: Make formatting of logged hex values more straightforward
| * general: Make formatting of logged hex values more straightforwardLioncash2018-05-021-1/+1
| | | | | | | | | | | | This makes the formatting expectations more obvious (e.g. any zero padding specified is padding that's entirely dedicated to the value being printed, not any pretty-printing that also gets tacked on).
* | ipc: Add support for PopIpcInterface() method.bunnei2018-05-021-0/+3
|/ | | | - This can be used for domain objects as inputs to service functions.
* kernel: Migrate logging macros to fmt-compatible onesLioncash2018-04-261-3/+3
|
* Clang FixesN00byKing2018-03-191-1/+2
|
* Clean Warnings (?)N00byKing2018-03-191-1/+1
|
* core: Move process creation out of global state.bunnei2018-03-141-1/+2
|
* Fix: change check for domain order and existance of domain message headermailwl2018-02-201-1/+1
|
* IPC: add domain header to response if only it exists in requestmailwl2018-02-201-1/+1
|
* Kernel/IPC: Add a small delay after each SyncRequest to prevent thread starvation.Subv2018-02-181-41/+56
| | | | | | | | Ported from citra PR #3091 The delay specified here is from a Nintendo 3DS, and should be measured in a Nintendo Switch. This change is enough to prevent Puyo Puyo Tetris's main thread starvation.
* server_session: Fix scenario where all domain handlers are closed.bunnei2018-01-251-3/+3
|
* hle: Rename RequestBuilder to ResponseBuilder.bunnei2018-01-251-1/+1
|
* hle: Integrate Domain handling into ServerSession.bunnei2018-01-251-5/+42
|
* kernel: Fix implementation of ConvertSessionToDomain.bunnei2017-12-291-2/+9
|
* service: Return proper result code for IPC::CommandType::Close.bunnei2017-11-011-5/+6
|
* Merge pull request #2793 from Subv/replyandreceiveSebastian Valle2017-06-301-6/+16
|\ | | | | Kernel/SVC: Partially implemented svcReplyAndReceive
| * Kernel/ServerSession: Keep track of which threads have issued sync requests.Subv2017-06-251-6/+16
| |
* | ResultVal: Remove MoveFrom()Yuri Kunde Schlesner2017-06-191-1/+1
|/ | | | | Replace it with std::move(result_val).Unwrap(), or Foo().Unwrap() in case you already have an rvalue.
* Kernel: Add a dedicated SetHleHandler method to ServerPort/ServerSessionYuri Kunde Schlesner2017-06-061-11/+5
| | | | | | This allows attaching a HLE handle to a ServerPort at any point after it is created, allowing port/session creation to be generic between HLE and regular services.
* HLE: Move SessionRequestHandler from Service:: to Kernel::Yuri Kunde Schlesner2017-06-061-2/+5
| | | | | Most of the code that works with this is or will be in the kernel, so it's a more appropriate place for it to be.
* Kernel/Sessions: Remove the ClientSession::Create function.Subv2017-05-221-1/+3
| | | | It is not meant to be used by anything other than CreateSessionPair.
* Kernel: Use a Session object to keep track of the status of a Client/Server session pair.Subv2017-05-151-7/+22
| | | | Reduce the associated port's connection count when a ServerSession is destroyed.
* Kernel: Object ShouldWait and Acquire calls now take a thread as a parameter.Subv2017-01-041-3/+3
| | | | This will be useful when implementing mutex priority inheritance.
* Fixed the codestyle to match our clang-format rules.Subv2016-12-141-10/+15
|
* Moved the HLE command buffer translation task to ServerSession instead of the HLE handler superclass.Subv2016-12-091-2/+13
|
* Added a framework for partially handling Session disconnections.Subv2016-12-081-2/+8
| | | | | | Further implementation will happen in a future commit. Fixes a regression.
* Use std::move where appropriate.Subv2016-12-081-3/+4
|
* KServerPorts now have an HLE handler "template", which is inherited by all ServerSessions created from it.Subv2016-12-051-3/+3
|
* Declare empty ServerSession and ClientSession constructors as default.Subv2016-12-031-2/+2
|
* Fixed the rebase mistakes.Subv2016-12-011-1/+0
|
* A bit of a redesign.Subv2016-12-011-13/+12
| | | | | | | Sessions and Ports are now detached from each other. HLE services are handled by means of a SessionRequestHandler class, Interface now inherits from this class. The File and Directory classes are no longer kernel objects, but SessionRequestHandlers instead, bound to a ServerSession when requested. File::OpenLinkFile now creates a new session pair and binds the File instance to it.
* fixup! Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication.Subv2016-12-011-1/+1
|
* Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication.Subv2016-12-011-0/+58
All handles obtained via srv::GetServiceHandle or svcConnectToPort are references to ClientSessions. Service modules will wait on the counterpart of those ClientSessions (Called ServerSessions) using svcReplyAndReceive or svcWaitSynchronization[1|N], and will be awoken when a SyncRequest is performed. HLE Interfaces are now ClientPorts which override the HandleSyncRequest virtual member function to perform command handling immediately.