mirror of
				https://git.eden-emu.dev/eden-emu/eden.git
				synced 2025-10-25 00:17:48 +00:00 
			
		
		
		
	Merge pull request #6465 from FernandoS27/sex-on-the-beach
GPU: Implement a garbage collector for GPU Caches (project Reaper+)
This commit is contained in:
		
						commit
						7503ca436b
					
				
					 25 changed files with 493 additions and 63 deletions
				
			
		|  | @ -822,6 +822,7 @@ void Config::ReadRendererValues() { | |||
|                       QStringLiteral("use_asynchronous_shaders"), false); | ||||
|     ReadSettingGlobal(Settings::values.use_fast_gpu_time, QStringLiteral("use_fast_gpu_time"), | ||||
|                       true); | ||||
|     ReadSettingGlobal(Settings::values.use_caches_gc, QStringLiteral("use_caches_gc"), false); | ||||
|     ReadSettingGlobal(Settings::values.bg_red, QStringLiteral("bg_red"), 0.0); | ||||
|     ReadSettingGlobal(Settings::values.bg_green, QStringLiteral("bg_green"), 0.0); | ||||
|     ReadSettingGlobal(Settings::values.bg_blue, QStringLiteral("bg_blue"), 0.0); | ||||
|  | @ -1410,6 +1411,7 @@ void Config::SaveRendererValues() { | |||
|                        Settings::values.use_asynchronous_shaders, false); | ||||
|     WriteSettingGlobal(QStringLiteral("use_fast_gpu_time"), Settings::values.use_fast_gpu_time, | ||||
|                        true); | ||||
|     WriteSettingGlobal(QStringLiteral("use_caches_gc"), Settings::values.use_caches_gc, false); | ||||
|     // Cast to double because Qt's written float values are not human-readable
 | ||||
|     WriteSettingGlobal(QStringLiteral("bg_red"), Settings::values.bg_red, 0.0); | ||||
|     WriteSettingGlobal(QStringLiteral("bg_green"), Settings::values.bg_green, 0.0); | ||||
|  |  | |||
|  | @ -31,6 +31,7 @@ void ConfigureGraphicsAdvanced::SetConfiguration() { | |||
|     ui->disable_fps_limit->setChecked(Settings::values.disable_fps_limit.GetValue()); | ||||
|     ui->use_assembly_shaders->setChecked(Settings::values.use_assembly_shaders.GetValue()); | ||||
|     ui->use_asynchronous_shaders->setChecked(Settings::values.use_asynchronous_shaders.GetValue()); | ||||
|     ui->use_caches_gc->setChecked(Settings::values.use_caches_gc.GetValue()); | ||||
|     ui->use_fast_gpu_time->setChecked(Settings::values.use_fast_gpu_time.GetValue()); | ||||
| 
 | ||||
|     if (Settings::IsConfiguringGlobal()) { | ||||
|  | @ -65,6 +66,8 @@ void ConfigureGraphicsAdvanced::ApplyConfiguration() { | |||
|     ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_asynchronous_shaders, | ||||
|                                              ui->use_asynchronous_shaders, | ||||
|                                              use_asynchronous_shaders); | ||||
|     ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_caches_gc, ui->use_caches_gc, | ||||
|                                              use_caches_gc); | ||||
|     ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_fast_gpu_time, | ||||
|                                              ui->use_fast_gpu_time, use_fast_gpu_time); | ||||
| 
 | ||||
|  | @ -105,6 +108,7 @@ void ConfigureGraphicsAdvanced::SetupPerGameUI() { | |||
|         ui->use_asynchronous_shaders->setEnabled( | ||||
|             Settings::values.use_asynchronous_shaders.UsingGlobal()); | ||||
|         ui->use_fast_gpu_time->setEnabled(Settings::values.use_fast_gpu_time.UsingGlobal()); | ||||
|         ui->use_caches_gc->setEnabled(Settings::values.use_caches_gc.UsingGlobal()); | ||||
|         ui->anisotropic_filtering_combobox->setEnabled( | ||||
|             Settings::values.max_anisotropy.UsingGlobal()); | ||||
| 
 | ||||
|  | @ -121,6 +125,8 @@ void ConfigureGraphicsAdvanced::SetupPerGameUI() { | |||
|                                             use_asynchronous_shaders); | ||||
|     ConfigurationShared::SetColoredTristate(ui->use_fast_gpu_time, | ||||
|                                             Settings::values.use_fast_gpu_time, use_fast_gpu_time); | ||||
|     ConfigurationShared::SetColoredTristate(ui->use_caches_gc, Settings::values.use_caches_gc, | ||||
|                                             use_caches_gc); | ||||
|     ConfigurationShared::SetColoredComboBox( | ||||
|         ui->gpu_accuracy, ui->label_gpu_accuracy, | ||||
|         static_cast<int>(Settings::values.gpu_accuracy.GetValue(true))); | ||||
|  |  | |||
|  | @ -39,4 +39,5 @@ private: | |||
|     ConfigurationShared::CheckState use_assembly_shaders; | ||||
|     ConfigurationShared::CheckState use_asynchronous_shaders; | ||||
|     ConfigurationShared::CheckState use_fast_gpu_time; | ||||
|     ConfigurationShared::CheckState use_caches_gc; | ||||
| }; | ||||
|  |  | |||
|  | @ -121,6 +121,16 @@ | |||
|           </property> | ||||
|          </widget> | ||||
|         </item> | ||||
|         <item> | ||||
|          <widget class="QCheckBox" name="use_caches_gc"> | ||||
|           <property name="toolTip"> | ||||
|            <string>Enables garbage collection for the GPU caches, this will try to keep VRAM within 3-4 GB by flushing the least used textures/buffers. May cause issues in a few games.</string> | ||||
|           </property> | ||||
|           <property name="text"> | ||||
|            <string>Enable GPU cache garbage collection (experimental)</string> | ||||
|           </property> | ||||
|          </widget> | ||||
|         </item> | ||||
|         <item> | ||||
|          <widget class="QWidget" name="af_layout" native="true"> | ||||
|           <layout class="QHBoxLayout" name="horizontalLayout_1"> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Mai M
						Mai M