summaryrefslogtreecommitdiff
path: root/src/core (follow)
Commit message (Collapse)AuthorAgeFilesLines
* Merge pull request #1704 from DarkLordZach/oss-sysarchiveGravatar bunnei2018-12-048-1/+227
|\ | | | | file_sys: Implement open source system archives
| * file_sys: Implement system archive synthesizer for NgWord (806)Gravatar Zach Hilman2018-11-225-6/+61
| |
| * fsp_srv: Add support for using open source archive if not found in NANDGravatar Zach Hilman2018-11-151-0/+10
| |
| * file_sys: Add framework for synthesizing open source archivesGravatar Zach Hilman2018-11-153-0/+109
| |
| * vfs_vector: Add VFS backend for std::arrayGravatar Zach Hilman2018-11-151-0/+52
| | | | | | | | Allows using constexpr/static const data with VFS.
* | Merge pull request #1838 from lioncash/dedupGravatar bunnei2018-12-041-27/+26
|\ \ | | | | | | file_sys/registered_cache: Eliminate variable shadowing
| * | file_sys/registered_cache: Eliminate variable shadowingGravatar Lioncash2018-12-011-27/+26
| | | | | | | | | | | | | | | Also inverts if statements where applicable to allow unindenting code a little bit.
* | | Merge pull request #1836 from lioncash/unusedGravatar bunnei2018-12-041-1/+0
|\ \ \ | | | | | | | | crypto/key_manager: Remove unused variable in GetTicketblob()
| * | | crypto/key_manager: Remove unused variable in GetTicketblob()Gravatar Lioncash2018-12-011-1/+0
| |/ /
* | | kernel/svc: Remove unused header inclusionGravatar Lioncash2018-12-041-1/+0
| | |
* | | kernel/svc: Implement svcSignalEvent()Gravatar Lioncash2018-12-041-1/+16
| | | | | | | | | | | | | | | | | | | | | | | | This function simply does a handle table lookup for a writable event instance identified by the given handle value. If a writable event cannot be found for the given handle, then an invalid handle error is returned. If a writable event is found, then it simply signals the event, as one would expect.
* | | kernel/svc: Implement svcCreateEvent()Gravatar Lioncash2018-12-042-1/+42
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcCreateEvent operates by creating both a readable and writable event and then attempts to add both to the current process' handle table. If adding either of the events to the handle table fails, then the relevant error from the handle table is returned. If adding the readable event after the writable event to the table fails, then the writable event is removed from the handle table and the relevant error from the handle table is returned. Note that since we do not currently test resource limits, we don't check the resource limit table yet.
* | | Merge pull request #1845 from lioncash/nroGravatar bunnei2018-12-045-19/+23
|\ \ \ | | | | | | | | loader/{nro, nso}: Remove dependency on the System class
| * | | loader/nso: Remove dependency on the System classGravatar Lioncash2018-12-023-8/+11
| | | | | | | | | | | | | | | | | | | | Similar to the NRO changes, we can also pass the process explicitly as a parameter from Load instead of indirecting through the System class.
| * | | loader/nro: Make the static LoadNro function internally linkedGravatar Lioncash2018-12-022-7/+5
| | | | | | | | | | | | | | | | | | | | This simply acts as a forwarding function for the Load() function, so this doesn't need to be directly exposed.
| * | | loader/nro: Remove dependency on the System classGravatar Lioncash2018-12-022-10/+13
| | | | | | | | | | | | | | | | | | | | | | | | Load() is already given the process instance as a parameter, so instead of coupling the class to the System class, we can just forward that parameter to LoadNro()
* | | | Merge pull request #1853 from lioncash/eventGravatar bunnei2018-12-045-10/+19
|\ \ \ \ | | | | | | | | | | kernel/object: Amend handle types to distinguish between readable and writable events
| * | | | kernel/object: Amend handle types to distinguish between readable and ↵Gravatar Lioncash2018-12-045-10/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | writable events Two kernel object should absolutely never have the same handle ID type. This can cause incorrect behavior when it comes to retrieving object types from the handle table. In this case it allows converting a WritableEvent into a ReadableEvent and vice-versa, which is undefined behavior, since the object types are not the same. This also corrects ClearEvent() to check both kernel types like the kernel itself does.
* | | | | kernel/handle_table: Amend reference to CTR-OS in Create()Gravatar Lioncash2018-12-041-2/+3
| | | | | | | | | | | | | | | | | | | | Another hold-over from Citra.
* | | | | kernel/svc: Implement the resource limit svcGetInfo optionGravatar Lioncash2018-12-044-9/+34
|/ / / / | | | | | | | | | | | | | | | | Allows a process to register the resource limit as part of its handle table.
* | | | [Kernel::CreateThread] Match format specifiers to LOG_TRACE's argumentsGravatar V.Kalyuzhny2018-12-041-1/+1
| | | |
* | | | Merge pull request #1840 from lioncash/infoGravatar bunnei2018-12-031-50/+100
|\ \ \ \ | | | | | | | | | | svc: Reorganize svcGetInfo, handle more error cases for existing implemented info categories
| * | | | svc: Use the current process' handle table for retrieving the process ↵Gravatar Lioncash2018-12-021-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | instance to act upon The kernel uses the handle table of the current process to retrieve the process that should be used to retrieve certain information. To someone not familiar with the kernel, this might raise the question of "Ok, sounds nice, but doesn't this make it impossible to retrieve information about the current process?". No, it doesn't, because HandleTable instances in the kernel have the notion of a "pseudo-handle", where certain values allow the kernel to lookup objects outside of a given handle table. Currently, there's only a pseudo-handle for the current process (0xFFFF8001) and a pseudo-handle for the current thread (0xFFFF8000), so to retrieve the current process, one would just pass 0xFFFF8001 into svcGetInfo. The lookup itself in the handle table would be something like: template <typename T> T* Lookup(Handle handle) { if (handle == PSEUDO_HANDLE_CURRENT_PROCESS) { return CurrentProcess(); } if (handle == PSUEDO_HANDLE_CURRENT_THREAD) { return CurrentThread(); } return static_cast<T*>(&objects[handle]); } which, as is shown, allows accessing the current process or current thread, even if those two objects aren't actually within the HandleTable instance.
| * | | | svc: Reorganize svcGetInfo, handle more error cases for existing implemented ↵Gravatar Lioncash2018-12-021-50/+99
| | |/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | info categories Our implementation of svcGetInfo was slightly incorrect in that we weren't doing proper error checking everywhere. Instead, reorganize it to be similar to how the kernel seems to do it.
* | | | Merge pull request #1835 from lioncash/cache-globalGravatar bunnei2018-12-036-31/+17
|\ \ \ \ | | | | | | | | | | filesystem: De-globalize registered_cache_union
| * | | | filesystem: De-globalize registered_cache_unionGravatar Lioncash2018-12-016-31/+17
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can just return a new instance of this when it's requested. This only ever holds pointers to the existing registed caches, so it's not a large object. Plus, this also gets rid of the need to keep around a separate member function just to properly clear out the union. Gets rid of one of five globals in the filesystem code.
* | | | Merge pull request #1803 from DarkLordZach/k-able-eventGravatar bunnei2018-12-0333-236/+397
|\ \ \ \ | | | | | | | | | | kernel: Divide Event into ReadableEvent and WritableEvent
| * | | | hle_ipc: Refactor SleepClientThread to avoid ReadableEventGravatar Zach Hilman2018-11-299-14/+14
| | | | |
| * | | | kernel/event: Reference ReadableEvent from WritableEventGravatar Zach Hilman2018-11-2930-311/+169
| | | | |
| * | | | core: Port all current usages of Event to Readable/WritableEventGravatar Zach Hilman2018-11-2925-153/+274
| | | | |
| * | | | hle_ipc: Use event pair for SleepClientThreadGravatar Zach Hilman2018-11-292-19/+22
| | | | |
| * | | | kernel: Add named event tableGravatar Zach Hilman2018-11-292-0/+30
| | | | | | | | | | | | | | | | | | | | Used to store ReadableEvents of all events on the system.
| * | | | kernel: Divide Event into ReadableEvent and WritableEventGravatar Zach Hilman2018-11-296-61/+210
| | | | | | | | | | | | | | | | | | | | More hardware accurate. On the actual system, there is a differentiation between the signaler and signalee, they form a client/server relationship much like ServerPort and ClientPort.
| * | | | kernel/object: Add descriptions to ResetTypesGravatar Zach Hilman2018-11-291-3/+3
| | | | |
* | | | | Merge pull request #1833 from lioncash/cleanGravatar bunnei2018-12-035-5/+97
|\ \ \ \ \ | | | | | | | | | | | | service/fsp_srv: Implement CleanDirectoryRecursively
| * | | | | file_sys: Override missing mutating functions to be stubbed out for ↵Gravatar Lioncash2018-11-302-0/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ReadOnlyVfsDirectory by default Ensures that read only indeed means read only.
| * | | | | service/fsp_srv: Implement CleanDirectoryRecursivelyGravatar Lioncash2018-11-305-5/+72
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is the same behavior-wise as DeleteDirectoryRecursively, with the only difference being that it doesn't delete the top level directory in the hierarchy, so given: root_dir/ - some_dir/ - File.txt - OtherFile.txt The end result is just: root_dir/
* | | | | | Merge pull request #1839 from lioncash/initGravatar bunnei2018-12-031-2/+2
|\ \ \ \ \ \ | | | | | | | | | | | | | | service/audio/audout_u: Amend constructor initialization list order
| * | | | | | service/audio/audout_u: Amend constructor initialization list orderGravatar Lioncash2018-12-011-2/+2
| | |_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | Orders the constructor initializer list the same way the members of the class are declared. Prevents -Wreorder warnings
* | | | | | Merge pull request #1841 from ogniK5377/npad-mode-fixGravatar bunnei2018-12-031-2/+3
|\ \ \ \ \ \ | | | | | | | | | | | | | | Fixed crash with SetNpadMode
| * | | | | | Fixed crash with SetNpadModeGravatar David Marcec2018-12-031-2/+3
| | |_|_|/ / | |/| | | | | | | | | | | | | | | | fixed crash due to handheld
* | | | | | service/usb: Update function tableGravatar Lioncash2018-12-021-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Updates the function table for IClientEpSession based off information provided by SwitchBrew.
* | | | | | service/erpt: Update function tableGravatar Lioncash2018-12-021-5/+7
|/ / / / / | | | | | | | | | | | | | | | | | | | | Updates the function table according to information provided by SwitchBrew.
* | | | | Merge pull request #1830 from Subv/vi_ubGravatar bunnei2018-12-011-0/+2
|\ \ \ \ \ | |/ / / / |/| | | | Services/VI: Dereferencing an uninitialized std::optional is undefined behavior.
| * | | | Services/VI: Dereferencing an uninitialized std::optional is undefined behavior.Gravatar Subv2018-11-301-0/+2
| | |/ / | |/| | | | | | | | | | Assert that it is not empty before using it in the DequeueBuffer wait callback.
* | | | Fix debug buildGravatar Lioncash2018-12-011-1/+1
| |/ / |/| | | | | | | | | | | A non-existent parameter was left in some formatting calls (the logging macro for which only does anything meaningful on debug builds)
* | | service/set: Convert GetLanguageCode over to using PushEnum()Gravatar Lioncash2018-11-301-1/+1
| | | | | | | | | | | | | | | This code was around prior to the introduction of PushEnum, so convert it over so we don't need to cast here.
* | | service/set: Implement MakeLanguageCodeGravatar Lioncash2018-11-302-1/+19
|/ / | | | | | | This function simply converts a given index into a language code.
* | Merge pull request #1801 from ogniK5377/log-before-executeGravatar bunnei2018-11-2951-390/+860
|\ \ | | | | | | Changed logging to be "Log before execution", Added more error logging, all services/svc should now log on some level
| * | Added comment on Main memory size for more clarityGravatar David Marcec2018-11-271-0/+1
| | |