Difference between revisions of "Template:Config"

From RPCS3 Wiki
(Added Async texture streaming)
(Added new Zcull options and deprecated the old one)
 
Line 18: Line 18:
{{{anisotropic filter|}}}
{{{anisotropic filter|}}}
{{{anti-aliasing|}}}
{{{anti-aliasing|}}}
{{{zcull accuracy|}}}
{{{default resolution|}}}
{{{default resolution|}}}
{{{resolution scale|}}}
{{{resolution scale|}}}
Line 63: Line 64:
{{{disable on-disk shader cache|}}}
{{{disable on-disk shader cache|}}}
{{{disable native float16 support|}}}
{{{disable native float16 support|}}}
{{{relaxed zcull sync|}}}
{{{driver wake-up delay|}}}
{{{driver wake-up delay|}}}
{{{vblank rate|}}}
{{{vblank rate|}}}
Line 120: Line 120:
{{{anisotropic filter|}}}
{{{anisotropic filter|}}}
{{{anti-aliasing|}}}
{{{anti-aliasing|}}}
{{{zcull accuracy|}}}
{{{default resolution|}}}
{{{default resolution|}}}
{{{resolution scale|}}}
{{{resolution scale|}}}
Line 149: Line 150:
{{!}}-
{{!}}-
{{#if: {{{anti-aliasing|}}} | {{!}} '''Anti-aliasing''' {{!!}} {{#ifeq: {{#regex: {{{anti-aliasing|}}} | /(Auto{{!}}Disabled)/rs}} | {{{anti-aliasing|}}} | {{{anti-aliasing|}}} {{#if: {{NAMESPACE}} | | [[Category:Anti-aliasing: {{{anti-aliasing|}}} (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{anti-aliasing notes|}}}}}
{{#if: {{{anti-aliasing|}}} | {{!}} '''Anti-aliasing''' {{!!}} {{#ifeq: {{#regex: {{{anti-aliasing|}}} | /(Auto{{!}}Disabled)/rs}} | {{{anti-aliasing|}}} | {{{anti-aliasing|}}} {{#if: {{NAMESPACE}} | | [[Category:Anti-aliasing: {{{anti-aliasing|}}} (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{anti-aliasing notes|}}}}}
{{!}}-
{{#if: {{{zcull accuracy|}}} | {{!}} '''ZCULL accuracy''' {{!!}} {{#ifeq: {{#regex: {{{zcull accuracy|}}} | /(Precise{{!}}Approximate{{!}}Relaxed)/rs}} | {{{zcull accuracy|}}} | {{{zcull accuracy|}}} {{#if: {{NAMESPACE}} | | [[Category:ZCULL accuracy: {{{zcull accuracy|}}} (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{zcull accuracy notes|}}}}}
{{!}}-
{{!}}-
{{#if: {{{default resolution|}}} | {{!}} '''Default resolution''' {{!!}} {{#ifeq: {{#regex: {{{default resolution|}}} | /(1920x1080{{!}}1280x720{{!}}720x480{{!}}720x576{{!}}1600x1080{{!}}1440x1080{{!}}1280x1080{{!}}960x1080)/rs}} | {{{default resolution|}}} | {{{default resolution|}}} {{#if: {{NAMESPACE}} | | [[Category:Default resolution: {{{default resolution|}}} (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{default resolution notes|}}}}}
{{#if: {{{default resolution|}}} | {{!}} '''Default resolution''' {{!!}} {{#ifeq: {{#regex: {{{default resolution|}}} | /(1920x1080{{!}}1280x720{{!}}720x480{{!}}720x576{{!}}1600x1080{{!}}1440x1080{{!}}1280x1080{{!}}960x1080)/rs}} | {{{default resolution|}}} | {{{default resolution|}}} {{#if: {{NAMESPACE}} | | [[Category:Default resolution: {{{default resolution|}}} (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{default resolution notes|}}}}}
Line 254: Line 257:
{{{disable on-disk shader cache|}}}
{{{disable on-disk shader cache|}}}
{{{disable native float16 support|}}}
{{{disable native float16 support|}}}
{{{relaxed zcull sync|}}}
{{{driver wake-up delay|}}}
{{{driver wake-up delay|}}}
{{{vblank rate|}}}
{{{vblank rate|}}}
Line 291: Line 293:
{{!}}-
{{!}}-
{{#if: {{{disable native float16 support|}}} | {{!}} '''Disable native float16 support''' {{!!}} {{#ifeq: {{#regex: {{{disable native float16 support|}}} | /(On{{!}}Off)/rs}} | {{{disable native float16 support|}}} | {{{disable native float16 support|}}} {{#if: {{NAMESPACE}} | | [[Category:Disable native float16 support: {{{disable native float16 support|}}} (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{disable native float16 support notes|}}}}}
{{#if: {{{disable native float16 support|}}} | {{!}} '''Disable native float16 support''' {{!!}} {{#ifeq: {{#regex: {{{disable native float16 support|}}} | /(On{{!}}Off)/rs}} | {{{disable native float16 support|}}} | {{{disable native float16 support|}}} {{#if: {{NAMESPACE}} | | [[Category:Disable native float16 support: {{{disable native float16 support|}}} (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{disable native float16 support notes|}}}}}
{{!}}-
{{#if: {{{relaxed zcull sync|}}} | {{!}} '''Relaxed ZCull sync''' {{!!}} {{#ifeq: {{#regex: {{{relaxed zcull sync|}}} | /(On{{!}}Off)/rs}} | {{{relaxed zcull sync|}}} | {{{relaxed zcull sync|}}} {{#if: {{NAMESPACE}} | | [[Category:Relaxed ZCull sync: {{{relaxed zcull sync|}}} (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{relaxed zcull sync notes|}}}}}
{{!}}-
{{!}}-
{{#if: {{{driver wake-up delay|}}} | {{!}} '''Driver wake-up delay''' {{!!}} {{#ifeq: {{#regex: {{{driver wake-up delay|}}} | /(^[0-9]${{!}}^[1-9][0-9]${{!}}^[1-9][0-9]{2}${{!}}^[1-6][0-9]{3}${{!}}^7000$)/rm}} | {{{driver wake-up delay|}}} | {{{driver wake-up delay|}}} {{#if: {{NAMESPACE}} | | [[Category:Driver wake-up delay (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{driver wake-up delay notes|}}}}}
{{#if: {{{driver wake-up delay|}}} | {{!}} '''Driver wake-up delay''' {{!!}} {{#ifeq: {{#regex: {{{driver wake-up delay|}}} | /(^[0-9]${{!}}^[1-9][0-9]${{!}}^[1-9][0-9]{2}${{!}}^[1-6][0-9]{3}${{!}}^7000$)/rm}} | {{{driver wake-up delay|}}} | {{{driver wake-up delay|}}} {{#if: {{NAMESPACE}} | | [[Category:Driver wake-up delay (Config)]]}} | [[Category:Incorrect configurations (Config)]]}} {{!!}} {{{driver wake-up delay notes|}}}}}
Line 348: Line 348:
-->{{#if: {{{anisotropic filter|}}} | {{#ifeq: {{{anisotropic filter|}}} | Auto | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{anisotropic filter|}}} | {{#ifeq: {{{anisotropic filter|}}} | Auto | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{anti-aliasing|}}} | {{#ifeq: {{{anti-aliasing|}}} | Auto | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{anti-aliasing|}}} | {{#ifeq: {{{anti-aliasing|}}} | Auto | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{zcull accuracy|}}} | {{#ifeq: {{{zcull accuracy|}}} | Precise | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{default resolution|}}} | {{#ifeq: {{{default resolution|}}} | 1280x720 | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{default resolution|}}} | {{#ifeq: {{{default resolution|}}} | 1280x720 | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{resolution scale|}}} | {{#ifeq: {{{resolution scale|}}} | 100 | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{resolution scale|}}} | {{#ifeq: {{{resolution scale|}}} | 100 | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
Line 392: Line 393:
-->{{#if: {{{disable on-disk shader cache|}}} | {{#ifeq: {{{disable on-disk shader cache|}}} | Off | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{disable on-disk shader cache|}}} | {{#ifeq: {{{disable on-disk shader cache|}}} | Off | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{disable native float16 support|}}} | {{#ifeq: {{{disable native float16 support|}}} | Off | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{disable native float16 support|}}} | {{#ifeq: {{{disable native float16 support|}}} | Off | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{relaxed zcull sync|}}} | {{#ifeq: {{{relaxed zcull sync|}}} | Off | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{driver wake-up delay|}}} | {{#ifeq: {{{driver wake-up delay|}}} | 0 | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{driver wake-up delay|}}} | {{#ifeq: {{{driver wake-up delay|}}} | 0 | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{vblank rate|}}} | {{#ifeq: {{{vblank rate|}}} | 60 | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
-->{{#if: {{{vblank rate|}}} | {{#ifeq: {{{vblank rate|}}} | 60 | {{#if: {{NAMESPACE}} | | [[Category:Default settings repeated (Config)]]}}}}}}<!--
Line 412: Line 412:
{{{enable thread scheduler|}}}
{{{enable thread scheduler|}}}
{{{firmware settings|}}}
{{{firmware settings|}}}
{{{relaxed zcull sync|}}}
| {{#if: {{NAMESPACE}} | | [[Category:Legacy parameters used (Config)]]}}}}<!--
| {{#if: {{NAMESPACE}} | | [[Category:Legacy parameters used (Config)]]}}}}<!--
--></includeonly><noinclude>{{/doc}}</noinclude>
--></includeonly><noinclude>{{/doc}}</noinclude>

Latest revision as of 13:36, 13 September 2021

This template is used on all game pages under the ==Configuration== sub-header. The purpose of the template is to capture deviations in configurations from the default settings to be used for the emulator for each game. Hence, while using this template in the game pages, only options which deviate from the default settings are to be recorded.

Mandatory vs. recommendatory settings

Before using this is template, it is imperative to understand the distinction between mandatory settings and recommendatory settings.

  • Mandatory settings - Settings without which the game would not work (for example, write color buffers for Demon's Souls and PPU Interpreter (precise) for The Elder Scrolls IV: Oblivion) or will significantly degrade performance.
  • Recommendatory settings - User specific settings which will improve the overall gaming experience based on the hardware available. For example, a higher option can be used for Anisotropic Filter and Resolution Scale if the user's hardware is capable of handling the additional load whereas settings such as Lower SPU Thread Priority should be used for better performance with weaker CPUs.

Given the nature of the options available, it is not feasible to capture all permutations of settings for each game using this template. Hence, only mandatory settings shall be listed in the game pages using this template. To know which recommendatory setting would be most appropriate, kindly read the guidance available for each setting in the default settings page. RPCS3 is alpha stage emulator and hence user will have to experiment with the recommendatory settings to optimise their gameplay experience.

An exception to the above rule would be Preferred SPU Threads where a value or range can be provided to identify the optimal option for each user.

Syntax

Below is the syntax of the template. This template must be present for all game pages irrespective of whether any non-default configurations are necessary. Where the game only requires default settings, the template should simply be used without any parameters.

{{config
|parameters =
}}

Parameters

The following are the only valid parameters accepted by this template. Unless mentioned otherwise, choose only one of the options mentioned for each setting. For any setting which deviates from the default configuration, an additional note may be given if required using the notes extension to highlight any necessary information.

CPU configuration

|ppu decoder                           = Interpreter (precise), Interpreter (fast), Recompiler (LLVM)
|ppu decoder notes                     = 
|spu decoder                           = Interpreter (precise), Interpreter (fast), Recompiler (ASMJIT), Recompiler (LLVM)
|spu decoder notes                     = 
|preferred spu threads                 = Auto, Single digit between 1 to 6 (e.g. 3), Range between 1 to 6 (e.g. 1 - 3)
|preferred spu threads notes           = 
|thread scheduler                      = Operating System, RPCS3 Scheduler, RPCS3 Alternative Scheduler
|thread scheduler notes                = 
|lower spu thread priority             = On, Off
|lower spu thread priority notes       = 
|enable spu loop detection             = On, Off
|enable spu loop detection notes       = 
|spu cache                             = On, Off
|spu cache notes                       = 
|accurate xfloat                       = On, Off
|accurate xfloat notes                 = 
|spu block size                        = Safe, Mega, Giga
|spu block size notes                  = 
|tsx instructions                      = Enabled, Disabled, Forced
|tsx instructions notes                = 

GPU configuration

|renderer                              = OpenGL, Vulkan, Disabled
|renderer notes                        = 
|graphics device                       = This option is used only with Vulkan renderer to select the graphics card to be used by 
                                         RPCS3 when multiple eligible cards exist. Do not use this parameter on game pages.
|graphics device notes                 = 
|aspect ratio                          = 4:3, 16:9
|aspect ratio notes                    = 
|framelimit                            = Off, 59.94, 50, 60, 30, Auto
|framelimit notes                      = 
|anisotropic filter                    = Auto, 2x, 4x, 8x, 16x
|anisotropic filter notes              = 
|anti-aliasing                         = Auto, Disabled
|anti-aliasing notes                   = 
|zcull accuracy                        = Precise, Approximate, Relaxed
|zcull accuracy notes                  = 
|default resolution                    = 1920x1080, 1280x720, 720x480, 720x576, 1600x1080, 1440x1080, 1280x1080, 960x1080
|default resolution notes              = 
|resolution scale                      = Value between 50% to 800%
|resolution scale notes                = 
|resolution scale threshold            = Value between 1 to 1024 in the format 16 x 16
|resolution scale threshold notes      = 
|shader mode                           = Legacy (singlethreaded), Async (multithreaded), Async with Shader Interpreter,
                                         Shader Interpreter only
|shader mode notes                     = 
|write color buffers                   = On, Off
|write color buffers notes             = 
|strict rendering mode                 = On, Off
|strict rendering mode notes           = 
|vsync                                 = On, Off
|vsync notes                           = 
|stretch to display area               = On, Off
|stretch to display area notes         = 
|enable 3d                             = On, Off
|enable 3d notes                       = 
|disable vertex cache                  = On, Off
|disable vertex cache notes            = 
|multithreaded rsx                     = On, Off
|multithreaded rsx notes               = 
|asynchronous texture streaming        = On, Off
|asynchronous texture streaming notes  = 

Audio configuration

|audio out windows                     = XAudio2, OpenAL, Disabled
|audio out windows notes               = 
|audio out linux                       = OpenAL, PulseAudio, ALSA, Disabled
|audio out linux notes                 = 
|audio channels                        = Surround 7.1, Downmix to Stereo, Downmix to 5.1
|audio channels notes                  = 
|dump to file                          = On, Off
|dump to file notes                    = 
|convert to 16-bit                     = On, Off
|convert to 16-bit notes               = 
|volume                                = Value between 0% to 200%
|volume notes                          = 
|enable buffering                      = On, Off
|enable buffering notes                = 
|audio buffer duration                 = Value between 20ms to 250ms
|audio buffer duration notes           = 
|enable time stretching                = On, Off
|enable time stretching notes          = 
|time stretching threshold             = Value between 0% to 100%
|time stretching threshold notes       = 
|microphone type                       = Disabled, Standard, SingStar, Real SingStar, Rocksmith
|microphone type notes                 = 

I/O configuration

|keyboard handler                      = Null, Basic
|keyboard handler notes                = 
|mouse handler                         = Null, Basic
|mouse handler notes                   = 
|camera input                          = Unknown, EyeToy, PS Eye, UVC 1.1
|camera input notes                    = 
|camera settings                       = Null, Fake
|camera settings notes                 = 
|move handler                          = Null, Fake, Mouse
|move handler notes                    = 

Advanced configuration

|debug console mode                    = On, Off
|debug console mode notes              = 
|accurate llvm dfma                    = On, Off
|accurate llvm dfma notes              = 
|accurate rsx reservation access       = On, Off
|accurate rsx reservation access notes = 
|ppu llvm accurate vector nans         = On, Off
|ppu llvm accurate vector nans notes   = 
|ppu llvm java mode handling           = True, False
|ppu llvm java mode handling notes     = 
|silence all logs                      = On, Off
|silence all logs notes                = 
|sleep timers accuracy                 = As Host, Usleep Only, All Timers
|sleep timers accuracy notes           = 
|maximum spurs threads                 = Unlimited, Single digit between 0 to 5 (e.g. 3)
|maximum spurs threads notes           = 
|firmware libraries                    = Switch to LLE, Switch to HLE
|firmware libraries notes              = Mention the libraries to be manually selected here
|read depth buffers                    = On, Off
|read depth buffers notes              = 
|write depth buffers                   = On, Off
|write depth buffers notes             = 
|read color buffers                    = On, Off
|read color buffers notes              = 
|disable on-disk shader cache          = On, Off
|disable on-disk shader cache notes    = 
|disable native float16 support        = On, Off
|disable native float16 support notes  = 
|driver wake-up delay                  = Value between 0 to 7000
|driver wake-up delay notes            = 
|vblank rate                           = Value between 1 to 500
|vblank rate notes                     = 
|clocks scale                          = Value between 10 to 1000
|clocks scale notes                    = 

Debug configuration

|disable zcull occlusion queries       = On, Off
|disable zcull occlusion queries notes = 
|force cpu blit emulation              = On, Off
|force cpu blit emulation notes        = 
|use gpu texture scaling               = On, Off
|use gpu texture scaling notes         = 
|accurate getllar                      = On, Off
|accurate getllar notes                = 
|hook static functions                 = On, Off
|hook static functions notes           = 
|accurate ppu 128 reservations         = Always Enabled, Disabled, Value between 1 to 8
|accurate ppu 128 reservations notes   = 

Examples

Demon's Souls - Standard

{{config
<!-- CPU configuration -->
|preferred spu threads                 = 3 - 4
<!-- GPU configuration -->
|renderer                              = Vulkan
|write color buffers                   = On
}}

Only options that deviate from the default configuration to ensure best performance are listed below. The full list of default options is available here.

CPU configuration

Setting Option Notes
Preferred SPU threads 3 - 4

GPU configuration

Setting Option Notes
Renderer Vulkan
Write color buffers On


Find a game that does this - When the game only uses default settings

{{config
}}

No options that deviate from the default configuration are recommended for this title. The full list of default options is available here.

Attribution and re-use

This template (along with its documentation template) has been adapted from Dolphin Emulator Wiki released under the Creative Commons Attribution-ShareAlike 3.0 License.