Custom textures rewrite (#6452)
* common: Add thread pool from yuzu * Is really useful for asynchronous operations like shader compilation and custom textures, will be used in following PRs * core: Improve ImageInterface * Provide a default implementation so frontends don't have to duplicate code registering the lodepng version * Add a dds version too which we will use in the next commit * rasterizer_cache: Rewrite custom textures * There's just too much to talk about here, look at the PR description for more details * rasterizer_cache: Implement basic pack configuration file * custom_tex_manager: Flip dumped textures * custom_tex_manager: Optimize custom texture hashing * If no convertions are needed then we can hash the decoded data directly removing the needed for duplicate decode * custom_tex_manager: Implement asynchronous texture loading * The file loading and decoding is offloaded into worker threads, while the upload itself still occurs in the main thread to avoid having to manage shared contexts * Address review comments * custom_tex_manager: Introduce custom material support * video_core: Move custom textures to separate directory * Also split the files to make the code cleaner * gl_texture_runtime: Generate mipmaps for material * custom_tex_manager: Prevent memory overflow when preloading * externals: Add dds-ktx as submodule * string_util: Return vector from SplitString * No code benefits from passing it as an argument * custom_textures: Use json config file * gl_rasterizer: Only bind material for unit 0 * Address review comments
This commit is contained in:
		| @@ -2,7 +2,9 @@ | ||||
| // Licensed under GPLv2 or any later version | ||||
| // Refer to the license.txt file included. | ||||
|  | ||||
| #include "common/common_funcs.h" | ||||
| #include <string> | ||||
|  | ||||
| #include "common/error.h" | ||||
| #include "common/logging/log.h" | ||||
| #include "common/thread.h" | ||||
| #ifdef __APPLE__ | ||||
| @@ -20,7 +22,6 @@ | ||||
| #ifndef _WIN32 | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #include <string> | ||||
|  | ||||
| #ifdef __FreeBSD__ | ||||
| #define cpu_set_t cpuset_t | ||||
| @@ -28,6 +29,56 @@ | ||||
|  | ||||
| namespace Common { | ||||
|  | ||||
| #ifdef _WIN32 | ||||
|  | ||||
| void SetCurrentThreadPriority(ThreadPriority new_priority) { | ||||
|     auto handle = GetCurrentThread(); | ||||
|     int windows_priority = 0; | ||||
|     switch (new_priority) { | ||||
|     case ThreadPriority::Low: | ||||
|         windows_priority = THREAD_PRIORITY_BELOW_NORMAL; | ||||
|         break; | ||||
|     case ThreadPriority::Normal: | ||||
|         windows_priority = THREAD_PRIORITY_NORMAL; | ||||
|         break; | ||||
|     case ThreadPriority::High: | ||||
|         windows_priority = THREAD_PRIORITY_ABOVE_NORMAL; | ||||
|         break; | ||||
|     case ThreadPriority::VeryHigh: | ||||
|         windows_priority = THREAD_PRIORITY_HIGHEST; | ||||
|         break; | ||||
|     case ThreadPriority::Critical: | ||||
|         windows_priority = THREAD_PRIORITY_TIME_CRITICAL; | ||||
|         break; | ||||
|     default: | ||||
|         windows_priority = THREAD_PRIORITY_NORMAL; | ||||
|         break; | ||||
|     } | ||||
|     SetThreadPriority(handle, windows_priority); | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| void SetCurrentThreadPriority(ThreadPriority new_priority) { | ||||
|     pthread_t this_thread = pthread_self(); | ||||
|  | ||||
|     const auto scheduling_type = SCHED_OTHER; | ||||
|     s32 max_prio = sched_get_priority_max(scheduling_type); | ||||
|     s32 min_prio = sched_get_priority_min(scheduling_type); | ||||
|     u32 level = std::max(static_cast<u32>(new_priority) + 1, 4U); | ||||
|  | ||||
|     struct sched_param params; | ||||
|     if (max_prio > min_prio) { | ||||
|         params.sched_priority = min_prio + ((max_prio - min_prio) * level) / 4; | ||||
|     } else { | ||||
|         params.sched_priority = min_prio - ((min_prio - max_prio) * level) / 4; | ||||
|     } | ||||
|  | ||||
|     pthread_setschedparam(this_thread, scheduling_type, ¶ms); | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #ifdef _MSC_VER | ||||
|  | ||||
| // Sets the debugger-visible name of the current thread. | ||||
| @@ -47,7 +98,7 @@ void SetCurrentThreadName(const char* name) { | ||||
|  | ||||
|     info.dwType = 0x1000; | ||||
|     info.szName = name; | ||||
|     info.dwThreadID = static_cast<DWORD>(-1); | ||||
|     info.dwThreadID = std::numeric_limits<DWORD>::max(); | ||||
|     info.dwFlags = 0; | ||||
|  | ||||
|     __try { | ||||
| @@ -81,6 +132,12 @@ void SetCurrentThreadName(const char* name) { | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #if defined(_WIN32) | ||||
| void SetCurrentThreadName(const char*) { | ||||
|     // Do Nothing on MingW | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
| } // namespace Common | ||||
|   | ||||
		Reference in New Issue
	
	Block a user