| Age | Commit message (Collapse) | Author | 
|---|
|  | We really don't need to pull in several headers of boost related
machinery just to perform the erase-remove idiom (particularly with
C++20 around the corner, which adds universal container std::erase and
std::erase_if, which we can just use instead).
With this, we don't need to link in anything boost-related into common. | 
|  | kernel/thread: Remove WaitCurrentThread_Sleep() and ExitCurrentThread() | 
|  | gpu: Use host address for caching instead of guest address. | 
|  | Puts the operation on global state in the same places as the rest of the
svc calls. | 
|  | Rather than make a global accessor for this sort of thing. We can make
it a part of the thread interface itself. This allows getting rid of a
hidden global accessor in the kernel code. | 
|  | Port citra-emu/citra#3924: "citra_qt: Settings (configuration) rework" | 
|  |  | 
|  | video_core/morton: Miscellaneous changes | 
|  | vk_sampler_cache: Implement a sampler cache | 
|  | kernel/process: Remove use of global system accessors | 
|  | gl_rasterizer: Use system instance passed from argument | 
|  | renderer_opengl/gl_global_cache: Add missing override specifiers | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | kernel/server_port: Make data members private | 
|  | core/hle/result: Tidy up the base error code result header. | 
|  | Port various Citra changes to input_common, including deadzone support | 
|  | service/vi: Unstub GetDisplayService | 
|  |  | 
|  | Co-Authored-By: ReinUsesLisp <reinuseslisp@airmail.cc> | 
|  |  | 
|  | Now that we pass in a reference to the system instance, we can utilize
it to eliminate the global accessors in Process-related code. | 
|  | kernel: Make the address arbiter instance per-process | 
|  | service/service: Remove unncessary calls to c_str() | 
|  |  | 
|  | gl_rasterizer: Encapsulate sampler queries into methods | 
|  | insert_or_assign
The previous code had some minor issues with it, really not a big deal,
but amending it is basically 'free', so I figured, "why not?".
With the standard container maps, when:
map[key] = thing;
is done, this can cause potentially undesirable behavior in certain
scenarios. In particular, if there's no value associated with the key,
then the map constructs a default initialized instance of the value
type.
In this case, since it's a std::shared_ptr (as a type alias) that is
the value type, this will construct a std::shared_pointer, and then
assign over it (with objects that are quite large, or actively heap
allocate this can be extremely undesirable).
We also make the function take the region by value, as we can avoid a
copy (and by extension with std::shared_ptr, a copy causes an atomic
reference count increment), in certain scenarios when ownership isn't a
concern (i.e. when ReserveGlobalRegion is called with an rvalue
reference, then no copy at all occurs). So, it's more-or-less a "free"
gain without many downsides. | 
|  | Two of the functions here are overridden functions, so we can append
these specifiers to make it explicit. | 
|  | With this, all kernel objects finally have all of their data members
behind an interface, making it nicer to reason about interactions with
other code (as external code no longer has the freedom to totally alter
internals and potentially messing up invariants). | 
|  |  | 
|  | operator
Previously this was required, as BitField wasn't trivially copyable.
BitField has since been made trivially copyable, so now this isn't
required anymore. | 
|  | Gets rid of another holdover from Citra, and describes the OS on the
Switch instead. | 
|  | Now that the final stray ErrorDescription member was relocated, we can
finally remove it and its relevant constructor in the ResultCode union. | 
|  | Relocates the error code to where it's most related, similar to how all
the other error codes are. Previously we were including a non-generic
error in the main result code header. | 
|  | These can just be passed regularly, now that we use fmt instead of our
old logging system.
While we're at it, make the parameters to MakeFunctionString
std::string_views. | 
|  | service/audio/hwopus: Move decoder state to its own class | 
|  | kernel/scheduler: Pass in system instance in constructor | 
|  | shader_ir: Remove "extras" from the MetaTexture | 
|  | gl_rasterizer_cache: Create texture views for array discrepancies | 
|  | audio_core/cubeb_sink: Convert _MSC_VER ifdefs to _WIN32 | 
|  | gl_rasterizer: Minor logger changes | 
|  | core/settings: Log more setting values | 
|  | This behavior also needs to be visible for MinGW builds as well. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  |