2014-09-12 17:06:13 -07:00
|
|
|
// Copyright 2014 Citra Emulator Project
|
2014-12-16 21:38:14 -08:00
|
|
|
// Licensed under GPLv2 or any later version
|
2014-09-12 17:06:13 -07:00
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
namespace DefaultINI {
|
|
|
|
|
2016-03-01 09:24:18 -08:00
|
|
|
const char* sdl2_config_file = R"(
|
2014-09-12 17:06:13 -07:00
|
|
|
[Controls]
|
2018-04-04 14:05:51 -07:00
|
|
|
# The input devices and parameters for each Switch native input
|
2017-01-28 05:30:42 -08:00
|
|
|
# It should be in the format of "engine:[engine_name],[param1]:[value1],[param2]:[value2]..."
|
|
|
|
# Escape characters $0 (for ':'), $1 (for ',') and $2 (for '$') can be used in values
|
2016-05-13 08:32:43 -07:00
|
|
|
|
2017-08-11 00:51:16 -07:00
|
|
|
# for button input, the following devices are available:
|
2017-01-28 05:30:42 -08:00
|
|
|
# - "keyboard" (default) for keyboard input. Required parameters:
|
|
|
|
# - "code": the code of the key to bind
|
|
|
|
# - "sdl" for joystick input using SDL. Required parameters:
|
|
|
|
# - "joystick": the index of the joystick to bind
|
|
|
|
# - "button"(optional): the index of the button to bind
|
|
|
|
# - "hat"(optional): the index of the hat to bind as direction buttons
|
2017-04-17 01:49:04 -07:00
|
|
|
# - "axis"(optional): the index of the axis to bind
|
2017-01-28 05:30:42 -08:00
|
|
|
# - "direction"(only used for hat): the direction name of the hat to bind. Can be "up", "down", "left" or "right"
|
2017-08-11 00:51:16 -07:00
|
|
|
# - "threshold"(only used for axis): a float value in (-1.0, 1.0) which the button is
|
2017-04-17 01:49:04 -07:00
|
|
|
# triggered if the axis value crosses
|
|
|
|
# - "direction"(only used for axis): "+" means the button is triggered when the axis value
|
|
|
|
# is greater than the threshold; "-" means the button is triggered when the axis value
|
|
|
|
# is smaller than the threshold
|
2017-01-28 05:30:42 -08:00
|
|
|
button_a=
|
|
|
|
button_b=
|
|
|
|
button_x=
|
|
|
|
button_y=
|
2018-01-14 23:31:59 -08:00
|
|
|
button_lstick=
|
|
|
|
button_rstick=
|
2017-01-28 05:30:42 -08:00
|
|
|
button_l=
|
|
|
|
button_r=
|
|
|
|
button_zl=
|
|
|
|
button_zr=
|
2018-01-14 23:31:59 -08:00
|
|
|
button_plus=
|
|
|
|
button_minus=
|
|
|
|
button_dleft=
|
|
|
|
button_dup=
|
|
|
|
button_dright=
|
|
|
|
button_ddown=
|
|
|
|
button_lstick_left=
|
|
|
|
button_lstick_up=
|
|
|
|
button_lstick_right=
|
|
|
|
button_lstick_down=
|
|
|
|
button_sl=
|
|
|
|
button_sr=
|
2018-01-15 01:27:30 -08:00
|
|
|
button_home=
|
|
|
|
button_screenshot=
|
2017-01-28 05:30:42 -08:00
|
|
|
|
2017-08-11 00:51:16 -07:00
|
|
|
# for analog input, the following devices are available:
|
2017-08-06 14:04:06 -07:00
|
|
|
# - "analog_from_button" (default) for emulating analog input from direction buttons. Required parameters:
|
2017-01-28 05:30:42 -08:00
|
|
|
# - "up", "down", "left", "right": sub-devices for each direction.
|
|
|
|
# Should be in the format as a button input devices using escape characters, for example, "engine$0keyboard$1code$00"
|
|
|
|
# - "modifier": sub-devices as a modifier.
|
|
|
|
# - "modifier_scale": a float number representing the applied modifier scale to the analog input.
|
|
|
|
# Must be in range of 0.0-1.0. Defaults to 0.5
|
|
|
|
# - "sdl" for joystick input using SDL. Required parameters:
|
|
|
|
# - "joystick": the index of the joystick to bind
|
|
|
|
# - "axis_x": the index of the axis to bind as x-axis (default to 0)
|
|
|
|
# - "axis_y": the index of the axis to bind as y-axis (default to 1)
|
2018-01-14 23:31:59 -08:00
|
|
|
lstick=
|
|
|
|
rstick=
|
2014-10-09 19:43:40 -07:00
|
|
|
|
2020-10-08 20:43:07 -07:00
|
|
|
# Whether to enable or disable vibration
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
vibration_enabled=
|
|
|
|
|
|
|
|
# Vibration strength percentage (Default: 100)
|
|
|
|
vibration_strength=
|
|
|
|
|
2017-08-06 14:04:06 -07:00
|
|
|
# for motion input, the following devices are available:
|
|
|
|
# - "motion_emu" (default) for emulating motion input from mouse input. Required parameters:
|
|
|
|
# - "update_period": update period in milliseconds (default to 100)
|
|
|
|
# - "sensitivity": the coefficient converting mouse movement to tilting angle (default to 0.01)
|
2019-08-24 06:57:49 -07:00
|
|
|
# - "cemuhookudp" reads motion input from a udp server that uses cemuhook's udp protocol
|
2017-08-06 14:04:06 -07:00
|
|
|
motion_device=
|
|
|
|
|
2017-08-08 16:57:42 -07:00
|
|
|
# for touch input, the following devices are available:
|
|
|
|
# - "emu_window" (default) for emulating touch input from mouse input to the emulation window. No parameters required
|
2019-08-24 06:57:49 -07:00
|
|
|
# - "cemuhookudp" reads touch input from a udp server that uses cemuhook's udp protocol
|
|
|
|
# - "min_x", "min_y", "max_x", "max_y": defines the udp device's touch screen coordinate system
|
2017-08-08 16:57:42 -07:00
|
|
|
touch_device=
|
|
|
|
|
2019-08-24 06:57:49 -07:00
|
|
|
# Most desktop operating systems do not expose a way to poll the motion state of the controllers
|
|
|
|
# so as a way around it, cemuhook created a udp client/server protocol to broadcast the data directly
|
|
|
|
# from a controller device to the client program. Citra has a client that can connect and read
|
|
|
|
# from any cemuhook compatible motion program.
|
|
|
|
|
|
|
|
# IPv4 address of the udp input server (Default "127.0.0.1")
|
2020-03-03 19:05:42 -08:00
|
|
|
udp_input_address=127.0.0.1
|
2019-08-24 06:57:49 -07:00
|
|
|
|
|
|
|
# Port of the udp input server. (Default 26760)
|
|
|
|
udp_input_port=
|
|
|
|
|
|
|
|
# The pad to request data on. Should be between 0 (Pad 1) and 3 (Pad 4). (Default 0)
|
|
|
|
udp_pad_index=
|
|
|
|
|
2014-10-25 12:54:44 -07:00
|
|
|
[Core]
|
2018-05-02 21:34:54 -07:00
|
|
|
# Whether to use multi-core for CPU emulation
|
2020-10-26 23:13:05 -07:00
|
|
|
# 0: Disabled, 1 (default): Enabled
|
2018-05-02 21:34:54 -07:00
|
|
|
use_multi_core=
|
|
|
|
|
2020-07-11 06:26:36 -07:00
|
|
|
[Cpu]
|
|
|
|
# Enable inline page tables optimization (faster guest memory access)
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
cpuopt_page_tables =
|
|
|
|
|
|
|
|
# Enable block linking CPU optimization (reduce block dispatcher use during predictable jumps)
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
cpuopt_block_linking =
|
|
|
|
|
|
|
|
# Enable return stack buffer CPU optimization (reduce block dispatcher use during predictable returns)
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
cpuopt_return_stack_buffer =
|
|
|
|
|
|
|
|
# Enable fast dispatcher CPU optimization (use a two-tiered dispatcher architecture)
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
cpuopt_fast_dispatcher =
|
|
|
|
|
|
|
|
# Enable context elimination CPU Optimization (reduce host memory use for guest context)
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
cpuopt_context_elimination =
|
|
|
|
|
|
|
|
# Enable constant propagation CPU optimization (basic IR optimization)
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
cpuopt_const_prop =
|
|
|
|
|
|
|
|
# Enable miscellaneous CPU optimizations (basic IR optimization)
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
cpuopt_misc_ir =
|
|
|
|
|
|
|
|
# Enable reduction of memory misalignment checks (reduce memory fallbacks for misaligned access)
|
|
|
|
# 0: Disabled, 1 (default): Enabled
|
|
|
|
cpuopt_reduce_misalign_checks =
|
|
|
|
|
2015-04-03 15:35:51 -07:00
|
|
|
[Renderer]
|
2020-01-21 11:37:41 -08:00
|
|
|
# Which backend API to use.
|
|
|
|
# 0 (default): OpenGL, 1: Vulkan
|
|
|
|
backend =
|
|
|
|
|
|
|
|
# Enable graphics API debugging mode.
|
|
|
|
# 0 (default): Disabled, 1: Enabled
|
|
|
|
debug =
|
|
|
|
|
|
|
|
# Which Vulkan physical device to use (defaults to 0)
|
|
|
|
vulkan_device =
|
|
|
|
|
2015-05-03 12:34:48 -07:00
|
|
|
# Whether to use software or hardware rendering.
|
2016-08-15 20:30:02 -07:00
|
|
|
# 0: Software, 1 (default): Hardware
|
2015-05-03 12:34:48 -07:00
|
|
|
use_hw_renderer =
|
|
|
|
|
2015-07-22 20:25:30 -07:00
|
|
|
# Whether to use the Just-In-Time (JIT) compiler for shader emulation
|
2016-08-15 20:30:02 -07:00
|
|
|
# 0: Interpreter (slow), 1 (default): JIT (fast)
|
2015-07-22 20:25:30 -07:00
|
|
|
use_shader_jit =
|
|
|
|
|
2020-02-13 19:17:28 -08:00
|
|
|
# Aspect ratio
|
2020-02-14 11:39:04 -08:00
|
|
|
# 0: Default (16:9), 1: Force 4:3, 2: Force 21:9, 3: Stretch to Window
|
2020-02-13 19:17:28 -08:00
|
|
|
aspect_ratio =
|
|
|
|
|
2020-02-23 16:01:17 -08:00
|
|
|
# Anisotropic filtering
|
|
|
|
# 0: Default, 1: 2x, 2: 4x, 3: 8x, 4: 16x
|
|
|
|
max_anisotropy =
|
|
|
|
|
2016-08-25 15:20:47 -07:00
|
|
|
# Whether to enable V-Sync (caps the framerate at 60FPS) or not.
|
|
|
|
# 0 (default): Off, 1: On
|
|
|
|
use_vsync =
|
|
|
|
|
2020-05-17 17:06:32 -07:00
|
|
|
# Whether to use OpenGL assembly shaders or not. NV_gpu_program5 is required.
|
2020-10-26 23:13:05 -07:00
|
|
|
# 0: Off, 1 (default): On
|
2020-05-17 17:06:32 -07:00
|
|
|
use_assembly_shaders =
|
|
|
|
|
2020-07-09 21:00:02 -07:00
|
|
|
# Whether to allow asynchronous shader building.
|
|
|
|
# 0 (default): Off, 1: On
|
|
|
|
use_asynchronous_shaders =
|
|
|
|
|
2018-08-20 16:14:06 -07:00
|
|
|
# Turns on the frame limiter, which will limit frames output to the target game speed
|
|
|
|
# 0: Off, 1: On (default)
|
|
|
|
use_frame_limit =
|
|
|
|
|
|
|
|
# Limits the speed of the game to run no faster than this value as a percentage of target speed
|
|
|
|
# 1 - 9999: Speed limit as a percentage of target game speed. 100 (default)
|
|
|
|
frame_limit =
|
|
|
|
|
2019-01-13 21:14:27 -08:00
|
|
|
# Whether to use disk based shader cache
|
|
|
|
# 0 (default): Off, 1 : On
|
|
|
|
use_disk_shader_cache =
|
|
|
|
|
2020-02-18 12:51:42 -08:00
|
|
|
# Which gpu accuracy level to use
|
|
|
|
# 0 (Normal), 1 (High), 2 (Extreme)
|
|
|
|
gpu_accuracy =
|
2018-06-26 11:36:26 -07:00
|
|
|
|
2019-01-07 18:46:33 -08:00
|
|
|
# Whether to use asynchronous GPU emulation
|
|
|
|
# 0 : Off (slow), 1 (default): On (fast)
|
|
|
|
use_asynchronous_gpu_emulation =
|
|
|
|
|
2020-02-13 19:06:11 -08:00
|
|
|
# Forces VSync on the display thread. Usually doesn't impact performance, but on some drivers it can
|
|
|
|
# so only turn this off if you notice a speed difference.
|
|
|
|
# 0: Off, 1 (default): On
|
|
|
|
use_vsync =
|
|
|
|
|
2016-12-29 21:35:38 -08:00
|
|
|
# The clear color for the renderer. What shows up on the sides of the bottom screen.
|
|
|
|
# Must be in range of 0.0-1.0. Defaults to 1.0 for all.
|
|
|
|
bg_red =
|
|
|
|
bg_blue =
|
|
|
|
bg_green =
|
|
|
|
|
2016-05-02 23:07:17 -07:00
|
|
|
[Layout]
|
|
|
|
# Layout for the screen inside the render window.
|
|
|
|
# 0 (default): Default Top Bottom Screen, 1: Single Screen Only, 2: Large Screen Small Screen
|
|
|
|
layout_option =
|
|
|
|
|
2017-02-01 00:22:47 -08:00
|
|
|
# Toggle custom layout (using the settings below) on or off.
|
2018-07-26 06:35:10 -07:00
|
|
|
# 0 (default): Off, 1: On
|
2017-02-01 00:22:47 -08:00
|
|
|
custom_layout =
|
|
|
|
|
|
|
|
# Screen placement when using Custom layout option
|
|
|
|
# 0x, 0y is the top left corner of the render window.
|
|
|
|
custom_top_left =
|
|
|
|
custom_top_top =
|
|
|
|
custom_top_right =
|
|
|
|
custom_top_bottom =
|
|
|
|
custom_bottom_left =
|
|
|
|
custom_bottom_top =
|
|
|
|
custom_bottom_right =
|
|
|
|
custom_bottom_bottom =
|
|
|
|
|
2016-05-02 23:07:17 -07:00
|
|
|
# Swaps the prominent screen with the other screen.
|
|
|
|
# For example, if Single Screen is chosen, setting this to 1 will display the bottom screen instead of the top screen.
|
|
|
|
# 0 (default): Top Screen is prominent, 1: Bottom Screen is prominent
|
|
|
|
swap_screen =
|
|
|
|
|
2016-04-27 05:53:23 -07:00
|
|
|
[Audio]
|
|
|
|
# Which audio output engine to use.
|
2018-07-30 20:57:53 -07:00
|
|
|
# auto (default): Auto-select, null: No audio output, cubeb: Cubeb audio engine (if available)
|
2016-04-27 05:53:23 -07:00
|
|
|
output_engine =
|
|
|
|
|
2018-08-23 05:33:03 -07:00
|
|
|
# Whether or not to enable the audio-stretching post-processing effect.
|
|
|
|
# This effect adjusts audio speed to match emulation speed and helps prevent audio stutter,
|
|
|
|
# at the cost of increasing audio latency.
|
|
|
|
# 0: No, 1 (default): Yes
|
|
|
|
enable_audio_stretching =
|
|
|
|
|
2017-01-25 19:33:26 -08:00
|
|
|
# Which audio device to use.
|
|
|
|
# auto (default): Auto-select
|
|
|
|
output_device =
|
|
|
|
|
2018-07-30 20:57:53 -07:00
|
|
|
# Output volume.
|
|
|
|
# 1.0 (default): 100%, 0.0; mute
|
|
|
|
volume =
|
|
|
|
|
2014-10-09 19:43:40 -07:00
|
|
|
[Data Storage]
|
2015-01-05 18:25:57 -08:00
|
|
|
# Whether to create a virtual SD card.
|
|
|
|
# 1 (default): Yes, 0: No
|
2014-10-09 19:43:40 -07:00
|
|
|
use_virtual_sd =
|
2014-10-27 14:18:28 -07:00
|
|
|
|
2019-04-23 05:35:12 -07:00
|
|
|
# Whether or not to enable gamecard emulation
|
|
|
|
# 1: Yes, 0 (default): No
|
2019-04-23 11:38:18 -07:00
|
|
|
gamecard_inserted =
|
2019-04-23 05:35:12 -07:00
|
|
|
|
|
|
|
# Whether or not the gamecard should be emulated as the current game
|
|
|
|
# If 'gamecard_inserted' is 0 this setting is irrelevant
|
|
|
|
# 1: Yes, 0 (default): No
|
2019-04-23 11:38:18 -07:00
|
|
|
gamecard_current_game =
|
2019-04-23 05:35:12 -07:00
|
|
|
|
|
|
|
# Path to an XCI file to use as the gamecard
|
|
|
|
# If 'gamecard_inserted' is 0 this setting is irrelevant
|
|
|
|
# If 'gamecard_current_game' is 1 this setting is irrelevant
|
2019-04-23 11:38:18 -07:00
|
|
|
gamecard_path =
|
2019-04-23 05:35:12 -07:00
|
|
|
|
2016-06-10 18:19:51 -07:00
|
|
|
[System]
|
2018-03-26 19:24:31 -07:00
|
|
|
# Whether the system is docked
|
2018-07-17 19:52:25 -07:00
|
|
|
# 1: Yes, 0 (default): No
|
2018-03-26 19:59:18 -07:00
|
|
|
use_docked_mode =
|
2018-03-26 19:24:31 -07:00
|
|
|
|
2018-10-23 16:28:17 -07:00
|
|
|
# Allow the use of NFC in games
|
|
|
|
# 1 (default): Yes, 0 : No
|
|
|
|
enable_nfc =
|
|
|
|
|
2018-11-11 19:34:23 -08:00
|
|
|
# Sets the seed for the RNG generator built into the switch
|
|
|
|
# rng_seed will be ignored and randomly generated if rng_seed_enabled is false
|
|
|
|
rng_seed_enabled =
|
|
|
|
rng_seed =
|
|
|
|
|
2018-12-28 15:35:55 -08:00
|
|
|
# Sets the current time (in seconds since 12:00 AM Jan 1, 1970) that will be used by the time service
|
|
|
|
# This will auto-increment, with the time set being the time the game is started
|
|
|
|
# This override will only occur if custom_rtc_enabled is true, otherwise the current time is used
|
2018-12-28 16:09:57 -08:00
|
|
|
custom_rtc_enabled =
|
|
|
|
custom_rtc =
|
2018-12-28 15:35:55 -08:00
|
|
|
|
2018-08-03 08:02:55 -07:00
|
|
|
# Sets the account username, max length is 32 characters
|
|
|
|
# yuzu (default)
|
2018-09-18 16:58:28 -07:00
|
|
|
username = yuzu
|
2018-08-03 08:02:55 -07:00
|
|
|
|
|
|
|
# Sets the systems language index
|
|
|
|
# 0: Japanese, 1: English (default), 2: French, 3: German, 4: Italian, 5: Spanish, 6: Chinese,
|
|
|
|
# 7: Korean, 8: Dutch, 9: Portuguese, 10: Russian, 11: Taiwanese, 12: British English, 13: Canadian French,
|
|
|
|
# 14: Latin American Spanish, 15: Simplified Chinese, 16: Traditional Chinese
|
|
|
|
language_index =
|
|
|
|
|
2018-07-06 06:47:06 -07:00
|
|
|
# The system region that yuzu will use during emulation
|
2016-11-30 01:32:09 -08:00
|
|
|
# -1: Auto-select (default), 0: Japan, 1: USA, 2: Europe, 3: Australia, 4: China, 5: Korea, 6: Taiwan
|
2015-01-05 18:25:57 -08:00
|
|
|
region_value =
|
2015-01-31 15:11:51 -08:00
|
|
|
|
2020-05-11 14:50:07 -07:00
|
|
|
# The system time zone that yuzu will use during emulation
|
|
|
|
# 0: Auto-select (default), 1: Default (system archive value), Others: Index for specified time zone
|
|
|
|
time_zone_index =
|
|
|
|
|
2014-10-27 14:18:28 -07:00
|
|
|
[Miscellaneous]
|
2015-01-05 18:25:57 -08:00
|
|
|
# A filter which removes logs below a certain logging level.
|
|
|
|
# Examples: *:Debug Kernel.SVC:Trace Service.*:Critical
|
2018-01-13 13:23:12 -08:00
|
|
|
log_filter = *:Trace
|
2015-09-02 05:56:38 -07:00
|
|
|
|
|
|
|
[Debugging]
|
2019-08-26 08:29:08 -07:00
|
|
|
# Record frame time data, can be found in the log directory. Boolean value
|
|
|
|
record_frame_times =
|
2015-09-02 05:56:38 -07:00
|
|
|
# Port for listening to GDB connections.
|
|
|
|
use_gdbstub=false
|
|
|
|
gdbstub_port=24689
|
2018-11-20 14:49:09 -08:00
|
|
|
# Determines whether or not yuzu will dump the ExeFS of all games it attempts to load while loading them
|
|
|
|
dump_exefs=false
|
2018-10-29 13:09:08 -07:00
|
|
|
# Determines whether or not yuzu will dump all NSOs it attempts to load while loading them
|
|
|
|
dump_nso=false
|
2019-06-28 15:37:33 -07:00
|
|
|
# Determines whether or not yuzu will report to the game that the emulated console is in Kiosk Mode
|
|
|
|
# false: Retail/Normal Mode (default), true: Kiosk Mode
|
|
|
|
quest_flag =
|
2020-05-28 21:53:27 -07:00
|
|
|
# Enables/Disables the macro JIT compiler
|
|
|
|
disable_macro_jit=false
|
2017-06-27 19:46:52 -07:00
|
|
|
|
|
|
|
[WebService]
|
2017-08-22 19:37:03 -07:00
|
|
|
# Whether or not to enable telemetry
|
|
|
|
# 0: No, 1 (default): Yes
|
|
|
|
enable_telemetry =
|
2018-09-16 11:05:51 -07:00
|
|
|
# URL for Web API
|
|
|
|
web_api_url = https://api.yuzu-emu.org
|
2018-03-24 01:18:48 -07:00
|
|
|
# Username and token for yuzu Web Service
|
2018-09-19 11:04:45 -07:00
|
|
|
# See https://profile.yuzu-emu.org/ for more info
|
2018-03-24 01:18:48 -07:00
|
|
|
yuzu_username =
|
|
|
|
yuzu_token =
|
2018-11-28 11:00:01 -08:00
|
|
|
|
2019-04-28 15:44:46 -07:00
|
|
|
[Services]
|
|
|
|
# The name of the backend to use for BCAT
|
|
|
|
# If this is set to 'boxcat' boxcat will be used, otherwise a null implementation will be used
|
|
|
|
bcat_backend =
|
|
|
|
|
2018-11-28 11:00:01 -08:00
|
|
|
[AddOns]
|
|
|
|
# Used to disable add-ons
|
|
|
|
# List of title IDs of games that will have add-ons disabled (separated by '|'):
|
2018-12-04 10:34:46 -08:00
|
|
|
title_ids =
|
2018-11-28 11:00:01 -08:00
|
|
|
# For each title ID, have a key/value pair called `disabled_<title_id>` equal to the names of the add-ons to disable (sep. by '|')
|
|
|
|
# e.x. disabled_0100000000010000 = Update|DLC <- disables Updates and DLC on Super Mario Odyssey
|
2014-09-12 17:06:13 -07:00
|
|
|
)";
|
|
|
|
}
|