Change to "FIFO Player" to be consistant with name in program.
parent
6db4f9fabc
commit
f1704d0550
|
@ -1,18 +1,18 @@
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
FifoPlayer is a powerful developer tool for debugging graphics related issues. It can be used to record an emulated scene during emulation and to playback it arbitrarily often later on.
|
FIFO Player is a powerful developer tool for debugging graphics related issues. It can be used to record an emulated scene during emulation and to playback it arbitrarily often later on.
|
||||||
Furthermore, it allows for close inspection of each FIFO command sent to the GPU during emulation.
|
Furthermore, it allows for close inspection of each FIFO command sent to the GPU during emulation.
|
||||||
Possible use cases for FifoPlayer include debugging rendering issues in games which a developer does not have access to.
|
Possible use cases for FIFO Player include debugging rendering issues in games which a developer does not have access to.
|
||||||
Users can just record a FIFO log and give it to devs, who can analyze the rendering commands without the actual game ISO.
|
Users can just record a FIFO log and give it to devs, who can analyze the rendering commands without the actual game ISO.
|
||||||
Also, having an automatically formatted FIFO command list very much eases the task of figuring out how a specific game's graphics are rendered and where it goes wrong in Dolphin.
|
Also, having an automatically formatted FIFO command list very much eases the task of figuring out how a specific game's graphics are rendered and where it goes wrong in Dolphin.
|
||||||
FifoPlayer can restrict the render output to the objects of interest, effectively cleaning up any irritating "unrelated" objects.
|
FIFO Player can restrict the render output to the objects of interest, effectively cleaning up any irritating "unrelated" objects.
|
||||||
|
|
||||||
## How to Record a FIFO Log
|
## How to Record a FIFO Log
|
||||||
|
|
||||||
All of the FifoPlayer functionality requires a FIFO log to be recorded. This basically intercepts all commands sent to the GPU during the recording and stores them in a `.dff` file to allow easy playback and inspection.
|
All of the FIFO Player functionality requires a FIFO log to be recorded. This basically intercepts all commands sent to the GPU during the recording and stores them in a `.dff` file to allow easy playback and inspection.
|
||||||
|
|
||||||
- While running a game, open the *Fifo Player* dialog from the *Tools* menu.
|
- While running a game, open the *FIFO Player* dialog from the *Tools* menu.
|
||||||
- In the Fifo Player dialog, select the *Record* tab.
|
- In the FIFO Player dialog, select the *Record* tab.
|
||||||
- Adjust the number of frames to render (different issues will need a different FIFO log length; for example when render output depends on the previously rendered frame, you'll want to record more than one frame).
|
- Adjust the number of frames to render (different issues will need a different FIFO log length; for example when render output depends on the previously rendered frame, you'll want to record more than one frame).
|
||||||
- Press *Record* and wait until the recording has finished.
|
- Press *Record* and wait until the recording has finished.
|
||||||
- Press *Save* and make sure the specified filename uses a `.dff` extension.
|
- Press *Save* and make sure the specified filename uses a `.dff` extension.
|
||||||
|
@ -27,17 +27,17 @@ Developers will want to use this to see if they can reproduce issues locally. Bu
|
||||||
- Use the *Open* toolbar button to open the `.dff` file that you want to play back. Note that FIFO logs won't appear in your game list. For a more streamlined workflow you might want to use dolphin in batch mode by calling `dolphin-emu -b -e file.dff` from the command line (this will play back the FIFO log and immediately close the emulator once you close the emulation window
|
- Use the *Open* toolbar button to open the `.dff` file that you want to play back. Note that FIFO logs won't appear in your game list. For a more streamlined workflow you might want to use dolphin in batch mode by calling `dolphin-emu -b -e file.dff` from the command line (this will play back the FIFO log and immediately close the emulator once you close the emulation window
|
||||||
- **Note:** If the emulator immediately crashes or shows FIFO errors when opening a `.dff` file, try disabling Dual Core mode. It's known to have some problems at the moment.
|
- **Note:** If the emulator immediately crashes or shows FIFO errors when opening a `.dff` file, try disabling Dual Core mode. It's known to have some problems at the moment.
|
||||||
- Render output is divided in *frames*. Each frame is divided in different *objects*. An object is defined as a group of vertices that are drawn consecutively with the same pipeline configuration.
|
- Render output is divided in *frames*. Each frame is divided in different *objects*. An object is defined as a group of vertices that are drawn consecutively with the same pipeline configuration.
|
||||||
- In the *Play* tab of the Fifo Player dialog, you can adjust which frames will be rendered during playback. Note that skipped frames are rendered (but not shown) nevertheless to ensure resource validity (e.g. for EFB copies) in the following frames.
|
- In the *Play* tab of the FIFO Player dialog, you can adjust which frames will be rendered during playback. Note that skipped frames are rendered (but not shown) nevertheless to ensure resource validity (e.g. for EFB copies) in the following frames.
|
||||||
- Similarly, you can limit the range of rendered objects. This is especially useful when you have a huge scene but are only interested in one single object which is rendered incorrectly.
|
- Similarly, you can limit the range of rendered objects. This is especially useful when you have a huge scene but are only interested in one single object which is rendered incorrectly.
|
||||||
- TODO: Explain Early Memory Updates.
|
- TODO: Explain Early Memory Updates.
|
||||||
- WARNING: Dual Core mode is currently broken when using FifoPlayer. As a workaround, disable DC and set framelimit to a fixed value, e.g. 30.
|
- WARNING: Dual Core mode is currently broken when using FIFO Player. As a workaround, disable DC and set framelimit to a fixed value, e.g. 30.
|
||||||
- tl;dr: Disable Dual Core, Disable XFBs, set framelimit to 30.
|
- tl;dr: Disable Dual Core, Disable XFBs, set framelimit to 30.
|
||||||
|
|
||||||
## How to Analyze a FIFO Log
|
## How to Analyze a FIFO Log
|
||||||
|
|
||||||
This is purely a developer tool because it requires strong knowledge of what GPU registers are and how they are used in the GPU FIFO.
|
This is purely a developer tool because it requires strong knowledge of what GPU registers are and how they are used in the GPU FIFO.
|
||||||
|
|
||||||
- Start FIFO log playback like explained above and open the *Analyze* tab in the Fifo Player dialog
|
- Start FIFO log playback like explained above and open the *Analyze* tab in the FIFO Player dialog
|
||||||
- You should see three columns there: The leftmost one will show you a list of rendered frames. The mid column lists all objects within the selected frame. The right column shows all FIFO commands called for that object. When selecting one of the FIFO commands, a more or less descriptive explanation will be shown at the bottom of the dialog.
|
- You should see three columns there: The leftmost one will show you a list of rendered frames. The mid column lists all objects within the selected frame. The right column shows all FIFO commands called for that object. When selecting one of the FIFO commands, a more or less descriptive explanation will be shown at the bottom of the dialog.
|
||||||
- Note that the FIFO command list is a tad unintuitive: The first command should generally be a vertex draw command (e.g. 0x80) which is the one which actually draws the command, while the FIFO commands after that refer to any state changes after that (i.e. they actually apply to the next object).
|
- Note that the FIFO command list is a tad unintuitive: The first command should generally be a vertex draw command (e.g. 0x80) which is the one which actually draws the command, while the FIFO commands after that refer to any state changes after that (i.e. they actually apply to the next object).
|
||||||
- There's also a search function that allows you to search within the currently shown command list (i.e. not across different objects/frames). It's a bit buggy at the moment, so it takes some time to get used to.
|
- There's also a search function that allows you to search within the currently shown command list (i.e. not across different objects/frames). It's a bit buggy at the moment, so it takes some time to get used to.
|
Loading…
Reference in New Issue