- Dec 05, 2018
- 
- 
heapo authoredIn some constexpr functions, msvc is building the LUT at runtime (pushing each element onto the stack) out of an abundance of caution. Moving the arrays into be file-scoped constexpr's avoids this and turns the functions into simple look-ups as intended. 
 
- 
- Dec 04, 2018
- 
- 
bunnei authoredloader/{nro, nso}: Remove dependency on the System class
- 
bunnei authoredkernel/object: Amend handle types to distinguish between readable and writable events 
- 
Marcos authored* Rewrited TEX/TEXS (TEX Scalar). * Style fixes. * Styles issues. 
- 
bunnei authoredkernel/svc: Implement the resource limit svcGetInfo option 
- 
bunnei authoredDon't try to route PFIFO methods (0-0x40) to the other engines. 
- 
Lioncash authoredTwo 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. 
- 
Lioncash authoredAnother hold-over from Citra. 
- 
Lioncash authoredAllows a process to register the resource limit as part of its handle table. 
- 
Subv authoredThis is a leftover from #1792 
- 
Subv authored
- 
Mat M authored[Kernel::CreateThread] Match format specifiers to LOG_TRACE's arguments 
- 
V.Kalyuzhny authored
 
- 
- Dec 03, 2018
- 
- 
bunnei authoredsvc: Reorganize svcGetInfo, handle more error cases for existing implemented info categories 
- 
bunnei authoredyuzu/configuration: Minor clean-up related changes 
- 
bunnei authoredfilesystem: De-globalize registered_cache_union 
- 
bunnei authoredgl_shader_decompiler: Introduce a scoped object and style changes 
- 
bunnei authoredkernel: Divide Event into ReadableEvent and WritableEvent 
- 
bunnei authoredservice/fsp_srv: Implement CleanDirectoryRecursively 
- 
bunnei authoredservice/audio/audout_u: Amend constructor initialization list order 
- 
bunnei authoredFixed crash with SetNpadMode 
- 
Sebastian Valle authoredhle/service: Update function tables for erpt:c and usb's IClientEpSession 
- 
Lioncash authoredSimilar to the NRO changes, we can also pass the process explicitly as a parameter from Load instead of indirecting through the System class. 
- 
Lioncash authoredThis simply acts as a forwarding function for the Load() function, so this doesn't need to be directly exposed. 
- 
Lioncash authoredLoad() 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() 
 
- 
- Dec 02, 2018
- 
- 
Lioncash authoredUpdates the function table for IClientEpSession based off information provided by SwitchBrew. 
- 
Lioncash authoredUpdates the function table according to information provided by SwitchBrew. 
- 
Lioncash authoredThese slots are only ever attached to event handling mechanisms within the class itself, they're never used externally. Because of this, we can make the functions private. This also removes redundant usages of the private access specifier. 
- 
Lioncash authoredResolves trivial compiler warnings. 
- 
Lioncash authoredThe previous code could potentially be a compilation issue waiting to occur, given we forward declare the type for a std::unique_ptr. If the complete definition of the forward declared type isn't visible in a translation unit that the class is used in, then it would fail to compile. Defaulting the destructor in a cpp file ensures the std::unique_ptr's destructor is only invoked where its complete type is known. 
- 
David Marcec authoredfixed crash due to handheld 
- 
Lioncash authoredThe 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.
- 
Lioncash authoredOur 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. 
- 
Lioncash authoredOrders the constructor initializer list the same way the members of the class are declared. Prevents -Wreorder warnings 
- 
bunnei authoredgl_rasterizer: Enable clip distances when set in register and in shader 
- 
bunnei authoredgl_shader_manager: Update pipeline when programs have changed 
- 
bunnei authoredvideo_core: Minor style changes 
- 
bunnei authoredgl_rasterizer_cache: Fix several surface copy issues. 
- 
Lioncash authoredWe 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. 
- 
bunnei authoredUI: Remove border from Game List 
 
-