Template:Config/doc: Difference between revisions

Template page
(→‎GPU configuration: Added AA options)
(→‎Parameters: Added Misc. config and PPU LLVM Java option)
(17 intermediate revisions by the same user not shown)
Line 23: Line 23:
=== CPU configuration ===
=== CPU configuration ===
<pre>
<pre>
|ppu decoder                         = Interpreter (precise), Interpreter (fast), LLVM Recompiler
|ppu decoder                           = Interpreter (precise), Interpreter (fast), Recompiler (LLVM)
|ppu decoder notes                   =
|ppu decoder notes                     =  
|spu decoder                         = Interpreter (precise), Interpreter (fast), ASMJIT Recompiler, LLVM Recompiler
|spu decoder                           = Interpreter (precise), Interpreter (fast), Recompiler (ASMJIT), Recompiler (LLVM)
|spu decoder notes                   =
|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                 = Auto, Single digit between 1 to 6 (e.g. 3), Range between 1 to 6 (e.g. 1 - 3)
|preferred spu threads notes         =
|preferred spu threads notes           =  
|firmware settings                  = Automatically load required libraries, Manually load selected libraries,
|enable thread scheduler               = On, Off
                                      Load automatic and manual selection, Load liblv2.sprx only
|enable thread scheduler notes         =  
|firmware settings notes            = Where Manually load selected libraries or Load automatic and manual selection options
|lower spu thread priority             = On, Off
                                      is selected, mention the list of libraries to be selected in this parameter
|lower spu thread priority notes       =  
|enable thread scheduler             = On, Off
|enable spu loop detection             = On, Off
|enable thread scheduler notes       =
|enable spu loop detection notes       =  
|lower spu thread priority           = On, Off
|spu cache                             = On, Off
|lower spu thread priority notes     =
|spu cache notes                       =  
|enable spu loop detection           = On, Off
|accurate xfloat                       = On, Off
|enable spu loop detection notes     =
|accurate xfloat notes                 =  
|spu cache                           = On, Off
|spu block size                       = Safe, Mega, Giga
|spu cache notes                     =
|spu block size notes                 =  
|accurate xfloat                     = On, Off
|tsx instructions                     = Enabled, Disabled, Forced
|accurate xfloat notes               =
|tsx instructions notes               =  
|spu block size                     = Safe, Mega, Giga
|spu block size notes               =
|tsx instructions                   = Enabled, Disabled, Forced
|tsx instructions notes             =
</pre>
</pre>


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


=== Audio configuration ===
=== Audio configuration ===
<pre>
<pre>
|audio out windows                   = XAudio2, OpenAL
|audio out windows                     = XAudio2, OpenAL, Disabled
|audio out windows notes             =
|audio out windows notes               =  
|audio out linux                     = OpenAL, PulseAudio, ALSA
|audio out linux                       = OpenAL, PulseAudio, ALSA, Disabled
|audio out linux notes               =
|audio out linux notes                 =
|dump to file                       = On, Off
|audio channels                        = Surround 7.1, Downmix to Stereo, Downmix to 5.1
|dump to file notes                 =  
|audio channels notes                  =  
|convert to 16-bit                   = On, Off
|dump to file                         = On, Off
|convert to 16-bit notes             =
|dump to file notes                   =  
|downmix to stereo                  = On, Off
|convert to 16-bit                     = On, Off
|downmix to stereo notes            =
|convert to 16-bit notes               =  
|volume                             = Range between 0% to 200%
|volume                               = Value between 0% to 200%
|volume notes                       =
|volume notes                         =  
|enable buffering                   = On, Off
|enable buffering                     = On, Off
|enable buffering notes             =
|enable buffering notes               =  
|audio buffer duration               = Range between 20ms to 250ms
|audio buffer duration                 = Value between 20ms to 250ms
|audio buffer duration notes         =
|audio buffer duration notes           =  
|enable time stretching             = On, Off
|enable time stretching               = On, Off
|enable time stretching notes       =
|enable time stretching notes         =  
|time stretching threshold           = Range between 0% to 100%
|time stretching threshold             = Value between 0% to 100%
|time stretching threshold notes     =
|time stretching threshold notes       =  
|microphone type                     = Null, Standard, SingStar, Real SingStar, Rocksmith  
|microphone type                       = Disabled, Standard, SingStar, Real SingStar, Rocksmith
|microphone type notes              =
|microphone type notes                =
</pre>
 
=== I/O configuration ===
<pre>
|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                    =
</pre>
 
=== Advanced configuration ===
<pre>
|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  =
|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 settings                    = Manually load selected libraries, Load automatic and manual selection, Load liblv2.sprx only,
                                        Load liblv2.sprx and manual selection, Load liblv2.sprx and strict selection
|firmware settings notes              = Where libraries are manually selected, mention the list of libraries to be 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  =
|relaxed zcull sync                    = On, Off
|relaxed zcull sync 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                    =  
</pre>
</pre>


=== Debug configuration ===
=== Debug configuration ===
<pre>
<pre>
|force cpu blit emulation           = On, Off
|disable zcull occlusion queries      = On, Off
|force cpu blit emulation notes     =
|disable zcull occlusion queries notes =
|use gpu texture scaling             = On, Off
|force cpu blit emulation             = On, Off
|use gpu texture scaling notes       =
|force cpu blit emulation notes       =  
|accurate getllar                   = On, Off
|use gpu texture scaling               = On, Off
|accurate getllar notes             =
|use gpu texture scaling notes         =  
|accurate putlluc                    = On, Off
|accurate getllar                     = On, Off
|accurate putlluc notes              =
|accurate getllar notes               =  
|hook static functions               = On, Off
|hook static functions                 = On, Off
|hook static functions notes         =
|hook static functions notes           =  
|debug console mode                  = On, Off
|accurate ppu 128 reservations        = Always Enabled, Disabled, Value between 1 to 8
|debug console mode notes           =
|accurate ppu 128 reservations notes   =  
</pre>
</pre>


=== Enhancements ===
=== Misc. configuration ===
<pre>
<pre>
|sleep timers accuracy              = Host, Usleep, All
|ppu llvm java mode handling          = true, false
|sleep timers accuracy notes        =
|ppu llvm java mode handling notes     =  
|clocks scale                        = Range between 10 to 1000
|clocks scale notes                  =
|vblank rate                        = Range between 1 to 500
|vblank rate notes                   =
</pre>
</pre>


Line 143: Line 191:
{{config
{{config
<!-- CPU configuration -->
<!-- CPU configuration -->
|preferred spu threads               = 3 - 4
|preferred spu threads                 = 3 - 4
<!-- GPU configuration -->
<!-- GPU configuration -->
|renderer                           = Vulkan
|renderer                             = Vulkan
|write color buffers                 = On
|write color buffers                   = On
}}
}}
</pre>
</pre>
{{config
{{config
<!-- CPU configuration -->
<!-- CPU configuration -->
|preferred spu threads               = 3 - 4
|preferred spu threads                 = 3 - 4
<!-- GPU configuration -->
<!-- GPU configuration -->
|renderer                           = Vulkan
|renderer                             = Vulkan
|write color buffers                 = On
|write color buffers                   = On
}}
}}



Revision as of 17:36, 14 January 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           = 
|enable thread scheduler               = On, Off
|enable 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                   = 
|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               = 

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   = 
|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 settings                     = Manually load selected libraries, Load automatic and manual selection, Load liblv2.sprx only, 
                                         Load liblv2.sprx and manual selection, Load liblv2.sprx and strict selection
|firmware settings notes               = Where libraries are manually selected, mention the list of libraries to be 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  = 
|relaxed zcull sync                    = On, Off
|relaxed zcull sync 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   = 

Misc. configuration

|ppu llvm java mode handling           = true, false
|ppu llvm java mode handling notes     = 

Examples

Demon's Souls - Standard

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

Options that deviate from RPCS3's default settings and provide the best experience with this title are listed below.

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 RPCS3's default settings are recommended for this title.

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.