|   |   | 
| (211 intermediate revisions by 10 users not shown) | 
| Line 1: | Line 1: | 
|  | This page describes the structure of the buffer for [[GSP_Shared_Memory|GX command]] 1 withthe registers at [[GPU|0x1EF018E0]]. This buffer is used for GPU commands including OpenGL commands, each 8-byte entry in the buffer is a command. Cmd+0 is the command parameter, and cmd+4 is the command header.
 |  | Merged with [[GPU/Internal_Registers]] | 
|  |   |  | 
|  | === Command Header ===
 |  | 
|  | {| class="wikitable" border="1"
 |  | 
|  | !  Bit
 |  | 
|  | !  Description
 |  | 
|  | |-
 |  | 
|  | | 19-0
 |  | 
|  | | Command ID
 |  | 
|  | |-
 |  | 
|  | | 30-20
 |  | 
|  | | Total words following the command, if any.
 |  | 
|  | |-
 |  | 
|  | | 31
 |  | 
|  | | ?
 |  | 
|  | |}
 |  | 
|  | The first word in the parameter data structure is the command parameter value, the rest of the data structure is from the data following the command. The word after the last data structure word is padding when needed for 8-byte alignment, for the following command.
 |  | 
|  |   |  | 
|  | === Commands ===
 |  | 
|  | {| class="wikitable" border="1"
 |  | 
|  | !  CommandID
 |  | 
|  | !  Parameter
 |  | 
|  | !  Description
 |  | 
|  | |-
 |  | 
|  | | 0x000F0010
 |  | 
|  | | Value is 0x12345678
 |  | 
|  | | This command is always the last command in the buffer.
 |  | 
|  | |-
 |  | 
|  | | 0x000F0110
 |  | 
|  | | Value 0x1
 |  | 
|  | | This command is immediately before CmdID 0x000F0010, this is used elsewhere in the buffer as well.
 |  | 
|  | |-
 |  | 
|  | | 0x000F0111
 |  | 
|  | | Value 0x1
 |  | 
|  | | This command is immediately before CmdID 0x000F0110, however CmdID 0x000F0110 doesn't always follow this command.
 |  | 
|  | |-
 |  | 
|  | | 0x000F0041
 |  | 
|  | | float Z vector
 |  | 
|  | | This sets Z scaling for the current matrix.
 |  | 
|  | |-
 |  | 
|  | | 0x000F0042
 |  | 
|  | | float Y vector
 |  | 
|  | | This sets Y scaling for the current matrix.
 |  | 
|  | |-
 |  | 
|  | | 0x000F0043
 |  | 
|  | | float unknown
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x000F0044
 |  | 
|  | | float X vector
 |  | 
|  | | This sets X scaling for the current matrix.
 |  | 
|  | |-
 |  | 
|  | | 0x801F004D
 |  | 
|  | | First word in parameter structure
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x000F02C0
 |  | 
|  | | <nowiki>0x80000000 | CoordinateType</nowiki>
 |  | 
|  | | This is used immediately before CmdID 0xXXXF02C1. This type field controls the command parameter buffer type.
 |  | 
|  | |-
 |  | 
|  | | 0xXXXF02C1
 |  | 
|  | | First word in the first coordinate entry
 |  | 
|  | | A list of coordinate entries follow this command.
 |  | 
|  | |}
 |  | 
|  |   |  | 
|  | === Coordinate Entry ===
 |  | 
|  | {| class="wikitable" border="1"
 |  | 
|  | !  Index Word
 |  | 
|  | !  Description
 |  | 
|  | |-
 |  | 
|  | | 0
 |  | 
|  | | float X coordinate
 |  | 
|  | |-
 |  | 
|  | | 1
 |  | 
|  | | float Y coordinate
 |  | 
|  | |-
 |  | 
|  | | 2
 |  | 
|  | | float Z coordinate
 |  | 
|  | |}
 |  | 
|  |   |  | 
|  | === Coordinate Types ===
 |  | 
|  | {| class="wikitable" border="1"
 |  | 
|  | !  Value
 |  | 
|  | !  Entries per chunk
 |  | 
|  | !  Description
 |  | 
|  | |-
 |  | 
|  | | 0x00
 |  | 
|  | | 4
 |  | 
|  | | Related to matrix translation?
 |  | 
|  | |-
 |  | 
|  | | 0x04
 |  | 
|  | | 4
 |  | 
|  | | Unknown, this is used immediately after type 0x00.
 |  | 
|  | |-
 |  | 
|  | | 0x08
 |  | 
|  | | 2
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x0A
 |  | 
|  | | 4
 |  | 
|  | | Texture related?
 |  | 
|  | |-
 |  | 
|  | | 0x0B
 |  | 
|  | | 3
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x14
 |  | 
|  | | <=30
 |  | 
|  | | Matrix related?
 |  | 
|  | |-
 |  | 
|  | | 0x4C
 |  | 
|  | | 4
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x50, 0x53, and 0x56
 |  | 
|  | | 1
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x51, 0x54, and 0x57
 |  | 
|  | | 1
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x52, 0x55, and 0x58
 |  | 
|  | | 1
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x59
 |  | 
|  | | 1
 |  | 
|  | | Unknown, the entry data is floats converted from s32s.
 |  | 
|  | |-
 |  | 
|  | | 0x5A
 |  | 
|  | | 2
 |  | 
|  | | ?
 |  | 
|  | |-
 |  | 
|  | | 0x5C
 |  | 
|  | | 1
 |  | 
|  | | ?
 |  | 
|  | |}
 |  |