mirror of https://github.com/PCSX2/pcsx2.git
Docs: Initial overhaul for stable 2024 (GameIndex)
Adds some new values and more contextual extra info. Needed for having up-to date information. Still need to update other docs like FAQ, Readme and Debugger but that's future work. Fixed some typos along the way.
This commit is contained in:
parent
d48c3cfce5
commit
a14d699f28
Binary file not shown.
|
@ -1,6 +1,6 @@
|
||||||
<!-- PDF METADATA STARTS ---
|
<!-- PDF METADATA STARTS ---
|
||||||
title: "PCSX2 - GameDB Documentation"
|
title: "PCSX2 - GameDB Documentation"
|
||||||
date: "2022"
|
date: "2024"
|
||||||
footer-left: "[Document Source](https://github.com/PCSX2/pcsx2/blob/{LATEST-GIT-TAG}/pcsx2/Docs/GameIndex.md)"
|
footer-left: "[Document Source](https://github.com/PCSX2/pcsx2/blob/{LATEST-GIT-TAG}/pcsx2/Docs/GameIndex.md)"
|
||||||
urlcolor: "cyan"
|
urlcolor: "cyan"
|
||||||
... PDF METADATA ENDS -->
|
... PDF METADATA ENDS -->
|
||||||
|
@ -66,7 +66,7 @@ SERIAL-12345: # !required! Serial number for the game, this is how games are loo
|
||||||
patch=1,EE,00000001,word,00000000
|
patch=1,EE,00000001,word,00000000
|
||||||
```
|
```
|
||||||
|
|
||||||
> Note that quoting strings in YAML is optional, but certain characters are reserved like '\*' and require the string to be quoted, be aware / use a YAML linter to avoid confusion.
|
> Note that quoting strings in YAML is optional, but certain characters are reserved like '\*' and require the string to be quoted. Be aware / use a YAML linter to avoid confusion.
|
||||||
|
|
||||||
## A Note on Case Sensitivity
|
## A Note on Case Sensitivity
|
||||||
|
|
||||||
|
@ -74,10 +74,10 @@ Both the serial numbers for the games, and the CRC patches are at the moment not
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
|
|
||||||
* `SLUS-123` will be stored and looked up in the GameDB as `slus-123`
|
* `SLUS-123` will be stored and looked up in the GameDB as `slus-123`
|
||||||
* Likewise, a CRC with upper-case hex `23AF6876` will be stored and looked up as `23af6876`
|
* Likewise, a CRC with upper-case hex `23AF6876` will be stored and looked up as `23af6876`
|
||||||
|
|
||||||
However, YAML is case-sensitive and will allow multiple serials that only differ on casing. To prevent mistakes, this will also throw a validation error and the first entry will be the one that wins.
|
However, YAML is case-sensitive and will allow multiple serials that only differ on casing. To prevent mistakes, this will also throw a validation error where the first entry will be the one that wins.
|
||||||
|
|
||||||
**Everything else can be safely assumed to be case sensitive!**
|
**Everything else can be safely assumed to be case sensitive!**
|
||||||
|
|
||||||
|
@ -85,48 +85,50 @@ However, YAML is case-sensitive and will allow multiple serials that only differ
|
||||||
|
|
||||||
`compat` can be set to the following values:
|
`compat` can be set to the following values:
|
||||||
|
|
||||||
* `0` = Unknown Compatibility Status
|
* `0` = Unknown Compatibility Status
|
||||||
* `1` = Nothing
|
* `1` = Nothing
|
||||||
* `2` = Intro
|
* `2` = Intro
|
||||||
* `3` = Menu
|
* `3` = Menu
|
||||||
* `4` = In-game
|
* `4` = In-game
|
||||||
* `5` = Playable
|
* `5` = Playable
|
||||||
* `6` = Perfect
|
* `6` = Perfect
|
||||||
|
|
||||||
## Rounding Modes
|
## Rounding Modes
|
||||||
|
|
||||||
The rounding modes are numerically based.
|
The rounding modes are numerically based.
|
||||||
|
|
||||||
These modes can be specified either on the **EE** (`eeRoundMode`) or **VU** (`vuRoundMode`)
|
These modes can be specified either on the **EE** (`eeRoundMode`) with(out) (`eeDivRoundMode`) or **VU** (`vuRoundMode`) or specific VUs like **VU0** (`vu0RoundMode`) or **VU1** (`vu1RoundMode`)
|
||||||
|
|
||||||
### Options for rounding
|
### Options for rounding
|
||||||
|
|
||||||
* `0` = **Nearest**
|
* `0` = **Nearest**
|
||||||
* `1` = **Negative Infinity**
|
* `1` = **Negative Infinity**
|
||||||
* `2` = **Positive Infinity**
|
* `2` = **Positive Infinity**
|
||||||
* `3` = **Chop (Zero)**
|
* `3` = **Chop (Zero)**
|
||||||
* The is the common default
|
* The is the common default
|
||||||
|
|
||||||
## Clamping Modes
|
## Clamping Modes
|
||||||
|
|
||||||
The clamp modes are also numerically based.
|
The clamp modes are also numerically based.
|
||||||
|
|
||||||
* `eeClampMode` refers to the EE's FPU co-processor and COP2
|
* `eeClampMode` refers to the EE's FPU co-processor and COP2
|
||||||
* `vuClampMode` refers to the VU's in micro mode
|
* `vuClampMode` refers to the VUs in micro mode
|
||||||
|
* `vu0ClampMode` refers to the VU0 in micro mode
|
||||||
|
* `vu1ClampMode` refers to the VU1 in micro mode
|
||||||
|
|
||||||
### eeClampMode
|
### eeClampMode
|
||||||
|
|
||||||
* `0` = **Disables** clamping completely
|
* `0` = **Disables** clamping completely
|
||||||
* `1` = Clamp **Normally** (only clamp results)
|
* `1` = Clamp **Normally** (only clamp results)
|
||||||
* `2` = Clamp **Extra+Preserve Sign** (clamp results as well as operands)
|
* `2` = Clamp **Extra+Preserve Sign** (clamp results as well as operands)
|
||||||
* `3` = **Full Clamping** for FPU
|
* `3` = **Full Clamping** for FPU
|
||||||
|
|
||||||
### vuClampMode
|
### vuClampMode
|
||||||
|
|
||||||
* `0` = **Disables** clamping completely
|
* `0` = **Disables** clamping completely
|
||||||
* `1` = Clamp **Normally** (only clamp results)
|
* `1` = Clamp **Normally** (only clamp results)
|
||||||
* `2` = Clamp **Extra** (clamp results as well as operands)
|
* `2` = Clamp **Extra** (clamp results as well as operands)
|
||||||
* `3` = Clamp **Extra+Preserve Sign**
|
* `3` = Clamp **Extra+Preserve Sign**
|
||||||
|
|
||||||
## GS Hardware Fixes
|
## GS Hardware Fixes
|
||||||
|
|
||||||
|
@ -136,102 +138,109 @@ The clamp modes are also numerically based.
|
||||||
|
|
||||||
### GS Hardware Mipmap Fixes
|
### GS Hardware Mipmap Fixes
|
||||||
|
|
||||||
* mipmap [`0` or `1` or `2`] {Off, Basic, Full} Default: Automatic (No value, looks up GameDB)
|
* mipmap [`0` or `1` or `2`] {Off, Basic, Full} Default: Automatic (No value, looks up GameDB)
|
||||||
* trilinearFiltering [`0` or `1` or `2`] {None, Trilinear, Trilinear Ultra} Default: None (`0`)
|
* trilinearFiltering [`0` or `1` or `2`] {None, Trilinear, Trilinear Ultra} Default: None (`0`)
|
||||||
|
|
||||||
### GS Hardware General Fixes
|
### GS Hardware General Fixes
|
||||||
|
|
||||||
* conservativeFramebuffer
|
* beforeDraw {`OI` with suffix } {None unless specific game GSC} Default: Automatic (No value, looks up GameDB) with valid variable name (ex. OI_BurnoutGames)
|
||||||
[`0` or `1`]
|
* afterDraw {`OO` with suffix } {None unless specific game GSC} Default: Automatic (No value, looks up GameDB) with valid variable name
|
||||||
{Off or On}
|
* conservativeFramebuffer [`0` or `1`] {Off or On} Default: On (`1`)
|
||||||
Default: On (`1`)
|
* texturePreloading [`0` or `1` or `2`] {None, Partial or Full Hash Cache} Default: None (`0`)
|
||||||
* texturePreloading
|
* deinterlace [Value between `0` to `9`] {Automatic, Off, WeaveTFF, WeaveBFF, BobTFF, BobBFF, BlendTFF, BlendBFF, AdaptiveTFF, AdaptiveBFF} Default: Automatic (No value, looks up GameDB)
|
||||||
[`0` or `1` or `2`]
|
|
||||||
{None, Partial or Full Hash Cache}
|
|
||||||
Default: None (`0`)
|
|
||||||
* deinterlace
|
|
||||||
[Value between `0` to `9`]
|
|
||||||
{Automatic, Off, WeaveTFF, WeaveBFF, BobTFF, BobBFF, BlendTFF, BlendBFF, AdaptiveTFF, AdaptiveBFF}
|
|
||||||
Default: Automatic (No value, looks up GameDB)
|
|
||||||
|
|
||||||
### GS Hardware Renderer Fixes
|
### GS Hardware Renderer Fixes
|
||||||
|
|
||||||
* autoFlush [`0` or `1`] {Off or On} Default: Off (`0`)
|
* autoFlush [`0` or `1` or `2`] {Disabled, Enabled (Sprites Only), Enabled (All Primitives)} Default: Off (`0`)
|
||||||
* disableDepthSupport [`0` or `1`] {Off or On} Default: Off (`0`)
|
* disableDepthSupport [`0` or `1`] {Off, On} Default: Off (`0`)
|
||||||
* disablePartialInvalidation [`0` or `1`] {Off or On} Default: Off (`0`)
|
* disablePartialInvalidation [`0` or `1`] {Off, On} Default: Off (`0`)
|
||||||
* cpuFramebufferConversion [`0` or `1`] {Off or On} Default: Off (`0`)
|
* cpuFramebufferConversion [`0` or `1`] {Off, On} Default: Off (`0`)
|
||||||
* preloadFrameData [`0` or `1`] {Off or On} Default: Off (`0`)
|
* preloadFrameData [`0` or `1`] {Off, On} Default: Off (`0`)
|
||||||
* textureInsideRT [`0` or `1`] {Off or On} Default: Off (`0`)
|
* textureInsideRT [`0` or `1`] {Disabled, Inside Targets, Merge Targets} Default: Off (`0`)
|
||||||
* halfBottomOverride [`0` or `1`] {Force-Disabled or Force-Enabled} Default: Automatic (No value, looks up GameDB)
|
* PCRTCOverscan [`0` or `1`] {Off, On} Default: Off (`0`)
|
||||||
* pointListPalette [`0` or `1`] {Off or On} Default: Off (`0`)
|
* cpuCLUTRender [`0` or `1` or `2`] {Disabled, Normal, Aggressive} Default: Disabled (`0`)
|
||||||
|
* cpuSpriteRenderBW [Value between `0` to `10`] {Disabled, 1 (64), 2 (128), 3 (192), 4 (256), 5 (320), 6 (384), 7 (448), 8 (512), 9 (576), 10 (640)} Default: Off (`0`)
|
||||||
|
* cpuSpriteRenderLevel [`0` or `1` or `2`] {Sprites only, Sprites/Triangles, Blended Sprites/Triangles} Default: Off unless cpuSpriteRenderBW has value other than Off then it is 'Sprites only' (`0`)
|
||||||
|
* estimateTextureRegion [`0` or `1`] {Off, On} Default: Off (`0`)
|
||||||
|
* getSkipCount {`GSC` with suffix } {None unless specific game GSC} Default: Disabled (`0`) unless valid variable name (ex. GSC_PolyphonyDigitalGames, GSC_UrbanReign, ...)
|
||||||
|
* gpuPaletteConversion [`0` or `1`] {Off, On} Default: Off (`0`)
|
||||||
|
* gpuTargetCLUT [`0` or `1` or `2`] {Disabled, Enabled (Exact Match), Enabled (Check Inside Target)} Default: Disabled (`0`)
|
||||||
|
* minimumBlendingLevel [`0` or `1` or `2` or `3` or `4` or `5`] {Minimum, Basic, Medium, High, Full(Slow), Maximum (Very Slow)} Default: Automatic (No value, looks up GameDB)
|
||||||
|
* maximumBlendingLevel [`0` or `1` or `2` or `3` or `4` or `5`] {Minimum, Basic, Medium, High, Full(Slow), Maximum (Very Slow)} Default: Automatic (No value, looks up GameDB)
|
||||||
|
* recommendedBlendingLevel [`0` or `1` or `2` or `3` or `4` or `5`] {Minimum, Basic, Medium, High, Full(Slow), Maximum (Very Slow)} Default: Automatic (No value, looks up GameDB)
|
||||||
|
* readTCOnClose [`0` or `1`] {Off, On} Default: Off (`0`) // Tab 3 Hardware Fixes (4th checkbox on right row 2)
|
||||||
|
|
||||||
### GS Hardware Upscaling Fixes
|
### GS Hardware Upscaling Fixes
|
||||||
|
|
||||||
* alignSprite [`0` or `1`] {Off or On} Default: Off (`0`)
|
* alignSprite [`0` or `1`] {Off or On} Default: Off (`0`)
|
||||||
* mergeSprite [`0` or `1`] {Off or On} Default: Off (`0`)
|
* mergeSprite [`0` or `1`] {Off or On} Default: Off (`0`)
|
||||||
* wildArmsHack [`0` or `1`] {Off or On} Default: Off (`0`)
|
* wildArmsHack [`0` or `1`] {Off or On} Default: Off (`0`)
|
||||||
* bilinearUpscale [`0` or `1`] {Off or On} Default: Off (`0`)
|
* bilinearUpscale [`0` or `1` or `2`] {Automatic, Force Bilinear, Force Nearest} Default: Automatic
|
||||||
* skipDrawStart [Value between `0` to `10000`] {0-10000} Default: Off (`0`)
|
* skipDrawStart [Value between `0` to `10000`] {0-10000} Default: Off (`0`)
|
||||||
* skipDrawEnd [Value between `0` to `10000`] {0-10000} Default: Off (`0`)
|
* skipDrawEnd [Value between `0` to `10000`] {0-10000} Default: Off (`0`)
|
||||||
* halfPixelOffset [`0` or `1` or `2` or `3`] {Off, Normal Vertex, Special Texture or Special Texture Aggressive} Default: Off (`0`)
|
* halfPixelOffset [`0` or `1` or `2` or `3` or `4`] {Off, Normal Vertex, Special (Texture), Special (Texture Aggressive), Align to Native} Default: Off (`0`)
|
||||||
* roundSprite [`0` or `1` or `2`] {Off, Half or Full} Default: Off (`0`)
|
* nativePaletteDraw [`0` or `1`] {Off, On} Default: Off (`0`)
|
||||||
|
* roundSprite [`0` or `1` or `2`] {Off, Half or Full} Default: Off (`0`)
|
||||||
|
|
||||||
## Game Fixes
|
## Game Fixes
|
||||||
|
|
||||||
These values are case-sensitive so take care. If you incorrectly specify a GameFix, you will get a validation error on startup. Any invalid game-fixes will be dropped from the game's list of fixes.
|
These values are case-sensitive, so take care. If you incorrectly specify a GameFix, you will get a validation error on startup. Any invalid game-fixes will be dropped from the game's list of fixes.
|
||||||
|
|
||||||
### Options for Game Fixes
|
### Game Fixes Options
|
||||||
|
|
||||||
* `VuAddSubHack`
|
* `FpuMulHack`
|
||||||
* Tri-ace games, they use an encryption algorithm that requires VU ADDI opcode to be bit-accurate.
|
* For Tales of Destiny: This fix addresses hanging issues.
|
||||||
|
|
||||||
- `FpuMulHack`
|
* `SoftwareRendererFMVHack`
|
||||||
- Tales of Destiny hangs.
|
* Used for complex FMV rendering in certain games.
|
||||||
|
|
||||||
* `FpuNegDivHack`
|
* `SkipMPEGHack`
|
||||||
* Gundam games messed up camera-view. Dakar 2's sky showing over 3D. Others...
|
* Prevents game hanging/freezing by skipping videos/FMVs.
|
||||||
|
|
||||||
* `XGKickHack`
|
* `GoemonTlbHack`
|
||||||
* Use accurate timing for VU XGKicks (Slower). Fixes graphical errors on WRC, Erementar Gerad, Tennis Court Smash and others.
|
* Preload TLB hack to prevent TLB miss on Goemon.
|
||||||
|
|
||||||
* `EETimingHack`
|
* `EETimingHack`
|
||||||
* General purpose timing hack.
|
* General-purpose timing hack affecting Digital Devil Saga, SSX, and others.
|
||||||
|
|
||||||
* `SkipMPEGHack`
|
* `InstantDMAHack`
|
||||||
* Finds sceMpegIsEnd pattern in games and then recompiles code to say the videos are finished.
|
* Resolves cache emulation problems, affecting games like Fire Pro Wrestling Z.
|
||||||
|
|
||||||
* `OPHFlagHack`
|
* `OPHFlagHack`
|
||||||
* Bleach Bankais and others.
|
* Affects games like Bleach Blade Battlers, Growlanser II and III, Wizardry.
|
||||||
|
|
||||||
* `DMABusyHack`
|
* `GIFFIFOHack`
|
||||||
* Mana Khemia, Metal Saga. Denies writes to the DMAC when it's busy.
|
* Corrects but slows down rendering, impacting games like FIFA Street 2.
|
||||||
|
|
||||||
* `VIFFIFOHack`
|
* `DMABusyHack`
|
||||||
* Transformers Armada, Test Drive Unlimited. Fixes slow booting issue.
|
* Affects games like Mana Khemia 1, Metal Saga, Pilot Down Behind Enemy Lines.
|
||||||
|
|
||||||
* `VIF1StallHack`
|
* `VIF1StallHack`
|
||||||
* SOCOM II HUD and Spy Hunter loading hang.
|
* Resolves hang issues in games like SOCOM 2 HUD and Spy Hunter.
|
||||||
|
|
||||||
* `GIFFIFOHack`
|
* `VIFFIFOHack`
|
||||||
* Enables the GIF FIFO. Needed for Wallace & Grommit, Hot Wheels, DJ Hero.
|
* Simulates VIF1 FIFO read ahead, affecting games like Test Drive Unlimited, Transformers.
|
||||||
|
|
||||||
* `GoemonTlbHack`
|
* `FullVU0SyncHack`
|
||||||
* Preload TLB hack to avoid tlb miss on Goemon.
|
* Enforces tight VU0 sync on every COP2 instruction.
|
||||||
|
|
||||||
* `IbitHack`
|
* `IbitHack`
|
||||||
* VU I bit Hack avoid constant recompilation in some games (Scarface The World Is Yours, Crash Tag Team Racing).
|
* Avoids constant recompilation in games like Scarface: The World is Yours, Crash Tag Team Racing.
|
||||||
|
|
||||||
* `FullVU0SyncHack`
|
* `VuAddSubHack`
|
||||||
* Increase the synchronisation points between COP2 and VU0.
|
* For Tri-Ace Games: Star Ocean 3, Radiata Stories, Valkyrie Profile 2.
|
||||||
|
|
||||||
* `VUSyncHack`
|
* `VUOverflowHack`
|
||||||
* Make the VU's run behind/in sync with the EE to fix some timing issues.
|
* Checks for possible float overflows (Superman Returns).
|
||||||
|
|
||||||
* `VUOverflowHack`
|
* `VUSyncHack`
|
||||||
* VU Overflow hack to check for possible float overflows (Superman Returns).
|
* Ensures synchronization between VUs and EE to fix timing issues.
|
||||||
|
|
||||||
* `SoftwareRendererFMVHack`
|
* `XGKickHack`
|
||||||
* Forces rendering into software mode during FMVs.
|
* Uses accurate timing for VU XGKicks, affecting games like WRC, Erementar Gerad, Tennis Court Smash.
|
||||||
|
|
||||||
|
* `BlitInternalFPSHack`
|
||||||
|
* Utilizes an alternative method to calculate internal FPS to avoid false readings in some games.
|
||||||
|
|
||||||
## SpeedHacks
|
## SpeedHacks
|
||||||
|
|
||||||
|
@ -239,21 +248,21 @@ These values are in a key-value format, where the value is assumed to be an inte
|
||||||
|
|
||||||
### Options for SpeedHacks
|
### Options for SpeedHacks
|
||||||
|
|
||||||
* `mvuFlagSpeedHack`
|
* `mvuFlagSpeedHack`
|
||||||
* Accepted Values - `0` / `1`
|
* Accepted Values - `0` / `1`
|
||||||
* Katamari Damacy have weird speed bug when this speed hack is enabled (and it is by default)
|
* Katamari Damacy has a peculiar speed bug when this speed hack is enabled (and it is by default)
|
||||||
* `MTVUSpeedHack`
|
* `MTVUSpeedHack`
|
||||||
* Accepted Values - `0` / `1`
|
* Accepted Values - `0` / `1`
|
||||||
* T-bit games dislike MTVU and some games are incompatible with MTVU.
|
* T-bit games dislike MTVU, and some games are incompatible with MTVU.
|
||||||
* `InstantVU1SpeedHack`
|
* `InstantVU1SpeedHack`
|
||||||
* Accepted Values - `0` / `1`
|
* Accepted Values - `0` / `1`
|
||||||
* Games such as Parappa the Rapper 2 need VU1 to sync, so you can force sync with this parameter.
|
* Games such as PaRappa the Rapper 2 need VU1 to sync, so you can force sync with this parameter.
|
||||||
|
|
||||||
## Memory Card Filter Override
|
## Memory Card Filter Override
|
||||||
|
|
||||||
By default, the FolderMemoryCard filters save games based on the game's serial, which means that only saves whose folder names containthe game's serial are loaded.
|
By default, the FolderMemoryCard filters save games based on the game's serial, which means that only saves whose folder names contain the game's serial are loaded.
|
||||||
|
|
||||||
This works fine for the vast majority of games, but fails in some cases, for which this override is for. Examples include multi-disc games, where later games often reuse the serial of the previous disc(s), and games that allow transfer of savedata between different games, such as importing data from a prequel.
|
This works fine for the vast majority of games, but fails in some cases, which this override is for. ** 'Examples include multi-disc games, where later games often reuse the serial of the previous disc(s) - and games that allow transfer of savedata between different games, such as importing data from a prequel. This can unlock certain content ranging from cosmetic features (gear/ visual costume) to mechanics (early unlock of weapons). These are not needed with file memcards as they don't hide the serials or outside date from the game itself nor its save memcard. **
|
||||||
|
|
||||||
> Values should be specified as a list of strings, example shown above.
|
> Values should be specified as a list of strings, example shown above.
|
||||||
|
|
||||||
|
@ -275,7 +284,7 @@ We provide a [JSON Schema](https://json-schema.org/) for the GameDB's format. Y
|
||||||
|
|
||||||
If you use VSCode and you want it to properly lint the GameIndex.yaml file you should:
|
If you use VSCode and you want it to properly lint the GameIndex.yaml file you should:
|
||||||
|
|
||||||
1. Download the YAML extension - https://marketplace.visualstudio.com/items?itemName=redhat.vscode-yaml
|
1. Download the YAML extension - <https://marketplace.visualstudio.com/items?itemName=redhat.vscode-yaml>
|
||||||
2. Add the following to your settings:
|
2. Add the following to your settings:
|
||||||
|
|
||||||
```json
|
```json
|
||||||
|
|
Loading…
Reference in New Issue