# GLINT R4® Reference Guide Volume III -Graphics Registers # PROPRIETARY AND CONFIDENTIAL INFORMATION # 3Dlabs® # GLINT R4® Reference Guide Volume III -Graphics Registers # PROPRIETARY AND CONFIDENTIAL INFORMATION **Issue 2** ### **Proprietary Notice** The material in this document is the intellectual property of **3D***labs*. It is provided solely for information. You may not reproduce this document in whole or in part by any means. While every care has been taken in the preparation of this document, **3D***labs* accepts no liability for any consequences of its use. Our products are under continual improvement and we reserve the right to change their specification without notice. **3D***labs* may not produce printed versions of each issue of this document. The latest version will be available from the **3D***labs* web site. **3D***labs* products and technology are protected by a number of worldwide patents. Unlicensed use of any information contained herein may infringe one or more of these patents and may violate the appropriate patent laws and conventions. **3D***labs* is the worldwide trading name of **3D***labs* Inc. Ltd. **3D***labs*, GLINT and PERMEDIA are registered trademarks of **3D***labs* Inc. Ltd. Microsoft, Windows and Direct3D are either registered trademarks or trademarks of Microsoft Corp. in the United States and/or other countries. OpenGL is a registered trademark of Silicon Graphics, Inc. All other trademarks are acknowledged and recognized. © Copyright **3D***labs* Inc. Ltd. 1999. All rights reserved worldwide. Email: info@3dlabs.com Web: http://www.3dlabs.com 3Dlabs Ltd. **3D**labs K.K. Meadlake Place Thorpe Lea Road, Egham Surrey, TW20 8HE United Kingdom Shiroyama JT Mori Bldg 16F 40301 Toranomon Minato-ku, Tokyo, 105, Japan Tel: +81-3-5403-4653 Tel: +44 (0) 1784 470555 Fax: +44 (0) 1784 470699 Fax: +91-3-5403-4646 **3D**labs Inc. 480 Potrero Avenue Sunnyvale, CA 94086, United States Tel: (408) 530-4700 Fax: (408) 530-4701 # **Change History** | Document | Issue | Date | Change | |----------|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 160.5.3 | 1 | 06 October 99 | Creation | | 160.5.3 | 2 | 05 December 99 | ReadMonitorMode, SetDeltaPort; consistent use of GLINT R4 nomenclature; adding app 55 new R4-only registers plus updates, delete P4-only registers; update TextureCoordMode note, add T1Start, add TextureData,add to TextGlyph, add FBHardwareWriteMask; delete FeedbackX, FeedBackY; ReadMonitor logic ops; Reinstate Download Address, Download Data; edit vertex registers to include deprecated fixed format for R4 delta; DMARectangleRead, DMAContinue not readbackable, DeltaMode TargetChip value fixed, Color reg reinstated, Context Dump/restore updated, removed priv. regs FBData & FBSourceData, R4 changes to FilterMode; LBClearDataU and ScanLineOwnership reinstated, other register updates; removed remaining instances of MultiRXBlit bits in Config2D, FillConfig2D; Removed dKsDx & other speculars; deleted FeedbackX and Y from Xref chapter, deleted from Xref Drawpoint, Provoking vertex, TextureLOD, Drawline & Linecoord; added Begin, End to Xref; | | Ta | ble o | f Contents | | |----|-------|---------------------------------|------| | 5 | GRA | APHICS REGISTERS | 5-1 | | 6 | REG | SISTER CROSS REFERENCE | 6-1 | | | 6.1 | Registers Alphabetically Sorted | 6-1 | | | 6.2 | Registers Sorted by Offset | 6-22 | 5 # **Graphics Registers** This chapter lists Permedia4 graphics core ('software') registers in region 0, offset group 0x8000-0xFFFF. Within this group the registers are listed alphanumerically. All other registers are described in chapter 4. Global cross-reference listings in alphanumeric and offset order are available in chapter 6. Register details have the following format information: **Name** The register's name. **Type** The region in which the register functions. **Offset** The offset of this register from the base address of the region. **Format** Can be bitfield or integer. Bit Name Unused **Read** Indicates whether the register bit can be read from. A ✓ mark indicates the register can be read from, a **X** indicates the register bit is not readable. Write Indicates whether the register bit can be written to. A ✓ mark indicates the register can be written to, a X indicates the register bit is not writable. **Reset** The value of the register following hardware reset. **Description** In the register descriptions: **Reserved** Indicates bits that may be used in future members of the PERMEDIA family. To ensure upwards compatibility, any software should not assume a value for these bits when read, and should always write them as zeros. **Not Used/** Indicates bits that are adjacent to numeric fields. These may be used in future members of the PERMEDIA family, but only to extend the dynamic range of these fields. The data returned from a read of these bits is undefined. When a Not Used field resides in the most significant position, a good convention to follow is to sign extend the numeric value, rather than masking the field to zero before writing the register. This will ensure compatibility if the dynamic range is increased in future members of the Permedia family. For enumeration fields that do not specify the full range of possible values, only the specified values should be used. An example of an enumeration field is the comparison field in the DepthMode register. Future members of the PERMEDIA family may define a meaning for the unused values. #### **AALineWidth** NameTypeOffsetFormatAALineWidthR4 Delta0x94C0Float Control register | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-------------------------------| | 031 | LineWidth | 1 | 1 | X | Floating point 32 bit integer | Notes: Defines the width of antialiased lines stored as a floating point number using the absolute value of the width. Lines with a zero width are drawn XXX and lines with a negative width are drawn as a line of the same positive width. Antialiased lines are drawn as rectangles aligned to the direction of the line. #### **AAPointSize** NameTypeOffsetFormatAAPointSizeR4 Delta0x94A0Float Control register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|------------------| | 031 | Point size | ✓ | ✓ | X | Point size value | Notes: Defines the width of antialiased points. In theory any size antialiased point can be defined but in fact the Point Table restricts the diameter of antialiased points from 0.5 to 16.0 in steps of 0.25 (when the antialiasing quality is 4x4) or 0.25 to 8.0 in steps of 0.125 (for 8x8 quality). Points with a zero size draw a single fragment and points with a negative size draw a point of the same positive size. N.B. Alpha blending modes must be set up first. The point size table is enabled in the *UsePointTable* field of the *Render* register. The table is 32 entries deep by 4 bits wide. The unsigned delta values in the table are held as one bit integer and 3 bits fraction. From the host's view the table is organised as four 32 bit words so the overhead of downloading when the point size changes is minimal. Only the parts of the table needed for a particular point size need to be loaded. The format of the points table is as follows: #### **Point Size Table** | | | 24 | | 16 | | 8 | | 0 | |-------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | PointTable0 | P <sub>7</sub> | P <sub>6</sub> | P <sub>5</sub> | P <sub>4</sub> | Р3 | P <sub>2</sub> | P <sub>1</sub> | P <sub>0</sub> | | PointTable1 | P <sub>15</sub> | P <sub>14</sub> | P <sub>13</sub> | P <sub>12</sub> | P <sub>11</sub> | P <sub>10</sub> | P9 | P8 | | PointTable2 | P <sub>23</sub> | P <sub>22</sub> | P <sub>21</sub> | P <sub>20</sub> | P <sub>19</sub> | P <sub>18</sub> | P <sub>17</sub> | P <sub>16</sub> | | PointTable3 | P <sub>31</sub> | P <sub>30</sub> | P29 | P <sub>28</sub> | P <sub>27</sub> | P <sub>26</sub> | P <sub>25</sub> | P <sub>24</sub> | # AlphaBlendAlphaModeAnd AlphaBlendAlphaModeOr Name Type Offset **Format** AlphaBlendAlphaMode Alpha Blend 0x AFA8 Bitfield AlphaBlendAlphaModeAnd Bitfield Logic Mask Alpha Blend 0x AD30 AlphaBlendAlphaModeOr Alpha Blend 0x AD38 Bitfield Logic Mask Control registers | Bits | Name | Read <sup>1</sup> | Write | Reset | Description | |------|---------------------|-------------------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | ✓ | X | When set causes the fragment's alpha to be alpha blended under control of the remaining bits in this register. When clear the fragment alpha remains unchanged (but may later to affected by the chroma test). | | 14 | SourceBlend | 1 | 1 | X | This field defines the source blend function to use. | | 57 | DestBlend | 1 | 1 | X | This field defines the destination blend function to use. | | 8 | Source<br>TimesTwo | 1 | <b>√</b> | х | This bit, when set causes the source blend result to be multiplied by two before it is combined with the dest blend result. When this bit is clear no multiply occurs. | | 9 | DestTimes<br>Two | <b>√</b> | ✓ | X | This bit, when set causes the dest blend result to be multiplied by two before it is combined with the source blend result. When this bit is clear no multiply occurs. | | 10 | Invert Source | 1 | 1 | x | This bit, when set, causes the incomming source data to be inverted before any blend operation takes place. | | 11 | Invert Dest | 1 | 1 | X | This bit, when set, causes the incomming dest data to be inverted before any blend operation takes place. | | 12 | NoAlpha<br>Buffer | 1 | 1 | X | When this bit is set the source alpha value is always set to 1.0. This is typically used when no retained alpha buffer is present but will also override any retained alpha value if one is present. Color formats with no alpha field defined automatically have their alpha value set to 1.0 regardless of the state of this bit. | | 13 | Alpha Type | 1 | <b>√</b> | X | This bit selects which set of equations are to be used for the alpha channel. 0 = OpenGL 1 = Apple | | 14 | Alpha<br>Conversion | 1 | ✓ | X | This bit selects how alpha component less than 8 bits wide are converted to 8 bit wide values prior to the alpha blend calculations. The options are $0 = \text{Scale}$ 1 = Shift | $<sup>^{1}\,\</sup>mathrm{Logic}$ Op register readback is via the main register. | 15 | Constant | 1 | 1 | X | This bit, when set, forces the Source color to come | |------|---------------|---|---|---|---------------------------------------------------------| | | Source | | | | from the AlphaSourceColor register (in 8888 format) | | | | | | | instead of the framebuffer. | | | | | | | 0 = Use framebuffer alpha | | | | | | | 1 = Use AlphaSourceColor register alpha value. | | 16 | Constant Dest | 1 | 1 | X | This bit, when set, forces the destination color to | | | | | | | come from the AlphaDestColor register (in 8888 | | | | | | | format) instead of the fragment's color. | | | | | | | 0 = Use fragment's alpha. | | | | | | | 1 = Use AlphaDestColor register alpha value | | 1719 | Operation | 1 | 1 | X | This field selects how the source and destination blend | | | | | | | results are to be combined. The options are: | | | | | | | 0 = Add $1 = Subtract (i.e. S - D)$ | | | | | | | 2 = Subtract reversed (i.e. D - S) | | | | | | | 3 = Minimum $4 = Maximum$ | Notes The Alpha Conversion bit selects the conversion method for alpha values read from the framebuffer. - The Scale method linearly scales the alpha values to fill the full range of an 8 bit value. This method is preferable when, for example, downloading an image with fewer bits per pixel into a deeper (i.e. more bits per pixel) framebuffer. - The Shift method just left shifts by the appropriate amount to make the component 8 bits wide. This method is preferable when blending into a dithered framebuffer as it preserves the framebuffer alpha when fragment alpha does not contribute to it. Alpha is controlled separately from color to allow, for example, the situation in antialiasing where it represents coverage - this must be linearly scaled to preserve the 100% covered state. For information on the implementation of specific belnd interpolations etc. refer to the *Permedia4 Programer's Guide*, volume II, Source Blending Functions The logic operator versions of the mode command behave the same way as the command but the new mode is AND'd or OR'd with the former mode before replacing it. The table below shows the different color modes supported. In the R, G, B and A columns the nomenclature $\underline{n@m}$ means this component is n bits wide and starts at bit position m in the framebuffer. The least significant bit position is 0 and a dash in a column indicates that this component does not exist for this mode. In the case of the RGB formats where no Alpha is shown then the alpha field is set to 255. In this case the *NoAlphaBuffer* bit in the **AlphaBlendAlphaMode** register should be set which causes the alpha component to be set to 255. Two color ordering formats are supported, namely ABGR and ARGB, with the right most letter representing the color in the least significant part of the word. This is controlled by the Color Order bit in the *AlphaBlendColorMode* register, and is easily implemented by just swapping the R and B components after conversion into the internal format. The only exception to this are the 3:3:2 formats where the actual bit fields extracted from the framebuffer data need to be modified as well because the R and B components are differing widths. CI processing is not effected by this swap and the result is always on internal R channel. The format to use is held in the *AlphaBlendColorMode* register. Note that in OpenGL the alpha blending is not defined for CI mode.. When converting a Color Index value to the internal format any unused bits are set to zero | | | | | | Interna | l Color Ch | annels | |----|--------|-------|---------|------|---------|------------|--------| | | Format | Color | Name | R | G | В | Α | | | | Order | | | | | | | | 0 | BGR | 8:8:8:8 | 8@0 | 8@8 | 8@16 | 8@24 | | | 1 | BGR | 4:4:4:4 | 4@0 | 4@4 | 4@8 | 4@12 | | С | 2 | BGR | 5:5:5:1 | 5@0 | 5@5 | 5@10 | 1@15 | | О | 3 | BGR | 5:6:5 | 5@0 | 6@5 | 5@11 | - | | 1 | 4 | BGR | 3:3:2 | 3@0 | 3@3 | 2@6 | = | | О | 0 | RGB | 8:8:8:8 | 8@16 | 8@8 | 8@0 | 8@24 | | u | 1 | RGB | 4:4:4:4 | 4@8 | 4@4 | 4@0 | 4@12 | | r | 2 | RGB | 5:5:5:1 | 5@10 | 5@5 | 5@0 | 1@15 | | | 3 | RGB | 5:6:5 | 5@11 | 6@5 | 5@0 | - | | | 4 | RGB | 3:3:2 | 3@5 | 3@2 | 2@0 | = | | CI | 15 | X | CI8 | 8@0 | 0 | 0 | 0 | # AlphaBlendColorMode AlphaBlendColorModeAnd AlphaBlendColorModeOr | Name | Type | Offset | Format | |------------------------|-------------------|---------|---------------------| | AlphaBlendColorMode | Alpha Blend | 0x AFA0 | Bitfield | | AlphaBlendColorModeAnd | Alpha Blend | 0x ACB0 | Bitfield Logic Mask | | AlphaBlendColorModeOr | Alpha Blend | 0x ACB8 | Bitfield Logic Mask | | - | Control registers | | | | Bits | Name | Read <sup>2</sup> | Write | Reset | Description | |------|--------------------|-------------------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | V | ~ | x | When set causes the fragment's color to be alpha blended under control of the remaining bits in this register. When clear the fragment color remains unchanged (but may later to effected by the chroma test). | | 14 | SourceBlend | ~ | • | X | This field defines the source blend function to use. See the table in the <i>AlphaBlendColorMode</i> register for the possible options | | 57 | DestBlend | ~ | • | x | This field defines the destination blend function to use. See the table in the <i>AlphaBlendColorMode</i> register for the possible options | | 8 | Source<br>TimesTwo | ~ | • | x | This bit, when set causes the source blend result to be multiplied by two before it is combined with the dest blend result. When this bit is clear no multiply occurs | | 9 | DestTimes<br>Two | ~ | ~ | X | This bit, when set causes the dest blend result to be multiplied by two before it is combined with the source blend result. When this bit is clear no multiply occurs | $<sup>^2\,\</sup>mathrm{Logic}$ Op register readback is via the main register | 10 | InvertSource | ~ | ~ | X | This bit, when set, causes the incomming source data to be inverted before any blend operation takes place | |------|---------------------|---|----------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 | InvertDest | ~ | ~ | X | This bit, when set, causes the incomming dest data to be inverted before any blend operation takes place | | 1215 | Color Format | ~ | - | Х | This field defines framebuffer color formats. See the table in the <i>AlphaBlendColorMode</i> register for the possible options | | 16 | ColorOrder | ~ | ~ | Х | This bit selects the color order in the framebuffer: 0 = BGR 1 = RGB | | 17 | Color<br>Conversion | V | ~ | X | This bit selects how color components less than 8 bits wide are converted to 8 bit wide values prior to the alpha blend calculations. The options are 0 = Scale 1 = Shift | | 18 | Constant<br>Source | • | <b>'</b> | X | This bit, when set, forces the Source color to come from the <i>AlphaSourceColor</i> register (in 8888 format) instead of the framebuffer. 0 = Use framebuffer 1 = Use AlphaSourceColor register | | 19 | ConstantDest | V | ~ | x | This bit, when set, forces the destination color to come from the <i>AlphaDestColor</i> register (in 8888 format) instead of the fragment's color. 0 = Use fragment's color. 1 = Use <i>AlphaDestColor</i> register. | | 2023 | Operation | • | <b>V</b> | x | This field selects how the source and destination blend results are to be combined. The options are: O Add Subtract (i.e. S - D) Subtract reversed (i.e. D - S) Minimum Maximum | | 24 | SwapSD | ~ | ~ | X | This bit, when set causes the source and destination pixel values to be swapped. The main use for this is to allow a downloaded color value to be in a format other than 8888 and use this unit to do color conversion. | Notes AlphaBlendColor combines the fragment's Color with the Color stored in the framebuffer using the alpha blend equations, to create lighting or translucncy effects for example. Alpha blending only works for pixels stored in the RGBA format (since Alpha values are not specified in color-index mode). After blending is done the new blended Color replaces the former Color. If alpha blending is disabled then the Color field passes the alpha blend unchanged. For information on the implementation of specific belnd interpolations etc. refer to the *Permedia4 Programer's Guide*, volume II, Source Blending Functions The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # AlphaDestColor | Name | Type | Offset | Format | |----------------|------------------|--------|----------| | AlphaDestColor | Alpha Blend | 0xAF88 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | | | | | | | | 07 | R | 1 | ✓ | X | Red | | 815 | G | ✓ | 1 | X | Green | | 1623 | В | ✓ | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: This register holds the destination color to use instead of the fragment color when ConstantDest (in *AlphaBlendcolorMode* or *AlphaBlendAlphaMode*) is enabled. Each color component has a separate boundary held as an unsigned 8-bit number from Red (least significant bit) to Alpha. # **AlphaSourceColor** | Name | Type | Offset | Format | |------------------|------------------|--------|---------| | AlphaSourceColor | Alpha Blend | 0xAF80 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 1 | 1 | X | Red | | 815 | G | ✓ | 1 | x | Green | | 1623 | В | 1 | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: This register holds the source color to use instead of the framebuffer color when ConstantSource (in AlphaBlendcolorMode or AlphaBlendAlphaMode) is enabled. Each color component has a separate boundary held as an unsigned 8-bit number from Red (least significant bit) to Alpha. # **AlphaTestMode** AlphaTestModeAnd AlphaTestModeOr Name Type Offset **Format** 0x 8800 Bitfield AlphaTestMode AlphaBlend Alpha Test Mode AndAlphaBlend Bitfield Logic Mask 0x ABF0 AlphaBlend Bitfield Logic Mask Alpha Test Mode Or0x ABF8 Control registers | Bits | Name | Read <sup>3</sup> | Write | Reset | Description | |------|-----------|-------------------|----------|-------|----------------------------------------------------------| | 0 | Enable | <b>V</b> | <b>/</b> | X | When set causes the fragment's alpha value to be | | | | | | | tested under control of the remaining bits in this | | | | | | | register. If the alpha test fails then the fragment is | | | | | | | discarded. When this bit is clear the fragment alway | | | | | | | passes the alpha test. | | | | | | | 0 = Disable $1 = Enable$ | | 13 | Compare | <b>/</b> | <b>/</b> | X | This field defines the unsigned comparison function to | | | _ | | | | use. The options are: | | | | | | | 0 = Never $1 = Less$ | | | | | | | 2 = Equal $3 = Less Equal$ | | | | | | | 4 = Greater 5 = Not Equal | | | | | | | 6 = Greater Equal 7 = Always | | | | | | | The comparison order is as follows: | | | | | | | result = fragment, Alpha Compare Function, | | | | | | | reference, Alpha. | | 411 | Reference | <b>V</b> | <b>/</b> | X | This field holds the 8 bit reference alpha value used in | | | | | | | the comparison. | | 1231 | Unused | 0 | 0 | X | | Notes The Alpha Test, if enabled, compares the alpha value of a fragment, after coverage weighting, against a reference value and if the compare passes the fragment is allowed to continue. If the comparison fails the fragment is culled and will not be drawn. <sup>&</sup>lt;sup>3</sup> Logic Op register readback is via the main register ## AntialiasMode AntialiasModeAnd AntialiasModeOr NameTypeOffsetFormatAntialiasModeAlpha Test0x 8808Bitfield Control registers AntialiasModeAnd Alpha Test 0x ABF0 Bitfield Logic Mask AntialiasModeOr Alpha Test 0x ABF8 Bitfield Logic Mask | Bits | Name | Read <sup>4</sup> | Write | Reset | Description | |------|-------------|-------------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | ~ | x | When set causes the fragment's alpha value to be scaled under control of the remaining bits in this register and the coverage value. When this bit is clear the fragment's alpha value is not changed. 0 = Disable 1 = Enable | | 1 | Color Mode | ~ | • | X | This bit defines the color format the fragment's color is in: 0 = RGBA 1 = CI | | 2 | Scale Color | ~ | ~ | X | This bit, when set allows the coverage value to scale the RGB components as well as the alpha component. When this bit is reset only the alpha component is scaled. This allows antialiasing of pre multiplied images used in compositing. | | 331 | Unused | 0 | 0 | X | | Notes: The register controls the operation of antialiasing. When the unit is enabled: - In Color Index (CI) mode the bottom 4 bits of the color index of a fragment is replaced by the coverage value scaled by 15/256, where the result is rounded to the nearest integer. - In RGBA mode the alpha component of a fragment is multiplied by the coverage value, but the RGB components are not changed. When antialiased primitives are being rendered the fragment's color is weighted by the percentage area of the pixel the fragment covers. An approximation to the area covered is calculated. If antialiasing is disabled then the color is passed onto the alpha test stage unchanged. Note that the CoverageEnable bit in the *Render* command must also be set to enable antialiasing. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. **3D**labs Proprietary and Confidential 5-9 <sup>&</sup>lt;sup>4</sup> Logic Op register readback is via the main register only # AreaStippleMode AreaStippleModeAnd AreaStippleModeOr NameTypeOffsetFormatAreaStippleModeStipple0x81A0Bitfield AreaStippleModeAnd Stipple 0xABD0 Bitfield Logic Mask AreaStippleModeOr Stipple 0xABD8 Bitfield Logic Mask Control registers | Bits | Name | Read <sup>5</sup> | Write | Reset | Description | |------|---------------------------|-------------------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | • | X | This field, when set, enables area stippling. The AreaStippleEnable bit in <i>Render</i> must also be set for this to have an effect. | | 13 | X address select: | ~ | ~ | x | 0 = 1 bit $1 = 2 bit$ $2 = 3 bit$ $3 = 4 bit$ $4 = 5 bit$ | | 46 | Y address select: | ~ | <b>'</b> | x | 0 = 1 bit $1 = 2 bit$ $2 = 3 bit$ $3 = 4 bit$ $4 = 5 bit$ | | 711 | X Offset | • | • | X | This field holds the offset to add to the X value before it is used to index into the stipple bit. This allows a window relative stipple pattern to be selected when the coordinates are given in screen relative format. | | 1216 | Y Offset | • | ~ | X | This field holds the offset to add to the Y value before it is used to index into the area stipple pattern table. This allows a window relative stipple pattern to be selected when the coordinates are given in screen relative format. | | 17 | Invert Stipple<br>Pattern | ~ | ~ | X | 0 = No Invert 1 = Invert | | 18 | Mirror X | <b>V</b> | ~ | X | 0 = No Mirror 1 = Mirror | | 19 | Mirror Y | <b>V</b> | <b>/</b> | X | 0 = No Mirror 1 = Mirror | | 20 | OpaqueSpan | ~ | ~ | x | This bit, when set, allows the area stipple pattern to modify the color mask, otherwise the pixel mask is modified. | | 2125 | XTableOffset | V | ~ | x | This field allows a sub area stipple pattern to be extracted from the area stipple table, i.e. the area stipple table is treated as a cache of smaller stipple patterns. | | 2630 | YTableOffset | V | <b>V</b> | X | This field allows a sub area stipple pattern to be extracted from the area stipple table, i.e. the area stipple table is treated as a cache of smaller stipple patterns. | | 31 | Unused | 0 | 0 | X | | 5-10 Proprietary and Confidential **3D**labs <sup>&</sup>lt;sup>5</sup> Logic Op register readback is via the main register only Notes: 1. This register controls Area Stippling. This involves applying the correct stipple pattern (mask) which can also be mirrored or inverted. The least significant bits of the fragment's XY coordinates index into a 2D stipple pattern. If the selected bit is set the fragment passes the test, otherwise it fails. An offset is added to the XY coordinate and the result optionally mirrored and/or inverted before the stipple bit is accessed. - **2.** Both the AreaStippleEnable bit in the *Render* command and the enable in the *AreaStippleMode* register must be set, to enable the area stipple test. - 3. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # AreaStipplePattern [0...15] AreaStipplePattern [16...31] NameTypeOffsetFormatAreaStipplePatternStipple0x8200 – 82F8BitmaskControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-----------------------------------| | 031 | Mask | 1 | 1 | X | 32 bit mask for area pattern data | Notes: These 32 registers provide the bitmask which enables and disables corresponding fragments for drawing when rasterizing a primtive with area stippling. They hold the LSBs and MSBs of area pattern data. The Y' value in the StippleMode register selects the row in the stipple RAM (row zero is at AreaStipplePattern[0]) and this is the first value of the AreaStippleMask. #### **AStart** NameTypeOffsetFormatAStartColor0x87C8Fixed point numberControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | 1 | X | | | 1523 | Integer | ✓ | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the initial Alpha value of a vertex when in Gouraud shading mode. The format is 24 bit 2's complement fixed point numbers in 9.15 format. # **BackgroundColor** | Name | Type | Offset | Format | |-----------------|------------------|--------|---------| | BackgroundColor | Logic Ops | 0xB0C8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Background<br>Color | ✓ | ✓ | X | 32 bit integer | Notes: With **ForegroundColor**, holds the foreground and background color values. A background pixel is a pixel whose corresponding bit in the color mask is zero. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. ### **BasePageOfWorkingSet** | Name | Type | Offset | Format | |----------------------|------------------|--------|---------| | BasePageOfWorkingSet | Texture Read | 0xB4C8 | Integer | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|--------------------------------------| | 015 | Page number | 1 | 1 | X | 16 bit integer value from 0 to 65535 | | 1531 | Unused | 0 | 0 | X | | Notes: Holds the page number of the start of the region of memory to be used as the working set. This is measured in units of 4K bytes from 0 (the first byte address with respect to R4's view of the memory map). This allows the Physical Page Allocation Table to be smaller as it doesn't have to include low memory locations reserved for Z buffer, color buffers, etc. The legal range of values is 0...65535. Before any logical or virtual texture management can be done there are a number of areas which need to be initialised (in addition to the usual mode, etc. register initialisation): - Space for the Logical Texture Page Table must be reserved in the local buffer and the table initialised to zero. The LogicalTexturePageAddr and LogicalTexturePageTableLength must be set up. - Space for the working set must be reserved in the local buffer and/or framebuffer. This need not be physically consecutive pages. The BasePageOfWorkingSet register is set up. # BasePageOfWorkingSetHost NameTypeOffsetFormatBasePageOfWorkingSetTexture Read0xB4E0Integer Host Control register | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-----------------------| | 019 | Page number | 1 | 1 | X | 20 bit integer value. | Notes: This 20 bit register holds the page number of the start of the region of host memory to be used as the working set. This is a 256MByte region and can be positioned anywhere in the 4GByte host address range. This is measured in units of 4K bytes from 0 (the first byte address in the physical memory map). ### **Begin** NameTypeOffsetFormatBeginR4 Delta0x9590Bitfield Command Rregister | Bits | Name | Read | Write | Reset | Description | |------|-----------------------|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | AreaStipple<br>Enable | X | ~ | X | When compatible with primitive type, enables area stippling of the fragments produced during rasterisation in the Stipple Unit. Note that area stipple in the Stipple Unit must be enabled as well for stippling to occur. When this bit is reset no area stippling occurs irrespective of the setting of the area stipple enable bit in the Stipple Unit. This bit is useful to temporarily force no area stippling for this primitive. | | 1 | LineStipple<br>Enable | × | ~ | X | When compatible with primitive type, enables line stippling of the fragments produced during rasterisation in the Stipple Unit. Note that line stipple in the Stipple Unit must be enabled as well for stippling to occur. When this bit is reset no line stippling occurs irrespective of the setting of the line stipple enable bit in the Stipple Unit. This bit is useful to temporarily force no line stippling for this primitive. | | 2 | ResetLine<br>Stipple | × | ~ | x | Overridden when incompatible with the primitive type. Generated by the vertex unit or supplied by the Gamma GeomTriangle or GeomQuad registers. | | 3 | FastFillEnable | X | <b>~</b> | X | Ignorced, disabled. | | 4, 5 | Unused | 0 | 0 | X | | 5-14 | 6, 7 | Primitive Type | × | ~ | X | Generally overridden (except where the <i>Type</i> and PolyMode settings are compatible) since support for | |----------|-------------------|---|----------|----------|------------------------------------------------------------------------------------------------------------| | | | | | | Gamma types in the Type field is much more extensive | | 8 | Antialiase | × | ~ | X | Qualifies the Antialiase enable held for each primitive | | | Enable | ^ | | A | by the Delta unit. When both are set, causes the | | | Lilabic | | | | generation of sub scanline data and the coverage value | | | | | | | to be calculated for each fragment. The number of | | | | | | | sub pixel samples to use is controlled by the | | | | | | | | | 9 | Α | | | | AntialiasingQuality bit. | | 9 | Antialiasing | × | ~ | X | Ignored - the information is held in the Delta unit on | | 10 | Quality | | | | a per-primitive basis. | | 10 | UsePoint Table | X | <b>/</b> | X | Ignored - generated locally when antialiasing points | | 11 | SyncOnBit<br>Mask | × | ~ | X | Ignored - disabled | | 12 | SyncOnHost | X | <b>V</b> | | Ignored - disabled | | | Data | | | | | | 13 | TextureEnable | X | <b>V</b> | X | Passed through Delta unit, also enables texturing in | | | | | | | Geometry and Lighting units. | | 14 | FogEnable | X | <b>V</b> | X | Passed through Delta unit, also enables fog calculation | | | | | | | to be performed in the Geometry unit. | | 15 | Coverage | X | V | X | Ignored on input and Set on output if the primitive is | | | Enable | | | | to be antialiased. | | 16 | SubPixel | X | ~ | X | Passed through Delta unit but modifies rasterizer | | | Correction | | | | setup. | | | Enable | | | | When set enables the sub pixel correction of the | | | | | | | colour, depth, fog and texture values at the start of a | | | | | | | scanline. When this bit is reset no correction is done | | | | | | | at the start of a scanline. Sub pixel corrections are | | | | | | | only applied to aliased trapezoids. | | 17 | Reserved | 0 | 0 | X | <del></del> | | 18 | SpanOperation | X | V | x | Passed through R4 Delta with no effect. | | _ | T | | | | This bit, when clear, indicates the writes are to use the | | | | | | | constant colour found in the previous FBBlockColour | | | | | | | message. When this bit is set write data is variable and | | | | | | | is either provided by the host (i.e. SyncOnHostData is | | | | | | | set) or is read from the framebuffer. | | 19 | Unused | 0 | 0 | x | | | 2026 | dErr | | <u>~</u> | <u>x</u> | This field holds the subpixel error to apply on the first | | 2020 | 31311 | X | _ | - | scanline. The subpixel correction occurs when the | | | | | | | SubPixelCorrection message is sent by the rasteriser | | | | | | | and the value here just allows the multiplication to be | | | | | | | pipelined. | | 27 | FBSourceRead | _ | • | <u>x</u> | This bit, when set enables source buffer reads to be | | <u> </u> | Enable | X | <u>~</u> | <u>A</u> | done in the Framebuffer Read Unit. Note that the | | | LATABLE | | | | Framebuffer Read Unit must be suitably enabled as | | | | | | | well for the source read to occur. | | | | | | | When this bit is reset no source reads occur | | | | | | | irrespective of the setting of the Framebuffer Read | | | | | | | | | | | | | | <u>Unit controls.</u> | | 2831 | Primitive type | × | ~ | X | This field sets up the primitive type to process on receiving each new vertex. It has the following value | | |------|----------------|---|---|---|-----------------------------------------------------------------------------------------------------------|-----------------| | | | | | | 0=null | 6=TriangleStrip | | | | | | | 1=points | 7=TriangleFan | | | | | | | 2=lines | 8=Quads | | | | | | | 3=lineLoop | 9=QuadStrip | | | | | | | 4=lineStrip | 10=Polygon | | | | | | | 5=Triangles | | | | | | | | | | Notes: The **Begin** command, as in OGL, starts a series of vertices by specifying the primitive type and various enables. The primitive type is held in the upper 4 bits and the lower bits hold the same fields as the **Render** command. The R4 **Begin** command is integrated with the Gamma Delta **Begin** command when the R4 is acting as rasterizer for a Gamma geometry accellerator. #### **BitMaskPattern** | Name | Type | Offset | Format | |----------------|---------------|-----------------|---------| | BitMaskPattern | Rasterizer | 0x8068 | Integer | | | Command and C | ontrol register | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Bitmask | X | 1 | X | 32 bit value | Notes: Value used to control the bit mask stipple operation (if enabled). Fragments are accepted or rejected based on the current BitMask test modes defined by the **RasterizerMode** register. Note: the *SyncOnBitmask* bit in the Render command must also be enabled. The bit mask is written in the **BitMaskPattern** register and can be modified in a number of ways before being used. These modifications are applied in the order below and are enabled using the corresponding bit in the **RasterizerMode** register. As each pixel in the primitive is generated one bit of the bit mask is consumed. Internally the bits are always consumed from the least significant end towards the most significant end, however the *MirrorBitMask* bit effectively reverses this order. | В | BitMaskPattern Application Bits in the RasterizerMode Register | | | | | |-----------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Mode | Raster- | Description (See RasterizerMode register for details) | | | | | | izer | | | | | | | Mode | | | | | | | Bit no. | | | | | | ByteSwapBitMask | 7,8 | Byte swaps the bit mask pattern as directed by the <i>BitMaskByteSwapMode</i> . This allows the bitmasks used internally for Windows or WindowsNT to be used directly | | | | | MirrorBitMask | 0 | The bit mask pattern is mirrored so bit 0 become bit 31, bit 1 becomes bit 30, etc. Bit 0 is the least significant bit. This feature allows the left most pixel in a window to be assigned to the most or least significant bit in the bit mask pattern. | | | | | InvertBitMask | 1 | The bit mask pattern is inverted before it is used so that fragments associated with '0' bits are now written instead of fragments associated with '1' bits. The inversion is useful when two passes are needed to draw the primitive, for example to draw the foreground pixels using a different logical operation to the background pixels for a character. | | | | | BitMaskPacking | 9 | Selects whether the bit mask pattern is packed so that adjacent rows butt together to minimise the number of words to transfer for the whole pattern. If not then a new bit mask pattern is required for every scanline. For span fills a new bit mask pattern <i>must</i> be provided at the start of every scanline. | | | | | BitMaskOffset | 1014 | Determines the first bit to use in the bit mask pattern for the first bit mask pattern on a scanline. Subsequent bit masks will always start at bit 0 until the next scanline is encountered. The default is zero and the bit position refers to the position <i>after</i> any byte swapping or mirroring has been done. This allows the source and destination rectangle alignments to be different. | | | | # BorderColor0 BorderColor1 | Name | Type | Offset | Format | |--------------|------------------|--------|----------| | BorderColor0 | Texture | 0x84A8 | Bitfield | | BorderColor1 | Texture | 0x84F8 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | | | | | | | | 07 | R | 1 | 1 | X | Red | | 815 | G | 1 | 1 | X | Green | | 1623 | В | 1 | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: If a border has not been provided in the texture map, but a border texel is needed, they are taken from the BorderColor registers. BorderColor0 holds the border color to be used for Texels T0...T3. Its format is red in byte 0, green in byte 1, blue in byte 2 and alpha in byte 3. BorderColor1 holds the border color to be used for Texels T4...T7. Its format is identical. #### **BStart** | Name | Type | Offset | Format | |--------|-------------------------|--------|--------------------| | BStart | Color | 0x87B0 | Fixed point number | | | $C \cdot 1 \cdot \cdot$ | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-------------| | 014 | Fraction | <b>√</b> | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the initial Blue value for a vertex when in Gouraud shading mode. The value is 24 bit 2's complement fixed point numbers in 9.15 format. ### ChromaFailColor | Name | Type | Offset | Format | | |-----------------|------------------|--------|----------|--| | ChromaFailColor | Color | 0xAF98 | Bitfield | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 1 | 1 | X | Red | | 815 | G | 1 | 1 | X | Green | | 1623 | В | 1 | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: This register holds the chroma color to use when the chroma test is enabled and the chroma operation is substitute fail color. Its format is 8 bit ABGR components packed into a 32 bit word with R in the LS byte. #### ChromaLower | Name | Type | Offset | Format | | |-------------|------------------|--------|----------|--| | ChromaLower | Color | 0x8F10 | Bitfield | | | | Control register | • | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | | | | | | | | 07 | R | 1 | 1 | x | Red | | 815 | G | 1 | 1 | X | Green | | 1623 | В | 1 | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: This register holds the lower bound color for the chroma test. Each color component has a seperate boundary held as an unsigned 8 bit number with Red in the lower byte, then green, then blue and finaly in the upper byte alpha. The test is inclusive so the fragment is in range if all its components are less than or equal to the upper bound and greater than or equal to the lower bound. The options are to reject the fragment so nothing gets drawn or the color is replaced by the value held in the ChromaPassColor or ChromaFailColor registers. Note this is different to GLINT MX #### **ChromaPassColor** | Name | Type | Offset | Format | | |-----------------|------------------|--------|----------|--| | ChromaPassColor | Color | 0xAF90 | Bitfield | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | | | | | | | | 07 | R | 1 | 1 | X | Red | | 815 | G | 1 | ✓ | X | Green | | 1623 | В | 1 | ✓ | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: This register holds the chroma color to use when the chroma test is enabled and the chroma operation is substitute pass color. Its format is 8 bit ABGR components packed into a 32 bit word with R in the LS byte. ## ChromaTestMode ChromaTestModeAnd ChromaTestModeOr Name Type Offset **Format** Bitfield Chroma Test ModeAlpha Blend 0x8F18 ChromaTestModeAnd Alpha Blend Bitfield Logic Mask 0xACC0 Alpha Blend Bitfield Logic Mask ChromaTestModeOr 0xACC8 Control registers | Bits | Name | Read <sup>6</sup> | Write | Reset | Description | |------|------------|-------------------|-------|-------|-------------------------------------------------------| | 0 | Enable | 1 | 1 | X | When set enables chroma testing under control of the | | | | | | | remaining bits in this register. When clear no chroma | | | | | | | test is done. | | 12 | Source | 1 | 1 | X | This field selects which color (after any suitable | | | | | | | conversion) is to be used for the chroma test. The | | | | | | | values are: | | | | | | | 0 = FBSourceData | | | | | | | 1 = FBData | | | | | | | 2 = Input Color (from fragment) | | | | | | | 3 = Output Color (after any alpha | | | | | | | blending) | | 34 | PassAction | 1 | 1 | X | This field defines what action is to be taken if the | | | | | | | chroma test passes (and is enabled). The options are: | | | | | | | 0 = Pass | | | | | | | 1 = Reject | | | | | | | 2 = Substitute ChromaPassColor | | | | | | | 3 = Substitute ChromaFailColor | | 56 | FailAction | 1 | 1 | X | This field defines what action is to be taken if the | | | | | | | chroma test fails (and is enabled). The options are: | | | | | | | 0 = Pass | | | | | | | 1 = Reject | | | | | | | 2 = Substitute ChromaPassColor | | | | | | | 3 = Substitute ChromaFailColor | | 7 31 | Unused | 0 | 0 | v | | Notes: Used to test the fragment's color against a range of colors after alphablending. The chroma test is enabled by the enable bit (0) in the register. Note: incompatible with MX programming. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. **3D**labs Proprietary and Confidential 5-19 <sup>&</sup>lt;sup>6</sup> Logic Op register readback is via the main register only ### ChromaUpper | Name | Type | Offset | Format | | |-------------|------------------|--------|----------|--| | ChromaUpper | Color | 0x8F08 | Bitfield | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 1 | 1 | x | Red | | 815 | G | 1 | 1 | X | Green | | 1623 | В | 1 | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | This register holds the upper bound color for the chroma test. Each color compoent has a seperate boundary held as an unsigned 8 bit number with Red in the lower byte, then greeen, then blue and finaly in the upper byte alpha. The test is inclusive so the a fragment is in range if all its components are less than or equal to the upper bound and greater than or equal to the lower bound. The options are to reject the fragment so nothing gets drawn or the color is replaced by the value held in the ChromaPassColor or ChromaFailColor registers. Note this is different to GLINT MX #### Color | Name | Type | Offset | Format | |-------|------------------|---------------|----------| | Color | Color | 0x8750 | Bitfield | | | Control register | $\mathcal{S}$ | | | Bits | Name | Read <sup>7</sup> | Write | Reset | Description | |------|-------|-------------------|----------|-------|-------------| | 07 | Red | × | ~ | x | | | 815 | Green | X | <b>v</b> | X | | | 1623 | Blue | X | <b>v</b> | X | | | 2431 | Alpha | X | <b>V</b> | X | | Notes: The Color register is supported primarily for backwards compatibility. It may be used to provide input to the Rasterizer during image download but cannot be written to as an alternative to ConstantColor for rendering flat shaded depth-buffered primitives. Note: The Color register cannot be saved dring context switch. The Color DDA must be disabled when using the Color register. For CI mode coloring the CI is placed in bits 0...7. If less than 8 bits it should be shifted to the MSB end and the LSBs set to 0. <sup>&</sup>lt;sup>7</sup> Logic Op register readback is via the main register only 5-21 # ColorDDAMode ColorDDAModeAnd ColorDDAModeOr | Name | Type | Offset | Format | |-----------------|-------------------|--------|---------------------| | ColorDDAMode | Color | 0x87E0 | Bitfield | | ColorDDAModeAnd | Color | 0xABE0 | Bitfield Logic Mask | | ColorDDAModeOr | Color | 0xABE8 | Bitfield Logic Mask | | | Control registers | | _ | | Bits | Name | Read <sup>8</sup> | Write | Reset | Description | |------|---------|-------------------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | <b>✓</b> | <b>✓</b> | X | This bit, when set, causes the current color to be generated. | | 1 | Shading | ✓ | ✓ | x | Selects the shading mode. The two options are: 0 = Flat – the color is taken from the Constant Color register. 1 = Gouraud – the color is taken from the DDAs. | | 231 | Unused | 0 | 0 | X | | Notes: The ColorDDAMode register controls the operation of the Color DDA unit using the Enable and Shading bits. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # CommandInterrupt | Name | Type | Offset | Format | |------------------|------------------|--------|----------| | CommandInterrupt | Host In | 0xA990 | Bitfield | | _ | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-----------------------------------------| | 0 | Output DMA | × | 1 | X | 1 = trigger on completion of output DMA | | 131 | Reserved | 0 | 0 | X | | | Matan | | | |--------|--|--| | Notes: | | | **3D**labs Proprietary and Confidential <sup>&</sup>lt;sup>8</sup> Logic Op register readback is via the main register only # Config2D NameTypeOffsetFormatConfig2DGlobal0xB618BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|-------------------------------|------|----------|-------|-----------------------------------------------------------------------------------| | 0 | OpaqueSpan | 1 | 1 | X | In RasterizerMode, AreaStippleMode, LogicalOpMode, FBWriteMode, TextureReadMode. | | 1 | MultiRXBlit | X | X | X | Reserved | | 2 | UserScissorEna<br>ble | ✓ | 1 | X | ScissorMode | | 3 | FBDestReadEn<br>able | ✓ | 1 | X | In FBDestReadMode bit 3 = (ReadEnable) | | 4 | AlphaBlendEna<br>ble | ✓ | 1 | X | In AlphaBlendColorMode and AlphaBlendAlphaMode: bit 4 = AlphaBlendEnable (Enable) | | 5 | DitherEnable | ✓ | 1 | X | In DitherMode: bit 5 = DitherEnable (Enable) | | 6 | ForgroundLogi<br>calOpEnable | ✓ | <b>√</b> | Х | In LogicalOpMode: bit 6 = ForgroundLogicalOpEnable (Enable) | | 710 | ForgroundLogi<br>calOp | ✓ | 1 | X | In LogicalOpMode: Bits 7-10 = ForgroundLogicalOp (LogicOp) | | 11 | BackgroundLog<br>icalOpEnable | ✓ | 1 | X | In LogicalOpMode: Bit 11 = BackgroundLogicalOpEnable (Background En.) | | 1215 | BackgroundLog icalOp | ✓ | 1 | X | In LogicalOpMode: Bits 12-15 = BackgroundLogicalOp | | 16 | UseConstantSo urce | ✓ | 1 | X | In LogicalOpMode: bit 16 = UseConstantSource | | 17 | FBWriteEnable | ✓ | 1 | X | In FBWriteMode: bit 17 = FBWriteEnable (WriteEnable) | | 18 | Blocking | ✓ | 1 | X | In FBSourceReadMode bit 18 = Blocking | | 19 | ExternalSource<br>Data | ✓ | 1 | X | In FBSourceReadMode bit 19 = ExternalSourceData | | 20 | LUTMode<br>Enable | ✓ | 1 | X | In LUTMode: bit 20 = Enable | Notes: This register updates the mode registers in multiple units as shown. The name in brackets is the field name in the corresponding mode register, if different to the field name for the *Config2D* command. Also note that bit 0 affects several mode registers. #### **Constant Color** | Name | Type | Offset | Format | |---------------|------------------|--------|----------| | ConstantColor | Delta | 0x87E8 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|----------|----------|-------|-------------| | | | | | | | | 07 | Red | ~ | <b>✓</b> | X | | | 815 | Green | <b>~</b> | <b>'</b> | X | | | 1623 | Blue | <b>V</b> | <b>v</b> | X | | | 2431 | Alpha | ~ | <b>'</b> | X | | Notes: This register holds the constant color in packed format. This is a legacy register maintained for backwards compatibility which has been superceded by the *ConstantColorDDA* register. The *ConstantColorDDA* register, as well as loading up the constant color register, also loads the DDA start register from the corresponding color byte and sets the dx and dyDom gradients to zero. This allows a constant color to be set up irrespective of the shading mode. #### **ConstantColorDDA** | Name | Type | Offset | Format | |------------------|------------------|--------|----------| | ConstantColorDDA | Color | 0xAFB0 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 1 | 1 | X | Red | | 815 | G | ✓ | 1 | X | Green | | 1623 | В | ✓ | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: This register holds the constant color in packed format. As well as loading up the constant color register it also loads up the DDA start register from the corresponding color byte and sets the dx and dyDom gradients to zero. This allows a constant color to be set up irrespective of the shading mode. #### ContextData | Name | Type | Offset | Format | |-------------|------------------|--------|----------| | ContextData | Global | 0x8DD0 | Variable | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|------------------------------------------------------------------------| | 115 | Reserved | | | | | | 1631 | ContextData | 1 | × | x | Undefined, returned by ContextDump command = (number of data words) -1 | Notes: The context data is read from the Host Out FIFO and stored in memory in a context buffer (excluding any tags), while the context mask is typically discarded. This context buffer can be restored by prefixing it with the three words: *RestoreContext* tag, context mask (used to generate the buffer in the first place) and the *ContextData* tag, and loading it all. The *ContextData* tag has the upper 16 bits set to the number of words of context data in the buffer minus one<sup>9</sup>. The layout of the data in the context dump buffer is not important (and is in fact largely undocumented) because no massaging of the data is necessary before it can be restored. # ContextDump | Name | Type | Offset | <b>Format</b><br>Bitfield | | |-------------|---------|--------|---------------------------|--| | ContextDump | Global | 0x8DC0 | | | | _ | Command | | | | | Bits | Name | Read | Write | Reset | Description | Data<br>Words | |------|-----------------|------|----------|-------|----------------------------------------------------------|---------------| | 0 | GeneralControl | × | V | x | Vertex list and Delta setup mode registers | 20 | | 1 | Geometry | X | V | X | Delta unit state | 68 | | 2 | Matrices | X | <b>V</b> | X | unused | 0 | | 3 | Material | X | V | X | unused | 0 | | 4 | Lights0_7 | X | ~ | X | unused | 0 | | 5 | Lights8_15 | X | V | X | unused | 0 | | 6 | RasterPos | × | V | x | unused | 0 | | 7 | CurrentState | × | V | x | unused | 0 | | 8 | TwoD | × | ~ | X | State used for 2D operations and 2D setup | 7 | | 9 | DMA | × | ~ | X | State used for tag-driven DMAs<br>(If using Command DMA) | 52<br>(51) | | 10 | Select | X | ~ | X | unused | 0 | | 11 | RasterizerState | X | V | X | General setup of the rasterization units | 225 | | 12 | DDA | X | V | X | DDA Values | 69 | | 13 | Ownership | X | V | x | Stripe ownership state | 2 | | 14 | FogTable | X | V | X | Contents of the Fog Table | 64 | | 15 | LUT | × | V | X | Contents of the LUT | 256 | <sup>&</sup>lt;sup>9</sup>A tag with a count in the upper 16 bits is a hold mode tag so all the subsequent data is automatically given the same tag. | 16 | TextureManage | X | <b>V</b> | X | State used for logical texturing (virtual | 9 | |------|---------------|---|----------|---|-------------------------------------------|---| | | ment | | | | texturing) | | | 1731 | Reserved | 0 | 0 | X | | 0 | Notes: This command forces the R4 to dump the selected context. Context switching can be done on any command boundary but not during internal processing or texture/image downloads. The context is dumped from each unit by the *ContextDump* command and restored by the *ContextRestore* command. The data sent with this command (the context mask) dictates what subset of the full context is to be dumped: - The context for each unit is defined by the ContextMask sent in the data word of the *ContextDump* and *ContextRestore* commands. - It appears in the Host Output FIFO tagged as *ContextData* where the host of the output DMA controller can read it. - The amount of data sent depends on the context mask sent with the command. - The last tag and data sent to the FIFO is the *ContextDump* tag and mask, but this is not included in the word counts above - For paired context dump and restore operations the same mask is required. - The context data is read from the Host Out FIFO and stored in memory in a context buffer (excluding any tags). - For further information see the ContextRestore, EndofFeedback, FilterMode and ContextData registers #### ContextRestore NameTypeOffsetFormatContextRestoreGlobal0x8DC8Bitfield Command | Bits | Name | Read | Write | Reset | Description | Data<br>Words | |------|-----------------------|------|----------|-------|-------------------------------------------------------|---------------| | 0 | GeneralControl | × | ~ | x | Vertex list and Delta setup mode registers | 20 | | 1 | Geometry | × | ~ | x | Delta unit state | 68 | | 2 | Matrices | X | ~ | x | unused | 0 | | 3 | Material | X | V | x | unused | 0 | | 4 | Lights0_7 | X | ~ | x | unused | 0 | | 5 | Lights8_15 | X | ~ | x | unused | 0 | | 6 | RasterPos | × | ~ | x | unused | 0 | | 7 | CurrentState | X | <b>V</b> | X | unused | 0 | | 8 | TwoD | × | ~ | X | State used for 2D operations and 2D setup | 7 | | 9 | DMA | X | ~ | x | State used for tag-driven DMAs (If using Command DMA) | 52<br>(51) | | 10 | Select | X | ~ | x | unused | 0 | | 11 | RasterizerState | X | V | X | General setup of the rasterization units | 225 | | 12 | DDA | × | V | x | DDA Values | 69 | | 13 | Ownership | × | ~ | x | Stripe ownership state | 2 | | 14 | FogTable | × | ~ | x | Contents of the Fog Table | 64 | | 15 | LUT | × | ~ | x | Contents of the LUT | 256 | | 16 | TextureManage<br>ment | X | ~ | X | State used for logical texturing (virtual texturing) | 9 | | 1731 | Reserved | 0 | 0 | X | | 0 | #### Notes: • - The context for each unit is defined by the ContextMask sent in the data word of the **ContextDump** and **ContextRestore** commands. The various fields in the mask and their effect on units is as shown. - For further information see the ContextDump, EndofFeedback, FilterMode and ContextData registers #### Continue | Name | Type | Offset | Format | |----------|------------|--------|---------| | Continue | Rasterizer | 0x8058 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------| | 015 | Scanlines | 1 | 1 | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: Continues rasterisation to continue after new delta value(s) have been loaded, but doesn't cause either of the trapezoid's edge DDAs to be reloaded. The data field holds the number of scanlines (or sub scanlines) to fill as a 16 bit unsigned integer. Note: this count does not get loaded into the *Count* register. #### **ContinueNewDom** | Name | Type | Offset | Format | |----------------|------------|--------|---------| | ContinueNewDom | Rasterizer | 0x8048 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------| | 015 | Scanlines | 1 | 1 | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: This command causes rasterization to continue with a new dominant edge. The dominant edge DDA in the rasterizer is reloaded with the new parameters. The subordinate edge is carried on from the previous trapezoid. This allows any convex 2D polygon to be broken down into a collection of trapezoids and continuity maintained across boundaries. Since this command only affects the rasterizer DDA (and not any of the other units), it is not suitable for 3D operations. The data field holds the number of scanlines (or sub scanlines) to fill. Note this count does not get loaded into the *Count* register. #### **ContinueNewLine** | Name | Type | Offset | Format | |-----------------|------------|--------|---------| | ContinueNewLine | Rasterizer | 0x8040 | Integer | | | Command | | _ | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------| | 015 | Scanlines | 1 | 1 | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: Allows the raterization to continue for the next segment in a polyline. The XY position is carried on from the previous line, however the fraction bits in the DDAs can be kept, set to zero or half under control of the *RasterizerMode*. The data field holds the number of scanlines (or sub scanlines) to fill as a 16 bit unsigned integer. Note this count does not get loaded into the *Count* register. The use of *ContinueNewLine* is not recommended for OpenGL because the DDA units will start with a slight error as compared with the value they would have been loaded with for the second and subsequent segments. #### **ContinueNewSub** | Name | Type | Offset | Format | | |----------------|------------|--------|---------|--| | ContinueNewSub | Rasterizer | 0x8050 | Integer | | | | Command | | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------| | 015 | Scanlines | 1 | 1 | x | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: This command causes rasterization to continue with a new subordinate edge. The subordinate edge DDA in the rasterizer is reloaded with the new parameters. The dominant edge is carried on from the previous trapezoid. This is very useful when scan converting triangles with a "knee" (i.e. two subordinate edges. The data field holds the number of scanlines (or sub scanlines) to fill. Note this count does not get loaded into the *Count* register. #### Count | Name | Type | Offset | Format | |-------|------------------|--------|---------| | Count | Rasterizer | 0x8030 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------| | 015 | variable | 1 | 1 | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: Mode set in Render command: - Number of pixels in a line. - Number of scanlines in a trapezoid. - Number of sub scanlines in an antialiased trapezoid. - Diameter of a point in sub scanlines. Unsigned 16 bits. #### dAdx | Name | Type | Offset | Format | |------|------------------|--------------|--------| | dAdx | Color | Color 0x87D0 | | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the X derivative for the Alpha value for the interior of a trapezoid when in Gouraud shading mode. The format is 24 bit 2's complement 9.15 fixed point numbers. With dBdx, dGdx and dRdx, holds the X gradient values for the Red, Green, Blue and Alpha Color components. See also dFdx for Fog rendering coefficient. # dAdyDom | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | dAdyDom | Color DDA | 0x87D8 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: This register is used to set the Y derivative dominant for the Alpha value along a line, or for the dominant edge of a trapezoid, when in Gouraud shading mode. The value is in 24 bit 2's complement 9.15 fixed point format. #### dBdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dBdx | Color | 0x87B8 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | ✓ | X | | | 1523 | Integer | 1 | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the X derivative for the Red value for the interior of a trapezoid when in Gouraud shading mode. The format is 24 bit 2's complement 9.15 fixed point numbers. # dBdyDom | Name | Type | Offset | Format | |---------|--------------|--------|-------------| | dBdyDom | Color | 0x87C0 | Fixed point | | | Control regi | ister | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | ✓ | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: This register is used to set the Y derivative dominant for the Blue value along a line, or for the dominant edge of a trapezoid, when in Gouraud shading mode. The value is in 24 bit 2's complement 9.15 fixed point format. # **DeltaMode DeltaModeAnd DeltaModeOr** | Name | Type | Offset | Format | |--------------|-------------------|--------|---------------------| | DeltaMode | Delta | 0x9300 | Bitfield | | DeltaModeAnd | Delta | 0xAAD0 | Bitfield Logic Mask | | DeltaModeOr | Delta | 0xAAD8 | Bitfield Logic Mask | | | Control registers | | | | | | | | | Bits | Name | Read<br>10 | Write | Reset | Description | |--------|------------------------------|------------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0, 1 | TargetChip | 1 | 1 | X | The bitfield is retained for backwards compatibility but in R4 the value must be initialized to 1. | | 2, 3 | DepthFormat | <b>√</b> | 1 | X | This field defines the depth format and hence the final format of the depth parameters to be written into the R4. The options are: $0 = 15 \text{ bits}$ $1 = 16 \text{ bits}$ $2 = 24 \text{ bits}$ $3 = 32 \text{ bits}$ | | 4 | FogEnable | ✓ | 1 | x | When set enables the fog calculations. This is qualified by the FogEnable bit in the Draw command. | | 5 | Texture Enable | <b>√</b> | 1 | X | When set enables the texture calculations. This is qualified by the <i>TextureEnable</i> bit in the Draw commands. | | 6 | Smooth Shad-<br>ing Enable | 1 | 1 | x | When set enables the color calculations. Only effective when the Draw* commands are used. | | 7 | Depth Enable | 1 | 1 | X | When set enables the depth calculations. | | 8 | Specular<br>Texture Enable | 1 | 1 | x | When set enables the specular texture calculations. | | 9 | Diffuse Texture<br>Enable | ✓ | 1 | x | When set enables the diffuse texture calculations | | 10 | SubPixelCorrec<br>tionEnable | <b>√</b> | 1 | X | When set provides the subpixel correction in Y. This is qualified by the <i>SubPixelCorrectionEnable</i> bit in the <b>Draw*</b> command. | | 11 | DiamondExit | <b>√</b> | 1 | X | When set enables the application of the OpenGL 'Diamond-exit' rule to modify the start and end coordinates of lines. | | 12 | NoDraw | <b>√</b> | 1 | X | When set prevents any rendering from starting after the set up calculations are done and parameters sent to R4. This only affects the <b>Draw*</b> commands. | | 13 | ClampEnable | <b>√</b> | 1 | X | When set causes the input values to be clamped into a parameter specific range. Note that the texture parameters are not included. | | 14, 15 | Texture<br>Parameter<br>Mode | ✓ | ✓ | X | These field causes the texture parameters to be: 0: Used as given 1: Clamped to lie in the range -1.0 to 1.0 2: Normalise to lie in the range -1.0 to 1.0 | | 16 | Reserved | 0 | 0 | X | Reserved | | 17 | Reserved | 0 | 0 | X | Reserved | $<sup>^{10}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only | 18 | Reserved | 1 | 1 | X | Reserved | |------|-----------------------|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19 | Bias<br>Coordinates | 1 | 1 | x | When set, adds the Xbias and Ybias values to the x and y coordinates. Allows (e.g.) remval of an OGL viewport bias or conversion of a windows-relative to screen-relative co-ordinate system. $0 = \text{off}$ , $1 = \text{on}$ | | 20 | Reserved | 1 | 1 | X | Reserved | | 21 | Reserved | 1 | 1 | X | Reserved | | 22 | FlatShading<br>Method | 1 | 1 | x | Specifies which shading method the Delta unit should direct the ColorDDA to employ: 0 = Use ConstantColor register value 1 = Use DDA with zero gradients | | 2331 | Reserved | 0 | 0 | X | Reserved | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ### **Depth** | Name | Type | Offset | Format | |-------|------------------|--------|---------| | Depth | Depth | 0x89A8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-------------------------------------------------------------------------| | 030 | Depth value | 1 | 1 | X | Integer value right-justified to LSB end and padded with 0s to 31 bits. | | 31 | Reserved | 0 | 0 | X | | Notes: Holds an externally sourced 31 bit depth value. If the depth buffer holds less than 31bits then the user supplied depth value is right justified to the least significant end. The unused most significant bits should be set to zero. This is used in the draw pixels function where the host supplies the depth values through the Depth register. Alternatively this is used when a constant depth value is needed, for example, when clearing the depth buffer, or for 2D rendering where the depth is held constant. # DepthMode DepthModeAnd DepthModeOr | Name | Type | Offset | Format | |--------------|-------------------|--------|---------------------| | DepthMode | Depth | 0x89A0 | Bitfield | | DepthModeAnd | Depth | 0xAC70 | Bitfield Logic Mask | | DepthModeOr | Depth | 0xAC78 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>11 | Write | Reset | Description | | |------|---------------------|------------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0 | Enable | ~ | ~ | x | This bit, when set, enables the depth test and the replacement depth value to depend on the outcome of the test. Otherwise the test always passes and the depth data in the local buffer is not changed. | | | 1 | WriteMask | • | • | X | This bit, when set enables the depth value in the local buffer to be updated when doing a read-modify-write operation. The byte enables (LB Write) can also be used when the Z value is 16 or 24 bits in size. | | | 23 | NewDepth<br>Source | V | V | x | The depth value to write to the local buffer can come from several places. The options are: 0 = DDA. 1 = Source depth (i.e. read from Local Buffer) 2 = Depth register 3 = LBSourceData register. Only generated when source and destination reads are enabled. | | | 46 | Compare<br>Function | V | ~ | X | This field selects the compare function to use. The options are: 0 = Never | | | 78 | Width | ~ | ~ | X | This field holds the width in bits of the depth field in local buffer. The options are: $0 = 16$ bits wide $2 = 31$ bits wide $3 = 15$ bits wide | | | 9 | Normalise | ~ | V | x | This bit, when set, will use all 50 bits of the DDA for Z interpolation, even for 24 or less bits of depth. The Width field must be set up to restrict the number of bits used in the comparison operation. When this bit is clear the depth test is compatible with GLINT MX. This bit should be 0 if NonLinearZ is set. | | | 10 | NonLinearZ | ~ | ~ | X | This bit, when set, enables the 32 bit DDA Z value to be encoded in 15, 16 or 24 bits using a non linear pseudo floating point representation. The non linear format is controlled by the following two fields. | | $<sup>^{11}</sup>$ Logic Op register readback is via the main register only | 1112 | Exponent Scale | ~ | ~ | X | This field defines how much | the exponent should be | |------|----------------|----------|---|---|-------------------------------|------------------------| | | | | | | scaled by. The options are: | | | | | | | | 0 = scale by 1 | 1 = scale by 2 | | | | | | | 2 = scale by 4 | 3 = scale by 8 | | 1314 | Exponent | <b>~</b> | / | X | This field defines the number | of bits in the depth | | | Width | | | | word to use as exponent bits. | The options are: | | | | | | | 0 = 1 bit wide exponent fi | eld | | | | | | | 1 = 2 bits wide | 2 = 3 bits wide | | | | | | | 3 = 4 bits wide | | | 1531 | Unused | 0 | 0 | X | | | Notes: The register defines Depth operation. It controls the comparison of a fragment's depth value and updating of the depth buffer. (If the compare function is LESS and result = TRUE then the fragment value is less than the source value.) The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### dFdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dFdx | Fog | 0x86A8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 021 | Fraction | 1 | 1 | X | | | 2231 | Integer | 1 | 1 | X | | Notes: Used to set the X derivative for the Fog value for trapezoid rendering. The format is 32 bit 2's complement 10.22 fixed point numbers. # dFdyDom | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | dFdyDom | Fog | 0x86B0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 021 | Fraction | 1 | 1 | X | | | 2231 | Integer | 1 | 1 | X | | Notes: This register holds the Y gradient values along the dominant edge for the Fog. The format is 32 bit 2's complement fixed point numbers in 10.22 format #### dGdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dGdx | Color | 0x87A0 | Fixed point | | | Control register | • | - | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | x | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the X derivative for the Green value for the interior of a trapezoid when in Gouraud shading mode. The format is 24 bit 2's complement 9.15 fixed point numbers. # dGdyDom | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | dGdyDom | Color | 0x87A8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2331 | Reserved | 0 | 0 | X | Unused | Notes: This register is used to set the Y derivative dominant for the Green value along a line, or for the dominant edge of a trapezoid, when in Gouraud shading mode. The value is in 2's complement 24 bit 9.15 fixed point format. # **DitherMode DitherModeAnd DitherModeOr** | Name | Type | Offset | Format | |------------|--------|--------|----------| | DitherMode | Global | 0x8818 | Bitfield | DitherModeAnd Global 0xACD0Bitfield Logic Mask DitherModeOr Global 0xACD8 Bitfield Logic Mask Control Register | Bits | Name | Read<br>12 | Write | Reset | Description | |------|------------------|------------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | • | • | X | When set causes the fragment's color values to be dithered or rounded under control of the remaining bits in this register. If this bit is clear then the fragment's color is passed unchanged. | | 1 | Dither Enable | ~ | ~ | x | When this bit is set any RGB format color is dithered, otherwise it is rounded to the destination size under control of the RoundingMode field. See the table below for the dither matrix and how it is combined with the color components. Color Index formats are always rounded. | | 25 | Color Format | <b>V</b> | <b>V</b> | X | The color format which in turn is coded from the size and position of the red, green, blue and (if present) the alpha components. | | 67 | Xoffset | ~ | ~ | X | This offset is added to the fragment's x coordinate to derive the x address in the dither table. This allows window-relative dithering using screen coordinates. | | 89 | Yoffset | ~ | ~ | x | This offset is added to the fragment's y coordinate to derive the y address in the dither table. This allows window-relative dithering using screen coordinates. | | 10 | Color Order | ~ | ~ | X | Holds the color order. The options are: 0 = BGR 1 = RGB | | 1113 | Reserved | 0 | 0 | x | | | 14 | Alpha Dither | ~ | ~ | x | This bit allows the alpha channel to be rounded even when the color channels are dithered. This helps when antialiasing. 0 = Alpha value is dithered (if DitherEnable is set) 1 = Alpha value is always rounded. | | 1516 | Rounding<br>Mode | ~ | ~ | Х | 0 = Truncate<br>1 = Round Up<br>2 = Round Down | | 1731 | Unused | 0 | 0 | X | | Dithering controls color formatting. The dither function converts the internal color format into the framebuffer color information format. $<sup>^{12}</sup>$ Logic Op register readback is via the main register only The following table shows the different color formats supported by the dither unit: - In the R, G, B and A columns the nomenclature n@m means this component is n bits wide and starts at bit position m in the framebuffer. The least significant bit position is 0 and a dash in a column indicates that this component does not exist for this mode. When two entries are shown the colour value is replicated into both fields. - Two color ordering formats are supported, namely ABGR and ARGB, with the right most letter representing the color in the least significant part of the word. This is controlled by the Color Order bit in the DitherMode register, and is easily implemented by just swapping the R and B components before conversion into the framebuffer format. - The only exception to this are the 3:3:2 formats where the actual bit fields sent to the framebuffer data need to be modified as well because the R and B components are differing widths. - CI processing is not affected by this swap. | | | Internal Colour Channels | | | | | | |----|--------|--------------------------|---------|-------------|------------|-------------|-------------| | | Format | Colour | Name | R | G | В | A | | | | Order | | | | | | | | 0 | BGR | 8:8:8:8 | <u>8@0</u> | <u>8@8</u> | <u>8@16</u> | <u>8@24</u> | | | 1 | BGR | 4:4:4:4 | <u>4@0</u> | <u>4@4</u> | <u>4@8</u> | <u>4@12</u> | | С | 2 | BGR | 5:5:5:1 | <u>5@0</u> | <u>5@5</u> | <u>5@10</u> | <u>1@15</u> | | О | 3 | BGR | 5:6:5 | <u>5@0</u> | <u>6@5</u> | <u>5@11</u> | - | | 1 | 4 | BGR | 3:3:2 | <u>3@0</u> | <u>3@3</u> | <u>2@6</u> | - | | О | 0 | RGB | 8:8:8:8 | <u>8@16</u> | <u>8@8</u> | <u>8@0</u> | 8@24 | | u | 1 | RGB | 4:4:4:4 | <u>4@8</u> | <u>4@4</u> | <u>4@0</u> | <u>4@12</u> | | r | 2 | RGB | 5:5:5:1 | <u>5@10</u> | <u>5@5</u> | <u>5@0</u> | <u>1@15</u> | | | 3 | RGB | 5:6:5 | <u>5@11</u> | <u>6@5</u> | <u>5@0</u> | - | | | 4 | RGB | 3:3:2 | 3@5 | 3@2 | 2@0 | - | | CI | 15 | X | CI8 | <u>8@0</u> | 8@8 | <u>8@16</u> | 8@24 | The format to use is held in the DitherMode register. In CI mode the lower byte (CI8) replicated up to the full 32 bit width as an aid to double buffering when the alternative buffers are stored in different bit planes in the same 32 bit word. The replication is done after dithering. #### dKdBdx | Name | Type | Offset | Format | |--------|------------------|--------|-------------| | dKdBdx | Texture Color | 0x8D38 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | ✓ | X | | | 2431 | reserved | 0 | 0 | X | | Notes: *dKdBdx* holds the X gradient value for the Blue Kd color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. ### dKdBdyDom | Name | Type | Offset | Format | |-----------|------------------|--------|-------------| | dKdBdyDom | Texture | 0x8D40 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Reserved | 0 | 0 | X | | Notes: dKdBdyDom holds the Y gradient value along the dominant edge for the Blue Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### dKdGdx | Name | Type | Offset | Format | |--------|------------------|--------|-------------| | dKdGdx | Texture Color | 0x8D20 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | 1 | X | | | 1523 | Integer | ✓ | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *dKdGdx* holds the X gradient value for the Green Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. # dKdGdyDom | Name | Type | Offset | Format | |-----------|------------------|--------|-------------| | dKdGdyDom | Texture | 0x8D28 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: The Ks and Kd DDA units are responsible for generating the specular and diffuse RGB values. dKdGdyDom holds the Y gradient value along the dominant edge for the Green Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### dKdRdx $\begin{array}{ccccc} \textbf{Name} & \textbf{Type} & \textbf{Offset} & \textbf{Format} \\ \text{dKdRdx} & \text{Texture} & 0x8D08 & \text{Fixed point} \\ & & & & & & & & & & & & & & & \\ & & & & & & & & & & & & & & \\ & & & & & & & & & & & & & & & \\ & & & & & & & & & & & & & & & \\ & & & & & & & & & & & & & & & \\ & & & & & & & & & & & & & & & \\ & & & & & & & & & & & & & & \\ & & & & & & & & & & & & & & \\ & & & & & & & & & & & & & \\ & & & & & & & & & & & & & \\ & & & & & & & & & & & & & \\ & & & & & & & & & & & & \\ & & & & & & & & & & & & \\ & & & & & & & & & & & \\ & & & & & & & & & & & \\ & & & & & & & & & & & \\ & & & & & & & & & & & \\ & & & & & & & & & & & \\ & & & & & & & & & & & \\ & & & & & & & & & & \\ & & & & & & & & & & \\ & & & & & & & & & & \\ & & & & & & & & & & \\ & & & & & & & & & & \\ & & & & & & & & & & \\ & & & & & & & & & & \\ & & & & & & & & & & \\ & & & & & & & & & \\ & & & & & & & & & \\ & & & & & & & & & \\ & & & & & & & & \\ & & & & & & & & \\ & & & & & & & & \\ & & & & & & & & \\ & & & & & & & & \\ & & & & & & & & \\ & & & & & & & & \\ & & & & & & & & \\ & & & & & & & \\ & & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & & \\ & & & & & & \\ & & & & & & & \\ & & & & & & \\ & & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & &$ | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *dKdRdx* holds the X gradient value for the Red Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. ### dKdRdyDom | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *dKdRdyDom* holds the Y gradient value along the dominant edge for the Red Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### dKsBdx | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKsBdx holds the X gradient value for the Blue Ks (specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. (Note: numeric format differs from the MX.) ### dKsBdyDom NameTypeOffsetFormatdKsBdyDomTexture0x8CC0Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | x | | | 1523 | Integer | 1 | 1 | X | | | 2431 | unused | 0 | 0 | X | | Notes: *dKsBdyDom* holds the Y gradient value along the dominant edge for the Blue Ks (Specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### dKsdx NameTypeOffsetFormatdKsdxTexture0x86D0Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|------------------------------------------| | 021 | Fraction | 1 | <b>√</b> | X | 2's complement 2.22 fixed point fraction | | 2223 | Integer | ✓ | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Ks (specular) derivative for unit X. The value is 2.22 2's complement format.. ## dKsdyDom NameTypeOffsetFormatdKsdyDomTexture0x86D8Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 021 | Fraction | 1 | 1 | X | | | 2223 | Integer | ✓ | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Ks (specular) derivative per unit Y along the dominant edge. The value is 2.22 2's complement format #### dKsGdx | Name | Type | Offset | Format | |--------|------------------|--------|-------------| | dKsGdx | Texture | 0x8CA0 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKsGdx holds the X gradient value for the Green Ks (specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. (Note: numeric format differs from MX.) ## dKsGdyDom | Name | Type | Offset | Format | |-----------|------------------|--------|-------------| | dKsGdyDom | Texture | 0x8CA8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | x | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKsGdyDom holds the Y gradient value along the dominant edge for the Green Ks (Specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. ### dKsRdx | Name | Type | Offset | Format | |--------|------------------|--------|-------------| | dKsRdx | Texture | 0x8C88 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKsRdx holds the X gradient value for the Re Ks (specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. (Note: numeric format has changed from the MX.) ### dKsRdyDom NameTypeOffsetFormatdKsRdyDomTexture0x8CC0Fixed point Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | x | | | 1523 | Integer | ✓ | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKsRdyDom holds the Y gradient value along the dominant edge for the Red Ks (Specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **DMAAddr** NameTypeOffsetFormatDMAAddrInput0xA980Integer Control Register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 01 | Reserved | 0 | 0 | X | | | 231 | Address | <b>V</b> | <b>V</b> | X | Address | Notes: This register holds the byte address of the next DMA buffer to read from (reading doesn't start until the *DMACount* command). The bottom two bits of the address are ignored, hence the byte address is forced to be 32 bit aligned. This register should not be confused with the PCI register of the same name. *DMAAddr* must be loaded by itself and not as part of any increment, hold or indexed group. See also: *DMACount*. #### **DMAContinue** NameTypeOffsetFormatDMAContinueInput0xA9F8IntegerCommand | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|---------------------------------| | 029 | Count | X | <b>'</b> | X | Number of DMA words to transfer | | 3031 | Reserved | 0 | 0 | X | | Notes: #### **DMACount** | Name | Type | Offset | Format | | |----------|------------------|--------|---------|--| | DMACount | Input | 0xA988 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|---------------------------------| | 029 | Count | ~ | <b>V</b> | X | Number of DMA words to transfer | | 3031 | Reserved | 0 | 0 | X | | Notes: At chip reset the MasterEnable bit in the CFGCommand register must be set to allow DMA to operate. Then, for the simplest form of DMA, the host software prepares a host buffer containing register address tag descriptions and data values. The host writes the base address of this buffer to the DMAAddr register and the count of the number of words to transfer to the DMACount register. Writing to the DMACount register starts the DMA transfer and the host is then free to perform other work. #### **DMAFeedback** | Name | Type | Offset | Format | |-------------|---------|--------|---------| | DMAFeedback | Input | 0xAA10 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------| | 029 | Count | X | ~ | X | Number of DMA words to transfer | | 3031 | Reserved | 0 | 0 | X | Reserved | Notes: The Feedback DMA mechanism allows the collection and transfer of an unspecified amount of data from the Host Out FIFO. This can be used for OpenGL feedback and select modes. - The feedback DMA transfer is set up by using the *DMAOutputAddress* register and the *DMAFeedback* command. - The *DMAOutputAddress* holds the address where the data is to be written The start address is given as a byte address but the lower two bits are ignored. - The *DMAFeedback* command with the length of the memory buffer (in words) is sent to start the Output DMA controller. Data is never written beyond the end of the given buffer length. - Once all the data to write to memory has been generated the *EndOfFeedback* command is sent to terminate the DMA operation. A count of the number of words transferred is recorded in the PCIFeedbackCount register. Note: Feedback DMA must run as external DMA only. # **DMAMemoryControl** NameTypeOffsetFormatDMAMemoryControlInput<br/>Command0xB780Bitfield | Bits | Name | Read | Write | Reset | Description | |-------|------------------------|----------|-------|-------|--------------------| | 0 | InputDMA<br>Memory | ~ | ~ | X | 0 = PCI, $1 = AGP$ | | 1 | Reserved | 0 | 0 | | | | 2 | Input DMA<br>Alignment | ~ | ~ | X | 0 = off, 1 = on | | 3 | Index Memory | <b>/</b> | ~ | X | 0 = PCI, 1 = AGP | | 4 | Reserved | 0 | 0 | X | | | 5 | Index<br>Alignment | ~ | ~ | x | 0 = off, 1 = on | | 6 | Vertex Memory | <b>'</b> | ~ | X | 0 = PCI, 1 = AGP | | 7 | Reserved | 0 | 0 | X | | | 8 | Vertex<br>Alignment | ~ | ~ | X | 0 = off, 1 = on | | 9 | ReadDMA<br>Memory | ~ | ~ | x | 0 = PCI, 1 = AGP | | 10 | Reserved | 0 | 0 | X | | | 11 | ReadDMA<br>Alignment | ~ | ~ | X | 0 = off, 1 = on | | 12-23 | Reserved | 0 | 0 | X | | | 24-28 | Burst Size | <b>/</b> | V | X | | | 29-30 | Reserved | 0 | 0 | X | | | 31 | WriteDMA | ~ | ~ | X | 0 = off, 1 = on | | Notes: | | | | |--------|--|--|--| | | | | | ## **DMAOutputAddress** | Name | Type | Offset | Format | |------------------|---------|--------|---------| | DMAOutputAddress | Input | 0xA9E0 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|------------------------| | 01 | Reserved | 0 | 0 | X | Reserved | | 231 | Address | <b>V</b> | <b>v</b> | X | 32 bit aligned address | Notes: This register holds the byte address where the output DMA controller will write to. The lower two bits of the address are ignored. This register must be loaded by itself and not as part of any increment, hold or indexed group. ### **DMAOutputCount** | Name | Type | Offset | Format | |----------------|---------|--------|---------| | DMAOutputCount | Input | 0xA9E8 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|---------------------------------| | 029 | Count | <b>✓</b> | <b>✓</b> | X | Number of DMA words to transfer | | 3031 | Reserved | 0 | 0 | X | | Notes: This command starts a new output DMA if the output DMA controller is idle, otherwise it will block until the output DMA controller becomes available and all subsequent commands and register loads are suspended. - The number of words to read from the R4 Host Out FIFO is given in the bottom 24 bits of the command, and the memory buffer address will have previously been set up in the DMAOutputAddress register. - The R4 FilterMode register must have been set up to allow the required tags and/or data to be written in to the FIFO.. - This register must be loaded by itself and not as part of any increment, hold or indexed group. - See also: DMAOutputAddress ### **DMARectangleRead** NameTypeOffsetFormatDMARectangleReadInput0xA9A8Bitfield Control Register | Bits | Name | Read | Write | Reset | Description | |-------|-----------|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-11 | Width | × | <b>/</b> | X | Width of the rectangle in pixels. Range 04095 | | 12-23 | Height | X | ~ | X | Height of the rectangle in pixels. Range 04095 | | 24-25 | PixelSize | X | ~ | X | The size of the pixels in the source image to read. The pixel size is used during alignment and packing. The values are: $0 = 8$ bits, $1 = 16$ bits, $2 = 24$ bits, $3 = 32$ bits | | 26 | Pack | X | ~ | x | This field, when set, causes the data to be packed into 32 bit words when used, otherwise the data is right justified and any unused bits (in the most significant end of the word) are set to zero. | | 27-28 | ByteSwap | × | ~ | x | These bits control the byte swapping of the data read from the PCI bus before it is aligned and packed/unpacked. If the input bytes are labeled ABCD on input then they are swapped as follows: 0 = ABCD (i.e. no swap) 1 = BADC 2 = CDAB 3 = DCBA | | 29 | Reserved | 0 | 0 | X | | | 30-31 | Alignment | X | ~ | x | When set, causes R4 to start and stop PCI or AGP transfers on 64 byte boundaries where possible. | #### Notes: - 1. The Rectangle DMA mechanism allows image data to be transferred from host memory to the R4. The image data may be a sub image of a larger image and have any natural alignment or pixel size. Information regarding the rectangle transfer is held in registers loaded from the input FIFO or a DMA buffer. - 2. The pixel data read from host memory is always packed, however when passed to R4 it can be in packed or unpacked format. It can also, optionally, be aligned on 64 byte boundaries. - 3. The minimum number of PCI reads are used to align and pack the image data. - 4. R4 is set up to rasterize the destination area for the pixel data (depth, stencil, color, etc.) with SyncOnHostData or SyncOnBitMask enabled in the **Render** command. This is done before the Rectangular DMA is started. - 5. This register must be loaded by itself and not as part of any increment, hold or indexed group. - 6. See also DMARectangleReadAddress; DMARectangleReadLinePitch; DMARectangleReadTarget. # **DMARectangleReadAddress** NameTypeOffsetFormatDMARectangleReadAddressInput0xA9B0IntegerControl Register | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|----------|-------|------------------------------| | 031 | Address | <b>✓</b> | <b>✓</b> | X | 32 bit pixel aligned address | Notes: This register provides the byte address of the first pixel in the image or sub image to read during a rectangular DMA transfer from host memory to R4. The address should be aligned to the natural size of the pixel, except for 24 bit pixels which may be aligned to any byte boundary. This register must be loaded by itself and not as part of any increment, hold or indexed group. See also: DMARectangleRead; DMARectangleReadLinePitch; DMARectangleReadTarget ### **DMARectangleReadLinePitch** NameTypeOffsetFormatDMARectangleReadLineInput0xA9B8IntegerPitch Control Register | Bits | Name | Read | Write | Reset | Description | |------|------------|----------|-------|-------|-------------| | 031 | Line Pitch | <b>~</b> | ~ | X | LinePitch | Notes: This register defines the amount, in bytes, to move from one scanline in the image to the next scanline during a rectangular DMA transfer from host memory to R4. For a sub image this is based on the width of the whole image. The pitch is held as a 32 bit 2's complement number. This is normally an integer multiple of the number of bytes in a pixel. The register must be loaded by itself and not as part of any increment, hold or indexed group. See also: DMARectangleReadAddress; DMARectangleRead; DMARectangleReadTarget. ### **DMARectangleReadTarget** NameTypeOffsetFormatDMARectangleReadTargetInput<br/>Command0xA9C0Bitfield | Bits | Name | Read | Write | Reset | Description | |----------|----------|----------|-------|-------|---------------------------| | 0-10 Tag | Tag | <b>'</b> | ~ | X | Tag to use with DMA data. | | 11-31 | Reserved | 0 | 0 | X | Reserved | Notes: - 1. This register holds the 16 bit tag sent to the Rasterizer just before the image data is sent during a rectangular DMA transfer from host memory to the R4. Normally it would be one of the tags allowed by the rasterizer during a SyncOnHostData or SyncOnBitMask operation with the tag mode set to Hold. The secondary PCI bus traffic is minimized by sending multiple image words with a single tag (with a count). - 2. This register must be loaded by itself and not as part of any increment, hold or indexed group. - 3. See also: DMARectangleReadAddress; DMARectangleReadLinePitch; DMARectangleRead ### **DMARectangleWrite** NameTypeOffsetFormatDMARectangleWriteInput0xA9C8BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |-------|-----------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-11 | Width | × | V | X | Width of the rectangle in pixels. Range 04095 | | 12-23 | Height | X | ~ | X | Height of the rectangle in pixels. Range 04095 | | 24-25 | PixelSize | X | ~ | X | The size of the pixels in the source image to read. The pixel size is used during alignment and packing. The values are: $0 = 8$ bits, $1 = 16$ bits, $2 = 24$ bits, $3 = 32$ bits | | 26 | Pack | × | V | x | 1 = data is right justified and any unused bits (in the most significant end of the word) are set to zero. 0 = data read from the Host Out FIFO is packed. N.B. this is the inverse of the bit setting in DMARectangleRead | | 27-28 | ByteSwap | × | ~ | x | These bits control the byte swapping of the data written to the PCI bus. If the input bytes are labeled ABCD on input then they are swapped as follows: 0 = ABCD (i.e. no swap) | | 29 | Reserved | 0 | 0 | X | | | 30-31 | Alignment | X | <b>/</b> | X | When set, causes R4 to start and stop PCI or AGP | |-------|-----------|---|----------|---|--------------------------------------------------| | | | | | | transfers on 64 byte boundaries where possible. | Notes: - 1. The Rectangle DMA mechanism allows image data to be transferred from R4 to host memory. The image data may be a sub image of a larger image and have any natural alignment or pixel size. Information regarding the rectangle transfer is held in registers loaded from the input FIFO or a DMA buffer. - Note: Failure to supply an EOF may have unpredictable results. - 2. The pixel data written to host memory is always packed, however when read from the Host Out FIFO it can be in packed or unpacked format. Note that it is packed when *Reset*. It can also, optionally, be aligned on 64 byte boundaries. - 3. The minimum number of PCI writes are used to align and pack the image data. - 4. P4 is set up to rasterize the source area for the pixel data (depth, stencil, color, etc.) enabled in the Render command. This is done before the Rectangular DMA is started. - 5. This register must be loaded by itself and not as part of any increment, hold or indexed group. - 6. See also: Erratum PEREN009; **DMARectangleReadAddress**; **DMARectangleReadLinePitch**; **DMARectangleReadTarget** ### **DMARectangleWriteAddress** NameTypeOffsetFormatDMARectangleWriteInput0xA9D0IntegerAddress Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|----------|-------|------------------------------| | 031 | Address | <b>/</b> | <b>/</b> | X | 32 bit pixel aligned address | Notes: - This register provides the byte address of the first pixel in the image or sub image to write during a rectangular DMA transfer from R4 to host memory. The address should be aligned to the natural size of the pixel, except for 24 bit pixels which may be aligned to any byte boundary. - This register must be loaded by itself and not as part of any increment, hold or indexed group. - See also: DMARectangleWrite; DMARectangleWriteLinePitch; DMAReadGLINTSource ### **DMARectangleWriteLinePitch** NameTypeOffsetFormatDMARectangleWriteLineInput0xA9D8IntegerPitch Control Register | Bits | Name | Read | Write | Reset | Description | |------|------------|----------|----------|-------|-------------| | 031 | Line Pitch | <b>✓</b> | <b>/</b> | X | LinePitch | Notes: This register defines the amount, in bytes, to move from one scanline in the image to the next scanline during a rectangular DMA transfer from R4 to host memory. For a sub image this is based on width of the whole image. - The pitch is held as a 32 bit 2's complement number. This is normally an integer multiple of the number of bytes in a group. - See also: DMARectangleWriteAddress; DMARectangleWrite; DMAReadGLINTSource #### **DownloadAddress** NameTypeOffsetFormatDownloadAddressFramebuffer0xB0D0IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|--------------------------------------| | 031 | Page Address | 1 | 1 | X | 32 bit integer value from 0 to 65535 | Notes: Holds the address to which to download 32 bits of data. The address is incremented after every write. The simplest way to download data to the framebuffer (or indeed any memory) is to use the **DownloadAddress** message to set up the word address. Each subsequent **DownloadData** command sends 32 bits of message data to the download address, after which the download address is auto incremented to address the next word. The bottom two bits of the **DownloadAddress** are forced to zero for the memory update, and readback will return the incremented address value #### **DownloadData** NameTypeOffsetFormatDownloadDataFramebuffer0xB0D8Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 031 | Data | X | 1 | X | 32 bit data | Notes: This register holds the data to write to memory. The address will have previously been set up using the DownloadAddress message. Each **DownloadData** command sends 32 bits of message data to the download address, after which the download address is auto incremented to address the next word. The bottom two bits of the **DownloadAddress** are forced to zero for the memory update, and readback returns the incremented address value ### DownloadGlyphWidth NameTypeOffsetFormatDownloadGlyphWidthSetup0xB658IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|--------------------------------------| | 015 | Glyph width | 1 | 1 | X | 16 bit integer value from 0 to 65535 | Notes: This register holds the width of the glyph in bytes (range 0...31) which is just about to be downloaded via the *GlyphData* register. This must be sent for every download as it sets up some state used to manage the download. # DownloadTarget NameTypeOffsetFormatDownloadTarget2DSetup0xB650Tag nameControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 012 | Tag name | 1 | ✓ | X | | Notes: This tag holds the register the various download operations will write the expanded or generated data to. It can hold any legal tag, but typically will be set to **FBData** or **FBSourceData**. #### dQ1dx | Name | Type | Offset | Format | |-------|------------------|--------|-------------| | dQ1dx | Texture | 0x8438 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | ✓ | X | | Notes: dQ1dx holds the X gradient values for the Q1 texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is arbitrary but must be consistent for all S1, T1 and Q1 values. # dQ1dyDom | Name | Type | Offset | Format | |----------|------------------|--------|-------------| | dQ1dyDom | Texture | 0x8440 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | ✓ | X | | | n31 | Integer | 1 | 1 | X | | Notes: dQ1dyDom holds the Y gradient values along the dominant edge for the Q1 texture coordinate. The format is 32 bit 2's complement fixed point. The binary point is at an arbitrary location, but must be consistent for all S1, T1 and Q1 values. #### dQdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dQdx | Texture | 0x83C0 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | ✓ | X | | Notes: Sets the X derivative for the Q parameter for texture map interpolation. The value is in 32 bit 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ### dQdy | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dQdy | Texture | 0x83E8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | 1 | X | | Notes: The register holds the Y gradient value for the Q texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ### dQdyDom | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | dQdyDom | Texture | 0x83C8 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | 1 | X | | Notes: Sets the Y derivative dominant for the Q parameter for texture map interpolation. Expressed in 32 bit 2's complement fixed point, binary point arbitrary but must be consistent for all S, T and Q values. #### DrawLine01 | Name | Type | Offset | Format | |-----------|---------|--------|----------| | DrawLine0 | Delta | 0x9318 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|----------|-------|----------------| | 015 | X | X | <b>v</b> | X | 2's complement | | 1631 | Y | X | <b>'</b> | X | 2's complement | Notes: • DrawLine0 sets up and renders a line from vertex 0 to vertex1, DrawLine1 draws a line from vertex 1 to vertex 0. The vertices are loaded separatel ### DrawLine10 Name Туре Offset Format Delta Bitfield DrawLine01 0x9320 Command | Bits | Name | Read | Write | Reset | Description | |------|------|------|----------|-------|----------------| | 015 | X | X | <b>~</b> | X | 2's complement | | 1631 | Y | X | <b>~</b> | X | 2's complement | Notes: Initiates a line (between V1 and V0) set up and render. DrawLine01 draws a line from vertex 0 to vertex1, DrawLine10 draws a line from vertex 1 to # DrawTriangle Name Type Offset **Format** DrawTriangle Delta 0x9308 Bitfield Command | Bits | Name | Read | Write | Reset | Description | | |------|-------------------------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0 | AreaStipple<br>Enable | X | ~ | X | Area stippling enable | | | 1 | LineStipple<br>Enable | × | ~ | X | Line stippling enable. | | | 2 | ResetLine<br>Stipple | × | ~ | X | Reset line stipple counters | | | 3 | FastFillEnable | X | ~ | X | Enable span fills | | | 4, 5 | Unused | 0 | 0 | X | | | | 6, 7 | Primitive Type | × | ~ | | Select primitive type:<br>0 = Line 1 = Trapezoid 2 = Point | | | 8 | Antialiase<br>Enable | X | ~ | | Enables antialiasing | | | 9 | Antialiasing<br>Quality | × | ~ | | Set (=1) sub pixel resolution to 8x8<br>Reset (=0) sub pixel resolution to 4x4. | | | 10 | UsePoint Table | × | - | | When this bit and the AntialiasingEnable are set, the dx values used to move from one scanline to the next are derived from the Point Table. | | | 11 | SyncOnBit<br>Mask | × | ~ | | See Render command for details | | | 12 | SyncOnHost<br>Data | X | • | | When this bit is set a fragment is produced only when one of the following registers have been received from the host: <i>Depth, Stencil, Color</i> or <i>FBData, FBSourceData</i> | | | 13 | TextureEnable | X | ~ | X | 1 = Enable 0 = Disable Enables texturing of the fragments produced during rasterisation. Used primarily to disable texture for specific primitives. C.f. <b>DeltaMode</b> register. | | | 14 | FogEnable | × | ~ | X | Enables fogging of the fragments produced during rasterisation. Note that the Fog Unit must be suitably enabled as well for any fogging to occur. | |------|----------------------------------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | Coverage<br>Enable | × | ~ | X | Enables the coverage value produced as part of the antialiasing to weight the alpha value in the alpha test unit. | | 16 | SubPixel<br>Correction<br>Enable | X | ~ | х | Enables the sub pixel correction of the color, depth, fog and texture values at the start of a scanline. | | 17 | RejectNegative<br>Face | × | ~ | X | Reject faces with negative area if backface cull is enabled | | 18 | SpanOperation | X | ~ | X | Indicates the writes are to use the constant color found in the previous FBBlockColor register. | | 1926 | Reserved | X | X | X | Reserved | | 27 | FBSourceRead<br>Enable | X | ~ | X | Enables source buffer reads to be done in the Framebuffer Read Unit. | Notes: Initiates a triangle set up and render. *Command* - data field duplicates the Render command – for details see the *Render* command description. #### dRdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dRdx | Color DDA | 0x8788 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|--------|-------------| | 014 | Fraction | 1 | 1 | v | | | 1523 | Integer | <b>V</b> | <b>V</b> | X<br>V | | | 2431 | | 0 | 0 | Λ | | | 2431 | Unused | U | U | X | | Notes: Used to set the X derivative for the Red value for the interior of a trapezoid when in Gouraud shading mode. The format is 24 bit 2's complement 9.15 fixed point numbers. #### dRdyDom NameTypeOffsetFormatdRdyDomColor0x8790Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | ✓ | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: This register is used to set the Y derivative dominant for the Red value along a line, or for the dominant edge of a trapezoid, when in Gouraud shading mode. The value is in 2's complement 9.15 fixed point format. #### dS1dx NameTypeOffsetFormatdS1dxTexture0x8408Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | 1 | X | | Notes: dS1dx holds the X gradient value for the S1 texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location, but must be consistent for all S1, T1 and Q1 values. Register known as **TexelCoordUV** in MS, Permedia2 and earlier chipsets. # dS1dyDom NameTypeOffsetFormatdS1dyDomTexture0x8410Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | x | | | n31 | Integer | 1 | 1 | X | | Notes: The dominant edge gradient of the texture S1 parameter. The format is 32 bit 2's complement fixed point numbers. The value is in 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S1, T1 and Q1 values. Register known as **TexelCoordU** in MS, Permedia2 and earlier chipsets. #### dSdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | DSdx | Texture | 0x8390 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | 1 | X | | Notes: Sets the X derivative for the S parameter for texture map interpolation. The value is in 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. # dSdy | Name | Type | Offset | Format | |------|------------------|--------|-------------| | DSdy | Texture | 0x83D8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | x | | | n31 | Integer | 1 | 1 | X | | Notes: The register holds the Y gradient value for the S texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ## dSdyDom | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | DSdyDom | Texture | 0x8398 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------| | 0n | Fraction | ✓ | <b>✓</b> | X | | | n31 | Integer | ✓ | 1 | X | | Notes: Sets the Y derivative dominant for the S parameter for texture map interpolation. Expressed in 2's complement fixed point, binary point arbitrary but must be consistent for all S, T and Q values. #### dT1dx | Name | Type | Offset | Format | |-------|------------------|--------|-------------| | DT1dx | Texture | 0x8420 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | 1 | X | | Notes: dT1dx holds the X gradient value for the T1 texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S1, T1 and Q1 values. # dT1dyDom | Name | Type | Offset | Format | |----------|------------------|--------|-------------| | DT1dyDom | Texture | 0x8428 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | 1 | X | | Notes: The dominant edge gradient of the texture T1 parameter. The format is 32 bit 2's complement fixed point numbers. The value is in 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S1, T1 and Q1 values. #### dTdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dTdx | Texture | 0x83A8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | x | | | n31 | Integer | 1 | 1 | X | | Notes: Sets the X derivative for the T parameter for texture map interpolation. The value is in 32 bit 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ### dTdy | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dTdy | Texture | 0x83E0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | 1 | X | | Notes: The register holds the Y gradient value for the T texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. # dTdyDom | Name | Type | Offset | Format | | | |---------|------------------|--------|-------------|--|--| | dTdyDom | Texture | 0x83B0 | Fixed point | | | | | Control register | | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | x | | | n31 | Integer | 1 | 1 | X | | Notes: Sets the Y derivative dominant for the T parameter for texture map interpolation. Expressed in 2's complement fixed point, binary point arbitrary but must be consistent for all S, T and Q values. #### dXDom | Name | Type | Offset | Format | |------------------|------------------|--------|-------------| | Delta X Dominant | Rasterizer | 0x8008 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | 1 | X | X | | | 1631 | Integer | 1 | X | X | | Notes: The gradient for the dominant edge held as a 16.16 fixed point 2s complement value. Value added when moving from one scanline (or sub scanline) to the next for the dominant edge in trapezoid filling. The register also holds the change in X when plotting lines. For Y major lines this will be some fraction (dx/dy), otherwise it is normally $\pm$ 1.0, depending on the required scanning direction. #### dXSub | Name | Type | Offset | Format | | |---------------------|------------------|--------|-------------|--| | Delta X Subordinate | Rasterizer | 0x8018 | Fixed point | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | ✓ | X | X | | | 1631 | Integer | 1 | X | X | | Notes: The gradient for the subordinate edge: the value added when moving from one scanline or sub scanline to the next for the subordinate edge in trapezoid filling. Two's complement fixed point 16.16 format. #### dY | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | Delta Y | Rasterizer | 0x8028 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | 1 | X | X | | | 1631 | Integer | 1 | X | X | | Notes: The change in Y between scanlines or sub-scanlines: the value added to Y to move from one scanline to the next. For X major lines this will be some fraction (dy/dx), otherwise it is normally $\pm$ 1.0, depending on the required scanning direction. Two's complement fixed point 16.16 format. #### dZdxL | Name | Type | Offset | Format | |-------|------------------|--------|------------------| | dZdxL | Fog | 0x89C8 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------| | 015 | Reserved | 0 | 0 | X | LSBs all 0 | | 1631 | Integer | 1 | 1 | X | 16bit LSB part of 32.16 fixed point value | Notes: dZdxL and dZdxU set the depth derivative per unit in X used in rendering trapezoids and/or for Fog when Fog mode is UseZ. dZdxU holds the 32 most significant bits, and dZdxL the least significant 16 bits. The value is in 2's complement 32.16 fixed point format. ### dZdxU | Name | Type | Offset | Format | |-------|------------------|--------|------------------| | dZdxU | Fog | 0x89C0 | Fixed point pair | | | Control register | | | Control register | ] | Bits | Name | Read | Write | Reset | Description | |---|------|-------|------|-------|-------|----------------| | 3 | 3263 | dZdxU | 1 | 1 | x | 32 bit integer | Notes: dZdxL and dZdxU set the depth derivative per unit in X used in rendering trapezoids and/or for Fog when Fog mode is UseZ. dZdxU holds the 32 most significant bits, and dZdxL the least significant 16 bits. The value is in 2's complement 32.16 fixed point format. ## dZdyDomL | Name | Type | Offset | Format | |----------|------------------|--------|------------------| | dZdyDomL | Fog | 0x89D8 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------| | 015 | Reserved | X | X | X | LSBs all 0 | | 1631 | Integer | 1 | 1 | X | 16bit LSB part or 32.16 value | Notes: dZdyDomL and dZdyDomU set the depth derivative per unit in Y along the dominant edge or along a line during trapezoid rendering when Fog mode is "UseZ". dZdyDomU holds the most significant bits, and the least significant bits. The value is in 2's complement 32.16 fixed point format. # dZdyDomU | Name | Type | Offset | Format | |----------|------------------|--------|------------------| | DZdyDomU | Fog | 0x89D0 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|---------------------| | 3263 | Integer | 1 | 1 | X | 32 bit integer part | Notes: DZdyDomU and dZdyDomL set the depth derivative per unit in Y for the dominant edge, or along a line. DZdyDomU holds the most significant bits, and dZdyDomL the least significant bits. The value is in 2's complement 32.16 fixed point format. #### End | Name | Type | Offset | Format | |------|------------------|--------|-------------| | End | Delta | 0x9598 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Fraction | 1 | X | X | | Terminates a Begin/End pair defining a primitive to render. End simply consumes the message since it is not used subsequently. See **Begin**. #### **EndOfFeedback** | Name | Type | Offset | Format | | |---------------|---------|--------|--------|--| | EndOfFeedback | Output | 0x8FF8 | unused | | | | Command | | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|----------|-------|-------------| | 0 | EndofFeedback | X | <b>/</b> | X | Command tag | DMA transfers to or from the R4 Host Out FIFO can use either a fixed count (where the precise amount of data is known) or a variable count (where the amount of data is unknown or undefined). EndofFeedback is used to terminate DMA variable-length mode transfers. #### Variable Count: Typically, variable count mode is used for Context Dump or Run Length Encoded data. In this mode the Output DMA controller is placed in Feedback mode and continues to transfer data from the Host Out FIFO until it finds an EndOfFeedback tag. The FilterMode register should be set up by setting bits 18 and 19 to allow both context data and tags through so tags and data inappropriate to this mode can be discarded and the EndOfFeedback tag can be identified. Bit 20 of the FilterMode register enables RLE data into the output FIFO. The Host Out FIFO does not need to be empty but this would be preferable. The PCI register holds the number of words written to memory when the Output DMA has finished. This method relieves the programmer from knowing beforehand how much context data will be saved. When R4 is used in conjunction with G1/G2, this tag is reserved for use by the Note: *Gamma and does not affect the rasterizer(s).* #### **FBBlockColor** | Name | Type | Offset | Format | | |--------------|------------------|--------|---------|--| | FBBlockColor | Framebuffer | 0x8AC8 | integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------------------------| | 031 | Color | 1 | 1 | X | 32 bit raw framebuffer format | Notes: Holds the color and optionally alpha value to write during span writes. The data is in raw framebuffer format and is automatically replicated up to 128 bits and loaded into FBBlockColor[0...3]. The local registers as well as the registers in the memory devices are updated. This color information is used for constant color transparent span fills or constant color opaque span fill for foreground pixels. Readback returns the data in FBBlockcolor0. # FBBlockColor [0] FBBlockColor [1] FBBlockColor [2] FBBlockColor [3] NameTypeOffsetFormatFBBlockColor [0...3]Framebuffer0xB060, 0xB068, 0xB070, 0xB078 Control registers | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|------------------------------| | 031 | Color word 1 | 1 | 1 | X | 32 bit raw framebuffer value | Notes: These registers update the corresponding 32 bits of block color (in raw framebuffer format) in the local register and memory devices. This color information is used for constant color transparent span fills or constant color opaque span fill for foreground pixels. Use of the individual registers allows different colors for pattern fills, for example. #### **FBBlockColorBack** NameTypeOffsetFormatFBBlockColorBackFramebuffer0xB0A0IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-------------------------------| | 031 | Color word | 1 | 1 | x | 32 bit raw framebuffer format | Notes: Holds the color and optionally alpha value to write during span writes. The data is in raw framebuffer format and is automatically replicated up to 128 bits. The local registers, FBBlockColorBack[0...3] are updated. This color information is used for constant color transparent span fills or constant color opaque span fill for foreground pixels. Readback returns the data in FBBlockcolor0. # FBBlockColorBack [0] FBBlockColorBack [1] FBBlockColorBack [2] FBBlockColorBack [3] NameTypeOffsetFormatFBBlockColorBack [0...3]Framebuffer0xB080, 0xB088, 0xB088, 0xB098integer Control registers | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|------------------------------| | 031 | Color word 1 | 1 | 1 | X | 32 bit raw framebuffer value | Notes: These registers update the corresponding 32 bits of block color (in raw framebuffer format) in the local register. This color information is used for constant color transparent span fills or constant color opaque span fill for background pixels. #### **FBColor** NameTypeOffsetFormatFBColorFramebuffer0x8A98Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | X | X | Reserved | Notes: Internal register used in image upload and processed as configured in FilterMode settings. This register should not be written to. It is documented solely to provide the tag name of the data returned through the Host Out FIFO. Format depends on the raw framebuffer organization and any reformatting which takes place in the Color unit. Processing ## FBDestReadBufferAddr[0...3] NameTypeOffsetFormatFBDestReadBufferAddrFramebuffer0xAE80, 0xAE88, 0xAE88, 0xAE98Integer[0...3]0xAE90, 0xAE98 Control registers | | Bits | Name | Read | Write | Reset | Description | |---|------|---------|------|-------|-------|--------------| | Ī | 031 | Address | 1 | 1 | X | 32 bit value | Notes: Holds the 32 bit base address of the four destination buffers in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. ## FBDestReadBufferOffset[0...3] NameTypeOffsetFormatFBDestReadBufferOffsetFramebuffer0xAEA0, 0xAEA8, Integer[0...3]0xAEB0, 0xAEB8 Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X offset | | 1631 | Y offset | 1 | ✓ | X | 2's complement Y offset | Notes: These registers hold the offset added to the fragment's coordinate for each destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). ## FBDestReadBufferWidth[0...3] NameTypeOffsetFormatFBDestReadBufferWidthFramebuffer0xAEC0, 0xAEC8,Integer[0...3]0xAED0, 0xAED8 Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|------------------------| | 011 | Width | 1 | 1 | X | 12 bit width of buffer | Notes: Holds the width of each destination buffer. The width is held as a 12 bit unsigned integer so has the range 0...4095. Bitfield Logic Mask # FBDestReadEnables FBDestReadEnablesAnd FBDestReadEnablesOr FBDestReadEnablesOr NameTypeOffsetFormatFBDestReadEnablesFramebuffer0xAEE8BitfieldFBDestReadEnablesAndFramebuffer0xAD20Bitfield Logic Mask Framebuffer Control registers | Bits | Name | Read<br>13 | Write | Reset | Description | |------|--------------------|------------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 03 | E0 to E3 | • | ~ | X | These bits are the Enable bits. Software assigns these to major modes which can be enabled or disabled (such as Alpha Blending) it wants the FB Read Unit to track so destination reads are automatically done when necessary. When a bit is 1 it is enabled. E0E3 are used for fragments. | | 47 | E4 to E7 | <b>/</b> | ~ | X | Used for spans | | 811 | R0 to R3 | <b>V</b> | ~ | | These are Read bits. Software assigns these to operations within a major mode which require reads. For example the major mode would be Alpha Blending, but not all alpha blending option require the destination buffer to be read. When a bit is 1 a read is required. R0R3 are used for fragments. | | 1215 | GLINT R4 to<br>R7 | ~ | ~ | x | Used for spans | | 2431 | Reference<br>Alpha | ~ | ~ | x | This is the alpha value used to disable reads when AlphaFiltering is enabled. | 0xAD28 Notes: Monitors potential FB Read activity on up to 4 parameters assignable in software. E.g.: E0 = Alpha Blend Enable R0 = Set whenever an alpha blend mode requires a read E1 = logically Enable R1 = Set whenever a logical operation requires a read The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 5-66 **3D**labs $<sup>^{13}</sup>$ Logic Op register readback is via the main register only ## FBDestReadMode FBDestReadModeAnd FBDestReadModeOr | Name | Type | Offset | Format | |-------------------|-------------------|--------|---------------------| | FBDestReadMode | Alpha Blend | 0xAEE0 | Bitfield | | FBDestReadModeAnd | Alpha Blend | 0xAC90 | Bitfield Logic Mask | | FBDestReadModeOr | Alpha Blend | 0xAC98 | Bitfield Logic Mask | | | Control registers | | _ | | Bits | Name | Read<br>14 | Write | Reset | Description | |------|--------------|------------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | ReadEnable | ~ | ~ | x | This bit, when set, causes fragments or spans to read from the those buffers which are enabled (Enable[03] fields). If this bit is clear then no reads from any of the destination buffers are made. | | 1 | Reserved | X | X | X | | | 24 | Stripe Pitch | ~ | ~ | X | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs times StripeHeight. The options are: $0 = 1$ $4 = 16$ $1 = 2$ $5 = 32$ $2 = 4$ $6 = 64$ $3 = 8$ $7 = 128$ This field will normally be set to zero for R4. | | 57 | StripeHeight | ~ | • | X | This field specifies the number of scanlines in a stripe. The options are: $0 = 1$ $3 = 8$ $1 = 2$ $4 = 16$ $2 = 4$ This field will normally be set to zero for R4. | | 8 | Enable0 | ~ | ~ | x | Enable reading from buffers 0. The ReadEnable bit must also be set. | | 9 | Enable1 | ~ | ~ | X | Enable reading from buffers 1. | | 10 | Enable2 | ~ | <b>'</b> | X | Enable reading from buffers 2. | | 11 | Enable3 | ~ | <b>'</b> | X | Enable reading from buffers 3. | | 1213 | Layout0 | ~ | V | X | Selects the layout of the pixel data in memory for buffer 0. The options are: 0 = Linear 1 = Patch64 Color buffer 2 = Patch32_2 Large texture maps 3 = Patch2 Small texture maps Note: 32_2 and Patch2 are not supported for span reads. | | 1415 | Layout1 | ~ | ~ | X | Selects the layout of the pixel data in memory for buffer 1. | $<sup>^{14}</sup>$ Logic Op register readback is via the main register only | 1617 | Layout2 | <b>/</b> | V | X | Selects the layout of the pixel data in memory for | |------|-----------------|----------|----------|-------------------------------------------------------|-------------------------------------------------------------| | | | | | | buffer 2. | | 1819 | Layout3 | <b>~</b> | ~ | X | Selects the layout of the pixel data in memory for | | | | | | | buffer 3. | | 20 | Origin0 | <b>/</b> | ~ | X | These fields selects where the window origin is for | | 21 | Origin1 | | | | buffer 03 respectively. The options are: | | 22 | Origin2 | | | | 0 = Top Left. | | 23 | Origin3 | | | | 1 = Bottom Left | | 24 | Blocking | <b>/</b> | ~ | X | This bit, when set, causes destination span reads to | | | | | | | block to prevent reads and writes from overlapping (in | | | | | | | time). Each span is read in full and then written. This | | | | | | | is less efficient than streaming (bit is clear), but allows | | | | | | overlapping blits (spans overlap) without corruption. | | | | | | | | Note this does not need to be set if the destination | | | | | | | read and write buffers are the same. | | 25 | Reserved | 0 | 0 | X | | | 26 | UseRead | <b>/</b> | <b>~</b> | X | When this bits is set the enables in the | | | Enables | | | | FBDestReadEnables register are used to determine if a | | | | | | | destination read is required. The ReadEnable bit must | | | | | | | also be set and the corresponding buffer bits as well | | | | | | | for a read to occur. | | 27 | Alpha Filtering | ~ | <b>✓</b> | X | This bit, when set, compares the fragment's alpha | | | | | | | value and if it is equal to the AlphaReference value | | | | | | | (held in the FBReadEnables register) then no read is | | | | | | | done. This is done to save memory bandwidth when | | | | | | | the alpha blend mode is such that with the given alpha | | | | | | | value the destination color doesn't contribute to the | | | | | | | fragment's color. | Notes: The destination address calculation(s) are controlled by the FBDestReadMode register and the address is a function of X, Y, FBDestReadBufferAddr, FBDestReadBufferOffset, FBDestReadBufferWidth and PixelSize parameters. The Addr, Offset and Width are specified independently for each of the four possible write buffers. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ### **FBHardwareWriteMask** Name Type Offset Format FBHardwareWriteMask Framebuffer 0x8AC0 Control registerr | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-------------| | 031 | Write mask | 1 | 1 | X | 32 bit mask | Notes: This message holds the write mask used for all writes. When a bit is set the corresponding bit in each framebuffer word is set (enabled for writing). The masking is actually done in the memory devices so has zero impact on performance and doesn't require any reads. - The hardware write mask applies only where a framebuffer hardware writemask is configured. Where it is not supported, this register should not be written to. - Where hardware writemask is supported and used, the software writemask must be disabled by setting all bits to 1. - If the framebuffer is used in 8bit packed mode the hardware writemask must be 8 bits wide and replicated to all four bytes of this register. #### **FBSoftwareWriteMask** NameTypeOffsetFormatFBSoftwareWriteMaskFramebuffer0x8820intControl registers | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-------------| | 031 | Write mask | 1 | 1 | X | 32 bit mask | Notes: Contains the software writemask for the framebuffer: - If a bit is set (=1) then the corresponding bit in the framebuffer is enabled for writing. - If hardware writemasking is implemented then the software writemask must be disabled by setting all bits to 1. - Framebuffer destination reads should be enabled if the write mask is *not* set to all ones. #### **FBSourceReadBufferAddr** | Name | Type | Offset | Format | |------------------------|------------------|--------|---------| | FBSourceReadBufferAddr | Framebuffer | 0xAF08 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | 1 | 1 | x | 32 bit value | Notes: This register holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. #### **FBSourceReadBufferOffset** | Name | Type | Offset | Format | |--------------------------|------------------|--------|---------| | FBSourceReadBufferOffset | Framebuffer | 0xAF10 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | 1 | 1 | X | 2's complement X offset | | 1631 | Y offset | 1 | 1 | X | 2's complement Y offset | Notes: Holds the offset added to the fragment's coordinate for the source buffer. The new coordinates are used for address calculations. The offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). ### **FBSourceReadBufferWidth** | Name | Type | Offset | Format | |-------------------------|------------------|--------|---------| | FBSourceReadBufferWidth | Framebuffer | 0xAF18 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------| | 011 | Width | 1 | 1 | X | 12 bit buffer width | Notes: This register holds the width of the source buffer. The width is held as a 12 bit unsigned integer so has the range 0...4095. ## FBSourceReadModeAnd FBSourceReadModeOr | Name | Type | Offset | Format | |---------------------|------------------|--------|----------| | FBSourceReadMode | Framebuffer | 0xAF00 | Bitfield | | FBSourceReadModeAnd | Framebuffer | 0xACA0 | Bitfield | | FBSourceReadModeOr | Framebuffer | 0xACA8 | Bitfield | | | Control register | | | | Bits | Name | Read<br>15 | Write | Reset | Description | |------|---------------|------------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | ReadEnable | ~ | • | x | This bit, when set, causes fragments or spans to read from the source buffer providing they are enabled in the <i>Render command</i> (using the FBSourceReadEnable bit, bit 27). If this bit is clear then no source reads are made. | | 1 | Reserved | X | X | X | | | 24 | StripePitch | ~ | V | X | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs * StripeHeight. The options are: $0 = 1$ $4 = 16$ $1 = 2$ $5 = 32$ $2 = 4$ $6 = 64$ $3 = 8$ $7 = 128$ This field will normally be set to zero for R4. | | 57 | Stripe Height | ~ | ~ | x | This field specifies the number of scanlines in a stripe. The options are: $0 = 1$ $3 = 8$ $1 = 2$ $4 = 16$ $2 = 4$ This field will normally be set to zero for R4. | | 89 | Layout | ~ | <b>V</b> | X | This field selects the layout of the pixel data in memory for buffer 03 respectively. The options are: 0 = Linear 1 = Patch64 | | 10 | Origin | ~ | ~ | X | This field selects where the window origin is. The options are: 0 = Top Left. 1 = Bottom Left | $<sup>^{15}</sup>$ Logic Op register readback is via the main register only | 11 | Blocking | ~ | V | x | This bit, when set, causes source span reads to block to prevent reads and writes from overlapping (in time). Each span is read in full and then written. This is less efficient than streaming (bit is clear), but allows overlapping blits (spans overlap) without corruption. | |------|-------------------------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12 | Reserved | X | X | X | | | 13 | UseTexel<br>Coord | V | V | X | This bit, when set, allows the texel coordinate generated in the Texture Read Unit to be used instead of the fragments X, Y coordinate as part of the source address calculation. The Texture Read Unit must also be set up as appropriate, although failure to do so will not cause a chip hang. This bit should not be set when span reads are done. This is useful for stretch blits when the source is the framebuffer. | | 14 | WrapX Enable | V | V | x | This bit, when set, causes the X coordinate to be wrapped. The wrapping is done on power of two pixel boundaries as defined in the WrapX field. When span reads are used the wrapping point must be a multiple of 16 bytes so smaller patterns must be replicated in X to be this width. Normal pixel reads do not suffer from this restriction. | | 15 | WrapY Enable | V | • | X | This bit, when set, causes the Y coordinate to be wrapped. The wrapping is done on power of two pixel boundaries as defined in the WrapY field. | | 1619 | WrapX | ~ | ~ | x | This field defines the mask to use for X wrapping. The options are: $09 \qquad \text{mask} = 2^{(\text{WrapX} + 1)} - 1$ $1015 \qquad \text{mask} = 0 \text{xffff}$ | | 2023 | WrapY | | | | This field defines the mask to use for Y wrapping. The options are: $09 \qquad \text{mask} = 2^{(\text{WrapY} + 1)} - 1$ $1015 \qquad \text{mask} = 0 \text{xffff}$ | | 24 | External Source<br>Data | | | | This bit, when set, indicates that even though source reads are disabled source data is being provided from an external source. This will be data downloaded by the host (using the Color command) or from the LUT. This data is interleaved with the destination data as if the source data had really been read from memory. This is important for span logical op processing when the source data is <i>not</i> from memory. | | 2531 | Unused | 0 | 0 | X | | Notes: Distinct source reads are still needed when a source image is to be blended or logically combined into the destination buffer or buffers. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## FBWriteBufferAddr[0...3] NameTypeOffsetFormatFBWriteBufferAddr[0...3]Framebuffer0xB000, 0xB008, 0xB008, 0xB010, 0xB018Integer Control registers | | Bits | Name | Read | Write | Reset | Description | |---|------|---------|------|-------|-------|--------------| | Ī | 031 | Address | 1 | 1 | X | 32 bit value | Notes: These registers holds the 32 bit base addresses of the four buffers in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size ## FBWriteBufferOffset[0...3] NameTypeOffsetFormatFBWriteBufferOffset[0...3]Framebuffer0xB020, 0xB028, 0xB028, 0xB038Integer Control registers | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | 1 | 1 | X | 2's complement X offset | | 1631 | Y offset | 1 | 1 | X | 2's complement Y offset | Notes: These registers hold the offset added to the fragment's coordinate for each buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). ## FBWriteBufferWidth[0...3] NameTypeOffsetFormatFBWriteBufferWidth[0...3]Framebuffer0xB040, 0xB048, 0xB048, 0xB048, 0xB048, 0xB048Integer 0xB050, 0xB058 Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|------------------------| | 011 | Width | 1 | 1 | X | 12 bit width of buffer | Notes: These registers hold the width of each buffer. The width is held as a 12 bit unsigned integer so has the range 0...4095 ## FBWriteMode FBWriteModeAnd FBWriteModeOr | Name | Type | Offset | Format | |-----------------|-------------------|--------|---------------------| | FBWriteMode | Alpha Blend | 0x8AB8 | Bitfield | | FBWriteMode And | Alpha Blend | 0xACF0 | Bitfield Logic Mask | | FBWriteMode Or | Alpha Blend | 0xACF8 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>16 | Write | Reset | Description | |------|-------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | WriteEnable | ~ | V | x | This bit, when set, causes fragment or spans to write to the buffer 0, or if mulit-reads in FBDestRead are enabled then writes are done to the corresponding buffers which were read. If this bit is clear then no writes to any buffer are made. Note that the Enable[03] bits are ignored unless Replicate is also set. | | 13 | Reserved | <b>V</b> | ~ | X | | | 4 | Replicate | ~ | ~ | x | This bit, when set, causes each fragment or span to be written into all the enabled buffers. It should not be set if multi-buffer reads are enabled in FBDestRead Mode. | | 5 | OpaqueSpan | ~ | ~ | X | This field determines how constant color spans are written (recall the Render command selects between constant color or variable color spans). The options are: 0 = Transparent 1 = Opaque Transparent spans just use one color for the foreground pixels and the background pixels are not written. Opaque spans write to foreground and background pixels using FBBlockColor for the foreground pixels and FBBlockColorBack for the background pixels. | | 68 | StripePitch | ~ | ~ | X | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs * StripeHeight. The options are: $0 = 1$ $4 = 16$ $1 = 2$ $5 = 32$ $2 = 4$ $6 = 64$ $3 = 8$ $7 = 128$ This field will normally be set to 0 for R4. | 5-74 $<sup>^{16}\,\</sup>mathrm{Logic}\,\mathrm{Op}$ register readback is via the main register only | 911 | StripeHeight | <b>'</b> | ~ | X | This field specifies the number of scanlines in a stripe. The options are: $0 = 1$ $3 = 8$ $1 = 2$ $4 = 16$ $2 = 4$ This field will normally be set to 0 for R4. | |------------------------------|------------------------------------------|----------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12<br>13<br>14<br>15 | Enable0<br>Enable1<br>Enable2<br>Enable3 | ~ | ~ | x | These bits, when set, enable writes to buffer 03 respectively during replication. The WriteEnable bit must also be set. | | 1617<br>1819<br>2021<br>2223 | Layout0<br>Layout1<br>Layout2<br>Layout3 | • | V | X | These fields select the layout of the pixel data in memory for buffer 03 respectively. The options are: 0 = Linear 1 = Patch64 Color buffer 2 = Patch32_2 Large texture maps 3 = Patch2 Small texture maps | | 24<br>25<br>26<br>27 | Origin0<br>Origin1<br>Origin2<br>Origin3 | <b>'</b> | ~ | X | These fields select where the window origin is for buffer 03 respectively. The options are: 0 = Top Left. 1 = Bottom Left | | 2831 | Unused | 0 | 0 | X | | Notes: The Framebuffer is responsible for: - Managing the updates to up to 4 memory buffers, - Calculating the write address(es) of the fragment in the memory, - Combining multiple fragments in the same memory word, - Calculating the write addresses of the spans in the memory, - Aligning span data and issuing multiple normal writes, - Implementing transparent or opaque fills, - Dispatch the addresses and data/mask to the Memory Controller . The FBWriteMode command controls write operations. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## **FillBackgroundColor** | Name | Type | Offset | Format | |---------------------|------------------|--------|---------| | FillBackgroundColor | 2DSetup | 0x8330 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Background<br>Color | × | ✓ | X | 32 bit integer | Notes: FillBackgroundColor is an alias for the BackGroundColor register. With ForegroundColor, holds the foreground and background color values. A background pixel is a pixel whose corresponding bit in the color mask is zero. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. # FillConfig2D0 FillConfig2D1 NameTypeOffsetFormatFillConfig2D02DSetup0x8338BitfieldFillConfig2D12DSetup0x8360BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|------------------------------|------|-------|-------|-----------------------------------------------------------------------------------| | 0 | Opaque Span | × | 1 | X | In RasterizerMode, AreaStippleMode, LogicalOpMode, FBWriteMode, TextureReadMode. | | 1 | MultiRXBlit | X | 1 | X | RasterizerMode, ScissorMode - reserved on R4 | | 2 | UserScissorEna<br>ble | × | 1 | X | ScissorMode | | 3 | FBDestReadEn<br>able | X | 1 | X | In FBDestReadMode bit 3 = (ReadEnable) | | 4 | AlphaBlendEna<br>ble | × | 1 | X | In AlphaBlendColorMode and AlphaBlendAlphaMode: bit 4 = AlphaBlendEnable (Enable) | | 5 | DitherEnable | × | 1 | X | In DitherMode: bit 5 = DitherEnable (Enable) | | 6 | ForgroundLogi<br>calOpEnable | × | 1 | X | In LogicalOpMode: bit 6 = ForgroundLogicalOpEnable (Enable) | | 710 | ForgroundLogi<br>calOp | X | ✓ | X | In LogicalOpMode: Bits 7-10 = ForgroundLogicalOp (LogicOp) | | 11 | BackgroundLog icalOpEnable | X | 1 | X | In LogicalOpMode: Bit 11 = BackgroundLogicalOpEnable (Background En.) | | 1215 | BackgroundLog<br>icalOp | × | 1 | X | In LogicalOpMode: Bits 12-15 = BackgroundLogicalOp | | 16 | UseConstantSo<br>urce | × | 1 | X | In LogicalOpMode: bit 16 = UseConstantSource | | 17 | FBWriteEnable | × | 1 | X | In FBWriteMode: bit 17 = FBWriteEnable (WriteEnable) | | 18 | Blocking | × | 1 | X | In FBSourceReadMode bit 18 = Blocking | | 19 | ExternalSource<br>Data | X | 1 | X | In FBSourceReadMode bit 19 = ExternalSourceData | | 20 | LUTMode<br>Enable | × | 1 | X | In LUTMode: bit 20 = Enable | | 2131 | Unused | 0 | 0 | X | | Notes: FillConfig2D0 and FillConfig2D1 are aliases for the Config2D register. This register updates the mode registers in multiple units as shown. The name in brackets is the field name in the corresponding mode register, if different to the field name for the Config2D command. Also note that bit 0 affects several mode registers. #### FillFBDestReadBufferAddr0 NameTypeOffsetFormatFillFBDestReadBufferAddr0Framebuffer0x8310IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | X | 1 | X | 32 bit value | Notes: An alias for FBDestReadBufferAddr0, this register holds the 32 bit base address of the destination buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. #### **FillFBSourceReadBufferAddr** NameTypeOffsetFormatFillFBSourceReadBuffer2DSetup0x8308Integer Addr Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | X | 1 | X | 32 bit value | Notes: This register is an alias for FBSourceReadBufferAddr and holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. #### FillFBSourceReadBufferOffset0 NameTypeOffsetFormatFillFBDestReadBuffer2DSetup0x8340IntegerOffset0 Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | 1 | ✓ | X | 2's complement X offset | | 1631 | Y offset | 1 | ✓ | X | 2's complement Y offset | Notes: Aliasing the FillFBDestReadBufferOffset0 register, this register holds the offset added to the fragment's coordinate for each destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). #### FillFBWriteBufferAddr0 NameTypeOffsetFormatFillFBWriteBuffer Addr02DSetup<br/>Control register0x8300Integer | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | X | 1 | x | 32 bit value | Notes: Aliasing for the FBW riteBuffer Addr0 registers, this register holds the 32 bit base addresses of the buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size ## FillForegroundColor0 NameTypeOffsetFormatFillForegroundColor02DSetup0x8328IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Foreground<br>Color | × | ✓ | X | 32 bit integer | Notes: This registers is an alias for the *ForegroundColor* register. With *BackgroundColor*, holds the foreground and background color values. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. ## FillForegroundColor1 NameTypeOffsetFormatFillForegroundColor12DSetup0x8358IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Foreground<br>Color | × | 1 | X | 32 bit integer | Notes: This register is an alias for the *ForegroundColor* register. With *BackgroundColor*, holds the foreground and background color values. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. ## **FillGlyphPosition** | Name | Type | Offset | Format | |-------------------|------------------|--------|---------| | FillGlyphPosition | 2DSetup | 0x8368 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-----------------------------| | 015 | X offset | X | <b>√</b> | X | 2's complement X coordinate | | 1631 | Y offset | X | 1 | X | 2's complement Y coordinate | Notes: This register is an alias for the *GlyphPosition* register. It defines the glyph origin for use by the *Render2Dglyph* command. ## **FillRectanglePosition** | Name | Type | Offset | Format | |-----------------------|------------------|--------|---------| | FillRectanglePosition | 2DSetup | 0x8348 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 015 | X offset | X | 1 | X | 2's complement X coordinate | | 1631 | Y offset | X | 1 | X | 2's complement Y coordinate | Notes: This is an alias for the Rectangle Position register. It defines the rectangle origin for use by the Render2D command. #### FillRender2D | Name | Type | Offset | Format | |--------------|------------------|--------|----------| | FillRender2D | 2DSetup | 0x8350 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|----------|-------|-----------------------------------------------------------| | | | | | | | | 011 | Width | × | <b>/</b> | X | Specifies the width of the rectangle in pixels. Its range | | | | | | | is 04095. | | 1213 | Operation | X | <b>/</b> | X | This two bits field is encoded as follows: | | | | | | | 0 = Normal | | | | | | | 1 = SyncOnHostData | | | | | | | 2 = SyncOnBitMask | | | | | | | 3 = PatchOrderRendering | | | | | | | The SyncOnHostData and SyncOnBitMask settings | | | | | | | just set the corresponding bit in the Render command. | | | | | | | PatchOrderRendering decomposes the input rectangle | | | | | | | in to a number of smaller rectangels to make better | | | | | | | use of the page structure of patched memory (see | | | | | | | later). | | 14 | FBReadSource | X | V | X | This bit sets the FBReadSourceEnable bit in the | |------|---------------|---|----------|---|----------------------------------------------------------| | | | | | | Render command. | | 15 | SpanOperation | X | <b>V</b> | X | This bit sets the SpanOperation bit in the Render | | | | | | | command. | | 1627 | Height | X | V | X | Specifies the height of the rectangle in pixels. Its | | | | | | | range is 04095. | | 28 | IncreasingX | X | <b>V</b> | X | This bit, when set, specifies the rasterisation is to be | | | | | | | done in increasing X direction. | | 29 | IncreasingY | X | <b>V</b> | X | This bit, when set, specifies the rasterisation is to be | | | | | | | done in increasing Y direction. | | 30 | AreaStipple | X | <b>V</b> | X | This bit sets the AreaStippleEnable bit in the Render | | | | | | | command. | | 31 | Texture | Х | V | X | This bit sets the TextureEnable bit in the Render | | | | | | | command. | Notes: This command starts a rectangle being rendered from the origin given by the RectanglePosition register. ### **FillScissorMaxXY** | Name | Type | Offset | Format | |------------------|------------------|--------|-------------| | FillScissorMaxXY | 2DSetup | 0x8320 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------------------------| | 015 | X coordinate | X | 1 | X | 2's complement fixed point X coordinate | | 1631 | Y coordinate | X | 1 | X | 2's complement fixed point Y coordinate | Notes: This register is an alias for ScissorMaxXY. It holds the maximum XY scissor coordinate - i.e. the rectangle corner farthest from the screen origin. #### **FillScissorMinXY** | Name | Type | Offset | Format | |------------------|------------------|--------|-------------| | FillScissorMinXY | 2DSetup | 0x8318 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------------------------| | 015 | X coordinate | X | 1 | X | 2's complement fixed point X coordinate | | 1631 | Y coordinate | X | 1 | X | 2's complement fixed point Y coordinate | Notes: This register is an alias for the *ScissorMinXY* register. It holds the minimum XY scissor coordinate - i.e. the rectangle corner closest to the screen origin. ## FilterMode FilterModeAnd FilterModeOr | Name | Type | Offset | Format | |---------------|--------|--------|---------------------| | FilterMode | Output | 0x8C00 | Bitfield | | FilterModeAnd | Output | 0xAD00 | Bitfield Logic Mask | | FilterModeOr | Output | 0xAD08 | Bitfield Logic Mask | | | | | | Control registers | Bits | Name | Read<br>17 | Write | Reset | Description | |------|----------------|------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | ActiveTag | ~ | • | X | When set allows the <b>PrepareToRender</b> , <b>SuspendReads</b> , <b>ActiveStepX</b> and <b>ActiveStepYDomEdge</b> tags to be written into the output FIFO. | | 1 | ActiveData | ~ | ~ | x | When set allows the <b>PrepareToRender</b> , <b>SuspendReads</b> , <b>ActiveStepX</b> and ActiveStepYDomEdge data to be written into the output FIFO. | | 2 | PassiveTag | <u>'</u> | ~ | x | When set allows the PassiveStepX and PassiveStepYDomEdge tag to be written into the output FIFO. | | 3 | PassiveData | ~ | ~ | X | When set allows the PassiveStepX and PassiveStepYDomEdge data to be written into the output FIFO. | | 4 | LBDepthTag | ~ | ~ | X | When set allows the <i>LBDepth</i> tag to be written into the output FIFO. | | 5 | LBDepthData | ~ | ~ | X | When set allows the data upload from the Depth buffer to be written into the output FIFO. | | 6 | StencilTag | ~ | ~ | X | When set allows the LBStencil tag to be written into the output FIFO. | | 7 | StencilData | ~ | ~ | X | When set allows the data upload from the Stencil buffer to be written into the output FIFO. | | 8 | FBColorTag | ~ | ~ | X | When set allows the <i>FBColor</i> tag to be written into the output FIFO. | | 9 | FBColorData | ~ | ~ | X | When set allows the data upload from the framebuffer to be written into the output FIFO. | | 10 | SyncTag | ~ | ~ | X | When set allows Sync tag to be written into the output FIFO. | | 11 | SyncData | ~ | ~ | X | When set allows the Sync data to be written into the output FIFO. | | 12 | Statistics Tag | ~ | ~ | x | When set allows the <i>PickResult</i> , <i>MaxHitRegion</i> and <i>MinHitRegion</i> tags to be written into the output FIFO. | | 13 | StatisticsData | ~ | ~ | x | When set allows the <i>PickResult, MaxHitRegion</i> and <i>MinHitRegion</i> data to be written into the output FIFO. | | 14 | RemainderTag | ~ | ~ | X | When set allows any tags not covered by the categories in this table to be written into the output FIFO. | $<sup>^{17}</sup>$ Logic Op register readback is via the main register only | 15 | Remainder<br>Data | ~ | ~ | X | When set allows any data not covered by the categories in this table to be written into the output FIFO. | |------|---------------------------|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1617 | ByteSwap | V | ~ | X | This field controls the byte swapping of the data field when it is written into the output FIFO. The options are: 0 = ABCD (i.e. no swap) 1 = BADC 2 = CDAB 3 = DCBA | | 18 | ContextTag | ~ | ~ | X | When set allows the <i>ContextData</i> and <i>EndOfFeedback</i> tags to be written into the output FIFO. | | 19 | ContextData | ~ | ~ | X | When set allows the ContextData and EndOfFeedback data to be written into the output FIFO. | | 20 | RunLength<br>Encode Data | ~ | ~ | X | This bit, when set, will write run length encoded data into the host out FIFO. | | 21 | ExternalDMA<br>Controller | V | • | X | This bit, when set, changes the protocols which are used when interacting with an external DMA controller (e.g. Gamma II). In this case the protocols are limited to what a PCI bus can support (i.e. limited to 32 bits). When clear an internal DMA controller is used (i.e. in P3) so a more efficient protocol can be used. This bit only has an effect when run length encoding is used. | | 2231 | Reserved | 0 | 0 | x | Reserved | Notes: This register can only be updated if the *Security* register is set to 0. #### Run Length Encoded Data Image data frequently contains runs of the same pixel data so lends itself to run length encoding so less data is needed to describe the image. This does not speed up the image upload from the core's viewpoint as it still needs to read the data, but it reduces the amount of data transferred over the PCI bus, and potentially the host effort in processing/copying the image data. When run length encoding is enabled then *any* data (but not tags) which would have been written into the FIFO is accumulated into the run length while it matches the 32 bit run length value. The accumulated run length is written to the FIFO when: - The new 32 bit word is different from the run being encoded. - A new scanline is started. - The end of the primitive occurs. The amount of data produced during the run length encoding is not known when the DMA controller is set up so an alternative mechanism is used to tell the DMA controller the upload data has finished. This is done by using the EndOfFeedback command and when this is detected in the DMA controller the DMA can be terminated as all the data will have been received. The run length data written into the FIFO depends on where the DMA controller resides. There are two options: - The DMA controller is external (i.e. in Gamma). In this case the tag and data are needed so the DMA controller can track what is going on and know when to finish. In this configuration the tag and data stream shown in the table below is written to the Host out FIFO: - The DMA controller is internal (i.e. on the same die as in the case of P3). In this case a more efficient protocol can be adopted so the tags are not included in the FIFO and an extra bit (on the FIFO width) is used to tell the DMA controller to finish. This bit is only set when an EndOfFeedback tag is received *during RLE processing*. This allows run length data to be uploaded at twice the rate available with an external DMA controller. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. Table 5.2 External DMA Controller FilterMode data | Gamma Name | Tag Value | Data | |---------------|-----------|---------------------------------| | Feedback_X | 0x1F1 | run length ( $max = 0xffffff$ ) | | Feedback_Y | 0x1F2 | run length value | | EndOfFeedback | 0x1FF | 0 (not used) | There are four entries in the output FIFO per run length in the order given in the above table. A zero run length will never be entered into the FIFO. The **EndOfFeedback** tag and null data identify the end of the upload. In normal operation the message filtering is set up so no tags are written to the FIFO and only the data pertinent for the upload is written. Note the tags are internally generated and are essential for any software or the output DMA controller to track and interpret the FIFO contents. If the output DMA controller is used in 'Feedback' mode then the tags are filtered out and just the data is written into memory. *Note:* The Output DMA controller can potentially hang the system when it is in feedback mode and the RunLengthEncodeData bit is <u>not</u> set. In this situation the tag will not be detected by the DMA controller, hence the software will not be informed the upload has finished. The graphics core continues to function but the Output DMA controller loops forever discarding data once the buffer count has expired. If the software is running with a time-out the Output DMA controller can be recovered by setting the *RunLengthEncodedData* bit and sending an **EndOfFeedback** message. Note that this situation should not legitimately occur as the only time when the Output DMA controller is used in feedback mode is when the amount of data to upload is not known and in an R4 only system this will only occur with run length encoded data. The security features of the Host In Unit will prevent accidental modification of the **FilterMode** register and initiation of Output DMA. A GLINT R4 with Gamma does not have this problem as the internal DMA controller is not used. ## **FlushSpan** NameTypeOffsetFormatFlushSpanRasterizer0x8060TagCommand | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 031 | Reserved | X | 0 | X | Reserved for future use | Notes: Causes any partial sub scanlines to be written out - command used when antialiasing to force rasterization of any remaining subscanlines in a primitive. ## **FlushWriteCombining** NameTypeOffsetFormatFlushWriteCombiningInput0x8910IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------| | 031 | Reserved | X | 1 | X | 32 bit value | Notes: ## **FogColor** NameTypeOffsetFormatFogColorFog0x8698BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-------------| | | | | | | | | 07 | Red | <b>~</b> | ~ | X | Red | | 815 | Green | ~ | ~ | X | Green | | 1623 | Blue | <b>V</b> | ~ | X | Blue | | 2431 | Reserved | 0 | 0 | X | Reserved | Notes: This register holds the fog color to use as a basis for interpolation.. ## FogMode FogModeOr | Name | Type | Offset | Format | |------------|-------------------|--------|---------------------| | FogMode | Fog | 0x8690 | Bitfield | | FogModeAnd | Fog | 0xAC10 | Bitfield Logic Mask | | FogModeOr | Fog | 0xAC18 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>18 | Write | Reset | Description | |------|-----------|------------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | V | ~ | X | This bit, when set, and qualified by the FogEnable bit in the <i>Render</i> command causes the current fragment color to be modified by the fog coefficient and background color. | | 1 | ColorMode | ~ | ~ | x | This bit selects the color mode. The two options are: 0 = RGB. The RGB fog equation is used. 1 = CI. The Color Index fog equation is used. | | 2 | Table | V | ~ | x | This bit, when set, causes the Fog Index to be mapped via the FogTable before it controls the blending between the fragment's color and the fog color, otherwise the DDA value is used directly. | | 3 | UseZ | ~ | ~ | x | This bit, when set, causes the DDA to be loaded with the Z DDA values instead of the Fog DDA values. It also adjusts the clamping of the DDA output. | | 48 | ZShift | ~ | V | X | This field specifies the amount the (z from DDA + zBias) is right shifted by before it is clamped against 255 and the bottom 8 bits used as the fog index. This should also take into account the number of depth bits there are. | | 9 | InvertFI | ~ | ~ | X | This bit, when set, inverts the fog index before it is used to interpolates between the fragment's color and the fog color. This is usually 0 when fog values are used and 1 for Z values. Fog values are set up so they decrease with increasing depth and obviously Z values increase with increasing depth. | | 1031 | Unused | 0 | 0 | X | • | Notes: The fog operation takes the Color value from a fragment and interpolates between the Color value (from the primitive's step registers) and a fog Color (from the **FogColor** register) using an internally generated interpolation coefficient. The interpolation coefficient is calculated on a per fragment basis using a DDA unit, and optionally remapped via a look up table. If the fog is disabled (either from the mode register or from the *FogEnable* bit in the **Render** command) then the fragment's Color is passed on to the next unit unchanged. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. $<sup>^{18}</sup>$ Logic Op register readback is via the main register only FogTable[0...15] FogTable[16...31] FogTable[32...47] FogTable[48...63] | Name | Type | Offset | Format | |----------------|-------------------|------------|----------| | FogTable[015] | Fog | 0xB100B178 | Bitfield | | FogTable[1631] | Fog | 0xB180B1F8 | Bitfield | | FogTable[3247] | Fog | 0xB200B278 | Bitfield | | FogTable[4863] | Fog | 0xB280B2F8 | Bitfield | | | Control registers | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|---------------------| | | | | | | | | 07 | | ~ | <b>/</b> | X | Fog index at tag +0 | | 815 | | ~ | ~ | X | Fog index at tag +1 | | 1623 | | ~ | ~ | X | Fog index at tag +2 | | 2431 | | <b>'</b> | V | X | Fog index at tag +3 | Notes: The fog index extracted from the DDA (either as a fog or z value as outlined above) can be used directly to control the blend, or it can be mapped via a table so some non-linear transfer function can be used. The fog table is organised as 256 x 8 so the 8 bit input fog index is mapped to an 8 bit output fog index. The fog table is loaded by the FogTable0...FogTable63 registers and each holds 4 fog values at a time. FogTable0, byte 0 loads the mapping for fog index 0, byte 1 for fog index 1, etc.. The fog table is enabled by the Table bit in FogMode and is independent of how the initial fog index is generated ## **ForegroundColor** | Name | Type | Offset | Format | |-----------------|------------------|--------|---------| | ForegroundColor | LogicOps | 0xB0C0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Foreground<br>Color | ✓ | ✓ | X | 32 bit integer | Notes: With BackgroundColor, holds the foreground and background color values. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. ## **FStart** | Name | Type | Offset | Format | |--------|------------------|--------|-------------| | FStart | Fog | 0x86A0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 021 | Fraction | 1 | 1 | x | | | 2231 | Integer | 1 | 1 | X | | Notes: Fog Coefficient start value. The interpolation coefficient is used to blend the fragment's color with the color in the **FogColor** register. The value is in 2's complement 10.22 fixed point format. ## GIDMode GIDModeAnd GIDModeOr | Name | Type | Offset | Format | |-------------|-------------------|---------|---------------------| | GIDMode | Localbuffer | 0xB538 | Bitfield | | GIDMode And | Localbuffer | 0x B5B0 | Bitfield Logic Mask | | GIDMode Or | Localbuffer | 0x B5B8 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>19 | Write | Reset | Description | |------|--------------------|------------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Fragment<br>Enable | <b>V</b> | • | X | This bit, when set, causes GID testing to occur on fragments. If the test fails then the fragment is discarded | | 1 | Span Enable | • | ~ | X | This bit, when set, allows the span pixel mask to be modified by GID testing each pixel. The mask is modified to disable those pixels which fail the test. | | 25 | Compare Value | ~ | ~ | x | This field holds the 4 bit GID value to compare against. Unused bits (where the GID width in the local buffer format is less than 4 bits) should be set to zero. | | 67 | Compare Mode | ~ | • | X | This field holds the comparison modes available for use during GID testing. The options are: 0 = Always pass 1 = Never pass (i.e. always fail) 2 = Pass when local buffer gid == CompareValue 3 = Pass when local buffer gid!= CompareValue | **3D**labs Proprietary and Confidential 5-87 $<sup>^{19}</sup>$ Logic Op register readback is via the main register only | 89 | Replace Mode | ~ | ~ | X | This field specifies the replacement mode. This is independent of the FragmentEnable bit (except when the replacement depends on the outcome of the GID | |------|---------------|----------|----------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | test). The options are: | | | | | | | 0 = Always replace | | | | | | | 1 = Never replace | | | | | | | 2 = Replace on GID test pass. | | | | | | | 3 = Replace on GID test fails | | 1013 | Replace Value | <b>/</b> | <b>✓</b> | X | This field holds the 4 bit GID value to replace the | | | | | | | value read from the local buffer, if the replace mode is | | | | | | | satisfied. | | 1331 | Reserved | 0 | 0 | X | Reserved | Notes: This register defines the Localbuffer GID operation. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## **GlyphData** | Name | Type | Offset | Format | | |-----------|------------------|--------|---------|--| | GlyphData | 2DSetup | 0xB660 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|----------|----------|-------|------------------------| | 031 | Packed data | <b>/</b> | <b>/</b> | X | Glyph data byte stream | Notes: A byte stream of glyph data (packed four to a word) can be downloaded and automatically chopped up and padded to the necessary width for the texture units to use as a bitmap. For example a gyph with a width between 17 and 24 pixels will be sent down as a stream of bytes and each triplet of bytes will be padded with zero and sent to be written into memory. If the input words have their bytes labelled: First word: DCBA (A is the least significant byte) Second word: HGFE Then the output words send on to the rasterizer are: First word: 0CBA Second word: 0FED ## **GlyphPosition** | Name | Type | Offset | Format | | |---------------|------------------|--------|---------|--| | GlyphPosition | 2DSetup | 0xB608 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 015 | X offset | 1 | 1 | X | 2's complement X coordinate | | 1631 | Y offset | 1 | 1 | X | 2's complement Y coordinate | Notes: This register defines the glyph origin for use by the Render2DGlyph command. This register is updated by the Render2DGlyph command and the updated values will be read back or context dumped. #### **GStart** | Name | Type | Offset | Format | |--------|------------------|--------|--------------------| | GStart | Color | 0x8798 | Fixed point number | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | x | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the initial Green value for a vertex when in Gouraud shading mode. The value is 24 bit 2's complement fixed point numbers in 9.15 format. ## HeadPhysicalPageAllocation[0...3] | Name | Type | Offset | Format | |----------------------------|-------------|--------|---------| | HeadPhysicalPageAllocation | Framebuffer | 0xB480 | Integer | | [03] | | | | Control register | Bits | ] | Name | Read | Write | Reset | Description | |------|---|---------|------|----------|-------|--------------------------------------| | 01 | 5 | Address | ✓ | <b>√</b> | X | 16 bit integer value from 0 to 65535 | Notes: These registers hold the head page for memory pools 0...3. This is usually the most recently referenced physical page in the pool of the working set. The range of physical pages is 0...65535 ## HostinDMAAddr NameTypeOffsetFormatDMAAddrInput0x8938Bitfield Control Register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------| | 01 | Reserved | 0 | 0 | X | | | 231 | Address | ~ | <b>/</b> | X | Address | Notes: This register holds the byte address of the next DMA buffer to read from (reading doesn't start until the *DMACount* command). The bottom two bits of the address are ignored. This register should not be confused with the PCI register of the same name. *DMAAddr* must be loaded by itself and not as part of any increment, hold or indexed group. See also: *DMACount*. #### **HostinID** NameTypeOffsetFormatHostinIDDelta0x8900IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|--------------------| | 031 | Data | 1 | 1 | X | User-defined field | Notes: The HostInID register can be used to mark any point in the command stream so that the use of index and vertex buffers can be monitored. This register is loaded with an ID field; like the DMA address register, which can be read at any time. #### **HostInState** NameTypeOffsetFormatHostInStateDelta0x8918IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|--------------| | 031 | State data | 1 | 1 | X | 32 bit value | Notes: This register is used to store a retained state that must be restored if a context switch occurs part way through a primitive. ### HostInState2 | Name | Type | Offset | Format | |--------------|-------|--------|---------| | HostInState2 | Delta | 0x8940 | Integer | | | | | _ | Control register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|--------------| | 031 | State data | 1 | ✓ | X | 32 bit value | Notes: This register is used to store a retained state that must be restored if a context switch occurs part way through a primitive. #### **IndexBaseAddress** | Name | Type | Offset | Format | | |------------------|------------------|--------|---------|--| | IndexBaseAddress | Input | 0xB700 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------------| | 0 | Reserved | 1 | 1 | X | Reserved | | 116 | Address | 1 | 1 | X | 16 bit address of base of buffer | Notes: ## IndexedDoubleVertex | Name | Type | Offset | Format | | |---------------------|------------------|--------|---------|--| | IndexedDoubleVertex | Input | 0xB7B0 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|---------------------------| | 015 | Index0 | X | 1 | X | Offset into vertex buffer | | 1631 | Index1 | X | 1 | X | Offset into vertex buffer | | Notes: | | | |--------|--|--| ### IndexedLineList NameTypeOffsetFormatIndexedLineListInput0xB728Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | X | 1 | X | Number of indices in primitive | Notes: ## IndexedLineStrip NameTypeOffsetFormatIndexedLineStripInput0xB730Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | X | 1 | X | Number of indices in primitive | Notes: #### IndexedPointList NameTypeOffsetFormatIndexedPointListInput0xB738Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | X | 1 | X | Number of indices in primitive | Notes: ## IndexedPolygon NameTypeOffsetFormatIndexedPolygonInput0xB740Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | X | 1 | X | Number of indices in primitive | Notes: ## Indexed Triangle Fan | Name | Type | Offset | Format | |--------------------|------------------|--------|---------| | IndexedTriangleFan | Input | 0xB718 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | X | 1 | X | Number of indices in primitive | Notes: ## Indexed Triangle List | Name | Type | Offset | Format | |---------------------|------------------|--------|---------| | IndexedTriangleList | Input | 0xB710 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | X | 1 | X | Number of indices in primitive | Notes: ## IndexedTriangleStrip | Name | Type | Offset | Format | |----------------------|------------------|--------|---------| | IndexedTriangleStrip | Input | 0xB720 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | X | 1 | X | Number of indices in primitive | Notes: ## IndexedVertex | Name | Type | Offset | Format | |---------------|------------------|--------|---------| | IndexedVertex | Input | 0xB7A8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------| | 031 | Index | X | 1 | X | Offset into index buffer | Notes: #### InvalidateCache NameTypeOffsetFormatInvalidateCacheTexture0xB358BitfieldCommandCommand | Bits | Name | Read | Write | Reset | Description | | |------|--------|------|----------|-------|------------------------------------|--| | | | | | | | | | 0 | Bank 0 | X | <b>~</b> | X | Invalidate bank 0 of Primary Cache | | | 1 | Bank 1 | X | <b>V</b> | X | Invalidate bank 1 of Primary Cache | | | 2 | TLB | X | <b>v</b> | X | Invalidate TLB | | | 331 | Unused | 0 | 0 | X | Reserved | | Notes: This command invalidates the cache. The bottom three bits control what it to be invalidated. #### **KdBStart** NameTypeOffsetFormatKdBStartTexture0x8D30Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | x | | | 1523 | Integer | 1 | 1 | X | | | 2431 | reserved | 0 | 0 | X | | Notes: KdBStart holds the start value for the Blue Kd color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **KdGStart** | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *KdGStart* holds the start value for the Green Kd color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **KdRStart** | Name | Type | Offset | Format | |----------|------------------|--------|-------------| | KdRStart | Texture | 0x8D00 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: KdRStart holds the start value for the Red Kd color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **KsBStart** | Name | Type | Offset | Format | |----------|------------------|--------|-------------| | KsBStart | Texture | 0x8CB0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: KsBStart holds the start value for the Blue Ks color components. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **KsGStart** | Name | Type | Offset | Format | |----------|------------------|--------|-------------| | KsGStart | Texture | 0x8C98 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | ✓ | 1 | X | | | 2431 | reserved | 0 | 0 | X | | Notes: KsGStart holds the start value for the Green Ks color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **KsRStart** | Name | Type | Offset | Format | |----------|------------------|--------|-------------| | KsRStart | Texture | 0x8C80 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: KsRStart holds the start values for the Red Ks color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **LBClearDataL** | Name | Type | Offset | Format | |--------------|------------------|--------|---------| | LBClearDataL | Localbuffer | 0xB550 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|----------------------| | 031 | Address | 1 | 1 | X | 32 bit integer value | Notes: This register holds the 32 bits of data to write into the local buffer (if so enabled) during a span operation. The data should be in the correct format to match up with the size and position of the depth, stencil and grapics ID fields. #### **LBClearDataU** | Name | Type | Offset | Format | |--------------|------------------|--------|---------| | LBClearDataU | Localbuffer | 0xB558 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|----------------------| | 031 | Address | 1 | 1 | X | 32 bit integer value | Notes: This register holds the 32 bits of data to write into the local buffer (if so enabled) during a span operation. The data should be in the correct format to match up with the size and position of the depth, stencil and grapics ID fields. ## **LBDepth** | Name | Type | Offset | Format | |---------|------------------|--------|---------| | LBDepth | Depth | 0x88B0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|----------------------| | 031 | LBDepth | X | 1 | X | 32 bit integer value | Notes: Internal register used in image upload of the depth buffer. This register should not be written to. It is documented here to give the tag value and format of the data which is read from the Host Out FIFO. Where the depth(Z) buffer width is less than 32bits, the depth value is right justified and zero extended. #### LBDestReadBufferAddr | Name | Type | Offset | Format | |----------------------|------------------|--------|---------| | LBDestReadBufferAddr | Local buffer | 0xB510 | Integer | | | Control register | | | | Bits | | Name | Read | Write | Reset | Description | |------|----|---------|------|-------|-------|--------------| | 03 | 31 | Address | ✓ | 1 | X | 32 bit value | Notes: This register holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected local buffer pixel size. #### LBDestReadBufferOffset | Name | Type | Offset | Format | |------------------------|------------------|--------|---------| | LBDestReadBufferOffset | Localbuffer | 0xB518 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | 1 | 1 | X | 2's complement X offset | | 1631 | Y offset | 1 | 1 | X | 2's complement Y offset | Notes: These registers hold the offset added to the fragment's coordinate for each destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). # LBDestReadEnables LBDestReadEnablesAnd LBDestReadEnablesOr | Name | Type | Offset | Format | |----------------------|-------------|--------|---------------------| | LBDestReadEnables | Localbuffer | 0xB508 | Bitfield | | LBDestReadEnablesAnd | Localbuffer | 0xB590 | Bitfield Logic Mask | | LBDestReadEnablesOr | Localbuffer | 0xB598 | Bitfield Logic Mask | | | C , 1 · , | | _ | Control registers | Bits | Name | Read<br>20 | Write | Reset | Description | |------|-------------------|------------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 03 | E0 to E3 | • | ~ | X | These bits are the Enable bits. Software assigns these to major modes which can be enabled or disabled (such as Depth Testing) it wants the LB Read Unit to track so destination reads are automatically done when necessary. When a bit is 1 it is enabled. E0E3 are used for fragments. | | 47 | E4 to E7 | ~ | <b>/</b> | X | Used for spans | | 811 | R0 to R3 | • | ~ | X | These are Read bits. Software assigns these to operations within a major mode which require reads. For example the major mode would be Depth Testing, but not all depth test option require the destination buffer to be read. When a bit is 1 a read is required. R0R3 are used for fragments. | | 1215 | GLINT R4 to<br>R7 | ~ | ~ | X | Used for spans | | 2431 | Reserved | 0 | 0 | X | Reserved | Notes: This new register contains 8 pairs of bits which the software can assign to activities which could require local buffer reads. The pairs of bits comprise an E bit and a R bit. The E bit reflects a major mode enable (e.g. stencil) and is set whenever that mode is enabled. The R bit is set when the operation within the major mode requires a read. For example: E0 = Depth Enable R0 = Set whenever a depth mode requires a read E1 = Stencil Enable R1 = Set whenever a stencil operation requires a read E2 = GID enable R2 = Set whenever the GID testing is required. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## LBDestReadMode LBDestReadModeAnd LBDestReadModeOr | Name | Type | Offset | Format | | |-------------------|-------------|--------|---------------------|--| | LBDestReadMode | Localbuffer | 0xB500 | Bitfield | | | LBDestReadModeAnd | Localbuffer | 0xB580 | Bitfield Logic Mask | | <sup>&</sup>lt;sup>20</sup> Logic Op register readback is via the main register only 20 LBDestReadModeOr Localbuffer 0xB588 Bitfield Logic Mask \*Control registers\*\* | Bits | Name | Read<br>21 | Write | Reset | Description | |------|--------------------|------------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | ~ | X | This bit, when set, causes fragments or spans to read from the destination buffer | | 1 | Reserved | X | X | X | | | 24 | StripePitch | V | V | x | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. (It would normally be set to a number of RXs * StripeHeight). The options are: $0 = 1 1 = 2 2 = 4 3 = 8 4 = 16$ $5 = 32 6 = 64 7 = 128$ This field will normally be set to zero for R4. | | 57 | StripeHeight | V | ~ | X | This field specifies the number of scanlines in a stripe. The options are: $0 = 1$ $1 = 2$ $2 = 4$ $3 = 8$ $4 = 16$ This field will normally be set to zero for R4. | | 8 | Layout | ~ | ~ | X | This field selects the layout of the pixel data in memory for the destination buffer. The options are: $0 = \text{Linear} \qquad 1 = \text{Patch64}$ | | 9 | Origin | ~ | • | х | This field selects where the window origin is for the destination buffer. The options are: 0 = Top Left. 1 = Bottom Left | | 10 | UseRead<br>Enables | V | ~ | X | When this bits is set the enables in the LBDestReadEnables register are used to determine if a destination read is required. The Enable bit must also be set as well for a read to occur. | | 11 | Packed16 | ~ | ~ | X | When this bit is set the pixel size is 16 bits so a single memory word can hold 8 depht values. | | 1223 | Width | ~ | ~ | X | This field holds the width of the destination buffer. Its range is 04095. | Notes: Defines the localbuffer destination read operation. The destination address calculations are controlled by the LBDestReadMode register and the address is a function of X, Y, LBDestReadBufferAddr, LBDestReadBufferOffset, width and Packed16 parameters. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ### **LBReadFormat** NameTypeOffsetFormatLBReadFormatLocalbuffer0x8888BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | | | | | | | $<sup>^{21}</sup>$ Logic Op register readback is via the main register only | 01 | DepthWidth | ~ | <b>'</b> | x | This field specifies the width of the depth field. The depth field always starts at bit position 0. The width options are: 0 = 16 bits | |------|-----------------|----------|----------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | are ignored and a one bit GID and Stencil are taken from bit 15. Only one of the GID or Stencil operation are enabled to select the desired field type. | | 25 | StencilWidth | ~ | <b>'</b> | X | This field specifies the width of the stencil field. The legal range of values are 08. The stencil field always starts at bit position given in the next field. | | 610 | StencilPosition | ~ | <b>'</b> | X | This field holds position of the least significant bit of the stencil field. The legal range of values are 023, representing bit positions 1639 respectively. | | 1114 | Reserved | 0 | 0 | X | | | 1519 | Reserved | 0 | 0 | X | | | 2022 | GIDWidth | ~ | • | x | This field specifies the width of the Graphics ID field. The legal range of values are 04. The GID field always starts at bit position given in the next field. | | 2327 | GIDPosition | <b>'</b> | • | X | This field holds position of the least significant bit of the Graphics ID field. The legal range of values are 023, representing bit positions 1639 respectively. | | 2831 | Unused | 0 | 0 | X | | Notes: This register defines the position and width of the depth, stencil and GID (Graphics ID) in the data read back from the local buffer. Note: LB ReadFormat register definition has changed to allow more flexible sizing and positioning of the GID and stencil fields. #### **LBSourceReadBufferAddr** NameTypeOffsetFormatLBSourceReadBufferAddrLocalbuffer0xB528IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | 1 | 1 | X | 32 bit value | Notes: This register holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. ### **LBSourceReadBufferOffset** | Name | Type | Offset | Format | |--------------------------|------------------|--------|---------| | LBSourceReadBufferOffset | Localbuffer | 0xB530 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | 1 | 1 | X | 2's complement X offset | | 1631 | Y offset | 1 | 1 | X | 2's complement Y offset | Notes: This register hold the offset added to the fragment's coordinate for the source buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). # LBSourceReadMode LBSourceReadModeAnd LBSourceReadModeOr | Name | Type | Offset | Format | |---------------------|-------------------|--------|---------------------| | LBSourceReadMode | Alpha Blend | 0xB520 | Bitfield | | LBSourceReadModeAnd | Alpha Blend | 0xB5A0 | Bitfield Logic Mask | | LBSourceReadModeOr | Alpha Blend | 0xB5A8 | Bitfield Logic Mask | | | Control registers | | G | | Bits | Name | Read<br>22 | Write | Reset | Description | |------|--------------|------------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | ~ | x | This bit, when set, causes fragments to be read from<br>the source buffer. If this bit is clear then no source<br>reads are made. | | 1 | Reserved | 0 | 0 | X | | | 24 | StripePitch | V | <b>'</b> | x | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs * StripeHeight. The options are: $0 = 1$ $4 = 16$ $1 = 2$ $5 = 32$ $2 = 4$ $6 = 64$ $3 = 8$ $7 = 128$ This field will normally be set to zero for R4. | | 57 | StripeHeight | V | • | X | This field specifies the number of scanlines in a stripe. The options are: $0 = 1$ $3 = 8$ $1 = 2$ $4 = 16$ $2 = 4$ This field will normally be set to zero for R4. | $<sup>^{22}</sup>$ Logic Op register readback is via the main register only | 8 | Layout | ~ | ~ | X | This field selects the layout of the pixel data in memory for the source buffer. The options are: 0 = Linear 1 = Patch64 | |------|----------|---|---|---|---------------------------------------------------------------------------------------------------------------------------| | 9 | Origin | ~ | ~ | X | This field selects where the window origin is. The options are: 0 = Top Left. 1 = Bottom Left | | 10 | Packed16 | ~ | ~ | X | When this bit is set the pixel size is 16 bits so a single memory word can hold 8 depth values. | | 1122 | Width | ~ | ~ | X | This field holds the width of the destination buffer. Its range is 04095. | | 2331 | Reserved | 0 | 0 | X | | Notes: This register defines the Localbuffer source read operation. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### **LBStencil** | Name | Type | Offset | Format | |-----------|-------------|--------|----------| | LBStencil | Localbuffer | 0x88A8 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | | | | | | | | 07 | Stencil | X | X | X | | | 815 | Reserved | X | X | X | | | 1619 | GID | X | X | X | | | 2031 | Reserved | 0 | 0 | X | | Notes: Internal register used in upload of the stencil buffer. It should not be written to and is documented here only to give the tag value and format of the data when read from the host out FIFO. ### **LBWriteBufferAddr** | Name | Type | Offset | Format | |-------------------|------------------|--------|---------| | LBWriteBufferAddr | Localbuffer | 0xB540 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | 1 | 1 | X | 32 bit value | Notes: This register holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. ### **LBWriteBufferOffset** | Name | Type | Offset | Format | |---------------------|------------------|--------|---------| | LBWriteBufferOffset | Localbuffer | 0xB548 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | 1 | 1 | X | 2's complement X offset | | 1631 | Y offset | 1 | 1 | X | 2's complement Y offset | Notes: This register holds the offset added to the fragment's coordinate for the destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). ### **LBWriteFormat** | Name | Type | Offset | <b>Format</b> | |---------------|------------------|--------|---------------| | LBWriteFormat | Localbuffer | 0x88C8 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------------|----------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01 | DepthWidth | ~ | ~ | X | This field specifies the width of the depth field. The depth field always starts at bit position 0. The width options are: 0 = 16 bits 1 = 24 bits 2 = 31 bits 3 = 15 bits When the depth width is 15 the GID and Stencil fields are ignored and a one bit GID and Stencil are taken from bit 15. Only one of the GID or Stencil | | 25 | StencilWidth | ~ | ~ | X | operation are enabled to select the desired field type. This field specifies the width of the stencil field. The legal range of values are 08. The stencil field always starts at bit position given in the next field. | | 610 | StencilPosition | <b>V</b> | <b>'</b> | X | This field holds position of the least significant bit of the stencil field. The legal range of values are 023, representing bit positions 1639 respectively. | | 1119 | Reserved | 0 | 0 | X | | | 2022 | GIDWidth | ~ | ~ | X | This field specifies the width of the Graphics ID field. The legal range of values are 04. The GID field always starts at bit position given in the next field. | | 2327 | GIDPosition | <b>V</b> | ~ | X | This field holds position of the least significant bit of the Graphics ID field. The legal range of values are 023, representing bit positions 1639 respectively. | | 2831 | Reserved | 0 | 0 | X | | Notes: This register defines the position and width of the depth, stencil, GID (Graphics ID) in the data read back from the local buffer. # LBWriteMode LBWriteModeAnd LBWriteModeOr | Name | Type | Offset | Format | |----------------|------------------|--------|----------| | LBWriteMode | Localbuffer | 0x88C0 | Bitfield | | LBWriteModeAnd | Localbuffer | 0xAC80 | Bitfield | | LBWriteModeOr | Localbuffer | 0xAC88 | Bitfield | | | Control register | | | | Bits | Name | Read<br>23 | Write | Reset | Description | |------|--------------|------------|----------|-------|--------------------------------------------------------------| | 0 | WriteEnable | <b>/</b> | <b>/</b> | X | This bit, when set, causes fragments or spans to | | | | | | | written to the destination buffer. Note each byte must | | | | | | | also be enabled in the ByteEnables field. | | 12 | Reserved | 0 | 0 | X | | | 35 | StripePitch | <b>~</b> | <b>✓</b> | X | This field specifies the number of scanlines between | | | | | | | the first scanline in a stripe and the first scanline in the | | | | | | | next stripe. It would normally be set to number of | | | | | | | RXs * StripeHeight. The options are: | | | | | | | 0 = 1 $4 = 16$ | | | | | | | 1 = 2 $5 = 32$ | | | | | | | 2 = 4 $6 = 64$ | | | | | | | 3 = 8 7 = 128 | | | | | | | This field will normally be set to zero for R4. | | 68 | StripeHeight | V | V | X | This field specifies the number of scanlines in a stripe. | | | | | | | The options are: | | | | | | | 0 = 1 $3 = 8$ | | | | | | | 1 = 2 $4 = 16$ | | | | | | | 2=4 | | | | | | | This field will normally be set to zero for R4. | | 9 | Layout | V | ~ | X | This field selects the layout of the pixel data in | | | | | | | memory for the destination buffer. The options are: | | | | | | | 0 = Linear | | | | | | | 1 = Patch64 | | 10 | Origin | <b>V</b> | ~ | X | This field selects where the window origin is for the | | | | | | | destination buffer. The options are: | | | | | | | 0 = Top Left. | | | | | | | 1 = Bottom Left | | 11 | Packed16 | <b>/</b> | ~ | x | When this bit is set the pixel size is 16 bits so a single | | | | | | | memory word can hold 8 depth values. | | 1223 | Width | <b>/</b> | ~ | X | This field holds the width of the destination buffer. | | | | | | | Its range is 04095. | $<sup>^{23}</sup>$ Logic Op register readback is via the main register only | 2428 | ByteEnables | • | V | Х | This field holds the byte enables for each byte in the pixel. A byte enable bit must be set for the corresponding byte to be written. Ideally the depth, stencil, etc. fields are byte aligned and integral bytes in length so these can be used to disable modifying a | |------|-------------|----------|----------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | field, otherwise read-modify-write operations will need to be done. | | 2931 | Operation | <b>'</b> | <b>'</b> | X | This field defines where the data is to be taken from to | | | | | | | do the write and what is to happen to it afterwards. | | | | | | | This is only of interest during an upload or download | | | | | | | operation. The options are: | | | | | | | 0 = No operation | | | | | | | 1 = Download depth | | | | | | | 2 = Download stencil | | | | | | | 3 = Upload depth | | | | | | | 4 = Upload stencil | Notes: The write requests have two forms: - Single pixel. This is the normal mode for 3D operation but is only used for exotic 2D operations. The calculated address is always a pixel address and this is shifted to take into account the width of a pixel (16 or 32 bits) in calculating the memory address and byte enables. The pixel data (Z, stencil and GID) are formatted and shifted into the correct byte lanes for the memory. - Pixel spans. Spans are useful for clearing down the local buffer but do not use any block fill capabilities of the memory (these are only available through the FB Write Unit), although 4 or 8 pixels will be cleared down per cycle. - N.B Write operation is not compatible with GLINT MX for programming purposes. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. Bitfield Logic Mask LineModeOr # LineMode LineModeAnd LineModeOr | Name | Type | Offset | Format | |-------------|-------|--------|---------------------| | LineMode | Delta | 0x94A8 | Bitfield | | LineModeAnd | Delta | 0xAAF0 | Bitfield Logic Mask | Control registers Delta | Bits | Name | Read<br>24 | Write | Reset | Description | |------|-------------------------|------------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | StippleEnable | ~ | ~ | x | This field, when set, enables the stippling of lines. It only effects wide lines or antialiased line set up. This will normally be the same value as the Enable field in the LineStippleMode GLINT register. | | 19 | RepeatFactor | ~ | ~ | x | This field holds the positive repeat factor for antialiased stippled lines. This will normally be the same value as the RepeatFactor field in the LineStippleMode GLINT register. The repeat factor stored here is one less than the desired repeat factor. | | 1025 | StippleMask | • | • | X | This field holds the stipple pattern to use for antialiased lines. This will normally be the same value as the StippleMask field in the LineStippleMode GLINT register. | | 26 | Mirror | • | ~ | X | This field, when set, will mirror the StippleMask before it is used for antialiased lines. This will normally be the same value as the Mirror field in the LineStippleMode GLINT register. | | 27 | AntialiasEnable | ~ | ~ | X | This field, when set, enables antialiasing of lines. This is qualified by the AntialiasEnable field in the Begin message. | | 28 | Antialiasing<br>Quality | ~ | ~ | X | This field defines the quality of antialiased points: 0 4x4 1 8x8 | | 29 | DrawLastPoint | • | ~ | X | This field defines if the last point on a non antialised line should be drawn. The normal state for OpenGL is not to draw, while in D3D this is an option. | 0xAAF8 Notes: Defines how wide and altialiased lines are processed - applies only to lines rendered using RenderLine. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. <sup>&</sup>lt;sup>24</sup> Logic Op register readback is via the main register only # LineStippleModeAnd LineStippleModeAnd LineStippleModeOr | Name | Type | Offset | Format | |--------------------|------------------|--------|---------------------| | LineStippleMode | Stipple | 0x81A8 | Bitfield | | LineStippleModeAnd | Stipple | 0xABC0 | Bitfield Logic Mask | | LineStippleModeOr | Stipple | 0xABC8 | Bitfield Logic Mask | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|----------|----------|-------|-----------------------------------------------------------| | | | | | | | | 0 | StippleEnable | <b>/</b> | <b>/</b> | X | This field, when set, enables the stippling of lines. The | | | | | | | LineStippleEnable bit in the Render command must | | | | | | | also be set. | | 19 | RepeatFactor | <b>/</b> | <b>/</b> | X | This field holds the positive repeat factor for stippled | | | | | | | lines. The repeat factor stored here is one less than | | | | | | | the desired repeat factor. | | 1025 | StippleMask | <b>/</b> | <b>/</b> | X | This field holds the stipple pattern. | | 26 | Mirror | ~ | <b>V</b> | X | This field, when set, will mirror the StippleMask | | | | | | | before it is used. | | 2731 | Unused | 0 | 0 | X | | Notes: Controls line stippling: - The repeat factor is set to one less than the required value. - The least significant bit of the *UpdateLineStippleCounters* register, controls loading the line stipple counters if set the line stipple counters are loaded with the previously saved values. If reset, the counters are cleared to zero. - The counters can also be reset by means of the ResetLineStipple bit in the Render command. - The Enable bit in the *LineStippleMode* register is qualified by the LineStippleEnable bit in the *Render* Command. #### LineWidth NameTypeOffsetFormatLineWidthDelta0x94B0Integer Command register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|---------------------------| | 07 | Width | <b>'</b> | <b>'</b> | X | Widths of 1 to 255 pixels | | 831 | Reserved | 0 | 0 | X | | Notes: Defines the width of an aliased line. A width 0 is considered to be 1. For aliased lines the LineWidth register holds the desired line width. The range of actual line widths are 1...255; a 0 line width is treated as a line width of 1. Lines are drawn according to OpenGL rules so wide lines are a sequence of lines offset in X or Y depending on whether the line is X major or Y major. The LineWidthOffset register is normally set to (line width - 1) / 2. For one pixel wide lines the LineWidthOffset is set to 0. If line stipples are enabled (in the LineMode register) then wide aliased lines will be stippled correctly by repeating the line (offset in X or Y), but with the stipple position re-established for each line used to make up the width. #### LineWidthOffset NameTypeOffsetFormatLineWidthOffsetDelta0x94B8Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 07 | Offset | 1 | 1 | X | Offset | | 831 | Reserved | 0 | 0 | X | | Notes: Defines how far to the left y-major (or lower for x-major) of the true line position an aliased line will be drawn (normally (LineWidth-1)/2). Line width 0 is seen as 1. This sets up the initial offset subtracted from the line's mathematical X (for Y major lines) or Y (for X major lines) before the line is stelled and repeated *LineWidth* times. # LoadLineStippleCounters NameTypeOffsetFormatLoadLineStippleCountersGlobal0x81B0BitfieldCommandCommand | Bits | Name | Read | Write | Reset | Description | |------|--------------------------|------|-------|-------|-------------| | 03 | LiveBit<br>Counter | X | ~ | X | | | 412 | LiveRepeat<br>Counter | × | ~ | X | | | 1316 | SegmentBit<br>Counter | × | ~ | X | | | 1725 | SegmentRepeat<br>Counter | × | ~ | X | | | 2631 | Unused | 0 | 0 | X | | Notes: Command used to restore the line stipple counters and segment register after a task switch. The counters are incremented during a line stipple so the value read from them, via the readback path may not match the value loaded in to them using this register. #### LOD | Name | Type | Offset | Format | |------|------------------|--------|-------------| | LOD | Texture | 0x83D0 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------| | | | | | | | | 07 | Fraction | 1 | 1 | X | | | 811 | Integer | 1 | 1 | X | | | 1231 | Reserved | 0 | 0 | X | Reserved for future use. Mask to 0. | Notes: Holds the computed level of detail value for texture 0. The format is 4.8 unsigned fixed point. The Level Of Detail (LOD) calculates the approximate area a fragment projects onto the texture map. The LOD calculation is enabled by the EnableLOD bit in the TextureCoordMode register. When this bit is clear no LOD is calculated and a constant LOD from the LOD register is used (when it is required by the *TextureReadMode* register setting). The format is unsigned 4.8 fixed point and can be interpreted as follows: - the integer part selects the higher resolution map of the pair to use with 0 using the map at the address given by TextureBaseAddress[0] register - the fraction gives the between map interpolation coefficient measured from the higher resolution map selected. #### LOD1 | Name | Type | Offset | Format | |------|------------------|--------|-------------| | LOD1 | Texture | 0x8448 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 07 | Fraction | 1 | ✓ | X | | | 811 | Integer | 1 | 1 | X | | | 1231 | Reserved | 0 | 0 | X | | Notes: Holds the constant level of detail to use for mip mapping from texture 1. The format is 4.8 unsigned fixed point. The Level Of Detail (LOD) calculates the approximate area a fragment projects onto the texture map. The LOD calculation is enabled by the EnableLOD bit in the TextureCoordMode register. When this bit is clear no LOD is calculated and a constant LOD from the LOD register is used (when it is required by the *TextureReadMode* register). The format is unsigned 4.8 fixed point and can be interpreted as follows: - the integer part selects the higher resolution map of the pair to use with 0 using the map at the address given by TextureBaseAddress[0] register - the fraction gives the between map interpolation coefficient measured from the higher resolution map selected. # LODRange0 | Name | Type | Offset | Format | |-----------|------------------|--------|-------------| | LODRange0 | Texture | 0xB348 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------| | | | | | | | | 011 | Min | 1 | 1 | X | 2's complement 4.8 fixed point fraction | | 1223 | Max | 1 | 1 | X | 2's complement 4.8 fixed point integer | | 2431 | Reserved | 0 | 0 | X | | Notes: This register holds the clamping range for lod0 calculations. Bits 0-11 define the minimum value, bits 12-23 hold the maximum value. # LODRange1 | Name | Type | Offset | Format | | |-----------|------------------|--------|-------------|--| | LODRange1 | Texture | 0xB350 | Fixed point | | | | Control register | | _ | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------| | 011 | Min | 1 | 1 | x | 2's complement 4.8 fixed point fraction | | 1223 | Max | 1 | 1 | X | 2's complement 4.8 fixed point integer | | 2431 | Reserved | 0 | 0 | X | | Notes: This register holds the clamping range for lod1 calculations. Bits 0-11 define the minimum value, bits 12-23 hold the maximum value. # LogicalOpMode LogicalOpModeAnd LogicalOpModeOr NameTypeOffsetFormatLogicalOpModeLogic Ops0x8828Bitfield LogicalOpModeAnd Logic Ops 0xAEC0 Bitfield Logic Mask LogicalOpModeOr Logic Ops 0xAEC8 Bitfield Logic Mask Control registers | Bits | Name | Read<br>25 | Write | Reset | Description | |------|----------------------------|------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | <i>v</i> | ~ | X | When set causes the fragment's color to be logial op'ed under control of the remaining bits in this register. When clear the fragment color remains unchanged that may later to effected by write marking) | | 14 | LogicOp | • | ~ | X | (but may later to effected by write masking). This field defines the logical op function to use. The options are: 0 = Clear (0) | | 5 | UseConstantFB<br>WriteData | • | • | X | There is no longer any performance advantage to using this bit but it is retained for backwards compatability. | | 6 | BackgroundEn<br>able | ~ | ~ | x | This bit, when set, enables a different logical operation to be done for background pixels. If this bit is clear then the same logical operation is applied to foreground and background pixels. Setting this bit when the Enable field is zero has no effect. A background pixel is a pixel whose corresponding bit in the color mask is zero. | | 710 | BackgroundLog<br>icalOp | <b>V</b> | • | X | This field specifies the logical operation to apply to background pixels, if this has been enabled by the BackgroundEnable field. The options and field values are the same as the LogicalOp field. | 5-112 $<sup>^{25}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only | 11 | UseConstantSo<br>urce | ~ | ~ | x | This field, when set, causes the source data to be taken from the ForegroundColor register, otherwise it is taken from the fragment, if needed. The color format is in the raw framebuffer format and 8 or 16 bit pixels should have their color replicated to fill the full 32 bits. | |------|-----------------------|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12 | OpaqueSpan | • | • | x | This bit determines how constant colour spans are to be processed. The two options are: 0 = Transparent 1 = Opaque Transparent spans take the source pixel colour from the message stream or the ForegroundColour register as appropriate. Opaque spans take the source pixel colour from the message stream or register. The ForegroundColour register is used when the corresponding bit in the SpanColourMask is 1, otherwise the BackgroundColour register is used. | | 1331 | Unused | 0 | 0 | X | | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## LogicalTexturePageTableAddr | Name | Type | Offset | Format | |-------------------------|---------|--------|---------| | LogicalTexturePageTable | Texture | 0xB4D0 | Integer | | Addr | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | 1 | 1 | X | 32 bit value | Notes: This register holds the base address of the Logical Texture Page Table. The address should be aligned to a 64 bit boundary. ### LogicalTexturePageTableLength NameTypeOffsetFormatLogicalTexturePageTableTexture0xB4D8Integer Length Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------------|------|-------|-------|--------------------------------------| | 016 | Logical page count | ✓ | ✓ | x | 17 bit integer value from 0 to 65536 | Notes: This register holds the number of logical pages to be managed. Any logical pages past this value are folded to logical page 0. Setting this register to zero effectively disables logical to physical mapping. The legal range of values is 0...65536. ### LUT[0...15] NameTypeOffsetFormatLUT[0..15]LUT0x8E80BitfieldControl registers **Bits** Read Write Name Reset Description Red 1 1 0...7 Green X 8...15 Blue X 16...23 Notes: These registers allow the lower 16 entries of the LUT to be loaded and read back directly. x #### **LUTAddress** 24...31 Alpha NameTypeOffsetFormatLUTAddressTexture0x84D0IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | 1 | 1 | X | 32 bit value | Notes: This register holds the physical address of a block of data to load into the LUT from memory. This is given as a byte address, but the bottom 4 bits are ignored so the address is effectively aligned to a 128 bit memory word. #### **LUTData** | Name | Type | Offset | Format | |---------|------------------|--------|---------| | LUTData | Texture | 0x84C8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|--------------| | 031 | LUT data word | 1 | 1 | X | 32 bit value | Notes: This register holds the 32 bits of data to load into the LUT. The data can be loaded in 'as is', have its red and green components swapped over or converted into a replicated 16 bit format. LUT readback is done by first reading the LUTIndex register. As well as returning the current LUT index it has the additional effect of setting the ReadIndex counter to zero. The ReadIndex counter is only used during readback and is not the same as the LUTIndex used for loading the LUT via the message stream. Each subsequent read from the LUTData register returns the LUT data at the ReadIndex and the ReadIndex counter is auto-incremented. The ReadIndex counter wraps from 255 to 0. #### **LUTIndex** | Name | Type | Offset | Format | |----------|------------------|--------|---------| | LUTIndex | Texture | 0x84C0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-----------------------------------| | 07 | Index | 1 | 1 | X | 8 bit integer value from 0 to 255 | | 831 | Unused | 0 | 0 | X | | Notes: This register holds the start index to update the LUT at when LUT data message is written. The index is automatically incremented after each load and wraps from 255 to 0. Readback from LUTIndex has side effect of clearing the *ReadIndex* register. # LUTMode LUTModeAnd LUTModeOr | Name | Type | Offset | Format | |------------|-------|--------|---------------------| | LUTMode | LUT | 0xB378 | Bitfield | | LUTModeAnd | LUT | 0xAD70 | Bitfield Logic Mask | | LUTModeOr | LUT | 0xAD78 | Bitfield Logic Mask | | | 0 . 1 | | _ | Control registers | Bits | Name | Read<br>26 | Write | Reset | Description | |------|--------------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | <b>'</b> | V | X | When set causes the fragment or span data to be modified under control of the remaining bits in this register. | | 1 | InColorOrder | V | • | x | This bit, when set, swaps the red and green bytes (i.e. bytes 0 and 2) of the 32 bit load data. This can be used to convert ARGB input data into ABGR data to match the internal processing format. | | 23 | LoadFormat | V | • | X | This field controls how the 32 bit data is to be loaded into the LUT. The options are: 0 = Copy (i.e. no formatting). 1 = 565 Replicated 2 = 5551 Replicated The conversion from 8 bits to 1, 5 or 6 bits is done by subtracting half and truncating. The 16 bit value is replicated into both halves of the LUT. | | 4 | LoadColorOrde<br>r | <b>'</b> | ~ | X | This bit controls the order the 16 bit color components are assembled in after the conversion while loading. The options are: 0 = BGR or ABGR 1 = RGB or ARGB | 5-116 $<sup>^{26}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only | 57 | FragmentOperation | | | x | This field specifies the operation to be done on each fragment when not using spans to do the rendering. The options are: 0 = None 1 = IndexedTexture. The 8 bit indexed texels are converted into 32 bit true color values. 2 = Translate8To32. The fragment's red channel is converted into a 32 bit ABGR value using the LUT. 3 = Translate32To32. Each of the four color components are translated using its own LUT. 4 = MotionComp. The LUT holds motion compensation data held in Planar 411 format as 8 bit or 9 bit YUV values. This is indexed based on the fragments coordinates and expanded to 9 bits, if necessary, and assigned to the fragment's color. 5 = Pattern. The LUT holds an 8x8 pattern for the chosen pixel size and this is used to set the fragment's color. Note the SwapSD bit in the | |-----|---------------------|----------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 810 | SpanOperation | V | V | x | AlphaBlendColorMode register may need to be set if the pixel size is 8 or 16 bits. This field specifies the operation to be done on each pixel in a span. The options are: | | 11 | MotionComp8 | <b>√</b> | | X | <ul> <li>None</li> <li>SpanPattern. The LUT holds an 8x8 pattern for the chosen pixel size and this is used to set the block color or the span pixel data depending on the span operation bit in the Render command (constant color uses block color, variable color uses span pixel data).</li> <li>Translate8To8. Each byte is translated using its corresponding LUT channel (so 8 bytes can be translated in parallel). Normally the LUT is set up so all four byte channels hold the same data.</li> <li>Translate8To16. Each byte is translated using a pair of LUT channels to generate a 16 bit pixel. The LUT is set up so that pairs of channels hold the same data. This can be arranged automatically when the LUT is first loaded</li> <li>Translate8To32. Each byte is translated into a 32 bit pixel using the LUT.</li> <li>Translate32To32. Each byte is translated using its corresponding LUT channel (so 8 bytes can be translated in parallel). Normally the LUT is set up so all four byte channels hold different data.</li> </ul> | | 11 | MotionComp8<br>Bits | ✓ | · | X | This bit, if set, specifies that the YUV data is held as 8 bit values, packed 4 per 32 bit LUT entry. If this bit is not set the YUV data is held as 9 bit values packed 2 per 32 bit LUT entry (on 16 bit boundaries within the 32 bit word). | | 1214 | XOffset | V | V | x | This field holds the X offset into the selected 8x8 pattern. This is used (together with the pixels X coordinate) to rotate the selects row of the pattern to give some control on its registration to the underlying rectangle. | |------|----------------------|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1517 | YOffset | ~ | V | x | This field holds the Y offset into the selected 8x8 pattern. This is used (together with the pixels Y coordinate) to select which row of the pattern to use. This gives some control of the patterns registration to the underlying rectangle. | | 1825 | PatternBase | • | • | X | This field holds the base address of the pattern to use. There are no restrictions on where a pattern starts, other than it must start on a 32 bit boundary (i.e. the start cannot be part way through a LUT entry). | | 26 | SpanCCXAlign<br>ment | • | • | X | This bit controls how the pattern is aligned along the X axis when Constant Color spans are used. The two options are: 0 = The first pixel in the span is taken from the pixel indexed for this row by XOffset. This is the normal method and fixes the pattern with respect to the screen (recall the block color registers are memory aligned). This preserves a vertical line in the pattern when applying to a trapezoid. 1 = The first pixel in the span is taken from (X + XOffset) % 8 | | 27 | SpanVCXAlign<br>ment | ~ | • | X | This bit controls how the pattern is aligned along the X axis when Constant Color spans are used. The two options are: 0 = The first pixel in the span is taken from the pixel indexed for this row by XOffset. 1 = The first pixel in the span is taken from (X + XOffset) % 8. This is the normal method and fixes the pattern with respect to the screen (recall these are done via normal writes so are not memory aligned). This preserves a vertical line in the pattern when applying to a trapezoid. | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### **LUTTransfer** | Name | Type | Offset | Format | |-------------|---------|--------|----------| | LUTTransfer | Texture | 0x84D8 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|----------|-------|-------------------------| | 07 | Start index | X | <b>'</b> | X | Index | | 814 | Count | X | ~ | X | Count in 128 bit words. | | 1531 | Reserved | 0 | 0 | X | | Notes: The start index and number of words to fill in the LUT are given by the **LUTTransfer** message with the index in the bits 0...7 and the count in bits 8...13. The **LUTTransfer** message also starts the transfer. A count of zero loads zero words into the LUT so this effectively disables the loading operation. The count is in multiple of 4 words and the **LUTAddress** is aligned to a 16 byte boundary. The transfer will wrap around in the LUT if necessary. # MaxHitRegion | Name | Type | Offset | Format | |--------------|---------|--------|----------| | MaxHitRegion | Output | 0x8C30 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|----------|-------|-------------------------------------| | 015 | Maximum X | X | <b>'</b> | X | maximum X in 2's complement format. | | 1631 | Maximum Y | X | <b>V</b> | X | maximum Y in 2's complement format. | Notes: This register causes the current value of the *maxRegion* register to be written to the output FIFO under control of the *FilterMode* register (which may cull the data depending on the setting of the Statistics bits). The data field (on input) is not used. ## **MaxRegion** | Name | Type | Offset | Format | | |-----------|------------------|--------|----------|--| | MaxRegion | Output | 0x8C18 | Bitfield | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|----------|-------|-------------------------------------| | 015 | Maximum X | × | ~ | x | maximum X in 2's complement format. | | 1631 | Maximum Y | × | <b>v</b> | X | maximum Y in 2's complement format. | Notes: This register initialises the maximum region register. The register is updated during extent testing: - During Picking it contains the max X,Y value for the Pick region. - During Extent collection it is set to the initial minimum extent and is updated whenever a fragment with a higher X or Y value is generated, to reflect the new X or Y. The StatisticMode register allows either fragments or those that were culled after being rasterised to be set as Eligible to update this register. Since register contents are updated during rendering it may not return the value previously written to it. # MinHitRegion | Name | Type | Offset | Format | | |--------------|------------------|--------|----------|--| | MinHitRegion | Output | 0x8C28 | Bitfield | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|----------|-------|-------------------------------------| | 015 | Minimum X | X | <b>v</b> | X | minimum X in 2's complement format. | | 1631 | Minimum Y | X | <b>V</b> | X | minimum Y in 2's complement format. | Notes: This register causes the current value of the *minRegion* register to be written to the output FIFO under control of the *FilterMode* register (which may cull the data depending on the setting of the Statistics bits). The data field (on input) is not used. ## **MinRegion** | Name | Type | Offset | Format | | |-----------|------------------|--------|----------|--| | MinRegion | Output | 0x8C10 | Bitfield | | | | Control register | | | | | | Bits | Name | Read | Write | Reset | Description | |---|------|-----------|------|----------|-------|-------------------------------------| | ĺ | 015 | Minimum X | X | <b>'</b> | X | minimum X in 2's complement format. | | | 1631 | Minimum Y | X | <b>/</b> | X | minimum Y in 2's complement format. | Notes: This register initialises the minimum region register. The register is updated during extent testing: - During Picking it contains the max X,Y value for the Pick region. - During Extent collection it is set to the initial minimum extent and is updated whenever a fragment with a higher X or Y value is generated, to reflect the new X or Y. The StatisticMode register allows either active fragments or those that were culled after being rasterised to be set as Eligible to update this register. Since register contents are updated during rendering it may not return the value previously written to it. #### Packed16Pixels | Name | Type | Offset | Format | |----------------|---------|--------|---------| | Packed16Pixels | 2DSetup | 0xB638 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|----------|-------|-------------| | 031 | Data word | X | <b>/</b> | X | | Notes: Packed Downloads: The target register for the expanded pixel data is set up with the Download Target command. Four bit packed pixel downloads are converted into eight bit packed pixels. The 8 and 16 packed pixels are particularly useful when downloading textures because spans (which take packed data) cannot be used when the target buffer layout is Patch2 or Patch32\_2. Each Packed16Pixels command will be expanded into 2 writes to the target register. If the input bytes are labelled DCBA (with byte A in bit positions 0...7) then this is converted to: First word: 00BA(0 is the byte set to zero) Second word: 000DC #### Packed4Pixels NameTypeOffsetFormatPacked16Pixels2DSetup0xB668Integer Command | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|----------|-------|-------------| | 031 | Data word | X | <b>/</b> | X | | Notes: Packed Downloads: The target register for the expanded pixel data is set up with the *DownloadTarget* command. Four bit packed pixel downloads are converted into eight bit packed pixels. This register holds the packed nibble pixel data to expand out into packed byte pixel data. Each Packed4Pixels command will be expanded into two writes to the target register. If the input nibbles are labelled HGFEDCBA (with nibble A in bit positions 0...3) then this is converted to: First word: 0C0D0A0B (0 is the nibble set to zero) Second word: 0G0H0E0F #### Packed8Pixels NameTypeOffsetFormatPacked8Pixels2DSetup0xB630IntegerCommand | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|----------|-------|-------------| | 031 | Data word | X | <b>~</b> | X | | Notes: Packed Downloads: The target register for the expanded pixel data is set up with the *DownloadTarget* command This register holds the packed 8 bit pixel data to expand out into 4 seperate 8 bit pixels during the download. The data is sent to the register defined in DownloadTarget. Each Packed8Pixels command will be expanded into four writes to the target register. If the input bytes are labelled DCBA (with byte A in bit positions 0...7) then this is converted to: First word: 000A (0 is the byte set to zero) Second word: 000B Third word: 000C Fourth word: 000D # PhysicalPageAllocationTableAddr NameTypeOffsetFormatPhysicalPageAllocationTexture0xB4C0Integer TableAddr Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|----------|-------|--------------| | 031 | Address | 1 | <b>√</b> | X | 32 bit value | Notes: This register holds the base address of the Physical Page Allocation Table. The address should be aligned to a 64 bit boundary. #### **PickResult** NameTypeOffsetFormatPickResultOutput0x8C38BitfieldCommand | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-------------| | 0 | Pick result | X | 1 | X | Flag | | 131 | Reserved | X | 0 | X | | Notes: This command causes the current value of the pick result flag to be written to the output FIFO under control of the FilterMode settings. The data field (on input) is not used. Output = 0 for false or 1 for true. #### **PixelSize** | Name | Type | Offset | Format | |-----------|------------|--------|----------| | PixelSize | Rasterizer | 0x80C0 | Bitfield | | | Command | | | | Bits | Name | Read<br>27 | Write | Reset | Description | |------|------------------------|------------|----------|-------|-----------------------------------------------| | 01 | Global | ~ | ~ | x | All units, if bit 31 is zero, otherwise | | 23 | Rasterizer | V | V | X | Rastrerizer | | 45 | Scissor and<br>Stipple | ~ | ~ | x | Scissor and Stipple functions | | 67 | Texture | <b>V</b> | <b>V</b> | X | | | 89 | LUT | V | V | X | | | 1011 | Framebuffer | V | V | X | | | 1213 | LogicalOps | V | V | X | | | 1415 | Framebuffer | <b>V</b> | <b>V</b> | X | | | 1617 | Setup | ~ | V | X | | | 1830 | Reserved | 0 | 0 | X | Reserved | | 31 | Global/local<br>toggle | ~ | ~ | x | selects global (0) or individual settings (1) | Two bit pixel size encoding: This field sets the pixel size to be used for merging the pixel data into Notes: memory. It is normally set to the same value for all functions, but for generating texture maps it may be advantageous to use a different write pixel size. - The pixel size is taken from bits 0...1 when bit 31 is 0 or taken from subsequent bites for local functionality when bit 31 is 1. - The two bit pixel size is encoded as follows: $$0 = 32 \text{ bpp}$$ $1 = 16 \text{ bpp}$ $2 = 8 \text{ bpp}$ - During readback bits 0...17 and 31 return values as loaded and bits 18...30 return zero. - Readback from Rasterizer unit <sup>&</sup>lt;sup>27</sup> The readback for PixelSize comes from the Rasterizer unit. # PointMode PointModeAnd PointModeOr NameTypeOffsetFormatPointModeDelta0x9490, 0xAAE0,bitfield PointModeAnd PointModeOr 0xAAE8 Control registers | Bits | Name | Read | Write | Reset | Description | |------|-------------------------|------|-------|-------|-------------------------------------------------------------------| | 0 | Antialias<br>Enable | ~ | ~ | X | Enabled = 1 | | 0 | Antialiasing<br>Quality | • | ~ | х | This field defines the quality of antialiased points: 0 4x4 1 8x8 | Notes: Defines if and how points are to be antialiased: AntialiasEnable: enables antialiasing of points, qualified by the AntialiasEnable field in the **Begin** register. Note the Point Table must be set up for the corresponding point size (held in **AAPointSize**) and AntialiasingQuality. ### **PointSize** | Name | Type | Offset | Format | |-----------|-------|--------|---------| | PointSize | Delta | 0x9498 | Integer | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-----------------------------------| | 07 | Size | <b>√</b> | <b>√</b> | X | 8 bit integer value from 0 to 255 | | 831 | Reserved | 0 | 0 | X | | Notes: Defines the size of an aliased point. For aliased points the **PointSize** register holds the desired point size. The range of actual point sizes are 1...255; a 0 point size is treated as a point size of 1. Points are drawn according to the OpenGL rules so wide points are drawn as squares centred on the vertex. ### PointTable[0...3] NameTypeOffsetFormatPointTable[0...3]Rasterizer0x8080, 0x8088,bitfield 0x8090, 0x8098 Control registers | Bits | Name | Read | Write | Reset | Description | | |------|------------|----------|----------|-------|---------------------------------------------|--| | 031 | PointTable | <b>V</b> | <b>'</b> | X | 8 delta values 07 in fixed point 1.3 format | | Notes: Antialiased point data table. There are 4 words in the table of packed dx point data. The format is unsigned 1.3 fixed point numbers. From the host's view the table is organised as 4 \* 32 bit words to minimize download overhead when points size changes. Only the parts of the table needed for a particular point size need to be loaded. #### **QStart** NameTypeOffsetFormatQStartTexture0x83B8Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | 1 | X | | Notes: Initial Q value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S, T and Q values. #### Q1Start NameTypeOffsetFormatQ1StartTexture0x8430Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------| | 0n | Fraction | 1 | 1 | X | 2's complement fixed point fraction | | n31 | Integer | 1 | 1 | X | 2's complement fixed point integer | Notes: Initial Q1 value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S1, T1 and Q1 values. # RasterizerMode RasterizerModeAnd RasterizerModeOr **Format** Name Type Offset RasterizerMode Rasterizer 0x80A0 Bitfield RasterizerModeAnd Rasterizer 0xABA0Bitfield Rasterizer Mode OrRasterizer 0xABA8Bitfield Control register | Bits | Name | Read<br>28 | Write | Reset | Description | |------|-----------------------------|------------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | MirrorBit Mask | ~ | • | X | <ul> <li>When set the bit mask bits are consumed from the most significant end towards the least significant end.</li> <li>When reset the bit mask bits are consumed from the least significant end towards the most significant end.</li> </ul> | | 1 | InvertBit Mask | ~ | ~ | X | When this bit is set the bit mask is inverted first before being tested. | | 2,3 | Fraction Adjust | • | ~ | x | These bits control the action of a ContinueNewLine cmmand and specify how the fraction bits in the Y and XDom DDAs are adjusted. 0: No adjustment is done, 1: Set the fraction bits to zero, 2: Set the fraction bits to half. 3: Set the fraction to nearly half, i.e. 0x7fff | | 4,5 | Bias<br>Coordinates | • | ~ | X | These bits control how much is added onto the SartXDom, StartXSub and StartY values when they are loaded into the DDA units. The original registers are not affected. 0: Zero is added, 1: Half is added, 2: Nearly half, i.e. 0x7fff is added | | 6 | | <b>V</b> | V | X | Reserved | | 7,8 | BitMask<br>ByteSwap<br>Mode | • | ~ | X | These bit controls the byte swapping of the BitMask data before it is used. If the bytes are labelled ABCD on input then they are swapped as follows: 0: ABCD (i.e. no swap) 1: BADC 2: CDAB 3: DCBA | | 9 | BitMask<br>Packing | V | ~ | x | This bit controls whether the bitMask data is packed or if a new BitMask data is required on every scanline. 0: BitMask data is packed, 1: BitMask data is provided for each scanline. | $<sup>^{28}</sup>$ Logic Op register readback is via the main register only | 10-14 | BitMaskOffset | • | V | X | These bits hold the bit position in the BitMask data where the first bit is taken from for the bit mask test for the first BitMask data on a new scanline. Subsequent BitMask data starts from bit 0 until the next scanline. Successive bits are taken from increasing bit positions until the bit mask is consumed (i.e. bit 31 is reached). The least significant bit is bit zero. | |-------|--------------------------|----------|----------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15,16 | HostDataByteS<br>wapMode | • | • | X | These bits controls the byte swapping of the BitMask data before it is used. If the bytes are labelled ABCD on input then they are swapped as follows: 0: ABCD (i.e. no swap) 1: BADC 2: CDAB 3: DCBA | | 17 | MultiGLINT | ~ | V | X | This bit selects whether the rasterizer is to work in single GLINT mode, or in multi-GLINT mode and consequently only process the scanlines allocated to it. 0: Single GLINT mode 1: Multi-GLINT mode | | 18 | YLimitsEnable | ~ | <b>'</b> | X | This bit, when set, enables the Y limits testing to be done between the minimum and maximum Y values given by the YLimits register. | | 19 | Reserved | <b>/</b> | <b>✓</b> | X | | | 2022 | StripeHeight | V | <b>'</b> | X | This field specifies the number of scanlines in a stripe. The options are: $0 = 1 \qquad 3 = 8$ $1 = 2 \qquad 4 = 16$ $2 = 4$ | | 23 | WordPacking | V | <b>'</b> | X | This bit controls how the two host words sent during, a span operation are packed into the 64 bit internal span data. 0 = first word in bits 031, second word in 3263 1 = first word in bits 3263, second word in 031 | | 24 | OpaqueSpans | • | • | x | This bit, when set allows the color of each pixel in the span to be either foreground or background as set by the supplied bit masks. If this bit is 0 then any supplied bit masks are anded with the pixel mask to delete pixels from the span. This bit should be set to 0 for performance reasons when foreground/background processing is not required. | | 25 | Reserved | 0 | 0 | X | | | 26 | D3DRules | ~ | ~ | X | This bit, if set, uses D3D rules for subpixel correction calculations, otherwise OpenGL rules are used. | | 2731 | Reserved | 0 | 0 | X | Mask to 0. Reserved for Primitive type - see <b>Begin</b> command | Notes: Defines the long term mode of operation of the rasterizer. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # ReadMonitorMode ReadMonitorModeAnd ReadMonitorModeOr | Name | Type | Offset | Format | |--------------------|------------------|--------|----------| | ReadMonitorMode | R4 ReadMonitor | 0x80F8 | Bitfield | | ReadMonitorModeAnd | R4 ReadMonitor | 0xB5C0 | Bitfield | | ReadMonitorModeOr | R4 ReadMonitor | 0xB5C8 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|----------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | ✓ | X | When set causes the fragment or span data to be modified under control of the remaining bits in this register. | | 13 | StripePitch | <b>V</b> | 1 | X | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of R4s * StripeHeight. The options are: $0 = 1$ $4 = 16$ $1 = 2$ $5 = 32$ $2 = 4$ $6 = 64$ $3 = 8$ $7 = 128$ | | 46 | StripeHeight | | | | This field specifies the number of scanlines in a stripe. The options are: $0 = 1 \qquad 3 = 8$ $1 = 2 \qquad 4 = 16$ $2 = 4$ | | 7 | HashFunction | | | | This bit controls the hash function used to index the monitor table from the fragment's xy coordinate. The options are 0 = concatenate the lower 5 bits of x and y together. 1 = xor the lower 10 bits of x and y together. | | 1631 | StripeOffset | | | | This field should hold the same value as the Rasteriser StripeOffsetY register. The field is a 16 bit 2's complement number. | Notes: Each primitive is assigned a unique number which is recorded in a table for each active pixel the primitive touches. Before the table is updated (during rendering) for a pixel in this primitive it is first tested to see if an earlier primitive had already been assigned to the pixel position. If it has the Suspend Reads mechanism is invoked and the table is reset (i.e. every entry is marked invalid). This significantly reduces unnecessary delays while waiting for a render to complete before starting the next memory writes. ### RectangleMode NameTypeOffsetFormatRectangleModeDelta0x94D0Float Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|--------------------------------------------------------------------------------------------| | 031 | RectangleMode | ✓ | ✓ | X | Holds the data used in the Render command sent to GLINT R4 duringGeomRectangle processing. | Notes: The width and height of the rectangle are held in the **RectangleWidth** and **RectangleHeight** registers as floating point numbers and the **RectangleMode** register holds data passed to the rasteriser in the **Render** command. ## RectangleHeight NameTypeOffsetFormatRectangleHeightDelta0x94E0Float Control register | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|--------------------------------------------------------| | 031 | Height | 1 | 1 | X | The height of the rectangle as a floating point number | Notes: # RectanglePosition NameTypeOffsetFormatRectanglePosition2DSetup0xB600IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 015 | X offset | 1 | 1 | X | 2's complement X coordinate | | 1631 | Y offset | 1 | 1 | X | 2's complement Y coordinate | Notes: This register defines the rectangle origin for use by the Render2D command. # RectangleWidth NameTypeOffsetFormatRectangleWidthDelta0x94D8Float Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------------------------------------------------| | 031 | Width | 1 | 1 | X | The width of the rectangle as a floating point number | Notes: ### Render NameTypeOffsetFormatRenderGlobal0x8038Bitfield Command | Bits | Name | Read | Write | Reset | Description | |------|-----------------------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | AreaStipple<br>Enable | × | ~ | X | This bit, when set, enables area stippling of the fragments produced during rasterisation in the Stipple Unit. Note that area stipple in the Stipple Unit must be enabled as well for stippling to occur. When this bit is reset no area stippling occurs irrespective of the setting of the area stipple enable bit in the Stipple Unit. This bit is useful to temporarily force no area stippling for this primitive. | | 1 | LineStipple<br>Enable | × | ~ | X | This bit, when set, enables line stippling of the fragments produced during rasterisation in the Stipple Unit. Note that line stipple in the Stipple Unit must be enabled as well for stippling to occur. When this bit is reset no line stippling occurs irrespective of the setting of the line stipple enable bit in the Stipple Unit. This bit is useful to temporarily force no line stippling for this primitive. | | 2 | ResetLine<br>Stipple | X | ~ | X | This bit, when set, causes the line stipple counters in the Stipple Unit to be reset to zero, and would typically be used for the first segment in a polyline. This action is also qualified by the LineStippleEnable bit and also the stipple enable bits in the Stipple Unit. When this bit is reset the stipple counters carry on from where they left off (if line stippling is enabled) | | 3 | FastFill Enable | × | ~ | X | This bit, when set, causes the span fill mechanisms to be used for the rasterisation process. The type of span filling is specified in the SpanOperation field. When this bit is reset the normal rasterisation process occurs. | | 4, 5 | Unused | 0 | 0 | X | | | 6, 7 | Primitive Type | X | <b>✓</b> | This two bit field selects the primitive type to rasterise. | |------|----------------|---|----------|-------------------------------------------------------------| | | )I | | | The primitives are: | | | | | | 0 = Line | | | | | | 1 = Trapezoid | | | | | | 2 = Point | | 8 | Antialiase | × | ~ | This bit, when set, causes the generation of sub | | | Enable | ^ | | scanline data and the coverage value to be calculated | | | Enable | | | _ | | | | | | for each fragment. The number of sub pixel samples | | | | | | to use is controlled by the Antialiasing Quality bit. | | 0 | A 1 | | | When this bit is reset normal rasterisation occurs. | | 9 | Antialiasing | X | <b>✓</b> | This bit, when set, sets the sub pixel resolution to be | | | Quality | | | 8x8 | | | | | | When this bit is reset the sub pixel resolution is 4x4. | | 10 | UsePoint Table | X | <b>✓</b> | When this bit and the Antialiasing Enable are set, the | | | | | | dx values used to move from one scanline to the next | | | | | | are derived from the Point Table. | | 11 | SyncOnBit | X | <b>/</b> | This bit, when set, causes a number of actions: | | | Mask | | | The least significant bit or most significant bit | | | | | | (depending on the MirrorBitMask bit) in the Bit Mask | | | | | | register is extracted and optionally inverted | | | | | | (controlled by the InvertBitMask bit). If this bit is 0 | | | | | | then any fragments are skipped. | | | | | | After every fragment the BitMask register is rotated by | | | | | | one bit. | | | | | | If all the bits in the BitMask register have been used | | | | | | then rasterisation is suspended until a new | | | | | | BitMaskPattern tag is received. If any other tag is | | | | | | | | | | | | received while the rasterisation is suspended then the | | | | | | rasterisation is aborted. The message which caused | | | | | | the abort is then processed as normal. | | | | | | Note the behaviour is slightly different when the | | | | | | SyncOnHostData bit is set to prevent a deadlock from | | | | | | occurring. In this case the rasterisation doesn't | | | | | | suspend when all the bits have been used and if new | | | | | | BitMaskPattern tags are not received in a timely | | | | | | manner then the subsequent fragments will just reuse | | | | | | the bit mask. | | 12 | SyncOnHost | X | <b>/</b> | When this bit is set a fragment is produced only when | | | Data | | | one of the following tags have been received from the | | | | | | host: Depth, Stencil, Color or FBData, FBSourceData. | | | | | | If SyncOnBitMask is reset then any tag other than one | | | | | | of these three is received then the rasterisation is | | | | | | aborted. If SyncOnBitMask is set then any tag other | | | | | | than one of these five or BitMaskPattern is received | | | | | | then the rasterisation is aborted. The tag which | | | | | | caused the abort is then processed as normal for that | | | | | | register type. The <i>BitMaskPattern</i> register doesn't | | | | | | cause any fragments to be generated, but just updates | | | | | | | | | 1 | | | the BitMask register. | | 13 | TextureEnable | X | ~ | X | This bit, when set, enables texturing of the fragments produced during rasterisation. Note that the Texture Units must be suitably enabled as well for any texturing to occur. When this bit is reset no texturing occurs irrespective of the setting of the Texture Unit controls. This bit is useful to temporarily force no texturing for this primitive. | |------|----------------------------------|---|----------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14 | FogEnable | x | • | X | This bit, when set, enables fogging of the fragments produced during rasterisation. Note that the Fog Unit must be suitably enabled as well for any fogging to occur. When this bit is reset no fogging occurs irrespective of the setting of the Fog Unit controls. This bit is useful to temporarily force no fogging for this primitive. | | 15 | Coverage<br>Enable | × | ~ | X | This bit, when set, enables the coverage value produced as part of the antialiasing to weight the alpha value in the alpha test unit. Note that this unit must be suitably enabled as well. When this bit is reset no coverage application occurs irrespective of the setting of the AntialiasMode. | | 16 | SubPixel<br>Correction<br>Enable | × | V | X | This bit, when set enables the sub pixel correction of the color, depth, fog and texture values at the start of a scanline. When this bit is reset no correction is done at the start of a scanline. Sub pixel corrections are only applied to aliased trapezoids. | | 17 | Reserved | 0 | 0 | X | | | 18 | SpanOperation | × | ~ | x | This bit, when clear, indicates the writes are to use the constant color found in the previous <b>FBBlockColor</b> register. When this bit is set write data is variable and is either provided by the host (i.e. <i>SyncOnHostData</i> is set) or is read from the framebuffer. | | 19 | Unused | 0 | 0 | X | | | 2026 | Reserved | X | <b>/</b> | X | | | 27 | FBSourceRead<br>Enable | × | • | X | This bit, when set enables source buffer reads to be done in the Framebuffer Read Unit. Note that the Framebuffer Read Unit must be suitably enabled as well for the source read to occur. When this bit is reset no source reads occur irrespective of the setting of the Framebuffer Read Unit controls. | | 2831 | Reserved | 0 | 0 | x | Reserved for primitive type - see <b>Begin</b> command | | NT 4 | | | |--------|--|--| | Notes: | | | | 1,000. | | | ### Render2D Name Type Offset Format Render2D Global 0xB640 Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|------------------------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 011 | Width | X | ~ | X | Specifies the width of the rectangle in pixels. Its range is 04095. | | 1213 | Operation | × | ~ | x | This two bits field is encoded as follows: 0 = Normal 1 = SyncOnHostData 2 = SyncOnBitMask 3 = PatchOrderRendering The SyncOnHostData and SyncOnBitMask settings just set the corresponding bit in the Render command. PatchOrderRendering decomposes the input rectangle in to a number of smaller rectangels to make better use of the page structure of patched memory. | | 14 | FBRead<br>SourceEnable | X | ~ | x | This bit sets the FBReadSourceEnable bit in the Render command. | | 15 | SpanOperation | × | ~ | x | This bit sets the SpanOperation bit in the Render command. | | 1627 | Height | × | ~ | x | Specifies the height of the rectangle in pixels. Its range is 04095. | | 28 | Increasing X when set | × | ~ | x | This bit, when set, specifies the rasterisation is to be done in increasing X direction. | | 29 | Increasing Y when set | X | ~ | x | This bit, when set, specifies the rasterisation is to be done in increasing Y direction. | | 30 | AreaStipple<br>Enable | X | ~ | x | This bit sets the AreaStippleEnable bit in the Render command. | | 31 | TextureEnable | X | ~ | X | This bit sets the TextureEnable bit in the Render command. | Notes: This command starts a rectangle being rendered from the origin given by the RectanglePosition register. ## Render2DGlyph | Name | Type | Offset | Format | |---------------|---------|--------|----------| | Render2DGlyph | Global | 0xB648 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|----------|-------|---------------------| | | | | | | | | 06 | Width | X | <b>✓</b> | X | | | 713 | Height | X | V | X | | | 1422 | X | X | <b>'</b> | X | Signed advance in X | | 2331 | Y | X | <b>V</b> | X | Signed advance in Y | Notes: This command starts a glyph being rendered from the position given by (GlyphPosition+Advance(X, Y)). ### RenderPatchOffset | Name | Type | Offset | Format | |-------------------|------------------|--------|----------| | RenderPatchOffset | Delta | 0xB610 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|----------|----------|-------|-----------------------------| | 015 | X coordinate | <b>V</b> | ~ | X | 2's complement X coordinate | | 1631 | Y coordinate | <b>/</b> | <b>/</b> | X | 2's complement Y coordinate | Notes: This register holds the amount needed to add to the rectangle origin to recover the memory page alignment for the rectangle when it is rendered in patch order. # RepeatLine | Name | Type | Offset | Format | | |------------|---------|--------|--------|--| | RepeatLine | Delta | 0x9328 | Tag | | | _ | Command | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: This command causes the previous line drawn with a DrawLine command to be repeated. It would be normal for some mode or other state information to have been changed before the line is repeated. An example of this is to use scissor clipping with the line being repeated for each clip rectangle. The data field used when this command is turned into the *Render command* is taken from the previous Draw register. ### RepeatTriangle NameTypeOffsetFormatRepeatTriangleDelta0x9310TagCommand | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: This command causes the previous triangle drawn with **DrawTriangle** to be repeated. It would be normal for some mode or other state information to have been changed before the triangle is repeated. An example of this is to use scissor clipping with the triangle being repeated for each clip rectangle. The data field used when this command is turned into the *Render command* is taken from the last Draw register. #### ResetPickResult NameTypeOffsetFormatResetPickResultOutput0x8C20TagCommand | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: This register resets the picking result flag. Data field is not used. #### RetainedRender NameTypeOffsetFormatRetainedRenderInput0xB7A0Bitfield Command | Bits | Name | Read | Write | Reset | Description | |------|---------|------|----------|-------|-------------------------------| | 031 | Command | X | <b>/</b> | X | Same as Render command format | Notes: See Render command. #### **RLCount** | Name | Type | Offset | Format | | |---------|------------------|--------|---------|--| | RLCount | 2DSetup | 0xB678 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 023 | Count | × | ~ | x | | | 2431 | Reserved | 0 | 0 | X | | Notes: This register starts the run length expansion being done. The data in RLData is written to the register defined in *DownloadTarget* **count** times. The count is held in bits 0...23 of this command. #### **RLData** | Name | Type | Offset | Format | |--------|------------------|--------|---------| | RLData | Delta | 0xB670 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|--------------| | 031 | RLData | 1 | 1 | X | 32 bit value | Notes: This register holds the 32 bits of data to be repeated when the run length decoding is initiated by the RLCount command. #### **RLEMask** | Name | Type | Offset | Format | | |---------|------------------|--------|----------|--| | RLEMask | Output | 0x8C48 | Bitfield | | | | Control register | | | | | Bits | | Name | Read | Write | Reset | Description | |------|----|------|----------|----------|-------|-------------| | 03 | 31 | Mask | <b>✓</b> | <b>✓</b> | 0 | Mask Data | Notes: This register holds the mask to AND with the run length encoded data and allows bits to be discounted from the comparison. It also sets the unwanted bits to zero in the data value returned with the run length. #### **RouterMode** NameTypeOffsetFormatRouterModeRouter0x8840Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|----------------------------------------------------| | 0 | Sequence | ~ | <b>✓</b> | X | Bit0 may be: 0=Texture, Depth; or 1=Depth, Texture | | 131 | Reserved | 0 | 0 | X | | Notes: Switches the order of some units in the pipeline. #### **RStart** NameTypeOffsetFormatRStartColor0x8780Fixed point numberControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | 1 | 1 | X | | | 1523 | Integer | 1 | 1 | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the initial Red value for a vertex when in Gouraud shading mode. The value is 24 bit 2's complement fixed point numbers in 9.15 format. #### S1Start NameTypeOffsetFormatS1StartTexture0x8400Fixed point Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------------------------------| | 0n | Fraction | 1 | <b>√</b> | X | 2's complement fixed point fraction | | n31 | Integer | 1 | 1 | X | 2's complement fixed point integer | Notes: Initial S1 value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S1, T1 and Q1 values. ## **SaveLineStippleCounters** NameTypeOffsetFormatSaveLineStippleCountersStipple0x81C0TagCommand | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: Copies the current counter values into an internal register for later restoration using the *UpdateLineStippleCounters* command. Useful in drawing stippled wide lines. ## **ScanLineOwnership** NameTypeOffsetFormatScanLineOwnershipRasterizer0x80B0Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|-----------|----------|----------|-------|-------------| | 02 | Owner ID | ~ | ~ | X | | | 35 | Stripe ID | <b>✓</b> | <b>✓</b> | X | | | 631 | Unused | 0 | 0 | X | | Notes: This message defines which R4 owns which scanlines. It has the following fields: bits 0...2 = mask to isolate the low order bits of Y as these identify the RX which owns this stripe. bits 3...5 = myId. The stripe this RX owns. Note that the contents of this register will be different for each R4 in the system. #### **ScissorMaxXY** NameTypeOffsetFormatScissorMaxXYScissor0x8190Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------------------------| | 015 | X coordinate | 1 | 1 | x | 2's complement fixed point X coordinate | | 1631 | Y coordinate | 1 | 1 | X | 2's complement fixed point Y coordinate | Notes: This register holds the maximum XY scissor coordinate - i.e. the rectangle corner farthest from the screen origin. #### **ScissorMinXY** | Name | Type | Offset | Format | |--------------|------------------|--------|----------| | ScissorMinXY | Scissor | 0x8188 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------------------------| | 015 | X coordinate | 1 | 1 | x | 2's complement fixed point X coordinate | | 1631 | Y coordinate | 1 | 1 | X | 2's complement fixed point Y coordinate | This register holds the minimum XY scissor coordinate - i.e. the rectangle corner closest to the screen Notes: ## **ScissorMode ScissorModeAnd ScissorModeOr** | Name | Type | Offset | Format | |----------------|---------|--------|---------------------| | ScissorMode | Scissor | 0x8180 | Bitfield | | ScissorModeAnd | Scissor | 0xABB0 | Bitfield Logic Mask | | ScissorModeOr | Scissor | 0xABB8 | Bitfield Logic Mask | | | | | | Control registers | Bits | Name | Read<br>29 | Write | Reset | Description | |------|-------------------------|------------|-------|-------|-------------------------------------| | 0 | UserScissor<br>Enable | ~ | ~ | X | enables the user scissor clipping | | 1 | ScreenScissor<br>Enable | ~ | ~ | X | enables the screen scissor clipping | | 231 | Unused | 0 | 0 | X | | Controls enabling of the screen and user scissor tests. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. $<sup>^{29}</sup>$ Logic Op register readback is via the main register only #### **ScreenSize** | Name | Type | Offset | Format | |------------|---------|--------|----------| | ScreenSize | Scissor | 0x8198 | Bitfield | Control register | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-------------| | 015 | Width | 1 | 1 | X | | | 1631 | Height | 1 | 1 | X | | Notes: Screen dimensions for screen scissor clipping. The screen boundaries are (0,0) to (width-1, height-1) inclusive. ## **Security** | Name | Type | Offset | Format | |----------|------------------|--------|----------| | Security | Input | 0x8908 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------| | 0 | Secure | ~ | ~ | X | 0 = normal mode<br>1 = secure mode | | 131 | Reserved | 0 | 0 | X | | Notes: This unit controls the security of the rest of the pipeline by filtering out any register loads that may cause the pipeline to lockup if used incorrectly. If the security mode is Enable, potentially dangerous registers can only be programmed by a direct write to the register, and not through DMA. This avoids the danger of DMA buffers in user address space being corrupted by another application and causing the chip to lockup. The following registers are filtered out of DMA command buffers if the security bit is enabled: - FilterMode - VTGAddress - VTGData - Security - DMARectangleWrite - DMAOutputCount - DMAFeedback - ContextDump - ContextRestore - ContextData #### **SetDeltaPort** NameTypeOffsetFormatSetDeltaPortR4 Delta0x80F0BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|----------------|----------|----------|-------|-------------| | 030 | Port Number | <b>V</b> | <b>v</b> | X | Port number | | 31 | Passed through | 0 | 0 | X | | Notes: This message sets which Delta port should be made the current port to receive subsequent messages. It is not normally used as an input and is provided only to make testing easier. ### **SetLogicalTexturePage** NameTypeOffsetFormatSetLogicalTexturePageTexture0xB360BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|----------|-------|---------------------| | 015 | PageNumber | ~ | <b>~</b> | X | Logical page number | | 1631 | Unused | 0 | 0 | X | | Notes: This register sets the logical page number to be used in subsequent *UpdateLogicalTextureInfo* commands. The logical page is held in bits 0...15. #### **SStart** NameTypeOffsetFormatSStartTexture0x8388Fixed pointControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | x | | | n31 | Integer | ✓ | ✓ | X | | Notes: Initial S value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S, T and Q values. #### **StartXDom** | Name | Type | Offset | Format | |------------------|------------------|--------|-------------| | Start X Dominant | Rasterizer | 0x8000 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | 1 | X | X | | | 1631 | Integer | 1 | X | X | | Notes: The start X coordinate for the dominant edge: initial X value for the dominant edge in trapezoid filling, or initial X value in line drawing. The value is in 2's complement 16.16 fixed point format. #### **StartXSub** | Name | Type | Offset | Format | |---------------------|------------------|--------|-------------| | Start X Subordinate | Rasterizer | 0x8010 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | 1 | × | x | | | 1631 | Integer | 1 | X | X | | Notes: The start X coordinate for the subordinate edge: initial X value for the subordinate edge in trapezoid filling. The value is in 2's complement 16.16 fixed point format. #### **StartY** | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | Start Y | Rasterizer | 0x8020 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | 1 | X | X | | | 1631 | Integer | 1 | X | X | | Notes: The start Y coordinate: initial scanline (or sub-scanline) in trapezoid filling, or initial Y position for line drawing. The value is in 2's complement 16.16 fixed point format. # StatisticMode StatisticModeAnd StatisticModeOr | Name | Type | Offset | Format | | |--------------------|--------|--------|----------|--| | StatisticMode | Output | 0x8C08 | Bitfield | | | Control Mr. 1 A. 1 | 0.6 | 0.4010 | D: C 11T | | StatisticModeAnd Output 0xAD10 Bitfield Logic Mask StatisticModeOr Output 0xAD18 Bitfield Logic Mask Command | Bits | Name | Read<br>30 | Write | Reset | Description | | |------|---------------------|------------|-------|-------|------------------------------------------------------------------------------------------------------|--| | 0 | Enable | ~ | ~ | X | When set allows the collection of statistics information. | | | 1 | StatsType | ~ | ~ | X | Selects the type of staticstics to gather. The options are: 0 = Picking 1 = Extent | | | 2 | ActiveSteps | ~ | ~ | X | When set includes active fragments in the statistics gathering, otherwise they are excluded. | | | 3 | PassiveSteps | ~ | ~ | x | When set includes culled fragments in the statistics gathering, otherwise they are excluded. | | | 4 | Compare<br>Function | V | ~ | X | Selects the type of compare function to use. The options are: 0 = Inside region 1 = Outside region | | | 5 | Spans | ~ | ~ | X | When set includes spans in the statistics gathering, otherwise they are excluded. | | | 631 | Unused | 0 | 0 | X | | | Notes: Statistic Collection: here the active fragments and spans are used to (a) record the extent of the rectangular region where rasterization has been occurring, or (b) if rasterization has occurred inside a specific rectangular region. These facilities are useful for picking and debug activities. Statistic collecting has two modes of operation: Picking In this mode the active and/or culled fragments, and spans have the associated XY coordinate compared against the coordinates specified in the MinRegion and MaxRegion registers. If the result is true then the PickResult flag is set otherwise it holds it previous state. The compare function can be either Inside or Outside. Before picking can start the ResetPickResult must be sent to clear the PickResult flag. Extent In this mode the active and/or culled fragments and spans have the associated XY coordinates compared to the *MinRegion* and *MaxRegion* registers and if found to be outside the defined rectangular region the appropriate register is updated with the new coordinate(s) to extend the region. The Inside/Outside bit has no effect in this mode. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. $<sup>^{30}</sup>$ Logic Op register readback is via the main register only #### **Stencil** | Name | Type | Offset | Format | |---------|------------|-----------------|----------| | Stencil | Stencil | 0x8998 | Bitfield | | | Command/co | ontrol register | | | | Bits | Name | Read | Write | Reset | Description | |---|------|---------------|----------|----------|-------|---------------------| | | 07 | Stencil value | <b>/</b> | <b>'</b> | X | 8 bit stencil value | | Ī | 831 | Reserved | 0 | 0 | X | | Notes: The *Stencil* register holds an externally sourced stencil value. It is a 32 bit register of which only the least significant 8 bits are used. The unused most significant bits should be set to zero. Set the register to the 8 bit stencil value to be used in clearing down the stencil buffer, or in drawing a primitive where the host supplies the stencil value. # StencilData StencilDataAnd StencilDataOr | Name | Type | Offset | Format | |----------------|-------------------|--------|---------------------| | StencilData | Stencil | 0x8990 | Bitfield | | StencilDataAnd | Stencil | 0xB3E0 | Bitfield Logic Mask | | StencilDataOr | Stencil | 0xB3E8 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>31 | Write | Reset | Description | | |------|---------------|------------|----------|-------|---------------------------------------------------|--| | 07 | Stencil value | <b>V</b> | <b>/</b> | X | 8 bit stencil test value | | | 815 | Compare mask | <b>~</b> | <b>/</b> | X | Determines which bits are significant in the test | | | 1623 | Writemask | <b>V</b> | <b>~</b> | X | Determines which bits in localbuffer are updated | | | 2431 | Reserved | 0 | 0 | X | | | Notes: The register holds data used in the Stencil test: - Stencil value is the reference value for the stencil test. - Compare mask is used to determine which bits are significant in the stencil test comparison. - The stencil writemask is used to control which stencil planes are updated as a result of the test. The stencil unit must be enabled to update the stencil buffer. If it is disabled then the stencil buffer will only be updated if ForceLBUpdate is set. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. **3D**/labs Proprietary and Confidential 5-145 <sup>31</sup> Logic Op register readback is via the main register only Bitfield Logic Mask StencilModeOr ## StencilMode StencilModeAnd StencilModeOr | Name | Type | Offset | Format | |----------------|---------|--------|---------------------| | StencilMode | Stencil | 0x8988 | Bitfield | | StencilModeAnd | Stencil | 0xAC60 | Bitfield Logic Mask | #### Control registers Stencil | Bits | Name | Read | Write | Reset | Description | |------|----------------|----------|----------|-------|------------------------------------------------------------| | | | 32 | | | | | 0 | Unit enable | ~ | <b>✓</b> | X | 0 = Disable | | | | | | | 1 = Enable | | 13 | Update method | <b>/</b> | V | X | if Depth test passes and Stencil test passes (see table 1) | | 46 | Update method | <b>/</b> | ~ | X | if Depth test fails and Stencil test passes (see table 1) | | 79 | Update method | <b>/</b> | V | X | if Stencil test fails (see table 1) | | 1012 | Mode 0-7 | <b>/</b> | ~ | X | Unsigned comparison function (see table 2) | | 1314 | Stencil source | <b>/</b> | ~ | X | 0 = Test Logic | | | | | | | 1 = Stencil Register | | | | | | | 2 = LBData | | | | | | | 3 = LBSourceData | | 1516 | Stencil widths | <b>~</b> | <b>V</b> | X | 0 = 4 bits | | | | | | | 1 = 8 bits | | | | | | | 2 = 1 bit | | 1731 | Unused | 0 | 0 | X | | 0xAC68 Notes: Controls the stencil test, which conditionally rejects fragments based on the outcome of a comparison between the value in the stencil buffer and a reference value in the *StencilData* register. If the test is LESS and the result is true then the fragment value is less than the source value.. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 5-146 <sup>32</sup> Logic Op register readback is via the main register only Table 1 - Update Method if Stencil Test fails | Mode | Method | Result | |------|-----------|--------------------------------------------------------------| | 0 | Keep | Source stencil | | 1 | Zero | 0 | | 2 | Replace | Reference stencil | | 3 | Increment | Clamp (Source stencil + 1) to 2 <sup>stencil width</sup> - 1 | | 4 | Decrement | Clamp (Source stencil -1) to 0 | | 5 | Invert | | **Table 2 - Unsigned Comparison Function** | Mode | Comparison Function | |------|---------------------| | 0 | NEVER | | 1 | LESS | | 2 | EQUAL | | 3 | LESS OR EQUAL | | 4 | GREATER | | 5 | NOT EQUAL | | 6 | GREATER OR EQUAL | | 7 | ALWAYS | # **StripeOffsetY** | Name | Type | Offset | Format | |---------------|------------------|--------|-------------| | StripeOffsetY | | 0x80C8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|------------------------------------| | 015 | Fixed point | 1 | 1 | X | 2's complement fixed point value | | 1623 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: This register holds the 16 bit 2's complement Y value added to the raster Y value to determine scanline ownership. ## SuspendUntilFrameBlank NameTypeOffsetFormatSuspendUntilFrameBlankFramebuffer0x8C78BitfieldCommandCommand | Bits | Name | Read | Write | Reset | Description | |------|------------|----------|----------|-------|-----------------------------------------| | 020 | ScreenBase | <b>V</b> | <b>V</b> | X | Base address of screen in 128 bit units | | 2131 | Reserved | 0 | 0 | X | | Notes: The SuspendUntilFrameBlank command flushes the write combine buffers and then is forwarded onto the Memory Controller where it prevents any further memory writes (normal or span writes) from this port until after the next the Vertical Frame Blank has happened. When frame blank occurs new writes are allowed to proceed. By using this register the host does not need to get involved with waiting for vertical frame blank itself before it can issue new instructions to R4. While waiting for frame blank any data or actions which do not involve writing to the memory via this unit (such as clearing down the depth buffer) can proceed. Attempting to write to the memory while waiting for frame blank will just result in the Write FIFO blocking for the duration and this will ripple back through the chip ## Sync | Name | Type | Offset | Format | |-----------------|------------------|--------|----------| | Synchronization | Output | 0x8C40 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|----------|-------|----------------------------------------------| | 030 | User defined | X | <b>~</b> | X | User defined | | 31 | Interrupt<br>enable | × | ~ | X | Interrupt after output FIFO write operations | Notes: This command can be used to synchronize with the host. It is also used to flush outstanding operations such as pending memory accesses. It also causes the current status of the picking result to be passed to the Host Out FIFO unless culled by the statistics bits in the *FilterMode* register. If bit 31 of the input data is set then an interrupt is generated. The data output is the value written to the register by this command. If interrupts are enabled, then the interrupt does not occur until the tag and/or data have been written to the output FIFO. #### T1Start | Name | Type | Offset | Format | |---------|---------|--------|-------------| | T1Start | Texture | 0x8418 | Fixed point | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------| | 0n | Fraction | 1 | 1 | X | 2's complement fixed point fraction | | n31 | Integer | 1 | 1 | X | 2's complement fixed point integer | Notes: Initial T1 value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S1, T1 and Q1 values. ## TailPhysicalPageAllocation[0...3] | Name | Type | Offset | Format | |----------------------------|---------|-----------------|---------| | TailPhysicalPageAllocation | Texture | 0xB4A0, 0xB4A8, | Integer | | [03] | | 0xB4B0, 0xB4B8 | | Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|---------------------| | 015 | Address | ✓ | 1 | X | 16 bit value 065535 | Notes: These registers hold the tail page for memory pools 0...3. This is usually the least recently referenced physical page in the pool of the working set. The range of physical pages is 0...65535. ## TextRender2DGlyph0...7 | Name | Type | Offset | Format | |--------------------|--------|--------|----------| | TextRender2DGlyph0 | Global | 0x8708 | Bitfield | | TextRender2DGlyph1 | Global | 0x8718 | Bitfield | | TextRender2DGlyph2 | Global | 0x8728 | Bitfield | | TextRender2DGlyph3 | Global | 0x8738 | Bitfield | | TextRender2DGlyph4 | Global | 0x8748 | Bitfield | | TextRender2DGlyph5 | Global | 0x8758 | Bitfield | | TextRender2DGlyph6 | Global | 0x8768 | Bitfield | | TextRender2DGlyph7 | Global | 0x8778 | Bitfield | | * - | C 1 | | | Command | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|---------------------| | | | | | | | | 06 | Width | X | ~ | X | | | 713 | Height | X | ~ | X | | | 1422 | X | X | ~ | X | Signed advance in X | | 2331 | Y | X | ~ | X | Signed advance in Y | Alias for Render2Dglyph. This command starts a glyph being rendered from the position given by Notes: (GlyphPosition+Advance(X, Y)). ## TextGlyphAddr0...7 | Name | Type | Offset | Format | |----------------|------------------|--------|---------| | TextGlyphAddr0 | Texture | 0x8700 | Integer | | TextGlyphAddr1 | Texture | 0x8710 | Integer | | TextGlyphAddr2 | Texture | 0x8720 | Integer | | TextGlyphAddr3 | Texture | 0x8730 | Integer | | TextGlyphAddr4 | Texture | 0x8740 | Integer | | TextGlyphAddr5 | Texture | 0x8750 | Integer | | TextGlyphAddr6 | Texture | 0x8760 | Integer | | TextGlyphAddr7 | Texture | 0x8770 | Integer | | | Control register | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|--------------| | 031 | Base address | X | 1 | x | 32 bit value | Alias for **TextureBaseAddrn**, to allow multiple updates without duplicating tag data. These registers hold the base address of each texture map (or level for a mip map). The address should be aligned to the natural size of the texture map, however some layouts impose additional restrictions. Readback is via the updated **TextureBaseAddress** register(s). # TextureApplicationMode TextureApplicationModeAnd TextureApplicationModeOr | Name | Type | Offset | Format | |--------------------------|-------------------|--------|---------------------| | TextureApplicationMode | Texture | 0x8680 | Bitfield | | | Application | | | | TextureApplication | Texture | 0xAC50 | Bitfield Logic Mask | | ModeAnd | Application | | | | TextureApplicationModeOr | Texture | 0xAC58 | Bitfield Logic Mask | | | Application | | | | | Control registers | | | | Bits | Name | Read<br>33 | Write | Reset | Description | |------|--------------|------------|----------|-------|--------------------------------------------------------------| | 0 | Enable | V | <b>V</b> | X | When set causes the output to be calculated as defined | | | | | | | by the fields in this register, otherwise the fragment's | | | | | | | data is passed through. | | 12 | ColorA | V | <b>/</b> | X | This field selects the source value for A. The options | | | | | | | are: | | | | | | | 0 = Color.C | | | | | | | 1 = Color.A | | | | | | | 2 = K.C (TextureEnvColor) | | | | | | | 3 = K.A (TextureEnvColor) | | 34 | ColorB | V | ~ | X | This field selects the source value for B. The options | | | | | | | are: | | | | | | | 0 = Texel.C | | | | | | | 1 = Texel.A | | | | | | | 2 = K.C (TextureEnvColor) | | | | | | | 3 = K.A (TextureEnvColor) | | 56 | ColorI | V | <b>/</b> | X | This field selects the source value for I. The options | | | | | | | are: | | | | | | | 0 = Color.A | | | | | | | 1 = K.A (TextureEnvColor) | | | | | | | 2 = Texel.C | | | | | | | 3 = Texel.A | | 7 | ColorInvertI | V | ~ | x | This bit, if set, will invert the selected I value before it | | | | | | | is used. | **3D**labs Proprietary and Confidential 5-151 $<sup>^{33}</sup>$ Logic Op register readback is via the main register only | 810 | Color | <b>/</b> | ~ | X | This field defines how the three inputs (A, B and I) are | |------|---------------|----------|----------|----------|----------------------------------------------------------------------| | 010 | Operation | | | 1 | combined. Note the I inputs can be optionally | | | Operation | | | | inverted before being combined. The 8 bit inputs are | | | | | | | unsigned 0.8 fixed point format, but 255 is treated as if | | | | | | | it were 1.0 for the calculations. The possible | | | | | | | _ | | | | | | | operations are: | | | | | | | $0 = \operatorname{PassA}(A)$ | | | | | | | 1 = PassB(B) | | | | | | | 2 = Add (A + B) | | | | | | | 3 = Modulate (A * B) | | | | | | | 4 = Lerp (A * (1.0 - I) + B * I) | | | | | | | 5 = ModulateColorAddAlpha (A * B + I) | | | | | | | 6 = ModulateAlphaAddColor (A * I + B) | | | | | | | 7 = ModulateBIAddA (B * I + A) | | 1112 | AlphaA | ~ | <b>/</b> | X | This field selects the source value for A. The options | | | | | | | are: | | | | | | | 0 = Color.C (effectively Color.A) | | | | | | | 1 = Color.A | | | | 1 | | | 2 = K.C (TextureEnvColor) (effectively | | | | | | | K.A) | | | | | | | 3 = K.A (TextureEnvColor) | | 1314 | AlphaB | V | ~ | X | This field selects the source value for B. The options | | | T | | | | are: | | | | | | | 0 = Texel.C (effectively T.A) | | | | | | | 1 = Texel.A | | | | | | | 2 = K.C (TextureEnvColor) (effectively | | | | | | | K.A) | | | | | | | 3 = K.A (TextureEnvColor) | | 1516 | AlphaI | <b>/</b> | V | X | This field selects the source value for I. The options | | 1310 | 711piiai | | | A | are: | | | | | | | 0 = Color.A | | | | | | | 1 = K.A (TextureEnvColor) | | | | | | | 2 = Texel.C (effectively T.A) | | | | | | | 3 = Texel.A | | 17 | A 11 T | 1 | | _ | | | 17 | Alpha InvertI | | <b>~</b> | X | This bit, if set, will invert the selected I value before it | | 1820 | Alpha | | | | is used. This field defines how the three inputs (A. B. and D. are.) | | 1020 | Alpha | <b>'</b> | <b>~</b> | X | This field defines how the three inputs (A, B and I) are | | | Operation | | | 1 | combined. Note the I inputs can be optionally | | | | 1 | | | inverted before being combined. The 8 bit inputs are | | | | | | 1 | unsigned 0.8 fixed point format, but 255 is treated as if | | | | 1 | | | it were 1.0 for the calculations. The possible | | | | | | 1 | operations are: | | | | 1 | | | 0 = PassA(A) | | | | | | 1 | 1 = PassB(B) | | | | 1 | | | 2 = Add (A + B) | | | | | | 1 | 3 = Modulate (A * B) | | | | 1 | | | 4 = Lerp (A * (1.0 - I) + B * I) | | | | | | 1 | 5 = ModulateABAddI (A * B + I) | | | | 1 | | | 6 = ModulateAIAddB (A * I + B) | | | | | | | 7 = ModulateBIAddA (B * I + A) | | 21 | KdEnable | <b>/</b> | ~ | X | When set this bit causes the RGB results of the texture | | | | | | | application to be multiplied by the Kd DDA values. It | | | | | | <u> </u> | also enables the Kd DDA sto be updated. | | L | • | • | • | • | | | 22 | KsEnable | ~ | ~ | x | When set this bit causes the RGB results of the application (or Kd processing) to be added with the Ks DDA values. It also enables the Ks DDAs to be updated. | |------|-----------------------|----------|----------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 23 | Motion Comp<br>Enable | <b>'</b> | <b>'</b> | X | This bit, when set causes the color field to re interpreted as holding YUV difference values as three 9 bit 2's complement numbers. These are subtracted from the RGB channels of the texel value (after all previous processing) and the result clamped. This is used as part of MPEG Motion Compensation processing. | | 2431 | Unused | 0 | 0 | X | | Notes: Formerly known as **TextureColorMode**. Defines the operation for the color channels in applying texture. Note that the *TextureEnable* bit in the *Render* command must be set for a primitive to be texture mapped. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## TextureBaseAddr[0...15] | Name | Type | Offset | Format | |----------------------|---------|--------|---------| | Texture Base Address | Texture | 0x8500 | Integer | | [015] | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | 1 | X | 32 bit value | Notes: This register holds the base address of each texture map (or level for a mip map). The address should be aligned to the natural size of the texture map, however some layouts impose additional restrictions. The <code>MapBaseRegister</code> field of the <code>TextureReadMode</code> register defines which <code>TextureBaseAddr</code> register should be used to hold the address for map level 0 when mip mapping, or the texture map when not mip mapping. Successive map levels are at increasing <code>TextureBaseAddr</code> registers upto (and including) the <code>MapMaxLevel</code>. 3D textures always use <code>TextureBaseAddr0</code>. ## TextureChromaLower0 TextureChromaUpper0 NameTypeOffsetFormatTextureChromaLower0Texture0x84F0BitfieldTextureChromaUpper00x84E8 Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 1 | 1 | X | Red | | 815 | G | 1 | 1 | X | Green | | 1623 | В | 1 | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: These registers hold the lower and upper chroma colors to use when the chroma test is enabled for texels from texture map 0. The format is 8 bit ABGR components packed into a 32 bit word with R in the ls byte. ## TextureChromaUpper1 TextureChromaLower1 NameTypeOffsetFormatTextureChromaUpper1Texture0x8600BitfieldTextureChromaLower1Texture0x8608BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | | | | | | | | 07 | R | 1 | 1 | X | Red | | 815 | G | 1 | 1 | X | Green | | 1623 | В | 1 | 1 | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: These registers hold the upper and lower chroma colors to use when the chroma test is enabled for texels T4...T7. Its format is 8 bit ABGR components packed into a 32 bit word with R in the ls byte. # TextureCompositeAlphaMode0 TextureCompositeAlphaMode0And TextureCompositeAlphaMode0Or | Name | Type | Offset | Format | |-----------------------|---------|--------|---------------------| | TextureCompositeAlpha | Texture | 0xB310 | Bitfield | | Mode0 | | | | | TextureCompositeAlpha | Texture | 0xB390 | Bitfield Logic Mask | | Mode0And | | | - | | TextureCompositeAlpha | Texture | 0xB398 | Bitfield Logic Mask | | Mode0Or | | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | ~ | x When set causes the output to be calculated as de by the fields in this register, otherwise the texel0 of is passed through for stage0 and Output data is p through for stage 1. | | | 14 | Arg1 | | | X | This field selects the source value for Arg1. The options are: 0 = Output.C of the previous stage or height if the first stage 1 = Output.A of the previous stage or height if the first stage 2 = Color.C 3 = Color.A 4 = TextureCompositeFactor0.C 5 = TextureCompositeFactor0.A 6 = Texel0.C 7 = Texel0.A 8 = Texel1.C 9 = Texel1.A 10 = Sum of the color components of the previous stage or 0 if the first stage. where C is the RGB or A depending on the channel. height is defined as clamp (Texel0.A - Texel1.A + 128) | | 5 | InvertArg1 | ~ | ~ | X | This bit, if set, will invert the selected Arg1 value before it is used. | | 69 | Arg2 | <b>'</b> | V | X | This field selects the source value for Arg2. The | |------|------------|----------|----------|---|-----------------------------------------------------------| | | | | | | options are: | | | | | | | 0 = Output.C of the previous stage or | | | | | | | height if the first stage | | | | | | | 1 = Output.A of the previous stage or | | | | | | | height if the first stage | | | | | | | 2 = Color.C | | | | | | | 3 = Color.A | | | | | | | 4 = TextureCompositeFactor0 C | | | | | | | 5 = TextureCompositeFactor0 A | | | | | | | 6 = Texel0.C | | | | | | | 7 = Texel0.A | | | | | | | 8 = Texel1.C | | | | | | | 9 = Texel 1.A | | | | | | | 10 = Sum of the color components of the | | | | | | | previous stage or 0 if the first stage. | | | | | | | where C is the RGB or A depending on the | | | | | | | channel, and height is defined as clamp (Texel0.A - | | | | | | | Texel1.A + 128) | | 10 | InvertArg2 | V | V | X | This bit, if set, will invert the selected Arg2 value | | | | | | | before it is used. This is new in Permedia3. | | 1113 | T | ~ | ~ | X | This field selects what is used as the interpolation | | | | | | | factor when the Operation field is set to Lerp, for | | | | | | | example. The options are: | | | | | | | 0 = Output.A of the previous stage or 0 if | | | | | | | the first stage | | | | | | | 1 = Colour.A | | | | | | | 2 = TextureCompositeFactorn.A | | | | | | | 3 = Texel0.A | | | | | | | 4 = Texel1.A | | | | | | | 5 = Texel0.C | | | | | | | 6 = Texel1.C | | | | | | | where n is the same as the message suffix and C is the | | | | | | | RGB or A depending on the channel. | | 14 | InvertI | · | V | X | This bit, if set, will invert the selected I value | | | | | | | before it is used. | | 15 | Α | | | | | | 15 | A | • | <b>"</b> | X | This bit selects which Arg (after any inversion) is to be | | | | | | | used as A in the Operation. The options are: | | | | | | | 0 = Arg1 | | 1.6 | D | | + _ | | 1 = Arg2 | | 16 | В | ~ | ~ | X | This bit selects which Arg (after any inversion) is to be | | | | | | | used as B in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | | | 1 = Arg2 | | 1720 | Operation | • | ~ | x | This field defines how the three inputs (A, B and I) are combined. Note the inputs can be optionally inverted before being combined. The 8 bit inputs are unsigned 0.8 fixed point format, but 255 is treated as if it were 1.0 for the calculations. The possible operations are: 0 = Pass (A) 1 = Add (A + B) 2 = AddSigned (A + B - 128) 3 = Subtract (A - B) 4 = Modulate (A * B) 5 = Lerp (A * (1.0 - I) + B * I) 6 = ModulateColorAddAlpha (A * B + I) 7 = ModulateAlphaAddColor (A * I + B) 8 = AddSmoothSaturate (A + B - A * B) 9 = ModulateSigned (A * B, but A and B are biased 8 bit numbers) | |------|-----------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2122 | Scale | 0 | 0 | X | This field selects the scale factor to apply to the final result before it is clamped. The options are: $0 = 0.5$ $1 = 1$ $2 = 2$ $3 = 4$ | | 2331 | Reserved | 0 | 0 | X | | The Texture unit composites the Color, Texel0 and Texel1 fragment's values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register defines the operation for the alpha channels in compositing stage 0 for this unit. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # TextureCompositeAlphaMode1 TextureCompositeAlphaMode1And TextureCompositeAlphaMode1Or | Name | Type | Offset | Format | |-----------------------|---------|--------|---------------------| | TextureCompositeAlpha | Texture | 0xB320 | Bitfield | | Mode1 | | | | | TextureCompositeAlpha | Texture | 0xB3B0 | Bitfield Logic Mask | | Mode1And | | | | | TextureCompositeAlpha | Texture | 0xB3B8 | Bitfield Logic Mask | | Mode1Or | | | | Control registers | Bits | Name | Read<br>34 | Write | Reset | Description | |------|------------|------------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | ~ | x | When set causes the output to be calculated as defined<br>by the fields in this register, otherwise the texel0 data<br>is passed through for stage0 and Output data is passed<br>through for stage 1. | | 14 | Arg1 | | ~ | X | This field selects the source value for Arg1. The options are: 0 = Output.C of the previous stage or height if the first stage 1 = Output.A of the previous stage or height if the first stage 2 = Color.C 3 = Color.A 4 = TextureCompositeFactor1C 5 = TextureCompositeFactor1A 6 = Texel0.C 7 = Texel0.A 8 = Texel1.C 9 = Texel1.A 10 = Sum of the color components of the previous stage or 0 if the first stage. where C is the RGB or A depending on the channel. height is defined as clamp (Texel0.A - Texel1.A + 128) | | 5 | InvertArg1 | ~ | ~ | X | This bit, if set, will invert the selected Arg1 value before it is used. | 5-158 $<sup>^{34}</sup>$ Logic Op register readback is via the main register only | | T | | | | | |------|------------|---|----------|---|--------------------------------------------------------------| | 69 | Arg2 | ~ | <b>~</b> | X | This field selects the source value for Arg2. The | | | | | | | options are: | | | | | | | 0 = Output.C of the previous stage or height | | | | | | | if the first stage | | | | | | | 1 = Output.A of the previous stage or height | | | | | | | if the first stage | | | | | | | 2 = Color.C | | | | | | | 3 = Color.A | | | | | | | 4 = TextureCompositeFactor1C | | | | | | | 5 = TextureCompositeFactor1A | | | | | | | 6 = Texel0.C | | | | | | | 7 = Texel0.A | | | | | | | 8 = Texel1.C | | | | | | | 9 = Texel1.A | | | | | | | 10 = Sum of the color components of the | | | | | | | previous stage or 0 if the first stage. | | | | | | | where C is the RGB or A depending on the channel. | | | | | | | height is defined as clamp (Texel0.A - Texel1.A + 128) | | 10 | InvertArg2 | V | V | X | This bit, if set, will invert the selected Arg2 value | | | | | | | before it is used. | | 1113 | Ι | ~ | <b>/</b> | X | This field selects what is used as the interpolation | | | | | | | factor when the Operation field is set to Lerp, for | | | | | | | example. The options are: | | | | | | | 0 = Output. A of the previous stage or 0 if | | | | | | | the first stage | | | | | | | 1 = Colour.A | | | | | | | 2 = TextureCompositeFactorn.A | | | | | | | 3 = Texel0.A | | | | | | | 4 = Texel1.A | | | | | | | 5 = Texel0.C | | | | | | | 6 = Texel1.C | | | | | | | where n is the same as the message suffix and C is the | | | | | | | RGB or A depending on the channel. | | 14 | InvertI | ~ | V | x | This bit, if set, will invert the selected I value before it | | | | | | | is used. | | 15 | A | ~ | <b>✓</b> | X | This bit selects which Arg (after any inversion) is to be | | | | | | | used as A in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | | | 1 = Arg2 | | 16 | В | ~ | ~ | X | This bit selects which Arg (after any inversion) is to be | | | | | | | used as B in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | | | 1 = Arg2 | | | • | • | 1 | 1 | 1 11124 | | 1720 | Operation | 1 | 1 | X | This field defines how the three inputs (A, B and I) are | |------|-----------|----------|----------|---|-----------------------------------------------------------| | | | | | | combined. Note the inputs can be optionally inverted | | | | | | | before being combined. The 8 bit inputs are unsigned | | | | | | | 0.8 fixed point format, but 255 is treated as if it were | | | | | | | 1.0 for the calculations. The possible operations are: | | | | | | | 0 = Pass(A) | | | | | | | 1 = Add (A + B) | | | | | | | 2 = AddSigned (A + B - 128) | | | | | | | 3 = Subtract (A - B) | | | | | | | 4 = Modulate (A * B) | | | | | | | 5 = Lerp (A * (1.0 - I) + B * I) | | | | | | | 6 = ModulateColorAddAlpha (A * B + I) | | | | | | | 7 = ModulateAlphaAddColor(A * I + B) | | | | | | | 8 = AddSmoothSaturate (A + B - A * B) | | | | | | | 9 = ModulateSigned (A * B, but A and B | | | | | | | are biased 8 bit numbers) | | 2122 | Scale | <b>/</b> | <b>/</b> | X | This field selects the scale factor to apply to the final | | | | | | | result before it is clamped. The options are: | | | | | | | 0 = 0.5 | | | | | | | 1 = 1 | | | | | | | 2=2 | | | | | | | 3 = 4 | | 2331 | Reserved | 0 | 0 | X | | Notes: The Texture unit composites the fragment's Color, Texel0 and Texel1 values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register defines the operation for the alpha channels in compositing stage 0 for this unit. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # TextureCompositeColorMode0 TextureCompositeColorMode0And TextureCompositeColorMode0Or | Name | Type | Offset | Format | |-----------------------|---------|--------|---------------------| | TextureCompositeColor | Texture | 0xB308 | Bitfield | | Mode0 | | | | | TextureCompositeColor | Texture | 0xB380 | Bitfield Logic Mask | | Mode0And | | | _ | | TextureCompositeColor | Texture | 0xB388 | Bitfield Logic Mask | | Mode0Or | | | <u> </u> | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | V | X | When set causes the output to be calculated as defined by the fields in this register, otherwise the texel0 data is passed through for stage0 and Output data is passed through for stage 1. | | 14 | Arg1 | | | X | This field selects the source value for Arg1. The options are: 0 = Output.C of the previous stage or height if the first stage 1 = Output.A of the previous stage or height if the first stage 2 = Color.C 3 = Color.A 4 = TextureCompositeFactor0.C 5 = TextureCompositeFactor0.A 6 = Texel0.C 7 = Texel0.A 8 = Texel1.C 9 = Texel1.A 10 = Sum of the color components of the previous stage or 0 if the first stage. where C is the RGB or A depending on the channel. Height is defined as clamp (Texel0.A - Texel1.A + 128) | | 5 | InvertArg1 | ~ | • | X | This bit, if set, will invert the selected Arg1 value before it is used. | | 69 | Arg2 | V | <b>V</b> | X | This field selects the source value for Arg2. The | |------|------------|----------|----------|---|------------------------------------------------------------------| | | | | | | options are: | | | | | | | 0 = Output.C of the previous stage or height | | | | | | | if the first stage | | | | | | | 1 = Output. A of the previous stage or height | | | | | | | if the first stage | | | | | | | 2 = Color.C | | | | | | | 3 = Color.A | | | | | | | 4 = TextureCompositeFactor0.C | | | | | | | 5 = TextureCompositeFactor0.A | | | | | | | 6 = Texel0.C | | | | | | | 6 - Texelo.C $7 = Texel0.A$ | | | | | | | | | | | | | | 8 = Texel1.C | | | | | | | 9 = Texel1.A | | | | | | | 10 = Sum of the color components of the | | | | | | | previous stage or 0 if the first stage. | | | | | | | where C is the RGB or A depending on the channel. | | | | | | | height is defined as clamp (Texel0.A - Texel1.A + 128) | | 10 | InvertArg2 | <b>~</b> | <b>~</b> | X | This bit, if set, will invert the selected Arg2 value | | | | | | | before it is used. | | 1113 | I | <b>V</b> | <b>~</b> | X | This field selects what is used as the interpolation | | | | | | | factor when the Operation field is set to Lerp, for | | | | | | | example. The options are: | | | | | | | 0 = Output.A of the previous stage or 0 if | | | | | | | the first stage | | | | | | | 1 = Colour.A | | | | | | | 2 = TextureCompositeFactorn.A | | | | | | | 3 = Texel0.A | | | | | | | 4 = Texel1.A | | | | | | | 5 = Texel0.C | | | | | | | 6 = Texel1.C | | | | | | | where n is the same as the message suffix and C is the | | | | | | | RGB or A depending on the channel. | | 14 | InvertI | ~ | ~ | X | This bit, if set, will invert the selected I value before it | | | | | | | is used. | | 15 | A | V | V | X | This bit selects which Arg (after any inversion) is to be | | 13 | 11 | | | Δ | used as A in the Operation. The options are: | | | | | | | used as $\Lambda$ in the Operation. The options are:<br>0 = Arg1 | | | | | | | © . | | 16 | В | | | | 1 = Arg2 | | 16 | D | <b>~</b> | ~ | X | This bit selects which Arg (after any inversion) is to be | | | | | | | used as B in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | | | 1 = Arg2 | | 1720 | Operation | ~ | ~ | X | This field defines how the three inputs (A, B and I) are combined. Note the inputs can be optionally inverted before being combined. The 8 bit inputs are unsigned 0.8 fixed point format, but 255 is treated as if it were 1.0 for the calculations. The possible operations are: 0 = Pass (A) 1 = Add (A + B) 2 = AddSigned (A + B - 128) 3 = Subtract (A - B) 4 = Modulate (A * B) 5 = Lerp (A * (1.0 - I) + B * I) 6 = ModulateColorAddAlpha (A * B + I) 7 = ModulateAlphaAddColor (A * I + B) 8 = AddSmoothSaturate (A + B - A * B) 9 = ModulateSigned (A * B, but A and B are biased 8 bit numbers) | |------|-----------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2122 | Scale | ~ | ~ | x | This field selects the scale factor to apply to the final result before it is clamped. The options are: $0 = 0.5$ $1 = 1$ $2 = 2$ $3 = 4$ | | 2331 | Reserved | 0 | 0 | X | | Notes: The Texture unit composites the framgent's Color, Texel0 and Texel1 values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register defines the operation for the alpha channels in compositing stage 0 for this unit. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # TextureCompositeColorMode1 TextureCompositeColorMode1And TextureCompositeColorMode1Or | Name | Type | Offset | Format | |-----------------------|---------|--------|---------------------| | TextureCompositeColor | Texture | 0xB318 | Bitfield | | Mode1 | | | | | TextureCompositeColor | Texture | 0xB3A0 | Bitfield Logic Mask | | Mode1And | | | | | TextureCompositeColor | Texture | 0xB3A8 | Bitfield Logic Mask | | Mode1Or | | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | V | x | When set causes the output to be calculated as defined by the fields in this register, otherwise the texel0 data is passed through for stage0 and Output data is passed through for stage 1. | | 14 | Arg1 | | ~ | X | This field selects the source value for Arg1. The options are: 0 = Output.C of the previous stage or height if the first stage 1 = Output.A of the previous stage or height if the first stage 2 = Color.C 3 = Color.A 4 = TextureCompositeFactor1.C 5 = TextureCompositeFactor1.A 6 = Texel0.C 7 = Texel0.A 8 = Texel1.C 9 = Texel1.A 10 = Sum of the color components of the previous stage or 0 if the first stage. where n is the same as the message suffix and C is the RGB or A depending on the channel. height is defined as clamp (Texel0.A - Texel1.A + 128) | | 5 | InvertArg1 | ~ | ~ | X | This bit, if set, will invert the selected Arg1 value before it is used. | | 69 | Λ #~? | | | | This field colouts the course for A = 2 Th | |------|------------|----------|----------|---|----------------------------------------------------------------| | 09 | Arg2 | | <b>/</b> | X | This field selects the source value for Arg2. The options are: | | | | | | | | | | | | | | 0 = Output.C of the previous stage or height | | | | | | | if the first stage | | | | | | | 1 = Output.A of the previous stage or height | | | | | | | if the first stage | | | | | | | 2 = Color.C | | | | | | | 3 = Color.A | | | | | | | 4 = TextureCompositeFactor1.C | | | | | | | 5 = TextureCompositeFactor1.A | | | | | | | 6 = Texel0.C | | | | | | | 7 = Texel 0.A | | | | | | | 8 = Texel1.C | | | | | | | 9 = Texel1.A | | | | | | | 10 = Sum of the color components of the | | | | | | | previous stage or 0 if the first stage. | | | | | | | where C is the RGB or A depending on the channel. | | | | | | | height is defined as clamp (Texel0.A - Texel1.A + 128) | | 10 | InvertArg2 | <b>/</b> | <b>V</b> | X | This bit, if set, will invert the selected Arg2 value | | | | | | | before it is used. | | 1113 | I | <b>V</b> | <b>V</b> | X | This field selects what is used as the interpolation | | | | | | | factor when the Operation field is set to Lerp, for | | | | | | | example. The options are: | | | | | | | 0 = Output. A of the previous stage or 0 if | | | | | | | the first stage | | | | | | | 1 = Colour.A | | | | | | | 2 = TextureCompositeFactorn.A | | | | | | | 3 = Texel0.A | | | | | | | 4 = Texel1.A | | | | | | | 5 = Texel0.C | | | | | | | 6 = Texel1.C | | | | | | | where n is the same as the message suffix and C is the | | | | | | | RGB or A depending on the channel. | | 14 | InvertI | ~ | <b>'</b> | x | This bit, if set, will invert the selected I value before it | | | | | | | is used. | | 15 | A | ~ | ~ | X | This bit selects which Arg (after any inversion) is to be | | 1 | _ | | | | used as A in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | | | 1 = Arg2 | | 16 | В | V | · | X | This bit selects which Arg (after any inversion) is to be | | 10 | <i>D</i> | <b>"</b> | <b>"</b> | Α | used as B in the Operation. The options are: | | | | | | | used as B in the Operation. The options are: $0 = \text{Arg1}$ | | • | | | | | | | | | | | | 1 = Arg2 | | 1720 | Operation | <b>V</b> | V | X | This field defines how the three inputs (A, B and I) are | |------|-----------|----------|---|---|-----------------------------------------------------------| | | | | | | combined. Note the inputs can be optionally inverted | | | | | | | before being combined. The 8 bit inputs are unsigned | | | | | | | 0.8 fixed point format, but 255 is treated as if it were | | | | | | | 1.0 for the calculations. The possible operations are: | | | | | | | 0 = Pass (A) | | | | | | | 1 = Add (A + B) | | | | | | | 2 = AddSigned (A + B - 128) | | | | | | | 3 = Subtract (A - B) | | | | | | | 4 = Modulate (A * B) | | | | | | | 5 = Lerp (A * (1.0 - I) + B * I) | | | | | | | 6 = ModulateColorAddAlpha (A * B + I) | | | | | | | 7 = ModulateAlphaAddColor(A * I + B) | | | | | | | 8 = AddSmoothSaturate (A + B - A * B) | | | | | | | 9 = ModulateSigned (A * B, but A and B | | | | | | | are biased 8 bit numbers) | | 2122 | Scale | / | ~ | X | This field selects the scale factor to apply to the final | | | | | | | result before it is clamped. The options are: | | | | | | | 0 = 0.5 | | | | | | | 1 = 1 | | | | | | | 2 = 2 | | | | | | | 3 = 4 | | 2331 | Reserved | 0 | 0 | X | | Notes: The Texture unit composites the fragment's Color, Texel0 and Texel1 values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register defines the operation for the alpha channels in compositing stage 0 for this unit. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## TextureCompositeFactor0 | Name | Type | Offset | Format | |-------------------------|---------|--------|----------| | TextureCompositeFactor0 | Global | 0xB328 | Bitfield | | _ | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|----------|-------|-------------| | 07 | red | ~ | ~ | X | red | | 815 | green | V | <b>V</b> | X | green | | 1623 | blue | V | <b>V</b> | X | blue | | 2431 | alpha | V | <b>V</b> | X | alpha | Notes: The Texture unit composites the fragment's Color, Texel0 and Texel1 values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register holds the constant factor to use with compositing stage 0. ## TextureCompositeFactor1 | Name | Type | Offset | Format | |-------------------------|---------|--------|----------| | TextureCompositeFactor1 | Texture | 0xB330 | Bitfield | | _ | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|----------|----------|-------|-------------| | | | | | | | | 07 | red | / | ~ | X | red | | 815 | green | V | ~ | X | green | | 1623 | blue | <b>V</b> | <b>/</b> | X | blue | | 2431 | alpha | <b>V</b> | <b>/</b> | X | alpha | Notes: The Texture unit composites the Color, Texel0 and Texel1 from a step message with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register holds the constant factor to use with compositing stage 1. ## **TextureCompositeMode** | Name | Type | Offset | Format | |----------------------|---------|--------|----------| | TextureCompositeMode | Texture | 0xB300 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|----------|-------|-----------------------------------------------| | 0 | Enable | V | <b>/</b> | X | Global enable/disable for Texture Composition | | 131 | Unused | 0 | 0 | X | | Notes: Global enable/disable for Texture Composite operation. Setting Bit0 causes the compositing operation to be calculated and to replace the texture0 value sent to the next unit, otherwise the texture value remains unchanged. This enable is also qualified by the TextureEnable bit in the *Render* command. # TextureCoordModeAnd TextureCoordModeOr | Name | Type | Offset | Format | |---------------------|---------|--------|----------| | TextureCoordMode | Texture | 0x8380 | Bitfield | | TextureCoordModeAnd | Texture | 0xAC20 | Bitfield | | TextureCoordModeOr | Texture | 0xAC28 | Bitfield | | | 0 . 1 | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|------------------------------|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | ~ | X | When set causes the output to be calculated as defined by the fields in this register, otherwise the output values are set to zero. The TextureEnable bit in the Render command must also be set to enable this unit. | | 12 | WrapS | V | ~ | x | This field determines how the s coordinate is brought into the range 0.01.0 when it is outside this range. The options are: 0 = Clamp 1 = Repeat 2 = Mirror | | 34 | WrapT | ~ | • | X | This field determines how the t coordinate is brought into the range 0.01.0 when it is outside this range. The options are: 0 = Clamp 1 = Repeat 2 = Mirror | | 5 | Operation | | <b>V</b> | X | This bit selects if the coordinates are to be treated as 2D coordinates and ignore perspective correction, or a 3D coordinates and be perspectively corrected. 0 = 2D mode 1 = 3D mode When reset the addresses are calculated in '2D mode' so no perspective correction is done. This will typically run twice as fast as '3D mode' where perspective correction is done. In the 2D case the wrap operation is always "repeat" as the DDA units are allowed to wrap around and have the fixed 0.32 fixed point format. Level of detail calculation is not done in 2D mode. | | 6 | InhibitDDA<br>Initialisation | ~ | ~ | x | This bit, when set, prevents the DDA from being updated from the Start registers at the start of a primitive. This is useful when the texture mapping is being used to provide the pattern or stipple along a polyline and it is desirable that the pattern continues smoothly from one line to the next. | | 7 | EnableLOD | ~ | ~ | X | This bit, when set, causes the level of detail calculation to be calculated. This also involves setting the start values of the S1, T1 and Q1 DDAs as a function of the DY gradients and the S, T and Q start values. | | 8 | EnableDY | ~ | <b>'</b> | X | This bit, when set, causes the DY gradients of S, T and Q to be calculated, otherwise they are provided by some external source. | |------|---------------------|---|----------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 912 | Width | ~ | <b>'</b> | X | map when mip mapping. Its legal range is 011 inclusive and is only used when the EnableLOD bit is 1. | | 1316 | Height | ~ | • | X | This field holds the height, as a power of 2, of the highest resolution texture map when mip mapping. Its legal range is 011 inclusive and is only used when the EnableLOD bit is 1. | | 17 | Туре | V | <b>'</b> | X | This bit selects type of texture map and is only used to disable the t derivatives from influencing the level of detail calculations when a 1D texture map is being used. 0 = 1D map 1 = 2D map | | 1819 | WrapS1 | V | <b>'</b> | X | This field determines how the s1 coordinate is brought into the range $0.01.0$ when it is outside this range. The options are: $0 = \text{Clamp}$ $1 = \text{Repeat}$ $2 = \text{Mirror}$ | | 2021 | WrapT1 | V | ~ | x | This field determines how the t1 coordinate is brought into the range 0.01.0 when it is outside this range. The options are: 0 = Clamp 1 = Repeat 2 = Mirror | | 22 | Duplicate<br>Coords | ~ | • | X | This bit, when set, causes any loading one of the DDA start, dx or dyDom registers to load the corresponding registers for both texture 0 and texture 1 DDA | | 2331 | Uused | 0 | 0 | X | | Notes: Provides overall control of the generation of texel addresses. In MX, Permedia2 and earlier chipsets known as **TextureAddressMode**, but the address data is now part of Texture Read functionality. #### **TextureData** NameTypeOffsetFormatTextureDataLocalbuffer0x88E8IntegerControl register | I | Bits | Name | Read | Write | Reset | Description | |---|------|---------------|------|-------|-------|--------------------------------------| | 0 | 31 | Texture value | X | ✓ x | | 32 bit integer value from 0 to 65535 | Notes: 32bit raw texture value, formatted to match the format that will be used when the texture is read back from the localbuffer. May include multiple texels (depending on the texel depth), in which case the order of texels within the register will depend on factors such as the byte swap mode, as defined in the TextureFormat register when the texture is subsequently read. ## **TextureEnvColor** NameTypeOffsetFormatTextureEnvironmentColorTexture0x8688Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>v</b> | <b>v</b> | X | Red | | 815 | G | <b>/</b> | <b>✓</b> | x | Green | | 1623 | В | <b>✓</b> | <b>v</b> | X | Blue | | 2431 | A | <b>/</b> | <b>'</b> | X | Alpha | Notes: Constant color value used in blend texturing mode.. ## TextureFilterMode TextureFilterModeAnd TextureFilterModeOr | Name | Type | Offset | Format | |----------------------|-------------------|--------|---------------------| | TextureFilterMode | Alpha Blend | 0x84E0 | Bitfield | | TextureFilterModeAnd | Alpha Blend | 0xAD50 | Bitfield Logic Mask | | ChromaTestModeOr | Alpha Blend | 0xAD58 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>35 | Write | Reset | Description | |------|---------------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | V | V | X | When set causes the output to be calculated as defined by the fields in this register, otherwise the texel0 and texel1 values are set to zero. The TextureEnable bit in the <i>Render</i> command must also be set to enable this unit. | | 14 | Format0 | • | • | x | This field selects the format of the texel data T0T3. The options are 0 = A4L4 1 = L8 2 = I8 3 = A8 4 = 332 5 = A8I8 6 = 5551 7 = 565 8 = 4444 9 = 888 10 = 8888 or YUV | | 5 | ColorOrder0 | • | ~ | x | This bit selects the color component order of the texel data T0T3. The two options are: 0 = AGBR 1 = ARGB | | 6 | AlphaMapEnab<br>le0 | • | ~ | x | This bit, when set, enables the alpha value of texels T0T3 to be forced to zero based on testing the color values. | | 7 | AlphaMapSense 0 | ~ | V | x | This bit selects if the alpha value for texels T0T3 should be set to zero when the colors are in range or out of range. The options are: 0 = Out of range 1 = In range | | 8 | CombineCaches | V | - | X | This bit, when set, combines both banks of the cache so they are used for texture 0. This is an optimisation and allows larger textures to be handled before scanline coherency starts to break down. | $<sup>^{35}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only | 912 | Format1 | ~ | <b>/</b> | X | This field selects the format of the texel data T4T7. | |-------|--------------------------|----------|----------|----|---------------------------------------------------------| | | | | | | The options are | | | | | | | 0 = A4L4 | | | | | | | 1 = L8 | | | | | | | 2 = I8 | | | | | | | 3 = A8 | | | | | | | 4 = 332 | | | | | | | 5 = A8I8 | | | | | | | 6 = 5551 | | | | | | | 7 = 565 | | | | | | | 8 = 4444 | | | | | | | 9 = 888 | | | | | | | 10 = 8888 or YUV | | 13 | ColorOrder1 | ~ | V | X | This bit selects the color component order of the texel | | | 30101014411 | | | 1 | data T4T7. The two options are: | | | | | | | 0 = AGBR | | | | | | | 1 = ARGB | | 14 | Alaha Man Enah | | | | | | 14 | AlphaMapEnab | <b>/</b> | ~ | X | This bit, when set, enables the alpha value of texels | | | le1 | | | | T4T7 to be forced to zero based on testing the | | | 11.1.1.0 | | | | color values. | | 15 | AlphaMapSense | ~ | <b>~</b> | X | This bit selects if the alpha value for texels T4T7 | | | 1 | | | | should be set to zero when the colors are in range or | | | | | | | out of range. The options are: | | | | | | | 0 = Out of range | | | | | | | 1 = In range | | 16 | AlphaMapFilter | / | / | X | This bit, when set, will allow the alpha mapped texels | | | ing | | | | (AlphaMapEnable must be set) to cause the fragment | | | | | | | to be discarded depending on the comparison of the | | | | | | | number of texels to be alpha mapped with the | | | | | | | following three limit fields. | | 1719 | AlphaMapFilter | V | ~ | X | This field holds the number of alpha mapped texels in | | 2725 | Limit0 | | | 1 | the group T0T3 which must be exceeded for the | | | | | | | fragment to be discarded. | | 2022 | Alpha Man Filtor | | | 37 | This field holds the number of alpha mapped texels in | | 2022 | AlphaMapFilter<br>Limit1 | ~ | ~ | X | | | | 141111111 | | | | the group T4T7 which must be exceeded for the | | 22 26 | A1.1 N.C T211. | | + | | fragment to be discarded. | | 2326 | AlphaMapFilter | <b>~</b> | <b>~</b> | X | This field holds the number of alpha mapped texels in | | | Limit01 | | | | the group T0T7 which must be exceeded for the | | | | | | | fragment to be discarded. | | 27 | MultiTexture | ~ | <b>~</b> | X | This bit, when set, prevents the Alpha Map Filtering | | | | | | | logic from testing the I4 interpolant and maybe | | | | | | | disregarding the alpha map result of T0T3 or | | | | | | | T4T7. This bit should be set for multi texture | | | | | | | operation when alpha map filtering is required. It | | | | | | | should be clear otherwise. | | 28 | ForceAlphaTo | ~ | ~ | X | This bit, when set, will force the alpha channel of | | | One0 | | • | | T0T3 to be set to 1.0 (255) regardless of the color | | | | | | | format or the presence of a real alpha channel. | | 29 | ForceAlphaTo | ~ | V | X | This bit, when set, will force the alpha channel of | | | One1 | | | Δ. | T4T7 to be set to 1.0 (255) regardless of the color | | | Onci | | | | | | | | | | | format or the presence of a real alpha channel. | | 30 | Shift0 | This bit, when set, causes the conv | ersion of T0T3 | |----|--------|------------------------------------------|---------------------| | | | for color components less than 8 b | its wide to be done | | | | by a shift operation, otherwise a sc | ale operation is | | | | needed. The shift operation is use | ful where the exact | | | | color (after dithering) is to be present | erved for flat | | | | shaded areas, such as in a stretch b | lit. | | 31 | Shift1 | This bit, when set, causes the conv | ersion of T4T7 | | | | for color components less than 8 b | | | | | by a shift operation, otherwise a sc | | | | | needed. The shift operation is use | ful where the exact | | | | color (after dithering) is to be present | | | | | shaded areas, such as in a stretch b | lit. | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # TextureIndexMode0 TextureIndexMode0And TextureIndexMode0Or | Name | Type | Offset | Format | |----------------------|-------------------|--------|---------------------| | TextureIndexMode0 | Texture | 0xB338 | Bitfield | | TextureIndexMode0And | Texture | 0xB3C0 | Bitfield Logic Mask | | TextureIndexMode0Or | Texture | 0xB3C8 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>36 | Write | Reset | Description | |------|--------|------------|----------|-------|----------------------------------------------------------| | 0 | Enable | 30<br>V | <b>V</b> | X | When set causes the output to be calculated as defined | | U | Enable | | | A | by the fields in this register, otherwise the fragment's | | | | | | | index and interpolation data is set to zero. | | 14 | Width | V | V | X | This field holds the width of the map as a power of | | | | | | | two. The legal range of values for this field is 0 (map | | | | | | | width $= 1$ ) to 11 (map width $= 2048$ ). | | 58 | Height | V | <b>/</b> | X | This field holds the height of the map as a power of | | | | | | | two. The legal range of values for this field is 0 (map | | | | | | | width $= 1$ ) to 11 (map width $= 2048$ ). | | 9 | Border | <b>✓</b> | <b>✓</b> | X | This bit, when set indicates there is a one texel border | | | | | | | surrounding the texture map. | | 1011 | WrapU | ~ | <b>✓</b> | X | This field selects how the u coordinate is to be | | | | | | | wrapped to fit on the texture map. The options are: | | | | | | | 0 = Clamp | | | | | | | 1 = Repeat | | | | | | | 2 = Mirror | | | | | | | 3 = ClampEdge | | | | | | | | $<sup>^{36}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only | 1213 | WrapV | <b>/</b> | <b>1</b> | X | This field selects how the v coordinate is to be | |-------|---------------------|----------|----------|----|-----------------------------------------------------------------------| | 1213 | Winp v | | | 21 | wrapped to fit on the texture map. The options are: | | | | | | | wrapped to in on the texture map. The options are: $0 = \text{Clamp}$ | | | | | | | <u> </u> | | | | | | | 1 = Repeat<br>2 = Mirror | | | | | | | | | | | | | | 3 = ClampEdge | | 14 | МарТуре | V | ~ | X | This bit selects the type of texture map. The options | | | | | | | are | | | | | | | 0 = 1D | | | | | | | 1 = 2D | | 15 | Magnification | V | ~ | X | This field selects the magnification filter to use. The | | | Filter | | | | options are | | | | | | | 0 = Nearest | | | | | | | 1 = Linear | | 1618 | Minification | ~ | ~ | X | This field selects the minification filter to use. The | | | Filter | | | | options are | | | | | | | 0 = Nearest | | | | | | | 1 = Linear | | | | | | | 2 = NearestMipNearest | | | | | | | 3 = NearestMipLinear | | | | | | | 4 = LinearMipNearest | | | | | | | 5 = LinearMipLinear | | | | | | | | | | | | | | This field only has an effect when Texture3DEnable | | 10 | T · 2DE | _ | | | or MipMapEnable are true. | | 19 | Texture3DEna | ~ | ~ | X | This bit, when set, enables 3D texture index | | 20 | ble<br>MipMapEnable | | | X | generation. This bit, when set, enables mip map index generation. | | 2122 | NearestBias | <b>V</b> | V | | This field defines the bias to add to the u and or v | | 2122 | inearestbias | • | | X | | | | | | | | coordinates (after the map's width and height have | | | | | | | been taken into account) for nearest neighbour | | | | | | | filtering. This can be used to move the texel sample | | | | | | | point. The options are: | | | | | | | 0 = -0.5 | | | | | | | 1 = 0 Use this for OpenGL | | 22 24 | T: D: | | | 1 | 2 = +0.5 | | 2324 | LinearBias | <b>/</b> | <b>~</b> | X | This field defines the bias to add to the u and or v | | | | | | | coordinates (after the map's width and height have | | | | | | | been taken into account) for linear filtering. This can | | | | | | | be used to move the texel sample point. The options | | | | | | | are: | | | | | | | 0 = -0.5 Use this for OpenGL | | | | | | | 1 = 0 | | | 1 | | | 1 | 2 = +0.5 | | 25 | SourceTexelEn | <b>~</b> | <b>~</b> | X | When set this bit causes the calculated index (i0, j0) to | | | able | | | | be passed to the Framebuffer Read Unit to be used as | | | | | | | a source pixel coordinates. This allows the | | | | | | | framebuffer to do stretch blits, rotates, etc. | | 2631 | Reserved | 0 | 0 | x | | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # TextureIndexMode1 TextureIndexMode1And TextureIndexMode1Or | Name | Type | Offset | Format | |----------------------|---------|--------|---------------------| | TextureIndexMode1 | Texture | 0xB340 | Bitfield | | TextureIndexMode1And | Texture | 0xB3D0 | Bitfield Logic Mask | | TextureIndexMode1Or | Texture | 0xB3D8 | Bitfield Logic Mask | Control registers | Bits | Name | Read<br>37 | Write | Reset | Description | |------|-------------------------|------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ~ | ~ | X | When set causes the output to be calculated as defined<br>by the fields in this register, otherwise the fragment's<br>index and interpolation data is set to zero. | | 14 | Width | • | ~ | x | This field holds the width of the map as a power of two. The legal range of values for this field is 0 (map width = 1) to 11 (map width = 2048). | | 58 | Height | • | ~ | x | This field holds the height of the map as a power of two. The legal range of values for this field is 0 (map width = 1) to 11 (map width = 2048). | | 9 | Border | ~ | ~ | X | This bit, when set indicates there is a one texel border surrounding the texture map. | | 1011 | WrapU | V | ~ | X | This field selects how the u coordinate is to be wrapped to fit on the texture map. The options are: 0 = Clamp 1 = Repeat 2 = Mirror 3 = ClampEdge | | 1213 | WrapV | ~ | ~ | x | This field selects how the v coordinate is to be wrapped to fit on the texture map. The options are: 0 = Clamp 1 = Repeat 2 = Mirror 3 = ClampEdge | | 14 | МарТуре | • | ~ | X | This bit selects the type of texture map. The options are $0 = 1D$ $1 = 2D$ | | 15 | MagnificationFi<br>lter | • | ~ | X | This field selects the magnification filter to use. The options are 0 = Nearest 1 = Linear | **3D**labs Proprietary and Confidential 5-175 $<sup>^{</sup>m 37}$ Logic Op register readback is via the main register only | 1618 | MinificationFilt | <b>V</b> | ~ | X | This field selects the minification filter to use. The | |------|------------------|----------|----------|---|-----------------------------------------------------------| | | er | | | | options are | | | | | | | 0 = Nearest | | | | | | | 1 = Linear | | | | | | | 2 = NearestMipNearest | | | | | | | 3 = NearestMipLinear | | | | | | | 4 = LinearMipNearest | | | | | | | 5 = LinearMipLinear | | | | | | | This field only has an effect when Texture3DEnable | | | | | | | or MipMapEnable are true. | | 19 | Reserved | 0 | 0 | X | | | 20 | MipMapEnable | <b>/</b> | <b>'</b> | X | This bit, when set, enables mip map index generation. | | 2122 | NearestBias | <b>~</b> | <b>~</b> | X | This field defines the bias to add to the u and or v | | | | | | | coordinates (after the map's width and height have | | | | | | | been taken into account) for nearest neighbour | | | | | | | filtering. This can be used to move the texel sample | | | | | | | point. The options are: | | | | | | | 0 = -0.5 | | | | | | | 1 = 0 Use this for OpenGL | | | | | | | 2 = +0.5 | | 2324 | LinearBias | <b>/</b> | ~ | X | This field defines the bias to add to the u and or v | | | | | | | coordinates (after the map's width and height have | | | | | | | been taken into account) for linear filtering. This can | | | | | | | be used to move the texel sample point. The options | | | | | | | are: | | | | | | | 0 = -0.5 Use this for OpenGL | | | | | | | 1 = 0 | | | | | | | 2 = +0.5 | | 25 | SourceTexelEn | <b>~</b> | ~ | X | When set this bit causes the calculated index (i0, j0) to | | | able | | | | be passed to the Framebuffer Read Unit to be used as | | | | | | | a source pixel coordinates. This allows the | | | | | | | framebuffer to do stretch blits, rotates, etc. | | 2631 | Reserved | 0 | 0 | X | | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ### **TextureLodBiasS** | Name | Type | Offset | Format | |-----------------|------------------|--------|-------------| | TextureLodBiasS | Texture | 0x8450 | Fixed point | | | Control magistan | | _ | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-------------| | 07 | Fraction | <b>√</b> | 1 | X | | | 812 | Integer | 1 | 1 | X | | | 1231 | Reserved | 0 | 0 | X | | Notes: This register holds the 2's complement bias value in 5.8 fixed point format for the S components in the level of detail calculation. Its default value should be zero #### **TextureLodBiasT** | Name | Type | Offset | Format | |-----------------|------------------|--------|-------------| | TextureLodBiasT | Texture | 0x8458 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 07 | Fraction | 1 | 1 | X | | | 812 | Integer | 1 | 1 | X | | | 1231 | Reserved | 0 | 0 | X | | Notes: This register holds the 2's complement bias value in 5.8 fixed point format for the T components in the level of detail calculation. Its default value should be zero # **TextureMapSize** | Name | Type | Offset | Format | |----------------|------------------|--------|---------| | TextureMapSize | Texture | 0xB428 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 023 | Offset | 1 | 1 | X | 24 bit unsigned integer | | 2431 | Reserved | 0 | 0 | X | | Notes: This register holds the texel offset between adjacent 2D slices in a 3D texture map. It is a 24 bit unsigned number. ## TextureMapWidth[0...15] | Name | Type | Offset | Format | |----------------------|------------------|--------|----------| | TextureMapWidth[015] | Texture | 0x8580 | Bitfield | | • | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|------------------------------| | | | | | | | | 011 | Width | 1 | 1 | 0 | Width (excluding any border) | | 12 | Border enable | 1 | 1 | 0 | Border present, if set | | 1314 | Layout | ✓ | ✓ | 0 | Layout | | 15 | Host Texture | 1 | 1 | 0 | HostTexture enabled if set | Notes: These registers hold the width, border, layout and memory type for of each mip map level: - The width is normally the power of 2 width corresponding to the level, but can be any value in the range 0...4095. - If a border is present then all mip levels should have the bit set. - The layout field selects the layout of the texel data in memory for the texture map using *TextureBaseAddr0* register. The options are: 0 = Linear 1 = Patch64 Color buffer 2 = Patch32\_2 Large texture maps 3 = Patch2 Small texture maps • The HostTexture bit is only used if the texture is a physical texture. Logical textures use a bit in the Logical Page Table to identify if a texture is a Host Texture. # TextureReadMode0 TextureReadMode0And TextureReadMode0Or | Name | Type | Offset | Format | |---------------------|-------------------|--------|---------------------| | TextureReadMode0 | Texture | 0xB400 | Bitfield | | TextureReadMode0And | Texture | 0xAC30 | Bitfield Logic Mask | | TextureReadMode0Or | Texture | 0xAC38 | Bitfield Logic Mask | | | Control registers | | 9 | | Bits | Name | Read<br>38 | Write | Reset | Description | |------|--------|------------|----------|-------|----------------------------------------------------------| | | | 36 | | | | | 0 | Enable | <b>V</b> | <b>✓</b> | X | When set causes any texels needed by the fragment to | | | | | | | be read. This is also qualified by the TextureEnable | | | | | | | bit in the Render command. | | 14 | Width | <b>/</b> | ~ | X | This field holds the width of the map as a power of | | | | | | | two. The legal range of values for this field is 0 (map | | | | | | | width = 1) to 11 (map width = $2048$ ). This is only | | | | | | | used when Texture3D is enabled and then is only used | | | | | | | for cache management purposes and <i>not</i> for address | | | | | | | calculations. | <sup>&</sup>lt;sup>38</sup> Logic Op register readback is via the main register only 20 | 58 | Height | V | ~ | X | This field holds the height of the map as a power of two. The legal range of values for this field is 0 (map height = 1) to 11 (map height = 2048). This is only used when Texture3D is enabled and then is only used for cache management purposes and <i>not</i> for address calculations. | |------|-------------------|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 910 | TexelSize | ~ | ~ | x | This field holds the size of the texels in the texture map. The options are: 0 = 8 bits | | 11 | Textue3D | ~ | ~ | x | This bit, when set, enables 3D texture index generation. The CombinedCache mode bit should not be set when 3D textures are being used. | | 12 | Combine<br>Caches | • | ~ | x | This bit, when set, causes the two banks of the Primary Cache to be joined together, thereby increasing the size of a single texture map which can be efficiently handled. | | 1316 | MapBaseLevel | V | • | x | This field defines which TextureBaseAddr register should be used to hold the address for map level 0 when mip mapping or the texture map when not mip mapping. Successive map levels are at increasing TextureBaseAddr registers upto (and including) the MaxMaxLevel (next field). 3D textures always use TextureBaseAddr0. | | 1720 | MapMaxLevel | ~ | ~ | X | This field defines the maximum TextureBaseAddr register this texture should use when mip mapping. Any attempt to use beyond this level will clamp to this level. | | 21 | LogicalTexture | • | ~ | x | This bit, when set, defines this texture or all mip map levels, if mip mapping, to be logically mapped so undergo logical to physical translation of the texture addresses. | | 22 | Origin | • | • | X | This field selects where the origin is for a texture map with a Linear or Patch64 layout. The options are: 0 = Top Left. 1 = Bottom Left A Patch32_2 or Patch2 texture map is always bottom left origin. | | 2324 | TextureType | • | • | X | This field defines any special processing needed on the texel data before it can be used. The options are: 0 = Normal. | | 2527 | ByteSwap | <b>~</b> | <b>'</b> | X | This field defines the byte swapping, if any, to be done | | | |------|------------|----------|----------|---|----------------------------------------------------------|--|--| | | | | | | on texel data when it is used as a bitmap. This is | | | | | | | | | automatically done when spans are used. Bit 27, when | | | | | | | | | set, causes adjacent bytes to be swapped, bit 26 | | | | | | | | | adjacent 16 bit words to be swapped and bit 27 | | | | | | | | | adjacent 32 bit words to be swapped. In combination | | | | | | | | | this byte swap the input (ABCDEFGH) as follows: | | | | | | | | | 0 ABCDEFGH | | | | | | | | | 1 BADCFEHG | | | | | | | | | 2 CDABGHEF | | | | | | | | | 3 ABCDEFGH | | | | | | | | | 4 EFGHABCD | | | | | | | | | 5 FEHGBADC | | | | | | | | | 6 GHEFCDAB | | | | | | | | | 7 HGFEDCBA | | | | 28 | Mirror | ~ | <b>V</b> | X | This bit, when set will mirror any bitmap data. This | | | | | | | | | only works for spans. | | | | 29 | Invert | ~ | V | X | This bit, when set will invert any bitmap data. This | | | | | | | | | only works for spans. | | | | 30 | OpaqueSpan | ~ | ~ | X | This bit, when set allows the color of each pixel in the | | | | | | | | | span to be either foreground or background as set by | | | | | | | | | the supplied bit masks. If this bit is 0 then any | | | | | | | | | supplied bit masks are anded with the pixel mask to | | | | | | | | | delete pixels from the span. | | | | 31 | Reserved | 0 | 0 | X | | | | - The unit is controlled by the *TextureReadMode0* and *TextureReadMode1* registers for texture 0 and texture 1 respectively. Not all combinations of modes across both registers are supported and where there is a clash the modes in *TextureReadMode0* take priority. - N.B. The layout and use of the *TextureReadMode* register is not compatible with GLINT MX: 1, 2, and 4 bit textures are no longer supported. - The OpaqueSpan field determines how constant color spans are written (recall the Render command selects between constant color or variable color spans). Transparent spans just use one color for the foreground pixels and the background pixels are not written. Opaque spans write to foreground and background pixels using FBBlockColor for the foreground pixels and FBBlockColorBack for the background pixels. This bit should be set to 0 for performance reasons when foreground/background processing is not required. - The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # TextureReadMode1 TextureReadMode1And TextureReadMode1Or NameTypeOffsetFormatTextureReadMode1Texture0xB408Bitfield TextureReadMode1And Texture 0xAD40 Bitfield Logic Mask TextureReadMode1Or Texture 0xAD48 Bitfield Logic Mask Control registers | Bits | Name | Read<br>39 | Write | Reset | Description | |--------|----------------|------------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | <b>V</b> | ~ | Х | When set causes any texels needed by the fragment to be read. This is also qualified by the TextureEnable bit in the <i>Render</i> command. | | 18 | Reserved | ~ | X | X | | | 910 | TexelSize | ~ | • | x | This field holds the size of the texels in the texture map. The options are: 0 = 8 bits 1 = 16 bits 2 = 32 bits 3 = 64 bits (Only valid for spans) | | 11, 12 | Reserved | ~ | × | X | | | 1316 | MapBaseLevel | ~ | <i>V</i> | x | This field defines which TextureBaseAddr register should be used to hold the address for map level 0 when mip mapping or the texture map when not mip mapping. Successive map levels are at increasing TextureBaseAddr registers upto (and including) the MaxMaxLevel (next field). 3D textures always use TextureBaseAddr0. | | 1720 | MapMaxLevel | ~ | ~ | x | This field defines the maximum TextureBaseAddr register this texture should use when mip mapping. Any attempt to use beyond this level will clamp to this level. | | 21 | LogicalTexture | ~ | ~ | x | This bit, when set, defines this texture or all mip map levels, if mip mapping, to be logically mapped so undergo logical to physical translation of the texture addresses. | | 22 | Origin | | • | X | This field selects where the origin is for a texture map with a Linear or Patch64 layout. The options are: 0 = Top Left. 1 = Bottom Left A Patch32_2 or Patch2 texture map is always bottom left origin. | $<sup>^{39}</sup>$ Logic Op register readback is via the main register only | 2324 | TextureType | | | X | This field defines any special processing needed on the texel data before it can be used. The options are: 0 = Normal. 1 = Eight bit indexed texture. 2 = Sixteen bit YVYU texture in 422 format. 3 = Sixteen bit VYUY texture in 422 format. | |------|----------------------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2527 | ByteSwap | • | | x | This field defines the byte swapping, if any, to be done on texel data when it is used as a bitmap. This is automatically done when spans are used. Bit 27, when set, causes adjacent bytes to be swapped, bit 26 adjacent 16 bit words to be swapped and bit 27 adjacent 32 bit words to be swapped. In combination this byte swap the input (ABCDEFGH) as follows: 0 ABCDEFGH 1 BADCFEHG 2 CDABGHEF 3 ABCDEFGH 4 EFGHABCD 5 FEHGBADC 6 GHEFCDAB 7 HGFEDCBA | | 28 | Mirror | ~ | ~ | x | This bit, when set, mirrors any bitmap data. This only works for spans. | | 29 | Invert | ~ | ~ | x | This bit, when set, inverts any bitmap data. This only works for spans. | | 30 | OpaqueSpan Reserved | 0 | 0 | x | This bit, when set allows the color of each pixel in the span to be either foreground or background as set by the supplied bit masks. If this bit is 0 then any supplied bit masks are anded with the pixel mask to delete pixels from the span. | #### Notes: • - Texture reading is controlled by the *TextureReadMode0* and *TextureReadMode1* registers for texture 0 and texture 1 respectively. Not all combinations of modes across both registers are supported and where there is a clash the modes in TextureReadMode0 take priority. - Note: The layout and use of the TextureReadMode register is not compatible with GLINT MX: 1, 2, and 4 bit textures are no longer supported. - The OpaqueSpan field determines how constant color spans are written (recall the Render command selects between constant color or variable color spans). Transparent spans just use one color for the foreground pixels and the background pixels are not written. Opaque spans write to foreground and background pixels using FBBlockColor for the foreground pixels and FBBlockColorBack for the background pixels. This bit should be set to 0 for performance reasons when foreground/background processing is not required. - The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## **TouchLogicalPage** | Name | Type | Offset | Format | |------------------|---------|--------|----------| | TouchLogicalPage | Texture | 0xB370 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | | |------|--------------|----------|----------|-------|--------------------------------------------|--| | | | | | | _ | | | 015 | logical page | ~ | <b>'</b> | X | The first Logical Page to mark as stale | | | 1529 | count | ~ | <b>'</b> | X | The number of pages to mark as stale. | | | 3031 | mode | <b>'</b> | <b>/</b> | X | 0 = Make page(s) non resident | | | | | | | | 1 = Load page(s) unconditionally. | | | | | | | | 2 = Make page(s) non resident | | | | | | | | 3 = Touch page(s) and load if not resident | | Notes: This command can be used to touch or mark as non resident a range of pages in the Logical Page Table. This is useful for preloading and when editing texture maps. For preloading, the command allows you to preload only non-resident pages (mode 3). When editing, the command allows you to mark pages as stale without immediately reloading by setting the mode to "non resident" (mode 2). # TriangleMode TriangleModeAnd TriangleModeOr | Name | Type | Offset | Format | |-----------------|-------|--------|--------| | TriangleMode | Delta | 0x94C8 | Float | | TriangleModeAnd | Delta | 0xAB00 | Float | | TriangleModeOr | Delta | 0xAB08 | Float | Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------|----------|-------|-------|--------------------------------------------------------------------------------------------------------------| | 031 | TriangleMode | <b>√</b> | ✓ | X | Defines if and how triangles are antialiased and the message protocols to use when communicating with GLINT. | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### **TStart** | Name | Type | Offset | <b>Format</b> | |--------|------------------|--------|---------------| | TStart | Texture | 0x83A0 | Fixed point | | | Control register | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | 1 | X | | | n31 | Integer | 1 | ✓ | X | | Notes: Initial T value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S, T and Q values. ## **UpdateLineStippleCounters** | Name | Type | Offset | Format | |---------------------------|---------|--------|----------| | UpdateLineStippleCounters | Stipple | 0x81B8 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------------------------|------|----------|-------|-----------------------------------------------------| | 0 | Update<br>Counters<br>Control | V | <b>V</b> | X | 0=reset counters to 0 1=load from segment register. | | 131 | Reserved | 0 | 0 | X | | Notes: This *Command* updates the current line stipple counters: If bit 0 is zero then the counters are set to zero, otherwise they are loaded from the segment register. Useful in drawing stippled wide lines. ## **UpdateLogicalTextureInfo** | Name | Type | Offset | Format | |--------------------------|---------|--------|--------| | UpdateLogicalTextureInfo | Texture | 0xB368 | Tag | | • | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: This command updates the Logical Texture Page Table at the page previously set up in the SetLogicalPageInfo command. After the update has been done the logical page number is incremented. The Resident bit is cleared and the Length, MemoryPool, VirtualHostPage and HostPage are set up. ## V0FixedKs V0FixedKd NameTypeOffsetFormatV0FixedKsR4 Delta0x9018FixedV0FixedKdR4 Delta0x9020Fixed Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|---------------------------------------------------| | 031 | | <b>'</b> | <b>'</b> | X | Vertex 0 Texture Ks and Kd in fixed point format. | Notes: These registers are deprecated and retained for backward compatibility only. ## V0FloatKs V0FloatKd NameTypeOffsetFormatV0FloatKsR4 Delta0x9198FloatV0FloatKdR4 Delta0x91A0Float Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|------------------------------------------------------| | 031 | | <b>/</b> | <b>✓</b> | X | Vertex 0 Texture Ks and Kd in floating point format. | Notes: Supported in R4 only V0FixedR V0FixedB V0FixedA V0FixedF V0FixedX V0FixedY V0FixedZ | Name | Type | Offset | Format | |----------|----------|---------|--------| | V0FixedR | R4 Delta | 0x9028 | Fixed | | V0FixedG | R4 Delta | 0x9030 | Fixed | | V0FixedB | R4 Delta | 0x9038 | Fixed | | V0FixedA | R4 Delta | 0x9040 | Fixed | | V0FixedF | R4 Delta | 0x9048 | Fixed | | V0FixedX | R4 Delta | 0x9050 | Fixed | | V0FixedY | R4 Delta | 0x9058 | Fixed | | V0FixedZ | R4 Delta | 0x99060 | Fixed | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|----------------------------------------------| | 031 | | <b>'</b> | <b>'</b> | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: Vertex 0 color, alpha, fog and coordinate values. These registers are deprecated and retained for backwards compatibility only. **V0FloatR** **V0FloatG** **V0FloatB** **V0FloatA** V0FloatF V0FloatX V0FloatX **V0FloatZ** | Name | Type | Offset | Format | |----------|-------|--------|--------| | V0FloatR | Delta | 0x91A8 | Float | | V0FloatG | Delta | 0x91B0 | Float | | V0FloatB | Delta | 0x91B8 | Float | | V0FloatA | Delta | 0x91C0 | Float | | V0FloatF | Delta | 0x91C8 | Float | | V0FloatX | Delta | 0x91D0 | Float | | V0FloatY | Delta | 0x91D8 | Float | | V0FloatZ | Delta | 0x91E0 | Float | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|----------------------------------------------| | 031 | | <b>'</b> | <b>'</b> | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: The R, G, B, Alpha, Fog, X, Y coordinates and Depth values for vertex 0 as IEEE single-precision floating point numbers. ## V0FixedS V0FixedT V0FixedQ | Name | Type | Offset | Format | |----------|----------|--------|--------| | V0FixedS | R4 Delta | 0x9000 | Float | | V0FixedT | R4 Delta | 0x9008 | Float | | V0FixedQ | R4 Delta | 0x9010 | Float | Control registers | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|----------|-------|----------------------| | 031 | Texture | <b>✓</b> | <b>✓</b> | X | Vertex texture value | Notes: The S, T and Q values for vertex 0 as fixed point 2s complement numbers. The format and clamping range are as defined for the GLINT Gamma - refer to the GLINT Gamma Programmers Reference Manual for details. These registers are deprecated and retained for backwards compatibility only. # V0FloatS V0FloatT V0FloatQ | Name | Type | Offset | Format | |----------|-------|--------|--------| | V0FloatS | Delta | 0x9180 | Float | | V0FloatT | Delta | 0x9188 | Float | | V0FloatQ | Delta | 0x9190 | Float | Control registers | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|----------|-------|-----------------------| | 031 | Texture | <b>/</b> | <b>/</b> | X | Vertex texture values | Notes: The texture S, T and Q values for vertex 0 as IEEE single-precision floating point numbers. ## V1FixedKs V1FixedKd | Name | Type | Offset | Format | |-----------|----------|--------|--------| | V0FixedKs | R4 Delta | 0x9098 | Fixed | | V0FixedKd | R4 Delta | 0x90A0 | Fixed | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|---------------------------------------------------| | 031 | | ~ | ~ | X | Vertex 1 Texture Ks and Kd in fixed point format. | Notes: These registers are deprecated and retained for backward compatibility only. ## V1FloatKs V1FloatKd NameTypeOffsetFormatV1FloatKsR4 Delta0x9198FloatV1FloatKdR4 Delta0x91A0Float Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|------------------------------------------------------| | 031 | | <b>/</b> | <b>✓</b> | X | Vertex 1 Texture Ks and Kd in floating point format. | Notes: Supported in R4 only V1FixedR V1FixedG V1FixedB V1FixedA V1FixedF V1FixedX **V1FixedY** V1FixedZ | Name | Type | Offset | Format | |----------|----------|--------|--------| | V1FixedR | R4 Delta | 0x90A8 | Fixed | | V1FixedG | R4 Delta | 0x90B0 | Fixed | | V1FixedB | R4 Delta | 0x90B8 | Fixed | | V1FixedA | R4 Delta | 0x90C0 | Fixed | | V1FixedF | R4 Delta | 0x90C8 | Fixed | | V1FixedX | R4 Delta | 0x90D0 | Fixed | | V1FixedY | R4 Delta | 0x90D8 | Fixed | | V1FixedZ | R4 Delta | 0x90E0 | Fixed | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|----------------------------------------------| | 031 | | <b>/</b> | ~ | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: Vertex 1 color, alpha, fog and coordinate values. These registers are deprecated and retained for backwards compatibility only. V1FloatR **V1FloatG** V1FloatB V1FloatA **V1FloatF** **V1FloatX** **V1FloatY** V1FloatZ | Name | Type | Offset | Format | |----------|------------------|--------|--------| | V1FloatR | Delta | 0x9228 | Float | | V1FloatG | Delta | 0x9230 | Float | | V1FloatB | Delta | 0x9238 | Float | | V1FloatA | Delta | 0x9240 | Float | | V1FloatF | Delta | 0x9248 | Float | | V1FloatX | Delta | 0x9250 | Float | | V1FloatY | Delta | 0x9258 | Float | | V1FloatZ | Delta | 0x9260 | Float | | | Control marietar | 20 | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|----------------------------------------------| | 031 | | <b>/</b> | <b>/</b> | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: The R, G, B, Alpha, Fog, X, Y coordinates and Depth values for vertex 1 as IEEE single-precision floating point numbers. # V1FixedS V1FixedT V1FixedQ | Name | Type | Offset | Format | |-----------|-------------------|--------|--------| | V1FixedS | R4 Delta | 0x9080 | Fixed | | V1FixedT | R4 Delta | 0x9088 | Fixed | | V1FixedQs | R4 Delta | 0x9090 | Fixed | | | Control registers | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-----------------------| | 031 | Texture | V | ~ | X | Vertex texture values | Notes: These registers are deprecated and retained for backwards compatibility only. # V1FloatS V1FloatT V1FloatQ | Name | Type | Offset | Format | |----------|----------------|--------|--------| | V1FloatS | Delta | 0x9200 | Float | | V1FloatT | Delta | 0x9208 | Float | | V1FloatQ | Delta | 0x9210 | Float | | | Controlmoister | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-----------------------| | 031 | Texture | V | V | X | Vertex texture values | Notes: The texture S, T and Q values for vertex 1 as IEEE single-precision floating point numbers. ## V2FixedKs V2FixedKd | Name | Type | Offset | Format | |-----------|----------|--------|--------| | V2FixedKs | R4 Delta | 0x9118 | Fixed | | V2FixedKd | R4 Delta | 0x9120 | Fixed | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|---------------------------------------------------| | 031 | | <b>/</b> | <b>/</b> | X | Vertex 1 Texture Ks and Kd in fixed point format. | Notes: These registers are deprecated and retained for backward compatibility only. # V2FloatKs V2FloatKd NameTypeOffsetFormatV2FloatKsR4 Delta0x9298FloatV2FloatKdR4 Delta0x92A0Float Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|------------------------------------------------------| | 031 | | <b>/</b> | <b>/</b> | X | Vertex 2 Texture Ks and Kd in floating point format. | Notes: Supported in R4 only V2FixedR V2FixedG V2FixedB V2FixedA V2FixedF V2FixedX **V2FixedY** V2FixedZ | Name | Type | Offset | Format | |----------|----------|--------|--------| | V2FixedR | R4 Delta | 0x9128 | Fixed | | V2FixedG | R4 Delta | 0x9130 | Fixed | | V2FixedB | R4 Delta | 0x9138 | Fixed | | V2FixedA | R4 Delta | 0x9140 | Fixed | | V2FixedF | R4 Delta | 0x9148 | Fixed | | V2FixedX | R4 Delta | 0x9150 | Fixed | | V2FixedY | R4 Delta | 0x9158 | Fixed | | V2FixedZ | R4 Delta | 0x9160 | Fixed | | | | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|----------------------------------------------| | 031 | | <b>/</b> | ~ | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: Vertex 2 color, alpha, fog and coordinate values. These registers are deprecated and retained for backwards compatibility only. **V2FloatR** **V2FloatG** **V2FloatB** **V2FloatA** **V2FloatF** **V2FloatX** **V2FloatY** **V2FloatZ** | Name | Type | Offset | Format | |----------|----------------|--------|--------| | V2FloatR | Delta | 0x92A8 | Float | | V2FloatG | Delta | 0x92B0 | Float | | V2FloatB | Delta | 0x92B8 | Float | | V2FloatA | Delta | 0x92C0 | Float | | V2FloatF | Delta | 0x92C8 | Float | | V2FloatX | Delta | 0x92D0 | Float | | V2FloatY | Delta | 0x92D8 | Float | | V2FloatZ | Delta | 0x92E0 | Float | | | Controlmoister | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|----------------------------------------------| | 031 | | <b>/</b> | <b>/</b> | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: The R, G, B, Alpha, Fog, X, Y coordinates and Depth values for vertex 2 as IEEE single-precision floating point numbers. ## V2FixedS V2FixedT V2FixedQ | Name | Type | Offset | Format | |----------|-------------------|--------|--------| | V2FixedS | R4 Delta | 0x9100 | Fixed | | V2FixedT | R4 Delta | 0x9108 | Fixed | | V2FixedQ | R4 Delta | 0x9110 | Fixed | | | Control registers | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|----------|-------|-----------------------| | 031 | Texture | <b>✓</b> | <b>✓</b> | X | Vertex texture values | Notes: V2 vertex texture values. These registers are deprecated and included for backwards compatibility only. ## V2FloatS V2FloatT V2FloatQ | Name | Type | Offset | Format | |----------|-------------------|--------|--------| | V2FloatS | Delta | 0x9280 | Float | | V2FloatT | Delta | 0x9288 | Float | | V2FloatQ | Delta | 0x9290 | Float | | | Control registers | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|----------|-------|-----------------------| | 031 | Texture | <b>/</b> | <b>/</b> | X | Vertex texture values | Notes: The texture S, T and Q values for vertex 2 as IEEE single-precision floating point numbers. #### Vertex0 | Name | Type | Offset | Format | |---------|------------------|--------|---------| | Vertex0 | Input | 0xB7B8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|----------|-------|-------|--------------------------| | 031 | Index | <b>✓</b> | 1 | X | Index into Vertex buffer | Notes: The vertex data can be loaded without using one of the primitive types using the Vertex0, Vertex1, and Vertex2 registers. These registers specify the vertex store to load, and the data field holds the index into the array. #### Vertex1 | Name | Type | Offset | Format | |---------|------------------|--------|---------| | Vertex1 | Input | 0xB7C0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|----------|-------|-------|--------------------------| | 031 | Vertex | <b>~</b> | 1 | X | Index into Vertex buffer | Notes: The vertex data can be loaded without using one of the primitive types using the Vertex0, Vertex1, and Vertex2 registers. These registers specify the vertex store to load, and the data field holds the index into the array. #### Vertex2 | Name | Type | Offset | Format | |---------|------------------|--------|---------| | Vertex2 | Input | 0xB7C8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|----------|-------|-------|--------------------------| | 031 | Index | <b>✓</b> | 1 | X | Index into Vertex buffer | Notes: The vertex data can be loaded without using one of the primitive types using the Vertex0, Vertex1, and Vertex2 registers. These registers specify the vertex store to load, and the data field holds the index into the array. ### **VertexBaseAddress** | Name | Type | Offset | Format | |-------------------|------------------|--------|---------| | VertexBaseAddress | Input | 0xB708 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------------| | 01 | Reserved | 0 | 0 | X | | | 231 | Address | ✓ | 1 | X | 32 bit address of base of buffer | | 3 T | | | |---------|--|--| | Notes: | | | | INOICS. | | | | | | | ### **VertexControl** | Name | Type | Offset | Format | | |---------------|------------------|---------------|--------|--| | VertexControl | Input | 0xB798 Bitfie | | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |-------|-------------|------|-------|-------|-----------------------------| | | | | | | | | 0-4 | Size | ~ | V | X | Size of vertex in 32 words | | 5 | CacheEnable | V | ~ | X | 0 = cache off, 1 = cache on | | 6 | Flat | ~ | V | X | 0 = off, 1 = on | | 7 | ReadAll | ~ | V | X | 0 = off, 1 = on | | 8 | SkipFlags | ~ | V | X | 0 = off, 1 = on | | 9 | OGL | ~ | V | X | 0 = D3D, $1 = OGL$ | | 10 | Line2D | ~ | V | X | 0 = off, 1 = 0n | | 11-31 | Reserved | 0 | 0 | X | | Notes: #### **VertexData** | Name | Type | Offset | Format | | |------------|------------------|--------|---------|--| | VertexData | Input | 0xB7E8 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|-------------| | 031 | Data | <b>/</b> | 1 | X | Vertex data | Notes: The vertex data can be loaded without using one of the primitive types using the Vertex0, Vertex1, and Vertex2 registers. These registers specify the vertex store to load, and the data field holds the index into the array. The VertexData register is used for inline vertex data. ## VertexData0 | Name | Type | Offset | Format | | |-------------|------------------|--------|---------|--| | VertexData0 | Input | 0xB7D0 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|-------------| | 031 | Data | <b>/</b> | 1 | X | Vertex data | ## VertexData1 | Name | Type | Offset | Format | | |-------------|------------------|--------|---------|--| | VertexData1 | Input | 0xB7D8 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|-------------| | 031 | Data | <b>/</b> | 1 | X | Vertex data | Notes: ## VertexData2 | Name | Type | Offset | <b>Format</b> | |-------------|------------------|--------|---------------| | VertexData2 | Input | 0xB7E0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 031 | Data | V | 1 | X | Vertex data | Notes: ### **VertexFormat** | Name | Type | Offset | Format | | |--------------|------------------|--------|---------|--| | VertexFormat | Input | 0xB790 | Integer | | | | Control register | , | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|------------------------------| | 031 | Mask | V | 1 | X | Mask of data valid in vertex | Notes: # VertexLineList | Name | Type | Offset | Format | | |----------------|------------------|--------|---------|--| | VertexLineList | Input | 0xB760 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | 1 | X | Number of vertices in primitive | # VertexLineStrip | Name | Type | Offset | Format | | |-----------------|-------|--------|---------|--| | VertexLineStrip | Input | 0xB768 | Integer | | | | | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | 1 | X | Number of vertices in primitive | Notes: ## **VertexPointList** NameTypeOffsetFormatVertexPointListInput0xB770Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | 1 | X | Number of vertices in primitive | Notes: # VertexPolygon NameTypeOffsetFormatVertexPolygonInput0xB778Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | 1 | x | Number of vertices in primitive | # VertexTagList[0...15] | Name | Type | Offset | Format | |--------------------|------------------|--------|----------| | VertexTagList[015] | Input | 0xB800 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-----------------------------------------------| | 010 | Tag | ~ | <b>~</b> | x | Tag to use for corresponding vertex data item | | 1131 | Reserved | 0 | 0 | X | | Notes: Typical usage would use the TagList to define the order in which data is delivered; the format mask and vertex size are used to set which modes are enabled (so if z is enabled the z bit in the format mask is set and the vertex size increased by 1). # VertexTagList[16...31] | Name | Type | Offset | Format | | |---------------------|------------------|--------|----------|--| | VertexTagList[1631] | Input | 0xB880 | Bitfield | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-----------------------------------------------| | 010 | Tag | <b>✓</b> | <b>'</b> | X | Tag to use for corresponding vertex data item | | 1131 | Reserved | 0 | 0 | X | | Notes: Typical usage would use the TagList to define the order in which data is delivered; the format mask and vertex size are used to set which modes are enabled (so if z is enabled the z bit in the format mask is set and the vertex size increased by 1). # VertexTriangleFan | Name | Type | Offset | Format | | |-------------------|------------------|--------|---------|--| | VertexTriangleFan | Input | 0xB750 | Integer | | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | 1 | X | Number of vertices in primitive | | Notes: | | | |--------|--|--| # VertexTriangleList | Name | Type | Offset | Format | |--------------------|-------|--------|---------| | VertexTriangleList | Input | 0xB748 | Integer | Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | 1 | X | Number of vertices in primitive | Notes: # VertexTriangleStrip | Name | Type | Offset | Format | |---------------------|-------|--------|---------| | VertexTriangleStrip | Input | 0xB750 | Integer | Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | 1 | X | Number of vertices in primitive | Notes: ## **VertexValid** NameTypeOffsetFormatVertexValidInput0xB788Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|------------------------------| | 031 | Mask | <b>/</b> | 1 | X | Mask of data valid in vertex | #### **VTGAddress** | Name | Type | Offset | Format | |------------|-------------|--------|---------| | VTGAddress | Framebuffer | 0xB0B0 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | / | 1 | X | 32 bit value | Notes: The VTG and RAMDAC can be read and written via the PCI bypass, but sometimes it is useful to control them synchronously with core rendering activities. This can be done by using the VTGAddress and VTGData commands. The address is sent first followed by the data. The address and data are the same as would be used if the VTG, Ramdac or any other device on the PCI bypass were accessed via the bypass. The core does not interpret the data in any way and is just the communications path. The VTG data and address is routed via the FB Memory Interface. #### **VTGData** | Name | Type | Offset | Format | |------------|-------------|--------|---------| | VTGAddress | Framebuffer | 0xB0B8 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------| | 031 | VTG Data | 1 | 1 | X | 32 bit value | Notes: This register holds the data for the VTG or bypass write and instigates the action via the FB Memory Controller. The VTG and RAMDAC can be read and written via the PCI bypass, but sometimes it is useful to control them synchronously with core rendering activities. This can be done by using the VTGAddress and VTGData commands. The address is sent first followed by the data. The address and data are the same as would be used if the VTG, Ramdac or any other device on the PCI bypass were accessed via the bypass. The core does not interpret the data in any way and is just the communications path. The VTG data and address is routed via the FB Memory Interface. ## WaitforCompletion | Name | Type | Offset | Format | |-------------------|------------|--------|----------| | WaitforCompletion | Rasterizer | 0x80B8 | Bitfield | | _ | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-------------------------------------------------| | | | | | | | | 0, 1 | Event | 0 | ✓ | X | 0 = LB Reads and writes and FB reads and writes | | | | | | | 1 = LB Reads and FB Reads | | | | | | | 2 = RenderSync | | | | | | | 3 = ScanlineSyncU | | 231 | Unused | 0 | 0 | X | | Notes: Command: This is used to suspend core graphics processing until outstanding reads and writes in both localbuffer and framebuffer memory have completed, or some other combination of events described above has taken place. This is intended to prevent a new primitive from starting to be rasterized before the previous primitive is completely finished. It would be used, for example, to separate texture downloads from the surrounding primitives. The same functionality can be achieved using the Sync register and waiting for it in the Host Out FIFO; however, this method doesn't involve the host and can be inserted into a DMA buffer. ## Window WindowAnd WindowOr | Name | Type | Offset | Format | |-----------|------------------|--------|----------| | Window | Localbuffer | 0x8980 | Bitfield | | WindowAnd | Localbuffer | 0xAB80 | Bitfield | | WindowOr | Localbuffer | 0xAB88 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------------|------|-------|-------|----------------------------------------------------------------------------------------------------------------------| | 02 | Reserved | 0 | 0 | X | | | 3 | ForceLB<br>Update | ~ | ~ | Х | This bit, when set, disregards the results of the stencil and depth tests and forced the local buffer to be updated. | | 4 | LBUpdate<br>Source | V | ~ | x | This bit selects the data to be written to the local buffer. The two options are: 0 = LB data. 1 = Registers. | | 58 | Reserved | 0 | 0 | X | | | 916 | FrameCount | ~ | ~ | x | This field holds the current frame count used as part of the Fast Clear Planes (FCP) mechanism | | 17 | Stencil FCP | ~ | ~ | x | This bit, when set, enables the FCP tests and substitution to occur for the Stencil field. | | 18 | DepthFCP | ~ | ~ | x | This bit, when set, enables the FCP tests and substitution to occur for the Depth field. | 5-205 | 19 | OverrideWrite<br>Filtering | ~ | ~ | x | This bit, when set, prevents writes to the local buffer from being filtered out because this unit has not changed the data. | |------|----------------------------|---|---|---|-----------------------------------------------------------------------------------------------------------------------------| | 2031 | Reserved | 0 | 0 | X | | Notes: Stencil operation generally is under control of the Window register: - The Force LB Update bit, when set overrides all the tests done in the Stencil and Depth units and the per unit enables to force the local buffer to be updated. When this bit is clear any update is conditional on the outcome of the stencil and depth tests. The main use of this bit is during window initialisation or copy. It may also be useful for hardware diagnostics. - The data used during ForceLBUpdate depends on the settings in the LBUpdateSource bit. When this bit is 0 the data is taken from the local buffer. Note that either destination or source local buffer data can be used depending on which is enabled. If both are enabled then the destination local buffer data will be used. - When the LBUpdateSource bit is set the source of the stencil and depth data is determined by the StencilMode and DepthMode registers respectively. - The Override Write Filtering control bit, when set causes the testing of LBData = LBWriteData to always fail. This is mainly used when the GID field needs to be changed. It also allows the LBReadFormat to be different to the LBWriteFormat so the write data as seen by the memory is really different to the data that was read. ## WindowOrigin | Name | Type | Offset | Format | |--------------|---------|--------|----------| | WindowOrigin | Scissor | 0x81C8 | Bitfield | | _ | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|---------------------------------------| | 015 | X coordinate | | | | X coordinate as 2's complement number | | 1631 | Y coordinate | | | | Y coordinate as 2's complement number | Notes: This register holds the window origin. As each fragment is generated by the rasterizer, this origin is added to the coordinates of the fragment to generate its localbuffer coordinate when the depth and stencil buffers are patched. #### **XBias** | Name | Type | Offset | Format | |-------|------------------|--------|--------| | XBias | Delta | 0x9480 | Float | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-------------| | 031 | Offset | 1 | 1 | x | | Notes: This register holds the single precision floating point bias (if enabled) added to the vertices' X coordinate just before rasterization. This ensures uniform floating point precision across the full range of screen coordinates. It can be easily removed for absolute coordinate addressing. #### **YBias** | Name | Type | Offset | Format | |-------|------------------|--------|--------| | YBias | Delta | 0x9488 | Float | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-------------| | 031 | Offset | 1 | 1 | X | | Notes: This register holds the single precision floating point bias (if enabled) added to the vertices' Y coordinate just before rasterization. This ensures uniform floating point precision across the full range of screen coordinates. It can be easily removed for absolute coordinate addressing. #### **YLimits** | Name | Type | Offset | Format | |---------|------------|--------|----------| | YLimits | Rasterizer | 0x80A8 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|----------------------------| | 015 | Ymin | ~ | ~ | x | 2's complement min Y value | | 1631 | Ymax | <b>V</b> | <b>/</b> | X | 2's complement max Y value | Notes: Defines the Y extent the Rasterizer should fill between. A scanline is filled if its Y value satisifies Ymin<Y<Ymax. #### YUVMode | Name | Type | Offset | Format | |---------|------------------|--------|----------| | YUVMode | YUV | 0x8F00 | Bitfield | | | Control register | • | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | • | • | X | When set causes the fragment's color values to be converted from YUV to RGB. If this bit is clear then the fragment's color is passed unchanged | | 131 | Reserved | 0 | 0 | X | | Notes: The conversion goes from the YCbCr color space to RGB. The term YCbCr is used interchangeably with YUV The output of the conversion is an RGB triple with each component 8 bits wide. The alpha component is passed through unchanged. ## **ZFogBias** | Name | Type | Offset | Format | |----------|------------------|--------|--------| | ZFogBias | Delta | 0x86B8 | Float | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------------------| | 031 | Bias | 1 | 1 | X | 2's complement value for Z | Notes: This register holds the 32 bit 2's complement value to add to the Z value extracted from the fog DDA before it is clamped and scaled. The bias essentially is used to set the Z value below which no blending occurs. #### **ZStartL** | Name | Type | Offset | Format | |---------|------------------|--------|------------------| | ZStartL | Depth | 0x89B8 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------| | 015 | Reserved | 0 | 0 | x | LSBs all 0 | | 1631 | Integer | 1 | 1 | X | 16bit LSB part of 32.16 fixed point value | Notes: This register holds the lower 16 bits of the 48 bit 2's complement Z start value. These bits are held in bits 16...31 of the data field. With ZstartU, it sets the start value for depth interpolation. ZStartU holds the most significant bits, and ZStartL the least significant bits. The value is in 2's complement 32.16 fixed point format. ## **ZStartU** | Name | Type | Offset | Format | |---------|------------------|--------|------------------| | ZStartU | Stencil | 0x89B0 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|----------------| | 031 | dZdxU | 1 | 1 | X | 32 bit integer | Notes: This register holds the upper 32 bits of the 48 bit 2's complement Z start value. With ZstartL, it sets the start value for depth interpolation. ZStartU holds the most significant bits, and ZStartL the least significant bits. The value is in 2's complement 32.16 fixed point format. 6 ## **Register Cross Reference** This chapter provides alphabetically- and offset-sorted Region 0 register listings. Not all legacy registers are included. ## 6.1 Registers Alphabetically Sorted | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |------------------------|--------------|----------|--------------|--------|----------------|----------|------| | AALineWidth | V | <b>'</b> | Delta | 94C0 | X | float | X | | AAPointSize | V | <b>/</b> | Delta | 94A0 | X | float | X | | AGPControl | ~ | <b>/</b> | Control | 0078 | | bitfield | | | | | | Status | | | | | | AlphaBlendAlphaMode | <b>✓</b> | <b>/</b> | Alpha | AFA8 | X | bitfield | X | | | | | blend | | | | | | AlphaBlendAlphaModeAnd | × | • | Alpha | AD30 | X | bitfield | X | | | | | blend | | | | | | AlphaBlendAlphaModeOr | × | ~ | Alpha | AD38 | X | bitfield | X | | | | | blend | | | | | | AlphaBlendColorMode | <b>✓</b> | ~ | Alpha | AFA0 | X | bitfield | X | | | | | blend | | | | | | AlphaBlendColorModeAnd | × | ~ | Alpha | ACB0 | X | bitfield | X | | | | | blend | | | | | | AlphaBlendColorModeOr | × | ~ | Alpha | ACB8 | X | bitfield | X | | | | | blend | | | | | | AlphaDestColor | <b>✓</b> | ~ | Alpha | AF88 | X | bitfield | X | | | | | blend | | | | | | AlphaSourceColor | <b>✓</b> | ~ | Alpha | AF80 | X | integer | X | | | | | blend | | | | | | AlphaTestMode | <b>✓</b> | <b>~</b> | Alpha | 8800 | X | Bitfield | × | | | | | Blend & | | | | | | | | | Alpha | | | | | | | | | Test | 1.000 | | 1 | | | AlphaTestModeAnd | × | ~ | Alpha | ABF0 | X | bitfield | X | | | | | Blend & | | | | | | | | | Alpha | | | | | | | | | Test | 1.00 | | 1 | | | AlphaTestModeOr | × | <b>~</b> | Alpha | ABF8 | X | bitfield | × | | | | | Blend & | | | | | | | | | Alpha | | | | | | A . 1 N N 1 | | | Test | 0000 | | D: C 11 | | | AntialiasMode | ~ | <b>~</b> | Alpha | 8808 | X | Bitfield | × | | A . 1 | | | test | 1.000 | | 1:011 | | | AntialiasModeAnd | × | <b>~</b> | Alpha | AC00 | X | bitfield | × | | | | | test | | | | | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |---------------------------------|----------|-----------------------------------------|-------------------|---------|-------|----------|---------------------------------------| | Ttallio | back | *************************************** | Name | Circot | Value | Onnat | mand | | AntialiasModeOr | X | / | Alpha | AC08 | х | bitfield | X | | | | | test | | | | | | ApertureOne | ~ | <b>~</b> | Control | 0050 | | bitfield | | | | | | Status | | | | | | ApertureTwo | ~ | ~ | Control | 0058 | | bitfield | | | A 0.1 1 3.6 1 | | | Status | 01.4.0 | | D: C 11 | | | AreaStippleMode | <b>V</b> | <b>/</b> | Stipple | 81A0 | X | Bitfield | X | | AreaStippleModeAnd | X | <b>/</b> | Stipple | ABD0 | X | bitfield | X | | AreaStippleModeOr | X | <b>/</b> | Stipple | ABD8 | X | bitfield | X | | AreaStipplePattern[015] | <b>✓</b> | <b>/</b> | Stipple | 8200 | X | Bitfield | X | | AreaStipplePattern[1631] | <b>/</b> | <b>/</b> | Stipple | 8280 | X | Bitfield | X | | AStart | <b>~</b> | ~ | Color<br>DDA | 87C8 | X | Fixed | × | | BackgroundColor | ~ | ~ | Logic | B0C8 | X | integer | × | | D. D. OAW, 11 C | | | Ops | D.4.600 | | 1. | | | BasePageOfWorking Set | ~ | <b>'</b> | Texture | B4C8 | X | integer | × | | Raca Paga OAV atlain a Sat Uast | | | Read<br>Texture | B4E0 | | intoon | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | BasePageOfWorking SetHost | ~ | ~ | Read | | X | integer | X | | Begin | X | <b>'</b> | Delta | 9590 | X | bitfield | X | | BitMaskPattern | × | ~ | Raster-<br>izer | 8068 | X | Integer | <b>✓</b> × | | BorderColor0 | ~ | ~ | Texture filter | 84A8 | X | Bitfield | × | | BorderColor1 | V | / | Texture | 84F8 | X | Bitfield | X | | | | | filter | | | | | | BStart | ~ | ~ | Color<br>DDA | 87B0 | x | Fixed | × | | ByAperture1Mode | ~ | ~ | Bypass<br>Control | 0300 | | Bitfield | | | ByAperture1Stride | <b>V</b> | <b>/</b> | Bypass | 0308 | | Integer | | | • • | | | Control | | | | | | ByAperture1UStart | <b>✓</b> | <b>✓</b> | Bypass | 0318 | | Integer | | | | | | Control | | | | | | ByAperture1VStart | ~ | ~ | Bypass | 0320 | | Integer | | | ByAperture1YStart | | | Control | 0310 | | Interes | | | DyAperture11 Start | ~ | • | Bypass<br>Control | 0310 | | Integer | | | ByAperture2Mode | · · | / | Bypass | 0328 | | Bitfield | | | | | | Control | | | | | | ByAperture2Stride | <b>V</b> | <b>/</b> | Bypass | 0330 | | Integer | | | | • | | Control | | | J | | | ByAperture2UStart | <b>~</b> | <b>/</b> | Bypass | 0340 | | Integer | | | D. A. OYYG | | | Control | 0010 | | | | | ByAperture2VStart | <b>~</b> | <b>~</b> | Bypass | 0348 | | Integer | | | By A nomety no 2VS to me | | | Control | 0338 | | Intocar | | | ByAperture2YStart | ~ | • | Bypass<br>Control | 0338 | | Integer | | | ByDMAReadCommandBase | <b>V</b> | ~ | Bypass | 0378 | | Integer | | | | | • | Control | 0070 | | Integer | | | | | 1 | Common | 1 | 1 | | | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |------------------------|--------------|----------|----------------------------------|--------|----------------|----------|------| | ByDMAReadCommandCount | ~ | <b>'</b> | Bypass<br>Control | 0380 | | Integer | | | ByDMAReadMode | ~ | <b>'</b> | Bypass<br>Control | 0350 | | Bitfield | | | ByDMAReadStride | ~ | <b>'</b> | Bypass<br>Control | 0358 | | Integer | | | ByDMAReadUStart | ~ | ~ | Bypass<br>Control | 0368 | | Integer | | | ByDMAReadVStart | ~ | <b>'</b> | Bypass<br>Control | 0370 | | Integer | | | ByDMAReadYStart | ~ | <b>'</b> | Bypass<br>Control | 0360 | | Integer | | | ByDMAWriteCommandBase | ~ | <b>'</b> | Bypass<br>Control | 03B0 | | Integer | | | ByDMAWriteCommandCount | ~ | <b>'</b> | Bypass<br>Control | 03B8 | | Integer | | | ByDMAWriteMode | ~ | <b>'</b> | Bypass<br>Control | 0388 | | Bitfield | | | ByDMAWriteStride | ~ | <b>'</b> | Bypass<br>Control | 0390 | | Integer | | | ByDMAWriteUStart | ~ | <b>'</b> | Bypass<br>Control | 03A0 | | Integer | | | ByDMAWriteVStart | ~ | <b>'</b> | Bypass<br>Control | 03A8 | | Integer | | | ByDMAWriteYStart | ~ | <b>'</b> | Bypass<br>Control | 0398 | | Integer | | | ChipConfig | ~ | • | Control<br>Status | 0070 | | bitfield | | | ChromaFailColor | ~ | • | Color<br>DDA &<br>Alpha<br>Blend | AF98 | X | bitfield | X | | ChromaLower | ~ | • | Color<br>DDA &<br>Alpha<br>Blend | 8F10 | X | bitfield | × | | ChromaPassColor | ~ | <b>'</b> | Color<br>DDA &<br>Alpha<br>Blend | AF90 | x | bitfield | × | | ChromaTestMode | ~ | • | Color<br>DDA &<br>Alpha<br>Blend | 8F18 | X | bitfield | × | | ChromaTestModeAnd | × | <b>'</b> | Color<br>DDA &<br>Alpha<br>Blend | ACC0 | x | bitfield | × | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |------------------------|----------|----------|-----------------|--------|-------|----------|----------| | | back | ' | Name | | Value | | mand | | ChromaTestModeOr | X | ~ | Color | ACC8 | X | bitfield | X | | | | | DDA & | | | | | | | | | Alpha | | | | | | | | | Blend | | | | | | ChromaUpper | <b>✓</b> | • | Color | 8F08 | X | bitfield | X | | | | | DDA & | | | | | | | | | Alpha<br>Blend | | | | | | Color | V | ~ | Color | 87F0 | X | Bitfield | × | | GOIOI | | | DDA | 0710 | 21 | Bitticia | ^ | | ColorDDAMode | <b>/</b> | ~ | Color | 87E0 | X | Bitfield | | | | | | DDA | | | | | | ColorDDAModeAnd | × | ~ | Color | ABE0 | X | bitfield | × | | | | | DDA | | | | | | ColorDDAModeOr | × | • | Color | ABE8 | X | bitfield | × | | C | | 4 | DDA<br>Host In | A990 | | bitfield | | | Config 2D | X | <b>/</b> | Global | B618 | X | bitfield | X | | Config2D ConstantColor | X | <b>/</b> | Color | 87E8 | | Bitfield | X | | ConstantColor | ~ | ~ | DDA | 0/E0 | X | Dittiela | | | ConstantColorDDA | × | <b>/</b> | Color | AFB0 | X | bitfield | × | | Constant Color De la | ^ | | DDA | 211 00 | A | bitticia | ^ | | ContextData | × | ~ | Global | 8DD0 | X | bitfield | X | | ContextDump | X | ~ | Global | 8DC0 | X | bitfield | V | | ContextRestore | × | ~ | Global | 8DC8 | X | bitfield | V | | Continue | X | ~ | Raster- | 8058 | x | Integer | V | | | | | izer | | | | | | ContinueNewDom | × | • | Raster- | 8048 | x | Integer | <b>~</b> | | | | | izer | | | | | | ContinueNewLine | × | <b>~</b> | Raster- | 8040 | X | Integer | <b>~</b> | | ContinueNewSub | | 4 | izer | 8050 | | T., | | | ContinuerNewSub | × | <b>~</b> | Raster-<br>izer | 8030 | X | Integer | <b>'</b> | | ControlDMAAddress | <b>~</b> | <b>/</b> | Control | 0028 | | integer | | | Gont of Divinitual coo | | | Status | 0020 | | integer | | | ControlDMAControl | <b>~</b> | ~ | Control | 0060 | | bitfield | | | | | | Status | | | | | | ControlDMACount | <b>~</b> | ~ | Control | 0030 | | integer | | | | | | Status | | | | | | Count | <b>✓</b> | × | Raster- | 8030 | X | Integer | X | | 1. 1 | _ | | izer | 0770 | | D: 1 | | | dAdx | ~ | ~ | Color | 87D0 | X | Fixed | × | | dAdyDom | ., | | DDA<br>Color | 87D8 | X | Fixed | | | aray Dom | ~ | • | DDA | 0100 | A | 1 IXCU | | | dBdx | V | <b>/</b> | Color | 87B8 | X | Fixed | × | | | | | DDA | | | | | | dBdyDom | <b>/</b> | <b>/</b> | Color | 87C0 | X | Fixed | X | | | · · | | DDA | | | | | | DeltaMode | <b>✓</b> | <b>/</b> | Delta | 9300 | X | bitfield | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |---------------------------------|----------|----------|--------------|--------|-------|----------|------------| | | back | | Name | | Value | | mand | | DeltaModeAnd | × | <b>'</b> | Delta | AAD0 | X | bitfield | X | | DeltaModeOr | × | <b>/</b> | Delta | AAD8 | X | bitfield | X | | Depth | <b>'</b> | <b>/</b> | Depth | 89A8 | X | Integer | <b>✓</b> X | | DepthMode | <b>'</b> | <b>/</b> | Depth | 89A0 | X | Bitfield | X | | DepthModeAnd | × | <b>/</b> | Depth | AC70 | X | bitfield | X | | DepthModeOr | × | <b>/</b> | Depth | AC78 | X | bitfield | X | | dFdx | <b>'</b> | / | Fog | 86A8 | X | Fixed | X | | dFdyDom | <b>'</b> | <b>/</b> | Fog | 86B0 | X | Fixed | X | | dGdx | ~ | <b>'</b> | Color<br>DDA | 87A0 | X | Fixed | × | | dGdyDom | <b>'</b> | <b>'</b> | Color<br>DDA | 87A8 | X | Fixed | × | | DisplayData | | | Video | 3068 | | bitfield | | | | | | Control | | | | | | DitherMode | <b>✓</b> | <b>'</b> | Dither | 8818 | X | Bitfield | X | | DitherModeAnd | × | <b>'</b> | Dither | ACD0 | X | bitfield | X | | DitherModeOr | × | <b>'</b> | Dither | ACD8 | X | bitfield | X | | dKdBdx | <b>'</b> | <b>'</b> | Texture | 8D38 | X | fixed | X | | dKdBdyDom | <b>'</b> | <b>'</b> | Texture | 8D40 | X | fixed | X | | dKdGdx | <b>'</b> | <b>~</b> | Texture | 8D20 | X | fixed | X | | dKdGdyDom | <b>'</b> | <b>'</b> | Texture | 8D28 | X | fixed | X | | dKdRdx | <b>✓</b> | <b>/</b> | Texture | 8D08 | X | fixed | X | | dKdRdyDom | <b>'</b> | <b>'</b> | Texture | 8D10 | X | fixed | X | | dKsBdx | <b>✓</b> | <b>/</b> | Texture | 8CB8 | X | fixed | X | | dKsBdyDom | <b>✓</b> | <b>/</b> | Texture | 8CC0 | X | fixed | X | | dKsGdx | <b>✓</b> | <b>/</b> | Texture | 8CA0 | X | fixed | X | | dKsGdyDom | <b>✓</b> | <b>/</b> | Texture | 8CA8 | X | fixed | X | | dKsRdx | <b>✓</b> | <b>/</b> | Texture | 8C88 | X | fixed | X | | dKsRdyDom | <b>✓</b> | <b>/</b> | Texture | 8C90 | X | fixed | X | | DMAAddr | × | <b>/</b> | Host In | A980 | X | integer | X | | DMAContinue | × | <b>/</b> | Host In | A9F8 | X | integer | <b>✓</b> | | DMACount | × | <b>/</b> | Host In | A988 | X | integer | X | | DMAFeedback | × | <b>/</b> | Host In | AA10 | X | integer | X | | <b>DMAMemoryControl</b> | <b>✓</b> | <b>/</b> | Host In | B780 | x | bitfield | X | | DMAOutput Address | × | <b>/</b> | Host In | A9E0 | X | integer | X | | <b>DMAOutputCount</b> | × | <b>~</b> | Host In | A9E8 | x | integer | X | | DMARectangle Read | × | <b>/</b> | Host In | A9A8 | x | bitfield | X | | DMARectangleRead LinePitch | <b>✓</b> | <b>~</b> | Host In | A9B8 | x | integer | X | | DMARectangleRead Target | <b>v</b> | <b>/</b> | Host In | A9C0 | X | bitfield | X | | <b>DMARectangleReadAddress</b> | <b>v</b> | <b>/</b> | Host In | A9B0 | X | integer | X | | <b>DMARectangleWrite</b> | X | <b>/</b> | Host In | A9C8 | X | bitfield | X | | <b>DMARectangleWriteAddress</b> | <b>~</b> | <b>/</b> | Host In | A9D0 | X | integer | X | | DMARectangleWriteLinePitch | <b>~</b> | <b>/</b> | Host In | A9D8 | X | integer | X | | DownloadAddress | <b>~</b> | <b>/</b> | | B0d0 | X | integer | X | | DownloadData | V | ~ | | B0d8 | X | integer | × | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |--------------------|----------|----------|------------------|--------|-------|----------|----------| | | back | | Name | | Value | | mand | | DownloadGlyphWidth | ✓ V | 1 | 2D Set | B658 | X | integer | X | | ) F | | | Up | | | | ^ | | DownloadTarget | <b>~</b> | <b>'</b> | 2D Set | B650 | X | | <b>/</b> | | | | | Up | | | | | | dQ1dx | <b>'</b> | / | Texture | 8438 | X | Fixed | X | | | | | coord | | | | | | dQ1dyDom | <b>✓</b> | <b>~</b> | Texture | 8440 | X | Fixed | X | | | | | coord | | | | | | dQdx | <b>✓</b> | <b>~</b> | Texture | 83C0 | X | Fixed | X | | | | | coord | | | | | | DQdy | <b>✓</b> | <b>~</b> | Texture | 83E8 | X | Fixed | X | | 10.1.0 | | | coord | 0.00 | | | | | dQdyDom | <b>✓</b> | ~ | Texture | 83C8 | X | Fixed | X | | | | | coord | 0010 | | | | | DrawLine0 | X | <b>'</b> | Delta | 9318 | X | fixed | <b>/</b> | | DrawLine1 | X | <b>'</b> | Delta | 9320 | X | fixed | <b>/</b> | | DrawTriangle | X | <b>'</b> | Delta | 9308 | X | bitfield | <b>/</b> | | dRdx | <b>✓</b> | <b>~</b> | Color | 8788 | X | Fixed | X | | | | | DDA | | | | | | dRdyDom | <b>✓</b> | <b>/</b> | Color | 8790 | X | Fixed | X | | | | | DDA | | | | | | | | | Delta | | | | | | dS1dx | <b>✓</b> | <b>~</b> | Texture | 8408 | X | Fixed | X | | | | | coord | | | | | | dS1dyDom | <b>✓</b> | <b>~</b> | Texture | 8410 | X | Fixed | X | | 10.1 | | | coord | 2222 | | | | | dSdx | <b>✓</b> | ~ | Texture | 8390 | X | Fixed | X | | 10.1 | | _ | coord | 0200 | | T: 1 | | | dSdy | ~ | <b>~</b> | Texture | 83D8 | X | Fixed | × | | 10 1-D | | | coord | 8398 | | T: 1 | ., | | dSdyDom | ~ | <b>~</b> | Texture | 8398 | X | Fixed | × | | dT1dx | | | coord<br>Texture | 8420 | v | Fixed | | | d i idx | <b>✓</b> | <b>✓</b> | coord | 0420 | X | Tixeu | × | | dT1dyDom | | <b>'</b> | Texture | 8428 | x | Fixed | × | | d I Idy Dolli | <b>~</b> | • | coord | 0420 | Λ | Tixcu | <b>X</b> | | dTdx | <b>V</b> | / | Texture | 83A8 | X | Fixed | X | | ulux | | | coord | 03/10 | Λ | Tixed | ^ | | dTdy | V | <b>/</b> | Texture | 83E0 | X | Fixed | X | | aray | | | coord | 0320 | 11 | 1 Execu | ^ | | dTdyDom | <b>'</b> | <b>/</b> | Texture | 83B0 | X | Fixed | X | | , | | | coord | | | | | | dXDom | <b>/</b> | X | Raster- | 8008 | X | fixed | × | | | | _ | izer | | | | | | dXSub | <b>~</b> | X | Raster- | 8018 | X | fixed | X | | | | | izer | | | | | | dY | <b>~</b> | × | Raster- | 8028 | X | fixed | X | | | | | izer | | | | | | dZdxL | ~ | <b>'</b> | Depth & | 89C8 | X | Fixed | X | | | | | Fog | | | | | | Name | | Write | Unit<br>Name | Offset | | Format | Com- | |----------------------------|----------|----------|-------------------|--------|--------|--------------------|------| | dZdxU | back | | Depth & | 80C0 | Value | Fixed | mand | | dzdxU | ~ | ~ | Fog | 8900 | X | rixea | X | | dZdyDomL | <b>/</b> | / | Depth & | 89D8 | X | Bitfield | X | | , | | | Fog | | | | | | dZdyDomU | <b>/</b> | ~ | Depth & | 89D0 | X | Fixed | X | | | | | Fog | | | | | | End | X | <b>'</b> | Delta | 9598 | X | fixed | X | | EndOfFeedback | <b>~</b> | <b>~</b> | Host | 8FF8 | X | tag | X | | | | | Out | 0020 | | 1 : 6 11 | | | ErrorFlags | | | Control | 0038 | | bitfield | | | FBBlockColor | | · · | Status<br>FB Read | 8AC8 | N. | integer | · · | | FBBlockColor[03] | <b>/</b> | × | FB Write | | X<br>X | integer | X | | FBBlockColorBack | <b>V</b> | | FB Write | | | integer | X | | FBBlockColorBack[03] | <b>V</b> | <b>/</b> | FB Write | | X | integer | X | | FBColor | <b>V</b> | 1 | FB Write | | X | integer<br>n/a | X | | FBDestReadBufferAddr[03] | <b>V</b> | × | FB Read | AE80 | X<br>X | integer | X | | FBDestReadBufferOffset[03] | <b>V</b> | | | AEA0 | X | | X | | FBDestReadBufferWidth[03] | <b>V</b> | <b>/</b> | FB Read | AEC0 | X | integer<br>integer | X | | FBDestReadEnables | <b>V</b> | <b>/</b> | | AEE8 | | bitfield | X | | FBDestReadEnablesAnd | <b>V</b> | <b>V</b> | FB Read | AD20 | X | bitfield | X | | FBDestReadEnablesOr | X | <b>/</b> | FB Read | AD28 | X<br>X | bitfield | X | | FBDestReadMode | X | <b>/</b> | FB Read | AEE0 | | bitfield | X | | FBDestReadModeAnd | <b>V</b> | | FB Read | AC90 | X<br>X | bitfield | X | | FBDestReadModeOr | X | <b>V</b> | FB Read | AC98 | X | bitfield | X | | FBHardwareWriteMask | × | <b>V</b> | FB Write | | X | mask | | | FBSoftwareWriteMask | | <b>V</b> | Logic | 8820 | X | | X | | r bontware w mewiask | ~ | <b>V</b> | Ops | 0020 | X | Integer | × | | FBSourceReadBufferAddr | V | ~ | FB Read | AF08 | X | integer | X | | FBSourceReadBufferOffset | ~ | ~ | FB Read | AF10 | X | integer | X | | FBSourceReadBufferWidth | ~ | ~ | FB Read | AF18 | X | integer | × | | FBSourceReadMode | <b>/</b> | ~ | FB Read | AF00 | X | bitfield | X | | FBSourceReadModeAnd | X | ~ | FB Read | ACA0 | X | bitfield | X | | FBSourceReadModeOr | X | ~ | FB Read | ACA8 | X | bitfield | X | | FBWriteBufferAddr[03] | <b>✓</b> | ~ | FB Write | B000 | X | integer | X | | FBWriteBufferOffset[03] | <b>/</b> | <b>/</b> | FB Write | B020 | x | integer | X | | FBWriteBufferWidth[03] | <b>~</b> | <b>/</b> | FB Write | B040 | x | integer | X | | FBWriteMode | <b>~</b> | <b>/</b> | FB Write | 8AB8 | x | bitfield | X | | FBWriteModeAnd | X | <b>'</b> | FB Write | ACF0 | X | bitfield | X | | FBWriteModeOr | X | <b>'</b> | FB Write | ACF8 | X | bitfield | X | | FifoControl | <b>~</b> | <b>'</b> | Video | 3078 | | bitfield | | | | | | Control | | | | | | FIFODiscon | <b>~</b> | <b>'</b> | Control | 0068 | | bitfield | | | EIID 1 10.1 | | | Status | 0220 | | • . | | | FillBackgroundColor | X | <b>V</b> | 2D Set | 8330 | X | integer | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |------------------------------|----------|----------|-----------------|--------|-------|----------|------| | Traine | back | VVIIC | Name | Onset | Value | Office | mand | | FillConfig2D0 | X | / | 2D Set | 8338 | X | bitfield | X | | 0 | | | Up | | | | | | FillConfig2D1 | X | ~ | 2D Set | 8360 | X | Bitfield | | | | | | Up | | | | | | FillFBDestReadBufferAddr0 | × | ~ | 2D Set | 8310 | X | integer | X | | E::::EDC D 1D | | | Up<br>2D Set | 8308 | | 1 | | | FillFBSourceReadBufferAddr | X | <b>'</b> | Up Set | 8308 | X | integer | × | | FillFBSourceReadBufferOffset | X | <b>/</b> | 2D Set | 8340 | X | Integer | X | | | | | Up | | | 8 | ^ | | FillFBWriteBufferAddr0 | X | ~ | 2D Set | 8300 | x | integer | X | | | | | Up | | | | | | FillForegroundColor0 | X | ~ | 2D Set | 8328 | X | integer | X | | EUE 10.1.4 | | | Up | 0250 | | т. | | | FillForegroundColor1 | × | ~ | 2D Set | 8358 | X | Integer | × | | FillGlyphPosition | X | / | Up<br>2D Set | 8368 | X | Integer | X | | 1 monyphi osition | ^ | | Up | 0300 | A | integer | ^ | | FillRectanglePosition | × | ~ | 2D Set | 8348 | X | Integer | × | | 3 | | | Up | | | U | | | FillRender2D | X | ~ | 2D Set | 8350 | X | Bitfield | X | | | | | Up | | | | | | FillScissorMaxXY | X | <b>'</b> | 2D Set | 8320 | X | fixed | X | | FillScissorMinXY | ., | ~ | Up<br>2D Set | 8318 | | fixed | | | THISCISSORVIIIIX I | X | | Up | 0310 | X | lixeu | × | | FilterMode | ~ | <b>'</b> | Host | 8C00 | X | bitfield | X | | | | | Out | | | | | | FilterModeAnd | X | ~ | Host | AD00 | X | bitfield | X | | | | | Out | | | | | | FilterModeOr | × | ~ | Host | AD08 | X | bitfield | X | | El 10. | | 4 | Out | 0070 | | | | | FlushSpan | X | <b>'</b> | Raster-<br>izer | 8060 | X | tag | ~ | | FlushWriteCombining | X | <b>'</b> | Host In | 8910 | X | Integer | × | | FogColor | · | ~ | Fog | 8698 | X | Fixed | X | | FogMode | <i>'</i> | <b>V</b> | Fog | 8690 | X | Bitfield | × | | FogModeAnd | X | ~ | Fog | AC10 | X | bitfield | X | | FogModeOr | X | ~ | Fog | AC18 | X | bitfield | X | | FogTable[015] | ~ | ~ | Fog | B100 | X | bitfield | X | | FogTable[1631] | ~ | <b>'</b> | Fog | B180 | X | bitfield | X | | FogTable[3247] | ~ | <b>'</b> | Fog | B200 | X | bitfield | X | | FogTable[4863] | ~ | / | Fog | B280 | X | bitfield | X | | ForegroundColor | ~ | 1 | Logic | B0C0 | X | integer | X | | | | | Ops | | | | | | Fstart | <b>'</b> | <b>'</b> | Fog | 86A0 | X | Fixed | X | | GIDMode | ~ | <b>'</b> | LB Read | B538 | X | bitfield | X | | GIDModeAnd | X | <b>'</b> | LB Read | B5B0 | X | bitfield | X | | GIDModeOr | X | <b>~</b> | LB Read | B5B8 | X | bitfield | X | | Name | Read | Write | | Offset | Reset | Format | Com- | |-----------------------------------------|----------|----------|-----------------|--------|----------|----------|----------| | ClyphData | back | | Name<br>2D Set | B660 | Value | intogra | mand | | GlyphData | × | ~ | 2D Set<br>Up | D00U | X | integer | × | | GlyphPosition | ~ | ~ | 2D Set | B608 | X | integer | × | | on pur control | | | Up | 2000 | | meger | ^ | | GPOutDMAAddress | <b>/</b> | X | Control | 0080 | | integer | | | | | | Status | | | | | | GStart | ~ | <b>~</b> | Color | 8798 | X | Fixed | X | | | | | DDA | | | | | | HbEnd | <b>~</b> | <b>~</b> | Video | 3020 | | integer | | | TT 1D1 : 1D 411 : 10 21 | _ | _ | Control | D 100 | | | | | HeadPhysicalPage Allocation[03] | <b>~</b> | <b>'</b> | Texture | B480 | X | integer | × | | HgEnd | | . 1 | Read<br>Video | 3018 | | integer | | | TISTIIG | • | <b>~</b> | Control | 2010 | | integer | | | HostInDMAAddress | V | X | Host In | 8938 | X | Integer | × | | HostInID | <i>'</i> | ~ | Host In | 8900 | X | Integer | × | | HostInState | <i>'</i> | <b>'</b> | Host In | 8918 | X | Integer | × | | HostInState2 | <i>'</i> | <b>V</b> | Host In | 8940 | X | Integer | X | | HostTextureAddress | <i>'</i> | X | Control | 0100 | Δ. | integer | ^ | | 110011 CAUMICIAUMICOS | | ^ | Status | 0100 | | integer | | | HsEnd | <b>'</b> | <b>/</b> | Video | 3030 | | integer | | | | | _ | Control | | | S | | | HsStart | <b>'</b> | <b>/</b> | Video | 3028 | | integer | | | | | | Control | | | | | | HTotal | <b>✓</b> | <b>~</b> | Video | 3010 | | integer | | | * · · · · · · · · · · · · · · · · · · · | | | Control | DESS | | | | | IndexBaseAddress | <b>'</b> | <b>'</b> | Host In | B700 | X | integer | X | | IndexedDoubleVertex | X | <b>'</b> | Host In | B7B0 | X | integer | X | | IndexedLineList | X | <b>'</b> | Host In | B728 | X | integer | X | | IndexedLineStrip | X | <b>'</b> | Host In | B730 | X | integer | X | | IndexedPointList | X | <b>'</b> | Host In | B738 | X | integer | X | | IndexedPolygon | X | <b>'</b> | Host In | B740 | X | integer | X | | IndexedTriangleFan | X | <b>'</b> | Host In | B718 | X | integer | X | | IndexedTriangleList | X | <b>'</b> | Host In | B710 | X | integer | X | | IndexedTriangleStrip | X | <b>'</b> | Host In | B720 | X | integer | X | | IndexedVertex | X | <b>'</b> | Host In | B7A8 | X | integer | X | | InFIFOSpace | <b>~</b> | X | Control | 0018 | | integer | | | T. D. 11 | | | Status | 0000 | <u> </u> | 11.0.11 | | | IntEnable | ~ | <b>'</b> | Control | 0008 | | bitfield | | | InterruptLine | | | Status<br>Video | 3060 | | integer | | | тистирилие | • | ~ | Control | 3000 | | integer | | | IntFlags | ~ | <b>/</b> | Control | 0010 | | bitfield | | | g | | | Status | 0010 | | Sitticia | | | InvalidateCache | × | <b>/</b> | Texture | B358 | X | bitfield | <b>'</b> | | | | | Read | | | | | | KdBStart | <b>~</b> | <b>/</b> | Texture | 8D30 | X | fixed | X | | KdGStart | <b>/</b> | ~ | Texture | 8D18 | X | fixed | X | | Name | Read | Write | | Offset | Reset | Format | Com- | |--------------------------|----------|----------|----------------------|--------|-------|----------|------| | | back | | Name | | Value | | mand | | KdRStart | <b>'</b> | <b>'</b> | Texture | 8D00 | X | fixed | X | | KsBStart | <b>✓</b> | ~ | Texture | 8CB0 | X | fixed | X | | | | | Applicati | | | | | | KsGStart | | | on | 8C98 | | fixed | | | KsGStart | <b>~</b> | <b>~</b> | Texture<br>Applicati | 8C98 | X | fixed | × | | | | | on | | | | | | KsRStart | ~ | <b>/</b> | Texture | 8C80 | x | fixed | X | | | | | Applicati | | | | | | | | | on | | | | | | LBClearDataL | ~ | <b>/</b> | LB Read | B550 | X | integer | X | | LBClearDataU | ~ | ~ | LB Read | B558 | X | integer | X | | LBDepth | × | <b>V</b> | LB | 88B0 | X | Integer | X | | | | | Read/H | | | | | | | | | ost Out | | | | | | LBDestReadBufferAddr | <b>'</b> | <b>'</b> | LB Read | | X | integer | | | LBDestReadBufferOffset | ~ | <b>'</b> | LB Read | B518 | X | integer | | | LBDestReadEnables | <b>~</b> | <b>'</b> | LB Read | | X | bitfield | X | | LBDestReadEnables And | × | <b>'</b> | LB Read | | X | bitfield | X | | LBDestReadEnables Or | × | <b>/</b> | LB Read | B598 | X | bitfield | X | | LBDestReadMode | <b>✓</b> | <b>/</b> | LB Read | B500 | X | integer | X | | LBDestReadModeAnd | × | <b>~</b> | LB Read | B580 | X | bitfield | X | | LBDestReadModeOr | × | <b>/</b> | LB Read | B588 | X | bitfield | X | | LBReadFormat | ~ | <b>/</b> | LB Read | 8888 | X | Bitfield | X | | LBReadModeAnd | × | <b>/</b> | Delta | AB90 | X | bitfield | X | | LBReadModeOr | × | <b>'</b> | Delta | AB98 | X | bitfield | X | | LBSourceReadBufferAddr | ~ | <b>/</b> | LB Read | B528 | X | integer | X | | LBSourceReadBufferOffset | ~ | <b>/</b> | LB Read | B530 | X | bitfield | X | | LBSourceReadMode | ~ | ~ | LB Read | B520 | X | integer | X | | LBSourceReadMode And | X | ~ | LB Read | B5A0 | X | bitfield | X | | LBSourceReadModeOr | X | ~ | LB Read | B5A8 | X | bitfield | X | | LBStencil | × | <b>'</b> | Host | 88A8 | X | Bitfield | X | | | | | Out | | | | | | LBWriteBufferAddr | <b>✓</b> | <b>/</b> | LB Write | B540 | X | integer | X | | LBWriteBufferOffset | <b>✓</b> | <b>/</b> | LB Write | | X | integer | X | | LBWriteFormat | ~ | <b>'</b> | LB Write | | X | Bitfield | X | | LBWriteMode | <b>/</b> | <b>/</b> | LB Write | | X | Bitfield | X | | LBWriteModeAnd | × | <b>/</b> | LB Write | AC80 | X | bitfield | X | | LBWriteModeOr | × | <b>/</b> | LB Write | AC88 | X | bitfield | X | | LineMode | V | <b>'</b> | Delta | 94A8 | X | bitfield | X | | LineModeAnd | × | <b>'</b> | Delta | AAF0 | X | bitfield | X | | LineModeOr | × | <b>'</b> | Delta | AAF8 | X | bitfield | X | | LineStippleMode | ~ | <b>V</b> | Stipple | 81A8 | X | Bitfield | X | | LineStippleModeAnd | X | <b>/</b> | Stipple | ABC0 | X | bitfield | X | | LineStippleModeOr | × | <b>/</b> | Stipple | ABC8 | X | bitfield | X | | LineWidth | ~ | <b>/</b> | Delta | 94B0 | X | integer | X | | LineWidthOffset | <b>/</b> | 1 | Delta | 94B8 | X | integer | X | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |--------------------------------|--------------|----------|--------------------|--------|----------------|----------|------| | LoadLineStippleCounters | ✓ V | / | Stipple | 81B0 | x | Bitfield | ✓ | | LocalMemCaps | <u> </u> | ~ | Memory | 1018 | Δ | Bitfield | | | LocalMemControl | <b>✓</b> | <b>'</b> | Control<br>Memory | 1028 | | Bitfield | | | LocalMemPowerDown | <b>✓</b> | <b>'</b> | Control<br>Memory | 1038 | | Bitfield | | | LocalMemRefresh | <b>✓</b> | <b>'</b> | Control<br>Memory | 1030 | | Bitfield | | | LocalMemTiming | <b>✓</b> | <b>'</b> | Control<br>Memory | 1020 | | Bitfield | | | LOD | <b>✓</b> | <b>'</b> | Control<br>Texture | 83D0 | x | Fixed | × | | LOD1 | <b>V</b> | <b>v</b> | Index<br>Texture | 8448 | X | Fixed | X | | LodRange0 | <b>V</b> | ~ | Index<br>Texture | B348 | X | bitfield | X | | LodRange1 | <b>V</b> | <b>V</b> | Index<br>Texture | B350 | X | fixed | × | | LogicalOpMode | <i>'</i> | <b>V</b> | Index<br>Logic | 8828 | X | Bitfield | X | | LogicalOpModeAnd | | <b>V</b> | Op<br>Logic | ACE0 | X | bitfield | | | • | X | | Op | | | | × | | LogicalOpModeOr | × | • | Logic<br>Op | ACE8 | X | bitfield | × | | LogicalTexturePage | <b>'</b> | X | Control<br>Status | 0118 | | integer | | | LogicalTexturePage TableAddr | <b>~</b> | <b>'</b> | Texture<br>Read | B4D0 | X | integer | × | | LogicalTexturePage TableLength | <b>~</b> | ~ | Texture<br>Read | B4D8 | X | integer | × | | LUT[015] | <b>V</b> | ~ | LUT | 8E80 | X | bitfield | X | | LUTAddress | ~ | ~ | Texture<br>Read | 84D0 | x | Integer | × | | LUTData | <b>~</b> | <b>/</b> | LUT | 84C8 | X | Integer | X | | LUTIndex | <b>/</b> | <b>/</b> | LUT | 84C0 | X | Integer | X | | LUTMode | <b>/</b> | ~ | LUT | B378 | X | bitfield | X | | LUTModeAnd | X | <b>/</b> | LUT | AD70 | x | bitfield | X | | LUTModeOr | X | <b>/</b> | LUT | AD78 | X | bitfield | X | | LUTTransfer | ~ | ~ | Texture<br>Read | 84D8 | X | Bitfield | × | | MaxHitRegion | × | ~ | Host<br>Out | 8C30 | X | bitfield | ~ | | MaxRegion | ~ | • | Host<br>Out | 8C18 | X | bitfield | | | MemBypassWriteMask | ~ | • | Memory<br>Control | 1008 | | Integer | | | MemCounter | <b>~</b> | X | Memory<br>Control | 1000 | | Integer | | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |---------------------------------|--------------|----------|-----------------------|--------|----------------|----------|----------| | MemScratch | ~ | ~ | Memory<br>Control | 1010 | | Integer | | | MinHitRegion | × | ~ | Host<br>Out | 8C28 | x | bitfield | ~ | | MinRegion | ~ | <b>'</b> | Host<br>Out | 8C10 | X | bitfield | × | | MiscControl | ~ | <b>'</b> | Video<br>Control | 3088 | | Bitfield | | | OutPutFIFOWords | ~ | X | Control<br>Status | 0020 | | integer | | | Packed16Pixels | X | <b>'</b> | 2D Set | B638 | X | integer | ~ | | Packed4Pixels | X | <b>'</b> | Up<br>2D Set | B668 | X | integer | ~ | | Packed8Pixels | × | ~ | Up<br>2D Set<br>Up | B630 | X | integer | ~ | | PCIAbortAddress | ~ | X | Control<br>Status | 0098 | | integer | | | PCIAbortStatus | ~ | X | Control<br>Status | 0090 | | bitfield | | | PCIFeedbackCount | ~ | X | Control<br>Status | 0088 | | integer | | | PCIPLLStatus | ~ | <b>'</b> | Control<br>Status | 00F0 | | bitfield | | | PhysicalPageAllocationTableAddr | ~ | <b>'</b> | Texture<br>Read | B4C0 | x | integer | × | | PickResult | × | <b>'</b> | Host<br>Out | 8C38 | x | bitfield | <b>'</b> | | PixelSize | ~ | <b>'</b> | Raster-<br>izer | 80C0 | X | Bitfield | <b>'</b> | | PointMode | ~ | <b>/</b> | Delta | 9490 | X | bitfield | X | | PointModeAnd | X | <b>V</b> | Delta | AAE0 | X | bitfield | X | | PointModeOr | X | 1 | Delta | AAE8 | X | bitfield | X | | PointSize | <b>/</b> | 1 | Delta | 9498 | X | integer | X | | PointTable[03] | ~ | ~ | Raster-<br>izer | 8080 | X | bitfield | X | | Q1Start | ~ | <b>'</b> | Texture<br>Coord | 8430 | x | Fixed | × | | QStart | ~ | ~ | Texture<br>Coord | 83B8 | x | Fixed | × | | RasterizerMode | ~ | ~ | Raster-<br>izer | 80A0 | X | Bitfield | × | | RasterizerModeAnd | × | ~ | Raster-<br>izer | ABA0 | X | bitfield | × | | RasterizerModeOr | × | <b>'</b> | Raster-<br>izer | ABA8 | X | bitfield | × | | RDIndexControl | • | <b>'</b> | RAMDA<br>C<br>Control | 4038 | | Integer | | | Name | | Write | | Offset | Reset | Format | Com- | |------------------------|----------|----------|------------------|--------|-------|----------|----------| | | back | | Name | | Value | | mand | | RDIndexedData | ~ | ~ | RAMDA | 4030 | | Integer | | | | | | C | | | | | | DDL 1 II: 1 | | | Control | 4020 | | T | | | RDIndexHigh | ~ | <b>'</b> | RAMDA<br>C | 4028 | | Integer | | | | | | Control | | | | | | RDIndexLow | <b>v</b> | / | RAMDA | 4020 | | Integer | | | | | | С | | | 8 | | | | | | Control | | | | | | RDPaletteData | <b>V</b> | <b>'</b> | RAMDA | 4008 | | Integer | | | | | | С | | | | | | | | | Control | | | _ | | | RDPaletteReadAddress | ~ | <b>'</b> | RAMDA | 4018 | | Integer | | | | | | C | | | | | | RDPaletteWriteAddress | | | Control<br>RAMDA | 4000 | | Intocar | | | RDPalette writeAddress | <b>~</b> | <b>'</b> | C | 4000 | | Integer | | | | | | Control | | | | | | RDPixelMask | V | / | RAMDA | 4010 | | Integer | | | TEST Menitudia | | | C | 1010 | | mieger | | | | | | Control | | | | | | ReadMonitorMode | ~ | <b>/</b> | Delta | 80F8 | X | Bitfield | X | | ReadMonitorModeAnd | × | <b>/</b> | Delta | B5C0 | X | bitfield | X | | ReadMonitorModeOr | × | / | Delta | B5C8 | X | bitfield | X | | RectangleHeight | V | <b>/</b> | Delta | 94E0 | X | float | X | | RectangleMode | V | <b>/</b> | Delta | 94D0 | X | bitfield | X | | RectanglePosition | V | <b>V</b> | 2D Set | B600 | x | integer | X | | <u> </u> | - | | Up | | | | | | RectangleWidth | <b>~</b> | <b>'</b> | Delta | 94D8 | X | integer | X | | RemoteMemControl | <b>~</b> | ~ | Memory | 1100 | | Integer | | | | | | Control | | | | | | Render | × | <b>'</b> | Raster- | 8038 | X | Bitfield | <b>~</b> | | D - 1 - 2D | , - | | izer | DC 40 | | 1.140 11 | | | Render2D | × | ~ | 2D Set | B640 | X | bitfield | × | | Render2DGlyph | ~ | ~ | Up<br>2D Set | B648 | X | bitfield | X | | Refider2DGfypfi | X | • | Up | D0+0 | A | DITTICIU | ^ | | RenderPatchOffset | <b>~</b> | <b>/</b> | 2D Set | B610 | X | bitfield | × | | | | | Up | | | | ^ | | RepeatLine | × | <b>/</b> | Delta | 9328 | X | tag | <b>'</b> | | RepeatTriangle | X | <b>V</b> | Delta | 9310 | X | tag | <b>V</b> | | ResetPickResult | X | <b>'</b> | Host | 8C20 | X | tag | <b>V</b> | | | | | Out | | | | | | ResetStatus | | | Control | 0000 | | integer | | | | | | Status | | | | | | RetainedRender | <b>v</b> | <b>'</b> | Host In | B7A0 | X | bitfield | <b>'</b> | | RLCount | × | ~ | 2D Set | B678 | X | integer | X | | | | | Up | | | | | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |---------------------------------|----------|----------|--------------------|--------------|-------|----------------------|------------| | | back | | Name | | Value | | mand | | RLData | <b>'</b> | ~ | 2D Set | B670 | x | integer | X | | | | | Up | | | | | | RLEMask | <b>✓</b> | ~ | Host | 8C48 | X | bitfield | X | | RouterMode | | | Out<br>Router | 8840 | | Bitfield | | | RStart | | <b>/</b> | Color | 8780 | X | Fixed | X | | Kotart | <b>~</b> | • | DDA | 0700 | A | Tixeu | X | | S1Start | <u> </u> | <b>/</b> | Texture | 8400 | X | Fixed | X | | | | | Coord | | | | | | SaveLineStippleCounters | × | <b>/</b> | Stipple | 81C0 | X | tag | <b>/</b> | | ScanLineOwnership | <b>✓</b> | ~ | Raster- | 80B0 | x | Bitfield | × | | 0.1.25 | | | izer | 0.1.0.0 | | D: 2.11 | | | ScissorMaxXY | ~ | <b>'</b> | Scissor | 8190 | X | Bitfield | X | | ScissorMinXY | | <b>/</b> | Scissor | 8188 | X | Bitfield | X | | ScissorMode | <u> </u> | <b>/</b> | Scissor | 8180 | X | Bitfield | X | | ScissorModeAnd<br>ScissorModeOr | X | <b>/</b> | Scissor<br>Scissor | ABB0<br>ABB8 | X | bitfield<br>bitfield | X | | ScreenBase | X | <b>/</b> | Video | 3000 | X | | × | | Screenbase | <b>~</b> | ~ | Control | 3000 | | integer | | | ScreenBaseRight | ~ | <b>/</b> | Video | 3080 | | Integer | | | <b>B</b> 1 | | | Control | | | | | | ScreenSize | <b>'</b> | ~ | Scissor | 8198 | X | Bitfield | X | | ScreenStride | <b>✓</b> | <b>/</b> | Video | 3008 | | Integer | | | | | | Control | | | D. 2.11 | | | Security | <b>'</b> | <b>/</b> | Host In | 8908 | X | Bitfield | X | | SetDeltaPort | X | <b>/</b> | Delta | 80F0 | X | Bitfield | <b>'</b> | | SetLogicalTexturePage | ~ | <b>'</b> | Texture<br>Read | B360 | X | bitfield | × | | SizeOfFramebuffer | <b>/</b> | ~ | LB Read, | BOA8 | x | integer | × | | oizeon fameballer | | | FB Read, | | A | integer | ^ | | | | | FB Write | | | | | | SStart | ~ | <b>/</b> | Texture | 8388 | X | Fixed | X | | 0 *** | | | Coord | 2000 | | 2 1 | | | StartXDom | ~ | X | Raster- | 8000 | X | fixed | × | | StartXSub | <b>✓</b> | X | izer<br>Raster- | 8010 | X | fixed | × | | | | ^ | izer | 0010 | A | lixed | ^ | | StartY | × | X | Raster- | 8020 | X | fixed | X | | | | | izer | | | | | | StatisticMode | ~ | <b>~</b> | Host | 8C08 | X | bitfield | × | | Carairai - Mar Ja Am J | | | Out | A D 10 | | 1.:46: 11 | | | <b>StatisticModeAnd</b> | X | ~ | Host<br>Out | AD10 | X | bitfield | × | | StatisticModeOr | X | <b>/</b> | Host | AD18 | X | bitfield | × | | | ^ | | Out | 12210 | | Sitticia | ^ | | Stencil | ~ | <b>/</b> | Stencil | 8998 | X | Bitfield | <b>√</b> X | | StencilData | ~ | <b>/</b> | Stencil | 8990 | X | Bitfield | | | StencilDataAnd | × | <b>/</b> | Stencil | B3E0 | X | bitfield | X | | StencilDataOr | × | <b>/</b> | Stencil | B3E8 | X | bitfield | X | | Name | Read | Write | | Offset | Reset | Format | Com- | |---------------------------------|----------|----------|--------------------------|--------|-------|----------|----------| | | back | | Name | | Value | D. 2.11 | mand | | StencilMode | <b>'</b> | <b>'</b> | Stencil | 8988 | X | Bitfield | X | | StencilModeAnd | X | <b>'</b> | Stencil | AC60 | X | bitfield | X | | StencilModeOr | X | <b>'</b> | Stencil | AC68 | X | bitfield | X | | StripeOffsetY | • | • | Raster-<br>izer | 80C8 | X | fixed | × | | SuspendUntilFrameBlank | × | <b>'</b> | Framebu<br>ffer<br>Write | 8C78 | X | bitfield | <b>'</b> | | Sync | × | ~ | Host<br>Out | 8C40 | x | bitfield | ~ | | T1Start | ~ | <b>'</b> | Texture coord | 8418 | x | Fixed | × | | TailPhysicalPage Allocation[03] | ~ | ~ | Texture<br>Read | B4A0 | x | integer | × | | TexDMAAddress | ~ | × | Control<br>Status | 0120 | | integer | | | TexFIFOSpace | ~ | × | Control<br>Status | 0128 | | integer | | | TextRender2DGlyph0 | × | <b>'</b> | Raster-<br>izer | 8708 | X | Bitfield | ~ | | TextRender2DGlyph1 | × | <b>'</b> | Raster-<br>izer | 8718 | X | Bitfield | ~ | | TextRender2DGlyph2 | × | <b>'</b> | Raster-<br>izer | 8728 | X | Bitfield | ~ | | TextRender2DGlyph3 | × | <b>'</b> | Raster-<br>izer | 8738 | X | Bitfield | <b>'</b> | | TextRender2DGlyph4 | × | <b>'</b> | Raster-<br>izer | 8748 | X | Bitfield | ~ | | TextRender2DGlyph5 | × | <b>'</b> | Raster-<br>izer | 8758 | X | Bitfield | <b>'</b> | | TextRender2DGlyph6 | × | <b>'</b> | Raster-<br>izer | 8768 | X | Bitfield | <b>'</b> | | TextRender2DGlyph7 | × | <b>'</b> | Raster-<br>izer | 8778 | X | Bitfield | • | | TextTGlyphAddr0 | × | <b>'</b> | Raster-<br>izer | 8700 | X | Integer | × | | TextTGlyphAddr1 | × | ~ | Raster-<br>izer | 8710 | x | Integer | × | | TextTGlyphAddr2 | × | • | Raster-<br>izer | 8720 | x | Integer | × | | TextTGlyphAddr3 | × | • | Raster-<br>izer | 8730 | x | Integer | × | | TextTGlyphAddr4 | × | <b>'</b> | Raster-<br>izer | 8740 | x | Integer | × | | TextTGlyphAddr5 | × | • | Raster-<br>izer | 8750 | x | Integer | × | | TextTGlyphAddr6 | × | • | Raster-<br>izer | 8760 | X | Integer | × | | TextTGlyphAddr7 | × | <b>'</b> | Raster-<br>izer | 8770 | X | Integer | × | | Name | Read | Write | | Offset | Reset | Format | Com- | |-------------------------------|----------|----------|----------------------------|--------|-------|-----------|------| | | back | | Name | 1.050 | Value | 1 : 6: 11 | mand | | TextureApplication ModeAnd | × | <b>/</b> | Texture<br>Applicati<br>on | AC50 | X | bitfield | × | | TextureApplication ModeOr | X | <b>'</b> | Texture<br>Applicati<br>on | AC58 | x | bitfield | × | | <b>TextureApplicationMode</b> | ~ | ~ | Texture<br>Applicati<br>on | 8680 | X | Bitfield | × | | TextureBaseAddr[16] | ~ | ~ | Texture<br>Read | 8500 | x | Integer | × | | TextureChromaLower0 | ~ | • | Color<br>DDA | 84F0 | X | Bitfield | × | | TextureChromaLower1 | ~ | <b>'</b> | Texture<br>Filter | 8608 | X | Bitfield | × | | TextureChromaUpper0 | ~ | <b>'</b> | Color<br>DDA | 84E8 | X | Bitfield | × | | TextureChromaUpper1 | ~ | <b>'</b> | Texture<br>Filter | 8600 | x | Bitfield | × | | TextureCompositeAlphaMode0 | ~ | <b>~</b> | Texture<br>Composi<br>te | B310 | x | bitfield | × | | TextureCompositeAlphaMode0And | X | <b>'</b> | Texture<br>Composi<br>te | B390 | х | bitfield | × | | TextureCompositeAlphaMode0Or | X | <b>~</b> | Texture<br>Composi<br>te | B398 | X | bitfield | × | | TextureCompositeAlphaMode1 | ~ | ~ | Texture<br>Composi<br>te | B320 | X | | × | | TextureCompositeAlphaMode1And | × | <b>'</b> | Texture<br>Composi<br>te | B3B0 | x | bitfield | × | | TextureCompositeAlphaMode1Or | X | ~ | Texture<br>Composi<br>te | B3B8 | x | bitfield | × | | TextureCompositeColorMode0 | <b>'</b> | ~ | Texture<br>Composi<br>te | B308 | x | bitfield | × | | TextureCompositeColorMode0And | × | ~ | Texture<br>Composi<br>te | B380 | X | bitfield | × | | TextureCompositeColorMode0Or | × | <b>~</b> | Texture<br>Composi<br>te | B388 | X | bitfield | × | | TextureCompositeColorMode1 | ~ | <b>~</b> | Texture<br>Composi<br>te | B318 | X | bitfield | × | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |-------------------------------|--------------|----------|--------------------------|--------|----------------|----------|------| | TextureCompositeColorMode1And | X | ~ | Texture<br>Composi<br>te | B3A0 | X | bitfield | X | | TextureCompositeColorMode1Or | X | ~ | Texture<br>Composi<br>te | B3A8 | X | bitfield | X | | TextureCompositeFactor0 | ~ | ~ | Texture<br>Composi<br>te | B328 | X | bitfield | | | TextureCompositeFactor1 | ~ | <b>'</b> | Texture<br>Composi<br>te | B330 | X | bitfield | × | | TextureCompositeMode | ~ | ~ | Texture<br>Composi<br>te | B300 | X | bitfield | × | | TextureCoordMode | ~ | <b>'</b> | Texture coord | 8380 | x | Bitfield | X | | TextureCoordModeAnd | × | <b>'</b> | Texture coord | AC20 | X | | × | | TextureCoordModeOr | × | <b>'</b> | Texture coord | AC28 | x | bitfield | × | | TextureData | × | <b>'</b> | Localbuf<br>fer R/W | | X | Integer | X | | TextureDownloadControl | | × | Control<br>Status | 0108 | | bitfield | | | TextureEnvColor | <b>'</b> | ~ | Texture | 8688 | X | Bitfield | X | | TextureFilterMode | <b>'</b> | <b>'</b> | Texture | 84E0 | X | Bitfield | X | | TextureFilterModeAnd | X | <b>'</b> | Texture | AD50 | X | bitfield | X | | TextureFilterModeOr | X | <b>/</b> | Texture | AD58 | X | bitfield | X | | TextureIndexMode0 | ~ | <b>'</b> | Texture<br>Index | B338 | X | bitfield | × | | TextureIndexMode0And | × | ~ | Texture<br>Index | B3C0 | X | bitfield | × | | TextureIndexMode0Or | × | • | Texture<br>Index | B3C8 | X | bitfield | X | | TextureIndexMode1 | <b>'</b> | ~ | Texture<br>Index | B340 | X | bitfield | X | | TextureIndexMode1And | × | <b>'</b> | Texture<br>Index | B3D0 | X | bitfield | × | | TextureIndexMode1Or | × | ~ | Texture<br>Index | B3D8 | X | bitfield | X | | TextureLodBiasS | <b>'</b> | • | Texture<br>Index | 8450 | X | Fixed | X | | TextureLodBiasT | <i>'</i> | • | Texture<br>Index | 8458 | X | Fixed | X | | TextureMapSize | <i>'</i> | • | Texture<br>Read | B428 | X | integer | X | | TextureMapWidth[16] | • | <b>'</b> | Texture<br>Read | 8580 | X | Bitfield | X | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |---------------------------|--------------|----------|-----------------|--------|----------------|-----------|----------| | TextureOperation | V | X | Control | 0110 | Value | integer | mana | | P | | | Status | | | | | | TextureReadMode0 | V | ~ | Texture | B400 | X | bitfield | X | | | | | Read | | | | | | TextureReadMode0And | × | ~ | Texture | AC30 | X | bitfield | X | | H D 116 1 00 | | _ | Read | 1.020 | | 1 : 6: 11 | | | TextureReadMode0Or | × | ~ | Texture<br>Read | AC38 | X | bitfield | × | | TextureReadMode1 | <b>/</b> | ~ | Texture | B408 | X | bitfield | × | | Texturesteadyrodes | | | Read | D 100 | A . | bitticia | ^ | | TextureReadMode1And | × | <b>/</b> | Texture | AD40 | X | bitfield | X | | | | | Read | | | | | | TextureReadMode1Or | × | ~ | Texture | AD48 | x | bitfield | × | | | | | Read | | | | | | <b>TouchLogicalPage</b> | × | <b>~</b> | Texture | B370 | X | bitfield | <b>✓</b> | | TriangleMode | | | Read<br>Delta | 94C8 | | bitfield | ., | | TriangleModeAnd | <b>/</b> | <b>/</b> | Delta | AB10 | X | bitfield | X | | TriangleModeOr | X | <b>/</b> | Delta | AB18 | X | bitfield | X | | TStart | X | <b>/</b> | Texture | 83A0 | X | Fixed | X | | 1 Start | ~ | <b>'</b> | coord | 03/10 | X | Tixeu | × | | UpdateLineStippleCounters | X | <b>/</b> | Stipple | 81B8 | X | Bitfield | ~ | | UpdateLogicalTextureInfo | × | <b>V</b> | Texture | B368 | X | tag | <b>/</b> | | 1 | | | Read | | | | | | V0FixedF | <b>/</b> | <b>/</b> | Delta | 9048 | x | fixed | X | | V0FixedQ | <b>/</b> | <b>/</b> | Delta | 9010 | X | fixed | X | | V0FixedS | <b>✓</b> | ~ | Delta | 9000 | x | fixed | X | | V0FixedT | <b>✓</b> | <b>/</b> | Delta | 9008 | X | fixed | X | | V0FixedX | <b>✓</b> | <b>~</b> | Delta | 9050 | X | fixed | X | | V0FixedY | <b>✓</b> | <b>/</b> | Delta | 9058 | X | fixed | X | | V0FixedZ | <b>✓</b> | <b>/</b> | Delta | 9060 | X | fixed | X | | V0FloatA | <b>✓</b> | <b>~</b> | Delta | 91C0 | X | float | X | | V0FloatB | <b>~</b> | <b>'</b> | Delta | 91B8 | X | float | X | | V0FloatF | <b>~</b> | <b>'</b> | Delta | 91C8 | X | float | X | | V0FloatG | <b>~</b> | <b>'</b> | Delta | 91B0 | X | float | X | | V0FloatKd | <b>~</b> | <b>'</b> | Delta | 91A0 | X | float | X | | V0FloatKd | <b>~</b> | <b>'</b> | Delta | 92A0 | X | float | X | | V0FloatKs | <b>~</b> | <b>'</b> | Delta | 9198 | X | float | X | | V0FloatKs | <b>~</b> | <b>'</b> | Delta | 9298 | X | float | X | | V0FloatQ | <b>~</b> | <b>'</b> | Delta | 9010 | X | float | X | | V0FloatR | <b>~</b> | <b>'</b> | Delta | 91A8 | X | float | X | | V0FloatS | <b>~</b> | <b>'</b> | Delta | 9000 | X | float | X | | V0FloatT | <b>~</b> | <b>'</b> | Delta | 9008 | X | float | X | | V0FloatX | <b>~</b> | <b>'</b> | Delta | 91D0 | X | float | X | | V0FloatY | <b>~</b> | <b>'</b> | Delta | 91D8 | X | float | X | | V0FloatZ | ~ | <b>/</b> | Delta | 91E0 | X | float | X | | V1FixedF | <b>✓</b> | <b>/</b> | Delta | 90C8 | X | fixed | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |-------------------|----------|----------|---------|--------|-------|-----------|------| | | back | | Name | | Value | | mand | | V1FixedQ | V | ~ | Delta | 9090 | X | float | X | | V1FixedS | ~ | ~ | Delta | 9080 | x | float | X | | V1FixedT | ~ | ~ | Delta | 9088 | x | float | X | | V1FixedX | ~ | ~ | Delta | 90D0 | x | fixed | X | | V1FixedY | <b>~</b> | ~ | Delta | 90D8 | X | fixed | X | | V1FixedZ | <b>v</b> | ~ | Delta | 90E0 | X | fixed | X | | V1FloatA | <b>v</b> | ~ | Delta | 9240 | X | float | X | | V1FloatB | <b>v</b> | ~ | Delta | 9238 | X | float | X | | V1FloatF | ~ | <b>/</b> | Delta | 9248 | x | float | X | | V1FloatG | ~ | <b>/</b> | Delta | 9230 | x | float | X | | V1FloatKd | <b>v</b> | ~ | Delta | 9220 | X | float | X | | V1FloatKs | <b>v</b> | ~ | Delta | 9218 | X | float | X | | V1FloatQ | <b>v</b> | ~ | Delta | 9210 | X | float | X | | V1FloatR | <b>v</b> | ~ | Delta | 9228 | X | float | X | | V1FloatS | <b>~</b> | ~ | Delta | 9200 | X | float | X | | V1FloatT | <b>v</b> | ~ | Delta | 9208 | X | float | X | | V1FloatX | <b>~</b> | ~ | Delta | 9250 | X | float | X | | V1FloatY | <b>v</b> | ~ | Delta | 9258 | X | float | X | | V1FloatZ | <b>v</b> | ~ | Delta | 9260 | X | float | X | | V2FixedF | V | ~ | Delta | 9148 | X | fixed | X | | V2FixedQ | V | ~ | Delta | 9110 | X | float | X | | V2FixedS | V | ~ | Delta | 9100 | X | float | X | | V2FixedT | <b>~</b> | ~ | Delta | 9108 | X | float | X | | V2FixedX | <b>v</b> | ~ | Delta | 9150 | X | fixed | X | | V2FixedY | <b>v</b> | ~ | Delta | 9158 | X | fixed | X | | V2FixedZ | <b>v</b> | ~ | Delta | 9160 | X | fixed | X | | V2FloatA | ~ | <b>/</b> | Delta | 92C0 | x | float | X | | V2FloatB | <b>~</b> | <b>/</b> | Delta | 92B8 | x | float | X | | V2FloatF | <b>~</b> | <b>/</b> | Delta | 92C8 | x | float | X | | V2FloatG | <b>~</b> | <b>/</b> | Delta | 92B0 | x | float | X | | V2FloatQ | ~ | <b>~</b> | Delta | 9290 | x | float | X | | V2FloatR | <b>✓</b> | <b>~</b> | Delta | 92A8 | X | float | X | | V2FloatS | <b>✓</b> | <b>~</b> | Delta | 9280 | x | float | X | | V2FloatT | <b>✓</b> | <b>~</b> | Delta | 9288 | x | float | X | | V2FloatX | <b>✓</b> | <b>~</b> | Delta | 92D0 | x | float | X | | V2FloatY | <b>✓</b> | <b>~</b> | Delta | 92D8 | x | float | X | | V2FloatZ | <b>~</b> | <b>/</b> | Delta | 92E0 | X | float | X | | VbEnd | ~ | <b>/</b> | Video | 3040 | X | integer | | | | | | Control | | | | | | VClkRDacCtl | ~ | <b>~</b> | Control | 0040 | 0 | bitfield | | | Vartario | | | Status | B7B8 | _ | into - ·· | | | Vertex0 | X | <b>/</b> | Host In | | X | integer | X | | Vertex1 | X | <b>/</b> | Host In | B7C0 | X | integer | X | | Vertex2 | X | <b>/</b> | Host In | B7C8 | X | integer | X | | VertexBaseAddress | <b>v</b> | <b>/</b> | Host In | B708 | X | integer | X | | VertexControl | <b>✓</b> | <b>/</b> | Host In | B798 | X | bitfield | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|--------------------|--------|-------|-----------|------| | Ttulilo | back | vviile | Name | Jiiset | Value | Jillat | mand | | VertexData | X | V | Host In | B7E8 | x | integer | X | | VertexData0 | X | 1 | Host In | B7D0 | x | integer | X | | VertexData1 | X | 1 | Host In | B7D8 | x | integer | X | | VertexData2 | X | 1 | Host In | B7E0 | x | integer | X | | VertexFormat | <b>V</b> | 1 | Host In | B790 | x | integer | X | | VertexLineList | X | ~ | Host In | B760 | x | integer | X | | VertexLineStrip | X | ~ | Host In | B768 | x | integer | X | | VertexPointList | X | ~ | Host In | B770 | x | integer | X | | VertexPolygon | X | ~ | Host In | B778 | x | integer | X | | VertexTagList[015] | <b>V</b> | 1 | Host In | B800 | x | bitfield | X | | VertexTagList[1631] | V | ~ | Host In | B880 | x | bitfield | X | | VertexTriangleFan | X | ~ | Host In | B750 | x | integer | X | | VertexTriangleList | X | ~ | Host In | B748 | x | integer | X | | VertexTriangleStrip | X | ~ | Host In | B758 | x | integer | X | | VertexValid | V | 1 | Host In | B788 | x | integer | X | | VerticalLineCount | V | × | Video | 3070 | | integer | | | | | | Control | | | | | | VideoControl | <b>✓</b> | <b>~</b> | Video | 3058 | | bitfield | | | | | | Control | | | | | | VideoOverlayBase0 | <b>✓</b> | • | Video | 3120 | | bitfield | | | | | | Overlay | | | | | | Video Overlay Recol | | | Control<br>Video | 3128 | | bitfield | | | VideoOverlayBase1 | <b>~</b> | <b>~</b> | Overlay | 3126 | | bittieid | | | | | | Control | | | | | | VideoOverlayBase2 | | <b>/</b> | Video | 3130 | | bitfield | | | , and the second | | | Overlay | | | | | | | | | Control | | | | | | VideoOverlayFieldOffset | ~ | <b>/</b> | Video | 3170 | | bitfield | | | | | | Overlay | | | | | | Till O I FIFE C | | | Control | 2110 | | 1 : 6: 11 | | | VideoOverlayFIFO Control | <b>~</b> | ~ | Video | 3110 | | bitfield | | | | | | Overlay<br>Control | | | | | | VideoOverlayHeight | <b>✓</b> | ~ | Video | 3148 | | integer | | | Videoovenayrieight | | | Overlay | 3110 | | integer | | | | | | Control | | | | | | VideoOverlayIndex | <b>V</b> | ~ | Video | 3118 | | bitfield | | | · | | | Overlay | | | | | | | | | Control | | | | | | VideoOverlayMode | <b>✓</b> | <b>✓</b> | Video | 3108 | | bitfield | | | | | | Overlay | | | | | | Vide a Organia re Originis | | | Control | 3150 | | L:4C:-1.1 | | | VideoOverlayOrigin | ~ | <b>~</b> | Video<br>Overlay | 3130 | | bitfield | | | | | | Control | | | | | | VideoOverlayShrinkXDelta | <b>✓</b> | <b>'</b> | Video | 3158 | | bitfield | | | · · · · · · · · · · · · · · · · · · · | | | Overlay | 3130 | | Sitticia | | | | | | Control | | | | | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |------------------------|--------------|----------|--------------------|--------|----------------|----------|----------| | VideoOverlayStatus | V | ~ | Video | 3178 | | bitfield | | | | | | Overlay | | | | | | | | | Control | | | | | | VideoOverlayStride | <b>✓</b> | ~ | Video | 3138 | | integer | | | | | | Overlay | | | | | | W.L.O. L. H. L. | | | Control | 2400 | | | | | VideoOverlayUpdate | ~ | <b>~</b> | Video | 3100 | | integer | | | | | | Overlay<br>Control | | | | | | VideoOverlayWidth | <b>✓</b> | ~ | Video | 3140 | | integer | | | videooveriay width | | | Overlay | 3140 | | integer | | | | | | Control | | | | | | VideoOverlayYDelta | <b>/</b> | <b>/</b> | Video | 3168 | | Integer | | | , | | | Overlay | | | 8 | | | | | | Control | | | | | | VideoOverlayZoomXDelta | <b>~</b> | ~ | Video | 3160 | | integer | | | | | | Overlay | | | | | | | | | Control | | | | | | VSDMACommandBase | <b>✓</b> | <b>✓</b> | Video | 5AC8 | | integer | | | | | | Stream | | | | | | TARREST 10 | | | Control | 5.50 | | | | | VSDMACommandCount | ~ | ~ | Video | 5AD0 | | integer | | | | | | Stream | | | | | | VSDMAMode | | 4 | Control<br>Video | 5AC0 | | bitfield | | | V SDIMAMOde | ~ | <b>~</b> | Stream | SACO | | Dittieid | | | | | | Control | | | | | | VsEnd | <b>v</b> | ~ | Video | 3050 | | integer | | | VSERU | | | Control | 3030 | | miteger | | | VSSerialBusControl | ~ | 1 | Video | 5810 | | bitfield | | | | | ' | Stream | 0010 | | Sittiera | | | | | | Control | | | | | | VsStart | V | <b>/</b> | Video | 3048 | | integer | | | | | | Control | | | | | | VSStatus | <b>'</b> | × | Video | 5808 | | bitfield | | | | | | Stream | | | | | | | | | Control | | | | | | VTGAddress | <b>/</b> | <b>'</b> | FB Write | | X | integer | <b>/</b> | | VTGData | <b>/</b> | <b>~</b> | FB Write | | X | integer | <b>✓</b> | | VTotal | <b>✓</b> | <b>✓</b> | Video | 3038 | | integer | | | | | | Control | | | | | | WaitForCompletion | × | ~ | Raster- | 80B8 | X | Bitfield | ~ | | ****** * | | 1 | izer | 0000 | | D: C 11 | | | Window | · | <b>/</b> | Stencil | 8980 | X | Bitfield | X | | WindowAnd | X | <b>/</b> | Stencil | AB80 | X | bitfield | X | | WindowOr | X | <b>/</b> | Stencil | AB88 | X | bitfield | X | | WindowOrigin | <b>✓</b> | ~ | Scissor | 81C8 | X | Bitfield | X | | XBias | <b>✓</b> | ~ | Delta | 9480 | X | float | X | | YBias | <b>~</b> | <b>/</b> | Delta | 9488 | X | float | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |----------|----------|----------|---------|--------|-------|----------|------| | | back | | Name | | Value | | mand | | YLimits | <b>✓</b> | <b>/</b> | Raster- | 80A8 | X | Bitfield | X | | | | | izer | | | | | | YUVMode | <b>✓</b> | <b>/</b> | YUV | 8F00 | X | bitfield | X | | | | | Unit | | | | | | ZfogBias | <b>/</b> | <b>~</b> | Fog | 86B8 | X | Float | X | | ZStartL | <b>✓</b> | <b>/</b> | Depth & | 89B8 | X | Fixed | X | | | | | Fog | | | | | | ZStartU | <b>✓</b> | <b>/</b> | Depth | 89B0 | X | Fixed | X | ## 6.2 Registers Sorted by Offset | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |-------------------|----------|----------|---------|--------|-------|----------|------| | | back | | Name | | Value | | mand | | ResetStatus | | | Control | 0000 | | integer | | | | | | Status | | | | | | IntEnable | <b>✓</b> | <b>✓</b> | Control | 0008 | | bitfield | | | | | | Status | | | | | | IntFlags | <b>✓</b> | <b>~</b> | Control | 0010 | | bitfield | | | | | | Status | | | | | | InFIFOSpace | <b>✓</b> | X | Control | 0018 | | integer | | | | | | Status | | | | | | OutPutFIFOWords | <b>✓</b> | X | Control | 0020 | | integer | | | | | | Status | | | | | | ControlDMAAddress | <b>✓</b> | <b>/</b> | Control | 0028 | | integer | | | | | | Status | | | | | | ControlDMACount | <b>✓</b> | <b>/</b> | Control | 0030 | | integer | | | | | | Status | | | | | | ErrorFlags | | | Control | 0038 | | bitfield | | | | | | Status | | | | | | VClkRDacCtl | <b>✓</b> | <b>/</b> | Control | 0040 | 0 | bitfield | | | | | | Status | | | | | | ApertureOne | <b>✓</b> | <b>/</b> | Control | 0050 | | bitfield | | | | | | Status | | | | | | ApertureTwo | <b>✓</b> | <b>~</b> | Control | 0058 | | bitfield | | | | | | Status | | | | | | ControlDMAControl | <b>✓</b> | <b>~</b> | Control | 0060 | | bitfield | | | | | | Status | | | | | | FIFODiscon | <b>✓</b> | <b>~</b> | Control | 0068 | | bitfield | | | | | | Status | | | | | | ChipConfig | <b>✓</b> | <b>~</b> | Control | 0070 | | bitfield | | | | | | Status | | | | | | AGPControl | <b>✓</b> | <b>✓</b> | Control | 0078 | | bitfield | | | | | | Status | | | | | | GPOutDMAAddress | <b>✓</b> | × | Control | 0080 | | integer | | | | | | Status | | | | | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |------------------------|--------------|----------|-----------------------------|--------|----------------|----------|------| | PCIFeedbackCount | ~ | × | Control<br>Status | 0088 | | integer | | | PCIAbortStatus | <b>v</b> | × | Control | 0090 | | bitfield | | | PCIAbortAddress | ~ | × | Status<br>Control<br>Status | 0098 | | integer | | | PCIPLLStatus | ~ | ~ | Control<br>Status | 00F0 | | bitfield | | | HostTextureAddress | ~ | X | Control<br>Status | 0100 | | integer | | | TextureDownloadControl | ~ | × | Control<br>Status | 0108 | | bitfield | | | TextureOperation | ~ | × | Control<br>Status | 0110 | | integer | | | LogicalTexturePage | ~ | × | Control<br>Status | 0118 | | integer | | | TexDMAAddress | ~ | X | Control<br>Status | 0120 | | integer | | | TexFIFOSpace | ~ | × | Control<br>Status | 0128 | | integer | | | ByAperture1Mode | ~ | ~ | Bypass<br>Control | 0300 | | Bitfield | | | ByAperture1Stride | ~ | ~ | Bypass<br>Control | 0308 | | Integer | | | ByAperture1YStart | ~ | ~ | Bypass<br>Control | 0310 | | Integer | | | ByAperture1UStart | ~ | ~ | Bypass<br>Control | 0318 | | Integer | | | ByAperture1VStart | ~ | ~ | Bypass<br>Control | 0320 | | Integer | | | ByAperture2Mode | ~ | ~ | Bypass<br>Control | 0328 | | Bitfield | | | ByAperture2Stride | ~ | ~ | Bypass<br>Control | 0330 | | Integer | | | ByAperture2YStart | ~ | ~ | Bypass<br>Control | 0338 | | Integer | | | ByAperture2UStart | ~ | <b>'</b> | Bypass<br>Control | 0340 | | Integer | | | ByAperture2VStart | ~ | <b>'</b> | Bypass<br>Control | 0348 | | Integer | | | ByDMAReadMode | ~ | <b>'</b> | Bypass<br>Control | 0350 | | Bitfield | | | ByDMAReadStride | ~ | ~ | Bypass<br>Control | 0358 | | Integer | | | ByDMAReadYStart | ~ | ~ | Bypass<br>Control | 0360 | | Integer | | | ByDMAReadUStart | ~ | ~ | Bypass<br>Control | 0368 | | Integer | | | ByDMAReadVStart | V | <b>'</b> | Bypass<br>Control | 0370 | | Integer | | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |-----------------------------|--------------|----------|-------------------|--------|----------------|----------|---------| | ByDMAReadCommandBase | | ~ | Bypass | 0378 | value | Integer | Illallu | | DyDMAReadCommandbase | ~ | • | Control | 0378 | | integer | | | ByDMAReadCommandCount | <b>/</b> | / | Bypass | 0380 | | Integer | | | By Divirica a command count | | • | Control | 0300 | | integer | | | ByDMAWriteMode | V | <b>/</b> | Bypass | 0388 | | Bitfield | | | | | | Control | | | | | | ByDMAWriteStride | <b>/</b> | <b>/</b> | Bypass | 0390 | | Integer | | | • | | | Control | | | | | | ByDMAWriteYStart | V | <b>/</b> | Bypass | 0398 | | Integer | | | | | | Control | | | | | | ByDMAWriteUStart | <b>✓</b> | <b>~</b> | Bypass | 03A0 | | Integer | | | | | | Control | | | | | | ByDMAWriteVStart | <b>✓</b> | <b>✓</b> | Bypass | 03A8 | | Integer | | | | | | Control | | | | | | ByDMAWriteCommandBase | <b>✓</b> | <b>~</b> | Bypass | 03B0 | | Integer | | | D DMAW' : 0 | | | Control | 0.2.00 | | - | | | ByDMAWriteCommandCount | ~ | ~ | Bypass | 03B8 | | Integer | | | M. C. | | | Control | 1000 | | т. | | | MemCounter | ~ | X | Memory<br>Control | 1000 | | Integer | | | Mara Perta a a Weita Maala | | | | 1008 | | Lutacan | | | MemBypassWriteMask | ~ | • | Memory<br>Control | 1006 | | Integer | | | MemScratch | <b>V</b> | <b>/</b> | Memory | 1010 | | Integer | | | Memocraten | | <b>V</b> | Control | 1010 | | integer | | | LocalMemCaps | · | / | Memory | 1018 | | Bitfield | | | 200amiem oaps | | | Control | 1010 | | Dittieta | | | LocalMemTiming | <b>/</b> | <b>/</b> | Memory | 1020 | | Bitfield | | | | | | Control | | | | | | LocalMemControl | <b>v</b> | ~ | Memory | 1028 | | Bitfield | | | | | | Control | | | | | | LocalMemRefresh | <b>✓</b> | <b>✓</b> | Memory | 1030 | | Bitfield | | | | | | Control | | | | | | LocalMemPowerDown | <b>✓</b> | <b>~</b> | Memory | 1038 | | Bitfield | | | | | | Control | | | | | | RemoteMemControl | <b>✓</b> | <b>~</b> | Memory | 1100 | | Integer | | | | | | Control | | | | | | ScreenBase | <b>✓</b> | ~ | Video | 3000 | | integer | | | 0 0 11 | | _ | Control | 2000 | | т. | | | ScreenStride | ~ | ~ | Video | 3008 | | Integer | | | HTotal | | | Control | 3010 | - | intono | | | TI OTAL | ~ | • | Video<br>Control | 3010 | | integer | | | HgEnd | | | Video | 3018 | | integer | | | 11g13HQ | ~ | ~ | Control | 2010 | | micgei | | | HbEnd | <b>/</b> | ~ | Video | 3020 | | integer | | | 1102114 | | <b>"</b> | Control | 3020 | | maga | | | HsStart | · | <b>'</b> | Video | 3028 | | integer | | | | | | Control | | | | | | HsEnd | · | <b>/</b> | Video | 3030 | | integer | | | | | | Control | | | 0 | | | Name | | Write | | Offset | | Format | Com- | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|------------------|--------|-------|----------|------| | *77** . 1 | back | | Name | 2020 | Value | • . | mand | | VTotal | <b>~</b> | ~ | Video<br>Control | 3038 | | integer | | | VbEnd | · · | / | Video | 3040 | X | integer | | | Vollid | | | Control | 3040 | Δ | integer | | | VsStart | ~ | / | Video | 3048 | | integer | | | | | | Control | | | 8 | | | VsEnd | <b>~</b> | <b>/</b> | Video | 3050 | | integer | | | | | | Control | | | | | | VideoControl | <b>v</b> | <b>/</b> | Video | 3058 | | bitfield | | | | | | Control | | | | | | InterruptLine | <b>✓</b> | <b>/</b> | Video | 3060 | | integer | | | | | | Control | | | | | | DisplayData | | | Video | 3068 | | bitfield | | | | | | Control | | | | | | VerticalLineCount | <b>✓</b> | X | Video | 3070 | | integer | | | | | | Control | | | | | | FifoControl | <b>✓</b> | <b>/</b> | Video | 3078 | | bitfield | | | | | | Control | | | | | | ScreenBaseRight | <b>✓</b> | <b>~</b> | Video | 3080 | | Integer | | | | | | Control | | | | | | MiscControl | <b>✓</b> | <b>~</b> | Video | 3088 | | Bitfield | | | 711.0 | | | Control | 2400 | | | | | VideoOverlayUpdate | <b>✓</b> | ~ | Video | 3100 | | integer | | | | | | Overlay | | | | | | 77.1 0 1 1/1 | | | Control | 2400 | | 1 . 6 11 | | | VideoOverlayMode | ~ | <b>'</b> | Video | 3108 | | bitfield | | | | | | Overlay | | | | | | Wil O I FIFO C I | | | Control<br>Video | 3110 | | bitfield | | | VideoOverlayFIFO Control | ~ | ~ | Overlay | 3110 | | Diffield | | | | | | Control | | | | | | VideoOverlayIndex | | <b>'</b> | Video | 3118 | | bitfield | | | VideoOverlayIndex | | | Overlay | 3110 | | bittieid | | | | | | Control | | | | | | VideoOverlayBase0 | <b>/</b> | <b>/</b> | Video | 3120 | | bitfield | | | . Laco o vermy Duoco | | | Overlay | 3120 | | Sitilate | | | | | | Control | | | | | | VideoOverlayBase1 | ~ | ~ | Video | 3128 | | bitfield | | | The state of s | | | Overlay | | | | | | | | | Control | | | | | | VideoOverlayBase2 | <b>~</b> | ~ | Video | 3130 | | bitfield | | | | | | Overlay | | | | | | | | | Control | | | | | | VideoOverlayStride | <b>~</b> | <b>'</b> | Video | 3138 | | integer | | | _ | - | | Overlay | | | | | | | | | Control | | | | | | VideoOverlayWidth | ~ | <b>'</b> | Video | 3140 | | integer | | | | | | Overlay | | | | | | | | | Control | | | | | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |--------------------------------------|--------------|----------|--------------------------------|--------|----------------|----------|------| | VideoOverlayHeight | ~ | ~ | Video<br>Overlay<br>Control | 3148 | | integer | | | VideoOverlayOrigin | ~ | <b>'</b> | Video<br>Overlay<br>Control | 3150 | | bitfield | | | VideoOverlayShrinkXDelta | • | <b>~</b> | Video<br>Overlay<br>Control | 3158 | | bitfield | | | VideoOverlayZoomXDelta | ~ | <b>'</b> | Video<br>Overlay<br>Control | 3160 | | integer | | | VideoOverlayYDelta | ~ | ~ | Video<br>Overlay<br>Control | 3168 | | Integer | | | VideoOverlayFieldOffset | ~ | ~ | Video<br>Overlay<br>Control | 3170 | | bitfield | | | VideoOverlayStatus | ~ | ~ | Video<br>Overlay<br>Control | 3178 | | bitfield | | | RDPaletteWriteAddress RDPaletteData | <i>'</i> | <b>'</b> | RAMDA<br>C<br>Control<br>RAMDA | | | Integer | | | | <i>'</i> | | C<br>Control | | | | | | RDPixelMask | • | <b>'</b> | RAMDA<br>C<br>Control | | | Integer | | | RDPaletteReadAddress | • | <b>~</b> | RAMDA<br>C<br>Control | 4018 | | Integer | | | RDIndexLow | ~ | ~ | RAMDA<br>C<br>Control | 4020 | | Integer | | | RDIndexHigh | ~ | ~ | RAMDA<br>C<br>Control | 4028 | | Integer | | | RDIndexedData | ~ | • | RAMDA<br>C<br>Control | 4030 | | Integer | | | RDIndexControl | ~ | ~ | RAMDA<br>C<br>Control | 4038 | | Integer | | | VSStatus | ~ | × | Video<br>Stream<br>Control | 5808 | | bitfield | | | Name | | Write | | Offset | Reset | Format | Com- | |---------------------|----------|------------|-----------------|---------|-------|----------|------------| | Vice of the Country | back | | Name | 5010 | Value | 1:.0.11 | mand | | VSSerialBusControl | ~ | l | Video<br>Stream | 5810 | | bitfield | | | | | | | | | | | | TICTOM AND 1 | | | Control | T A CO | | 1:.0.11 | | | VSDMAMode | <b>~</b> | ~ | Video | 5AC0 | | bitfield | | | | | | Stream | | | | | | WODALLO ID | | | Control | 5 4 60 | | • | | | VSDMACommandBase | <b>✓</b> | ~ | Video | 5AC8 | | integer | | | | | | Stream | | | | | | Wabara 10 | | | Control | 5 1 D 0 | | | | | VSDMACommandCount | <b>✓</b> | • | Video | 5AD0 | | integer | | | | | | Stream | | | | | | | | | Control | | | | | | StartXDom | <b>✓</b> | X | Raster- | 8000 | X | fixed | X | | | | | izer | | | | | | dXDom | <b>✓</b> | X | Raster- | 8008 | X | fixed | X | | | | | izer | | | | | | StartXSub | V | X | Raster- | 8010 | X | fixed | X | | | | | izer | | | | | | dXSub | <b>/</b> | × | Raster- | 8018 | X | fixed | X | | | | | izer | | | | | | StartY | X | X | Raster- | 8020 | X | fixed | X | | O W 10 1 | ^ | ^ | izer | 0020 | | | ^ | | dY | ~ | X | Raster- | 8028 | X | fixed | × | | u i | | ^ | izer | 0020 | A | lixed | ^ | | Count | | \ <u>/</u> | Raster- | 8030 | X | Integer | \ <u>'</u> | | Count | ~ | × | izer | 0030 | Λ | integer | × | | Render | | | Raster- | 8038 | X | Bitfield | | | Kender | × | <b>'</b> | | 0030 | X | Dittield | ~ | | ContinueNewLine | | | izer | 0040 | | Т., | 4 | | ContinueNewLine | × | <b>'</b> | Raster- | 8040 | X | Integer | <b>~</b> | | <u> </u> | | | izer | 0040 | | T | | | ContinueNewDom | × | ~ | Raster- | 8048 | X | Integer | <b>~</b> | | | | | izer | | | | | | ContinueNewSub | × | <b>/</b> | Raster- | 8050 | X | Integer | ~ | | | | | izer | | | | | | Continue | × | <b>~</b> | Raster- | 8058 | X | Integer | <b>~</b> | | | | | izer | | | | | | FlushSpan | × | <b>✓</b> | Raster- | 8060 | X | tag | <b>✓</b> | | | | | izer | | | | | | BitMaskPattern | × | / | Raster- | 8068 | X | Integer | <b>✓</b> × | | | | | izer | | | | | | PointTable[03] | V | ~ | Raster- | 8080 | X | bitfield | X | | • | | | izer | | | | | | RasterizerMode | <b>~</b> | ~ | Raster- | 80A0 | X | Bitfield | X | | | | | izer | | | | | | YLimits | ~ | <b>/</b> | Raster- | 80A8 | X | Bitfield | × | | | | | izer | 00110 | | Zillicia | ^ | | ScanLineOwnership | ~ | ~ | Raster- | 80B0 | X | Bitfield | × | | oemine o whership | | | izer | 0000 | Δ | Ditticit | ^ | | WaitForCompletion | ., | | | 80B8 | v | Bitfield | | | ward or completion | × | <b>/</b> | Raster-<br>izer | രവാര | X | Dittiela | <b>~</b> | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------------|--------------|----------|-----------------|--------|----------------|----------|--------------| | PixelSize | ~ | ~ | Raster-<br>izer | 80C0 | X | Bitfield | ~ | | StripeOffsetY | ~ | ~ | Raster-<br>izer | 80C8 | x | fixed | × | | SetDeltaPort | X | <b>V</b> | Delta | 80F0 | X | Bitfield | <b>'</b> | | ReadMonitorMode | <b>/</b> | 1 | Delta | 80F8 | X | Bitfield | X | | ScissorMode | <b>/</b> | ~ | Scissor | 8180 | X | Bitfield | X | | ScissorMinXY | <b>/</b> | ~ | Scissor | 8188 | X | Bitfield | X | | ScissorMaxXY | <b>/</b> | ~ | Scissor | 8190 | X | Bitfield | X | | ScreenSize | <b>/</b> | ~ | Scissor | 8198 | X | Bitfield | X | | AreaStippleMode | <b>V</b> | 1 | Stipple | 81A0 | x | Bitfield | X | | LineStippleMode | <b>/</b> | 1 | Stipple | 81A8 | x | Bitfield | X | | LoadLineStippleCounters | <b>V</b> | 1 | Stipple | 81B0 | x | Bitfield | <b>V</b> | | <b>UpdateLineStippleCounters</b> | X | 1 | Stipple | 81B8 | x | Bitfield | <b>'</b> | | SaveLineStippleCounters | X | ~ | Stipple | 81C0 | x | tag | <b>V</b> | | WindowOrigin | V | 1 | Scissor | 81C8 | X | Bitfield | X | | AreaStipplePattern[015] | <b>/</b> | <b>V</b> | Stipple | 8200 | X | Bitfield | X | | AreaStipplePattern[1631] | <b>/</b> | <b>V</b> | Stipple | 8280 | X | Bitfield | X | | FillFBWriteBufferAddr0 | X | ~ | 2D Set<br>Up | 8300 | x | integer | X | | FillFBSourceReadBufferAddr | × | ~ | 2D Set<br>Up | 8308 | X | integer | X | | FillFBDestReadBufferAddr0 | X | <b>'</b> | 2D Set<br>Up | 8310 | X | integer | × | | FillScissorMinXY | X | <b>'</b> | 2D Set<br>Up | 8318 | X | fixed | × | | FillScissorMaxXY | × | <b>'</b> | 2D Set<br>Up | 8320 | X | fixed | X | | FillForegroundColor0 | X | ~ | 2D Set<br>Up | 8328 | x | integer | × | | FillBackgroundColor | X | ~ | 2D Set<br>Up | 8330 | x | integer | X | | FillConfig2D0 | X | <b>'</b> | 2D Set<br>Up | 8338 | X | bitfield | X | | FillFBSourceReadBufferOffset | X | <b>'</b> | 2D Set<br>Up | 8340 | X | Integer | X | | FillRectanglePosition | X | <b>'</b> | 2D Set<br>Up | 8348 | X | Integer | X | | FillRender2D | X | <b>'</b> | 2D Set<br>Up | 8350 | x | Bitfield | X | | FillForegroundColor1 | × | ~ | 2D Set<br>Up | 8358 | X | Integer | × | | FillConfig2D1 | × | ~ | 2D Set<br>Up | 8360 | X | Bitfield | | | FillGlyphPosition | × | ~ | 2D Set<br>Up | 8368 | x | Integer | × | | TextureCoordMode | ~ | • | Texture coord | 8380 | X | Bitfield | × | | Start | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------|----------|--------------|--------|----------------|--------|---------------------------------------| | Coord Coor | SStart | | ./ | | 8388 | | Fixed | | | Assume | Source | | | | 0300 | 1 | 1 IACG | ^ | | Coord Coor | dSdx | ~ | ✓ | | 8390 | X | Fixed | × | | Texture | | | | | | | | | | Coord Coor | dSdyDom | ~ | ~ | | 8398 | X | Fixed | X | | Coord Coor | • | | | coord | | | | | | Texture Sand X Fixed X | TStart | <b>V</b> | <b>/</b> | Texture | 83A0 | X | Fixed | X | | Coord Coo | | | | coord | | | | | | Texture coord | dTdx | <b>✓</b> | <b>~</b> | | 83A8 | X | Fixed | X | | Coord Coo | | | | | | | | | | V | dTdyDom | ~ | <b>~</b> | | 83B0 | X | Fixed | X | | Coord Coor | | | | | | | | | | V | QStart | <b>~</b> | ~ | | 83B8 | X | Fixed | X | | COORD | 10.1 | | _ | | 0200 | | F: 1 | | | Texture S3C8 x Fixed x | dQdx | <b>~</b> | <b>/</b> | | 83C0 | X | Fixed | X | | Coord Coor | 10.1.0 | | | | 0260 | | F: 1 | | | | aQayDom | • | | | 8308 | X | Fixed | X | | Index | LOD | | | | 02100 | | T: 1 | | | Texture coord Saba X | LOD | | | | 83D0 | X | Fixed | X | | Coord Sabo X | 10.1 | | | | 02100 | | Time d | ., | | DQdy | dSdy | | • | | 63D6 | X | rixed | X | | Coord Coor | dTdv | | | | 83E0 | v | Fixed | V/ | | DQdy | uTuy | | | | 03120 | Λ | Tixcu | X | | Coord S1Start | DOdy | •/ | ./ | | 83F8 | v | Fixed | ~ | | V | 2 Quy | | | | OJLO | 1 | Taca | ^ | | Coord Coor | S1Start | <b>~</b> | <b>~</b> | | 8400 | x | Fixed | Y | | dSidx V Texture coord dSidyDom V Texture coord dSidyDom V Texture coord dSidyDom V Texture coord dSidyDom V Texture coord dSidyDom V Texture coord dSidyDom V Texture coord dTistart V Texture coord dTidyDom V Texture coord dTidyDom V Texture coord dQidyDom dAtta x Fixed X Fixed X Fixed X Fixed X Fixed X TextureLodBiasS V Texture 8450 x Fixed X Fixed X | 0.10.00.10 | | | | 0.00 | | Tined | ^ | | Coord Coo | dS1dx | ~ | <b>/</b> | | 8408 | X | Fixed | X | | Coord Coo | | | | coord | | | | | | Coord Coo | dS1dyDom | <b>v</b> | <b>/</b> | Texture | 8410 | X | Fixed | X | | Coord Coo | | | | coord | | | | | | Coord Coor | T1Start | <b>✓</b> | <b>/</b> | Texture | 8418 | X | Fixed | X | | Coord Coo | | | | coord | | | | | | dT1dyDom ✓ Texture coord 8428 x Fixed X Q1Start ✓ Texture Coord 8430 x Fixed X dQ1dx ✓ Texture coord 8438 x Fixed X dQ1dyDom ✓ Texture coord 8440 x Fixed X LOD1 ✓ Texture Index 8448 x Fixed X TextureLodBiasS ✓ Texture lodge 8450 x Fixed X TextureLodBiasT ✓ Texture lodge 8458 x Fixed X | dT1dx | <b>✓</b> | <b>~</b> | | 8420 | X | Fixed | X | | Coord Q1Start Texture 8430 x Fixed X Coord dQ1dx Texture 8438 x Fixed X coord dQ1dyDom Texture 8440 x Fixed X Coord Texture 8448 x Fixed X TextureLodBiasS TextureLodBiasT Texture 8450 x Fixed X Texture 8450 x Fixed X Texture 8450 x Fixed X Texture 8450 x Fixed X | | | | | | | | | | Q1Start ✓ Texture Coord 8430 x Fixed X dQ1dx ✓ Texture coord 8438 x Fixed X dQ1dyDom ✓ Texture coord 8440 x Fixed X LOD1 ✓ Texture Index 8448 x Fixed X TextureLodBiasS ✓ Texture Index 8450 x Fixed X TextureLodBiasT ✓ Texture 8458 x Fixed X | dT1dyDom | <b>✓</b> | <b>~</b> | | 8428 | X | Fixed | X | | Coord | | | | | | | | | | dQ1dx Image: Coord of coor | Q1Start | <b>✓</b> | <b>/</b> | | 8430 | X | Fixed | X | | Coord Coo | 1041 | | | | 0.420 | | F: 1 | | | dQ1dyDom ✓ Texture coord 8440 x Fixed x LOD1 ✓ Texture Index 8448 x x Fixed x TextureLodBiasS ✓ Texture Index 8450 x Fixed x TextureLodBiasT ✓ Texture 8458 x Fixed x | dQldx | <b>~</b> | <b>~</b> | | 8438 | X | Fixed | X | | Coord Coo | 101 L-D | | | | 0440 | | T7: 1 | | | LOD1 Texture 8448 x Fixed X Index TextureLodBiasS TextureLodBiasT Texture 8450 x Fixed X Index TextureLodBiasT Texture 8458 x Fixed X | aQlayDom | <b>~</b> | • | | 8440 | X | Fixed | X | | Index TextureLodBiasS ✓ Texture 8450 x Fixed X Index TextureLodBiasT ✓ Texture 8458 x Fixed X | I OD1 | | | | 9119 | | Eirod | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | TextureLodBiasS ✓ Texture Index 8450 x Fixed X TextureLodBiasT ✓ Texture 8458 x Fixed X | LODI | <b>'</b> | • | | 0440 | X | 1.1xea | X | | Index TextureLodBiasT ✓ Texture 8458 x Fixed X | Texture I ad Bias S | | | | 8450 | v | Fixed | V | | TextureLodBiasT ✓ ✓ Texture 8458 x Fixed X | 1 CAUICEOUDIASS | | ~ | | 0730 | Α | 1 1ACU | X | | | TextureLodBiasT | | | | 8458 | v | Fixed | ~ | | Indev | 1 CAUTCHOUDIAS I | | ~ | Index | 0730 | Δ | 1 1200 | ^ | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |-------------------------------|----------|----------|-----------------|--------|-------|----------|----------| | | back | ' | Name | | Value | | mand | | BorderColor0 | ~ | <b>'</b> | Texture | 84A8 | x | Bitfield | × | | Y 7 1771 Y 1 | | | filter | 0.4.00 | | | | | LUTIndex | <b>/</b> | <b>/</b> | LUT | 84C0 | X | Integer | X | | LUTData | <b>~</b> | ~ | LUT | 84C8 | X | Integer | X | | LUTAddress | <b>✓</b> | <b>~</b> | Texture | 84D0 | X | Integer | × | | LUTTransfer | | | Read<br>Texture | 84D8 | | Bitfield | | | LO 1 1 ransier | ~ | • | Read | 04100 | X | Dittieta | X | | TextureFilterMode | <b>~</b> | ~ | Texture | 84E0 | x | Bitfield | X | | TextureChromaUpper0 | <b>V</b> | 1 | Color | 84E8 | x | Bitfield | X | | • • | | | DDA | | | | | | TextureChromaLower0 | ~ | <b>'</b> | Color | 84F0 | X | Bitfield | × | | D . 1 . C 1 . 4 | | | DDA | 0.450 | | D: C 11 | | | BorderColor1 | ~ | <b>~</b> | Texture filter | 84F8 | X | Bitfield | × | | TextureBaseAddr[16] | <u></u> | <b>'</b> | Texture | 8500 | X | Integer | X | | TextureDaseridar[10] | | | Read | 0300 | Α | integer | ^ | | TextureMapWidth[16] | V | <b>V</b> | Texture | 8580 | X | Bitfield | X | | | | | Read | | | | | | TextureChromaUpper1 | <b>v</b> | ~ | Texture | 8600 | X | Bitfield | X | | | | | Filter | | | | | | TextureChromaLower1 | <b>✓</b> | <b>/</b> | Texture | 8608 | X | Bitfield | X | | | | | Filter | | | | | | <b>TextureApplicationMode</b> | <b>✓</b> | <b>~</b> | Texture | 8680 | X | Bitfield | X | | | | | Applicati | | | | | | TextureEnvColor | | | on<br>Texture | 8688 | | Bitfield | | | | <u> </u> | <b>/</b> | | 8690 | X | Bitfield | X | | FogMode FogColor | <u> </u> | <b>/</b> | Fog | 8698 | X | Fixed | X | | FogColor | | <b>/</b> | Fog | | X | | X | | Fstart | <u> </u> | <b>/</b> | Fog | 86A0 | X | Fixed | X | | dFdx | <u> </u> | <b>/</b> | Fog | 86A8 | X | Fixed | X | | dFdyDom | <u> </u> | <b>/</b> | Fog | 86B0 | X | Fixed | X | | ZfogBias | <b>'</b> | <b>/</b> | Fog | 86B8 | X | Float | X | | TextTGlyphAddr0 | × | <b>~</b> | Raster- | 8700 | X | Integer | × | | Tours Don don 2DChamba | ., | | izer | 9709 | | Bitfield | | | TextRender2DGlyph0 | × | <b>~</b> | Raster-<br>izer | 8708 | X | Diffield | ~ | | TextTGlyphAddr1 | X | ~ | Raster- | 8710 | X | Integer | X | | 1 CX11 Gly pintau11 | ^ | • | izer | 0710 | Λ | integer | ^ | | TextRender2DGlyph1 | × | <b>/</b> | Raster- | 8718 | X | Bitfield | <b>'</b> | | | ^ | | izer | | | | | | TextTGlyphAddr2 | × | ~ | Raster- | 8720 | X | Integer | X | | · · | | | izer | | | | | | TextRender2DGlyph2 | × | <b>/</b> | Raster- | 8728 | x | Bitfield | <b>'</b> | | ** | | | izer | | | | | | TextTGlyphAddr3 | × | <b>/</b> | Raster- | 8730 | X | Integer | X | | | | | izer | | | | | | TextRender2DGlyph3 | × | • | Raster- | 8738 | X | Bitfield | <b>✓</b> | | | | | izer | | | | | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |---------------------------|--------------|----------|-----------------|--------|----------------|----------|----------| | TextTGlyphAddr4 | X | ~ | Raster- | 8740 | x | Integer | X | | | ^ | | izer | 00 | | Integer | ^ | | TextRender2DGlyph4 | X | ~ | Raster- | 8748 | X | Bitfield | <b>/</b> | | | | | izer | | | | | | TextTGlyphAddr5 | × | ~ | Raster- | 8750 | X | Integer | X | | T . D . 1 . D C 1 . 1 . T | | | izer | 0750 | | D: C 11 | | | TextRender2DGlyph5 | X | ~ | Raster-<br>izer | 8758 | X | Bitfield | ~ | | TextTGlyphAddr6 | X | <b>/</b> | Raster- | 8760 | X | Integer | × | | Text Glypin unio | ^ | | izer | 0700 | A | integer | ^ | | TextRender2DGlyph6 | × | / | Raster- | 8768 | x | Bitfield | ~ | | 71 | | | izer | | | | | | TextTGlyphAddr7 | X | <b>'</b> | Raster- | 8770 | x | Integer | X | | | | | izer | | | | | | TextRender2DGlyph7 | X | ~ | Raster- | 8778 | X | Bitfield | <b>~</b> | | | | | izer | | | | | | RStart | • | ~ | Color | 8780 | X | Fixed | X | | 1D 1 | | 4 | DDA | 0700 | | Fixed | | | dRdx | <b>~</b> | ~ | Color<br>DDA | 8788 | X | Fixed | × | | dRdyDom | ~ | ~ | Color | 8790 | x | Fixed | × | | ukuybom | | | DDA | 0770 | Λ | Tixcu | ^ | | | | | Delta | | | | | | GStart | ~ | / | Color | 8798 | x | Fixed | X | | | | | DDA | | | | | | dGdx | 1 | <b>'</b> | Color | 87A0 | X | Fixed | X | | | | | DDA | | | | | | dGdyDom | <b>~</b> | ~ | Color | 87A8 | X | Fixed | X | | DO: | | _ | DDA | 07700 | | E: 1 | | | BStart | ~ | <b>'</b> | Color<br>DDA | 87B0 | X | Fixed | X | | dBdx | ~ | <b>✓</b> | Color | 87B8 | X | Fixed | × | | ubux | | | DDA | 0/100 | X | Tixeu | X | | dBdyDom | ~ | / | Color | 87C0 | X | Fixed | × | | | | | DDA | 0.00 | | 111100 | ^ | | AStart | ~ | <b>'</b> | Color | 87C8 | X | Fixed | X | | | | | DDA | | | | | | dAdx | <b>~</b> | ~ | Color | 87D0 | x | Fixed | X | | | | | DDA | | | | | | dAdyDom | ~ | <b>'</b> | Color | 87D8 | X | Fixed | | | C.L. DDAM. I | | | DDA | 0750 | | D: C 11 | | | ColorDDAMode | ~ | ~ | Color | 87E0 | X | Bitfield | | | ConstantColor | | | DDA<br>Color | 87E8 | X | Bitfield | | | ConstantColor | ~ | <b>~</b> | DDA | 0/10 | X | Dittield | | | Color | V | ~ | Color | 87F0 | x | Bitfield | × | | 00101 | • | • | DDA | 0/10 | -A | Ditticia | ^ | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |---------------------|----------|----------|---------------------|--------|-------|----------|------------| | | back | | Name | | Value | | mand | | AlphaTestMode | V | <b>'</b> | Alpha | 8800 | X | Bitfield | X | | | | | Blend & | | | | | | | | | Alpha | | | | | | | | | Test | 0000 | | D: 2.11 | | | AntialiasMode | ~ | ~ | Alpha<br>test | 8808 | X | Bitfield | × | | DitherMode | V | <b>/</b> | Dither | 8818 | X | Bitfield | × | | FBSoftwareWriteMask | V | ~ | Logic | 8820 | X | Integer | X | | | | | Ops | | | | | | LogicalOpMode | ~ | ~ | Logic<br>Op | 8828 | X | Bitfield | × | | RouterMode | V | <b>'</b> | Router | 8840 | X | Bitfield | × | | LBReadFormat | <i>V</i> | <b>V</b> | LB Read | 8888 | x | Bitfield | X | | LBStencil | × | 1 | Host | 88A8 | X | Bitfield | X | | | | | Out | | | | | | LBDepth | × | <b>~</b> | LB | 88B0 | X | Integer | X | | | | | Read/H | | | | | | | | | ost Out | | | D. 2.11 | | | LBWriteMode | ~ | ~ | LB Write | | X | Bitfield | X | | LBWriteFormat | <b>✓</b> | <b>'</b> | LB Write | | X | Bitfield | X | | TextureData | X | • | Localbuf<br>fer R/W | 88E8 | X | Integer | X | | HostInID | V | <b>V</b> | Host In | 8900 | X | Integer | X | | Security | <i>V</i> | <b>V</b> | Host In | 8908 | X | Bitfield | X | | FlushWriteCombining | × | 1 | Host In | 8910 | X | Integer | X | | HostInState | V | ~ | Host In | 8918 | x | Integer | X | | HostInDMAAddress | V | × | Host In | 8938 | x | Integer | X | | HostInState2 | V | ~ | Host In | 8940 | X | Integer | X | | Window | V | ~ | Stencil | 8980 | x | Bitfield | X | | StencilMode | V | ~ | Stencil | 8988 | X | Bitfield | X | | StencilData | V | ~ | Stencil | 8990 | X | Bitfield | | | Stencil | V | <b>~</b> | Stencil | 8998 | X | Bitfield | <b>✓</b> × | | DepthMode | <b>V</b> | <b>'</b> | Depth | 89A0 | X | Bitfield | X | | Depth | <b>~</b> | <b>/</b> | Depth | 89A8 | X | Integer | <b>✓</b> × | | ZStartU | <b>✓</b> | <b>/</b> | Depth | 89B0 | x | Fixed | X | | ZStartL | ~ | <b>/</b> | Depth & | 89B8 | X | Fixed | X | | | | | Fog | | | | | | d <b>Z</b> dxU | ~ | <b>~</b> | Depth & | 89C0 | X | Fixed | X | | dZdxL | | | Fog<br>Depth & | 9009 | X | Fixed | | | dzuxL | <b>✓</b> | <b>~</b> | Fog | 0900 | X | Tixeu | × | | dZdyDomU | V | <b>/</b> | Depth & | 89D0 | x | Fixed | × | | ( | | • | Fog | | | | | | dZdyDomL | <b>/</b> | <b>/</b> | Depth & | 89D8 | X | Bitfield | X | | • | | | Fog | | | | | | FBColor | <b>v</b> | X | FB Write | | X | n/a | X | | FBWriteMode | <b>~</b> | <b>'</b> | FB Write | | X | bitfield | X | | FBHardwareWriteMask | <b>✓</b> | <b>✓</b> | FB Write | 8AC0 | X | mask | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |------------------------|----------|----------|----------------------------|--------|-------|----------|----------| | | back | | Name | | Value | | mand | | FBBlockColor | <b>v</b> | × | FB Read | 8AC8 | x | integer | X | | FilterMode | ~ | ~ | Host<br>Out | 8C00 | X | bitfield | X | | StatisticMode | ~ | ~ | Host<br>Out | 8C08 | X | bitfield | X | | MinRegion | ~ | ~ | Host | 8C10 | X | bitfield | × | | MaxRegion | ~ | <b>'</b> | Out | 8C18 | X | bitfield | | | ResetPickResult | × | <b>'</b> | Out<br>Host | 8C20 | X | tag | <b>/</b> | | MinHitRegion | × | <b>'</b> | Out<br>Host | 8C28 | X | bitfield | <b>V</b> | | MaxHitRegion | × | <b>V</b> | Out<br>Host | 8C30 | x | bitfield | <b>V</b> | | PickResult | × | · | Out<br>Host | 8C38 | X | bitfield | <i>'</i> | | | | | Out<br>Host | 8C40 | X | bitfield | | | Sync | × | ~ | Out | | | | ~ | | RLEMask | <b>'</b> | <b>'</b> | Host<br>Out | 8C48 | X | bitfield | × | | SuspendUntilFrameBlank | × | <b>~</b> | Framebu<br>ffer<br>Write | 8C78 | X | bitfield | <b>'</b> | | KsRStart | ~ | ~ | Texture<br>Applicati<br>on | 8C80 | X | fixed | × | | dKsRdx | <b>V</b> | ~ | Texture | 8C88 | X | fixed | X | | dKsRdyDom | <b>'</b> | ~ | Texture | 8C90 | x | fixed | X | | KsGStart | ~ | ~ | Texture<br>Applicati<br>on | 8C98 | X | fixed | × | | dKsGdx | <b>v</b> | ~ | Texture | 8CA0 | X | fixed | X | | dKsGdyDom | <b>v</b> | ~ | Texture | 8CA8 | X | fixed | X | | KsBStart | ~ | <b>'</b> | Texture<br>Applicati<br>on | 8CB0 | X | fixed | X | | dKsBdx | <b>'</b> | <b>/</b> | Texture | 8CB8 | x | fixed | X | | dKsBdyDom | <b>V</b> | <b>'</b> | Texture | 8CC0 | X | fixed | X | | KdRStart | <b>V</b> | <b>V</b> | Texture | 8D00 | X | fixed | X | | dKdRdx | <b>V</b> | <b>/</b> | Texture | 8D08 | X | fixed | X | | dKdRdyDom | <b>V</b> | <b>'</b> | Texture | 8D10 | X | fixed | X | | KdGStart | <b>V</b> | <b>/</b> | Texture | 8D18 | X | fixed | X | | dKdGdx | <b>V</b> | <b>/</b> | Texture | 8D20 | X | fixed | X | | dKdGdyDom | <b>V</b> | <b>/</b> | Texture | 8D28 | X | fixed | X | | KdBStart | <b>V</b> | <b>/</b> | Texture | 8D30 | X | fixed | X | | dKdBdx | <b>V</b> | <b>V</b> | Texture | 8D38 | X | fixed | X | | dKdBdyDom | ~ | <b>'</b> | Texture | 8D40 | X | fixed | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |----------------------|----------|----------|----------------|--------------|--------|----------|----------| | | back | | Name | | Value | | mand | | ContextDump | X | <b>'</b> | Global | 8DC0 | х | bitfield | <b>✓</b> | | ContextRestore | × | <b>/</b> | Global | 8DC8 | X | bitfield | <b>~</b> | | ContextData | × | <b>/</b> | Global | 8DD0 | X | bitfield | X | | LUT[015] | <b>✓</b> | <b>'</b> | LUT | 8E80 | X | bitfield | X | | YUVMode | <b>✓</b> | <b>'</b> | YUV | 8F00 | X | bitfield | X | | | | | Unit | | | | | | ChromaUpper | <b>✓</b> | ~ | Color | 8F08 | X | bitfield | × | | | | | DDA &<br>Alpha | | | | | | | | | Blend | | | | | | ChromaLower | ~ | <b>'</b> | Color | 8F10 | X | bitfield | X | | | | | DDA & | | | | | | | | | Alpha | | | | | | | | | Blend | | | | | | ChromaTestMode | <b>✓</b> | <b>~</b> | Color | 8F18 | X | bitfield | × | | | | | DDA & | | | | | | | | | Alpha<br>Blend | | | | | | EndOfFeedback | ~ | <b>'</b> | Host | 8FF8 | X | tag | X | | Zina o ii ceasaon | | | Out | 0110 | 14 | 8 | ^ | | V0FixedS | ~ | ~ | Delta | 9000 | X | fixed | X | | V0FixedT | V | ~ | Delta | 9008 | X | fixed | X | | V0FixedQ | V | ~ | Delta | 9010 | x | fixed | X | | V0FixedF | V | ~ | Delta | 9048 | X | fixed | X | | V0FixedX | V | ~ | Delta | 9050 | X | fixed | X | | V0FixedY | <b>✓</b> | <b>'</b> | Delta | 9058 | X | fixed | X | | V0FixedZ | <b>✓</b> | <b>/</b> | Delta | 9060 | X | fixed | X | | V1FixedS | <b>✓</b> | <b>/</b> | Delta | 9080 | X | float | X | | V1FixedT | <b>✓</b> | <b>/</b> | Delta | 9088 | X | float | X | | V1FixedQ | <b>~</b> | <b>'</b> | Delta | 9090 | X | float | X | | V1FixedF | <b>/</b> | <b>~</b> | Delta | 90C8 | X | fixed | X | | V1FixedX | <b>/</b> | <b>~</b> | Delta | 90D0 | X | fixed | X | | V1FixedY | <b>✓</b> | <b>'</b> | Delta | 90D8 | X | fixed | X | | V1FixedZ | <b>✓</b> | <b>'</b> | Delta | 90E0 | X | fixed | X | | V2FixedS | <b>'</b> | ~ | Delta | 9100 | X | float | X | | V2FixedT | <b>~</b> | <b>'</b> | Delta | 9108 | X | float | X | | V2FixedQ | <u> </u> | <b>/</b> | Delta | 9110 | X | float | X | | V2FixedF | <u> </u> | <b>/</b> | Delta | 9148 | X | fixed | X | | V2FixedX | <u> </u> | <b>/</b> | Delta | 9150 | X | fixed | X | | V2FixedY | <b>✓</b> | <b>/</b> | Delta | 9158 | X | fixed | X | | V2FixedZ | <u> </u> | <b>V</b> | Delta | 9160 | X | fixed | X | | V0FloatS<br>V0FloatT | <b>V</b> | <b>V</b> | Delta<br>Delta | 9000 | X | float | X | | V0FloatQ | <b>V</b> | <b>/</b> | Delta | 9008 | X | float | X | | V0FloatKs | <b>V</b> | <b>V</b> | Delta | 9198 | X | float | X | | V0FloatKd | <b>V</b> | <b>V</b> | Delta | 9198<br>91A0 | X<br>X | float | X | | V0FloatR | <b>V</b> | <b>V</b> | Delta | 91A0<br>91A8 | | float | X | | VOLIOAUX | <b>✓</b> | <b>/</b> | Dena | 21/10 | X | поат | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |----------------|----------|----------|-------|--------|-------|----------|----------| | | back | | Name | | Value | | mand | | V0FloatG | <b>'</b> | <b>'</b> | Delta | 91B0 | X | float | X | | V0FloatB | <b>'</b> | <b>'</b> | Delta | 91B8 | X | float | X | | V0FloatA | <b>'</b> | <b>'</b> | Delta | 91C0 | X | float | X | | V0FloatF | <b>'</b> | <b>'</b> | Delta | 91C8 | X | float | X | | V0FloatX | <b>'</b> | <b>'</b> | Delta | 91D0 | X | float | X | | V0FloatY | <b>'</b> | <b>~</b> | Delta | 91D8 | X | float | X | | V0FloatZ | <b>'</b> | <b>'</b> | Delta | 91E0 | X | float | X | | V1FloatS | <b>'</b> | <b>'</b> | Delta | 9200 | X | float | X | | V1FloatT | <b>'</b> | <b>~</b> | Delta | 9208 | X | float | X | | V1FloatQ | <b>'</b> | <b>'</b> | Delta | 9210 | X | float | X | | V1FloatKs | <b>'</b> | <b>/</b> | Delta | 9218 | X | float | X | | V1FloatKd | <b>'</b> | <b>/</b> | Delta | 9220 | X | float | X | | V1FloatR | <b>/</b> | <b>/</b> | Delta | 9228 | X | float | X | | V1FloatG | <b>/</b> | <b>/</b> | Delta | 9230 | X | float | X | | V1FloatB | <b>/</b> | <b>/</b> | Delta | 9238 | X | float | X | | V1FloatA | ~ | <b>~</b> | Delta | 9240 | x | float | X | | V1FloatF | ~ | <b>~</b> | Delta | 9248 | X | float | X | | V1FloatX | ~ | <b>✓</b> | Delta | 9250 | x | float | X | | V1FloatY | ~ | <b>✓</b> | Delta | 9258 | x | float | X | | V1FloatZ | ~ | <b>/</b> | Delta | 9260 | x | float | X | | V2FloatS | ~ | <b>/</b> | Delta | 9280 | x | float | X | | V2FloatT | <b>/</b> | <b>/</b> | Delta | 9288 | X | float | X | | V2FloatQ | ~ | ~ | Delta | 9290 | X | float | X | | V0FloatKs | <b>/</b> | <b>/</b> | Delta | 9298 | X | float | X | | V0FloatKd | ~ | ~ | Delta | 92A0 | X | float | X | | V2FloatR | ~ | <b>/</b> | Delta | 92A8 | x | float | X | | V2FloatG | <b>/</b> | <b>/</b> | Delta | 92B0 | X | float | X | | V2FloatB | <b>/</b> | <b>/</b> | Delta | 92B8 | X | float | X | | V2FloatA | ~ | <b>/</b> | Delta | 92C0 | x | float | X | | V2FloatF | ~ | <b>/</b> | Delta | 92C8 | x | float | X | | V2FloatX | ~ | <b>/</b> | Delta | 92D0 | x | float | X | | V2FloatY | ~ | <b>/</b> | Delta | 92D8 | x | float | X | | V2FloatZ | ~ | <b>/</b> | Delta | 92E0 | x | float | X | | DeltaMode | <b>/</b> | <b>/</b> | Delta | 9300 | X | bitfield | X | | DrawTriangle | X | <b>/</b> | Delta | 9308 | x | bitfield | <b>'</b> | | RepeatTriangle | X | <b>/</b> | Delta | 9310 | X | tag | <b>'</b> | | DrawLine0 | X | <b>/</b> | Delta | 9318 | x | fixed | <b>'</b> | | DrawLine1 | × | <b>/</b> | Delta | 9320 | x | fixed | <b>~</b> | | RepeatLine | X | <b>/</b> | Delta | 9328 | X | tag | <b>~</b> | | XBias | ~ | <b>/</b> | Delta | 9480 | x | float | X | | YBias | ~ | V | Delta | 9488 | X | float | X | | PointMode | ~ | V | Delta | 9490 | X | bitfield | X | | PointSize | ~ | <b>/</b> | Delta | 9498 | X | integer | X | | AAPointSize | ~ | <b>V</b> | Delta | 94A0 | x | float | X | | LineMode | ~ | <b>/</b> | Delta | 94A8 | X | bitfield | X | | Name | Read | Write | | Offset | | Format | Com- | |-----------------------------------|----------|----------|-----------------|--------------|--------|------------------|------| | LineWidth | back | | Name<br>Delta | 94B0 | Value | interes | mand | | LineWidthOffset | <b>/</b> | <b>V</b> | Delta<br>Delta | 94B0<br>94B8 | X | integer | X | | AALineWidth | <b>/</b> | <b>/</b> | Delta | 94C0 | X<br>X | integer<br>float | X | | TriangleMode | <b>V</b> | <b>V</b> | Delta | 94C0<br>94C8 | X | bitfield | X | | RectangleMode | <b>V</b> | <b>V</b> | Delta | 94D0 | X | bitfield | X | | RectangleWidth | <b>/</b> | <b>V</b> | Delta | 94D8 | X | integer | X | | Rectangle Width Rectangle Height | <i>V</i> | <b>V</b> | Delta | 94E0 | X | float | × | | Begin | - | <b>V</b> | Delta | 9590 | X | bitfield | × | | End | X | <b>V</b> | Delta | 9598 | X | fixed | × | | DMAAddr | × | <b>V</b> | Host In | A980 | X | integer | × | | DMACount | × | <b>V</b> | Host In | A988 | X | integer | × | | Command Interrupt | × | <b>V</b> | Host In | A990 | X | bitfield | × | | DMARectangle Read | X | <b>V</b> | Host In | A9A8 | X | bitfield | × | | DMARectangle ReadAddress | × / | <b>V</b> | Host In | A9B0 | X | integer | × | | DMARectangleRead LinePitch | <i>V</i> | <b>V</b> | Host In | A9B8 | X | integer | × | | DMARectangleRead Target | <i>'</i> | <b>'</b> | Host In | A9C0 | X | bitfield | X | | DMARectangleWrite | × | V | Host In | A9C8 | X | bitfield | X | | DMARectangleWriteAddress | ~ | V | Host In | A9D0 | X | integer | X | | DMARectangleWriteLinePitch | <i>'</i> | V | Host In | A9D8 | X | integer | X | | DMAOutput Address | × | <b>V</b> | Host In | A9E0 | X | integer | X | | DMAOutputCount | X | <b>V</b> | Host In | A9E8 | X | integer | X | | DMAContinue | X | <b>'</b> | Host In | A9F8 | X | integer | ~ | | DMAFeedback | X | <b>V</b> | Host In | AA10 | X | integer | X | | DeltaModeAnd | X | <b>V</b> | Delta | AAD0 | X | bitfield | X | | DeltaModeOr | X | <b>V</b> | Delta | AAD8 | X | bitfield | X | | PointModeAnd | X | <b>V</b> | Delta | AAE0 | X | bitfield | X | | PointModeOr | X | ~ | Delta | AAE8 | X | bitfield | X | | LineModeAnd | X | 1 | Delta | AAF0 | X | bitfield | X | | LineModeOr | X | <b>V</b> | Delta | AAF8 | X | bitfield | X | | TriangleModeAnd | X | 1 | Delta | AB10 | x | bitfield | X | | TriangleModeOr | × | ~ | Delta | AB18 | X | bitfield | X | | WindowAnd | X | ~ | Stencil | AB80 | X | bitfield | X | | WindowOr | X | ~ | Stencil | AB88 | x | bitfield | X | | LBReadModeAnd | X | ~ | Delta | AB90 | x | bitfield | X | | LBReadModeOr | X | ~ | Delta | AB98 | X | bitfield | X | | RasterizerModeAnd | × | <b>'</b> | Raster-<br>izer | ABA0 | x | bitfield | X | | RasterizerModeOr | X | ~ | Raster-<br>izer | ABA8 | x | bitfield | × | | ScissorModeAnd | × | <b>'</b> | Scissor | ABB0 | X | bitfield | X | | ScissorModeOr | × | <b>V</b> | Scissor | ABB8 | X | bitfield | × | | LineStippleModeAnd | X | <b>V</b> | Stipple | ABC0 | X | bitfield | X | | LineStippleModeOr | X | <b>V</b> | Stipple | ABC8 | X | bitfield | X | | AreaStippleModeAnd | X | <b>/</b> | Stipple | ABD0 | X | bitfield | X | | <b>AreaStippleModeOr</b> | X | ~ | Stipple | ABD8 | X | bitfield | X | | Name | Read | Write | | Offset | Reset | Format | Com- | |------------------------------|------|----------|------------------|--------|-------|----------|------| | C.I. DDAM I A. I | back | | Name | ADEO | Value | bitfield | mand | | ColorDDAModeAnd | × | ~ | Color<br>DDA | ABE0 | X | bittield | X | | ColorDDAModeOr | × | <b>/</b> | Color | ABE8 | X | bitfield | X | | | | | DDA | | | | | | AlphaTestModeAnd | × | <b>~</b> | Alpha | ABF0 | X | bitfield | X | | | | | Blend & | | | | | | | | | Alpha | | | | | | | | | Test | ADEO | | 1::0:11 | | | AlphaTestModeOr | X | <b>'</b> | Alpha<br>Blend & | ABF8 | X | bitfield | X | | | | | Alpha | | | | | | | | | Test | | | | | | AntialiasModeAnd | X | / | Alpha | AC00 | X | bitfield | X | | | ^ | | test | 11000 | A | bitticia | ^ | | AntialiasModeOr | × | ~ | Alpha | AC08 | X | bitfield | X | | | | | test | | | | | | FogModeAnd | X | <b>/</b> | Fog | AC10 | X | bitfield | X | | FogModeOr | X | <b>/</b> | Fog | AC18 | X | bitfield | X | | TextureCoordModeAnd | X | <b>/</b> | Texture | AC20 | X | | X | | | | | coord | | | | | | TextureCoordModeOr | × | <b>✓</b> | Texture | AC28 | X | bitfield | X | | | | | coord | | | | | | TextureReadMode0And | × | <b>~</b> | Texture | AC30 | X | bitfield | × | | TextureReadMode0Or | ., | | Read<br>Texture | AC38 | | bitfield | ., | | 1 exture Read Mode Or | × | <b>✓</b> | Read | AC38 | X | Dittieid | × | | TextureApplication ModeAnd | X | <b>'</b> | Texture | AC50 | X | bitfield | X | | Tenture appround in touching | ^ | | Applicati | 11030 | 14 | bittieta | ^ | | | | | on | | | | | | TextureApplication ModeOr | × | <b>'</b> | Texture | AC58 | x | bitfield | X | | | | | Applicati | | | | | | | | | on | | | | | | StencilModeAnd | × | <b>'</b> | Stencil | AC60 | X | bitfield | X | | StencilModeOr | × | <b>'</b> | Stencil | AC68 | X | bitfield | X | | DepthModeAnd | X | <b>'</b> | Depth | AC70 | X | bitfield | X | | DepthModeOr | X | <b>'</b> | Depth | AC78 | X | bitfield | X | | LBWriteModeAnd | X | <b>/</b> | LB Write | AC80 | X | bitfield | X | | LBWriteModeOr | × | <b>/</b> | LB Write | | X | bitfield | X | | FBDestReadModeAnd | × | <b>/</b> | | | X | bitfield | X | | FBDestReadModeOr | × | <b>/</b> | | AC98 | X | bitfield | X | | FBSourceReadModeAnd | × | <b>/</b> | FB Read | ACA0 | X | bitfield | X | | FBSourceReadModeOr | × | <b>/</b> | FB Read | ACA8 | X | bitfield | X | | AlphaBlendColorModeAnd | × | <b>/</b> | Alpha | ACB0 | X | bitfield | × | | | | | blend | 1.00 | | 1. 2 | | | AlphaBlendColorModeOr | × | <b>~</b> | Alpha | ACB8 | X | bitfield | × | | | | | blend | | | | | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |----------------------------|----------|----------|-----------------|--------|-------|----------|------| | | back | | Name | | Value | | mand | | ChromaTestModeAnd | X | <b>/</b> | Color | ACC0 | x | bitfield | X | | | | | DDA & | | | | | | | | | Alpha | | | | | | | | | Blend | 1.000 | | 1. 6.11 | | | ChromaTestModeOr | X | <b>'</b> | Color<br>DDA & | ACC8 | X | bitfield | × | | | | | Alpha | | | | | | | | | Blend | | | | | | DitherModeAnd | X | / | Dither | ACD0 | X | bitfield | X | | DitherModeOr | X | <b>V</b> | Dither | ACD8 | X | bitfield | X | | LogicalOpModeAnd | X | 1 | Logic | ACE0 | X | bitfield | X | | | | | Op | | | | | | LogicalOpModeOr | × | <b>/</b> | Logic | ACE8 | X | bitfield | X | | | | | Op | | | | | | FBWriteModeAnd | × | <b>'</b> | FB Write | | X | bitfield | X | | FBWriteModeOr | X | <b>'</b> | FB Write | | X | bitfield | X | | FilterModeAnd | × | <b>~</b> | Host | AD00 | X | bitfield | X | | | | | Out | | | 1. 6.11 | | | FilterModeOr | X | <b>'</b> | Host | AD08 | X | bitfield | × | | StatisticModeAnd | ., | | Out<br>Host | AD10 | | bitfield | ., | | StatisticiviodeAnd | × | • | Out | ADIO | X | bittieid | × | | StatisticModeOr | X | <b>'</b> | Host | AD18 | X | bitfield | × | | | ^ | | Out | 711010 | A . | bitticia | ^ | | FBDestReadEnablesAnd | X | <b>/</b> | | AD20 | X | bitfield | X | | FBDestReadEnablesOr | X | ~ | FB Read | AD28 | X | bitfield | X | | AlphaBlendAlphaModeAnd | × | <b>/</b> | Alpha | AD30 | X | bitfield | X | | - | | | blend | | | | | | AlphaBlendAlphaModeOr | × | <b>/</b> | Alpha | AD38 | X | bitfield | X | | | | | blend | | | | | | TextureReadMode1And | × | ~ | Texture | AD40 | X | bitfield | X | | T . D DV 140 | | | Read | A D 40 | | 1:.0:11 | | | TextureReadMode1Or | × | <b>'</b> | Texture<br>Read | AD48 | X | bitfield | × | | TextureFilterModeAnd | X | ~ | Texture | AD50 | X | bitfield | × | | TextureFilterModeOr | X | <b>'</b> | Texture | AD58 | X | bitfield | × | | LUTModeAnd | X | <b>V</b> | LUT | AD70 | X | bitfield | X | | LUTModeOr | X | <b>'</b> | LUT | AD78 | X | bitfield | × | | FBDestReadBufferAddr[03] | ~ | <b>V</b> | FB Read | AE80 | X | integer | × | | FBDestReadBufferOffset[03] | <i>'</i> | <b>V</b> | | AEA0 | X | integer | × | | FBDestReadBufferWidth[03] | <i>'</i> | <b>V</b> | FB Read | AEC0 | X | integer | × | | FBDestReadMode | <i>V</i> | <b>V</b> | FB Read | AEE0 | X | bitfield | × | | FBDestReadEnables | <i>'</i> | <b>V</b> | | AEE8 | X | bitfield | × | | FBSourceReadMode | <i>'</i> | <b>V</b> | FB Read | AF00 | X | bitfield | × | | FBSourceReadBufferAddr | <i>'</i> | <b>V</b> | FB Read | AF08 | X | integer | × | | FBSourceReadBufferOffset | <i>V</i> | <b>V</b> | FB Read | AF10 | X | integer | × | | FBSourceReadBufferWidth | i i | V | FB Read | AF18 | X | integer | | | 1 Douise Readbuilet width | <b>✓</b> | V | TD Read | 111.10 | A | uneger | X | | Name | Read | Write | | Offset | | Format | Com- | |----------------------------|----------|----------|----------------------------------|--------|-------|----------|----------| | | back | | Name | | Value | | mand | | AlphaSourceColor | <b>~</b> | ~ | Alpha<br>blend | AF80 | X | integer | × | | AlphaDestColor | ~ | ~ | Alpha<br>blend | AF88 | X | bitfield | × | | ChromaPassColor | ~ | • | Color<br>DDA &<br>Alpha<br>Blend | AF90 | X | bitfield | × | | ChromaFailColor | ~ | <b>'</b> | Color<br>DDA &<br>Alpha<br>Blend | AF98 | x | bitfield | × | | AlphaBlendColorMode | ~ | • | Alpha<br>blend | AFA0 | x | bitfield | × | | AlphaBlendAlphaMode | ~ | <b>'</b> | Alpha<br>blend | AFA8 | X | bitfield | × | | ConstantColorDDA | X | • | Color<br>DDA | AFB0 | X | bitfield | × | | FBWriteBufferAddr[03] | <b>~</b> | <b>'</b> | FB Write | | X | integer | X | | FBWriteBufferOffset[03] | <b>~</b> | <b>'</b> | FB Write | | X | integer | X | | FBWriteBufferWidth[03] | <b>✓</b> | <b>✓</b> | FB Write | B040 | X | integer | X | | FBBlockColor[03] | <b>✓</b> | <b>~</b> | FB Write | B060 | X | integer | X | | FBBlockColorBack[03] | ~ | <b>'</b> | FB Write | B080 | x | integer | X | | FBBlockColorBack | ~ | <b>/</b> | FB Write | B0A0 | X | integer | X | | SizeOfFramebuffer | ~ | <b>'</b> | LB Read,<br>FB Read,<br>FB Write | | x | integer | × | | VTGAddress | <b>✓</b> | <b>/</b> | FB Write | | X | integer | <b>✓</b> | | VTGData | <b>✓</b> | <b>~</b> | FB Write | B0B8 | X | integer | <b>~</b> | | ForegroundColor | ~ | <b>'</b> | Logic<br>Ops | B0C0 | X | integer | × | | BackgroundColor | ~ | <b>'</b> | Logic<br>Ops | B0C8 | X | integer | × | | DownloadAddress | <b>✓</b> | <b>~</b> | | B0d0 | X | integer | X | | DownloadData | <b>v</b> | <b>/</b> | | B0d8 | X | integer | X | | FogTable[015] | ~ | <b>/</b> | Fog | B100 | X | bitfield | X | | FogTable[1631] | ~ | <b>/</b> | Fog | B180 | X | bitfield | X | | FogTable[3247] | <b>'</b> | <b>/</b> | Fog | B200 | X | bitfield | × | | FogTable[4863] | <b>/</b> | <b>V</b> | Fog | B280 | X | bitfield | X | | TextureCompositeMode | ~ | ~ | Texture<br>Composi<br>te | B300 | X | bitfield | × | | TextureCompositeColorMode0 | ~ | ~ | Texture<br>Composi<br>te | B308 | X | bitfield | × | | TextureCompositeAlphaMode0 | ~ | ~ | Texture<br>Composi<br>te | B310 | X | bitfield | × | | Name | Read | Write | | Offset | | Format | Com- | |-------------------------------|----------|----------|---------|--------------|-------|----------|----------| | | back | | Name | | Value | | mand | | TextureCompositeColorMode1 | <b>✓</b> | <b>✓</b> | Texture | B318 | X | bitfield | X | | | | | Composi | | | | | | | | | te | | | | | | TextureCompositeAlphaMode1 | <b>~</b> | <b>~</b> | Texture | B320 | X | | X | | | | | Composi | | | | | | | | | te | | | | | | TextureCompositeFactor0 | <b>~</b> | <b>~</b> | Texture | B328 | X | bitfield | | | | | | Composi | | | | | | | | | te | | | | | | TextureCompositeFactor1 | <b>~</b> | <b>~</b> | Texture | B330 | X | bitfield | X | | | | | Composi | | | | | | | | | te | | | | | | TextureIndexMode0 | <b>V</b> | <b>/</b> | Texture | B338 | X | bitfield | X | | | | | Index | | | | | | TextureIndexMode1 | <b>✓</b> | <b>✓</b> | Texture | B340 | X | bitfield | X | | | | | Index | | | | | | LodRange0 | <b>V</b> | <b>/</b> | Texture | B348 | X | bitfield | X | | | | | Index | | | | | | LodRange1 | <b>/</b> | <b>/</b> | Texture | B350 | X | fixed | X | | 0 | | | Index | | | | | | InvalidateCache | X | ~ | Texture | B358 | X | bitfield | ~ | | | ^ | | Read | 2000 | | Sittiera | | | SetLogicalTexturePage | <b>'</b> | <b>/</b> | Texture | B360 | X | bitfield | X | | octhogical resturer age | | • | Read | <b>D</b> 300 | 21 | bitticia | ^ | | UpdateLogicalTextureInfo | × | <b>'</b> | Texture | B368 | X | tag | <b>'</b> | | o punte Logicai i exture into | ^ | • | Read | D300 | 21 | tag | • | | TouchLogicalPage | × | / | Texture | B370 | X | bitfield | <b>'</b> | | TouchLogican age | <b>X</b> | • | Read | D370 | Δ | bitticid | | | LUTMode | | <b>'</b> | LUT | B378 | X | bitfield | · · | | | <b>/</b> | - | | | | | X | | TextureCompositeColorMode0And | × | <b>~</b> | Texture | B380 | X | bitfield | × | | | | | Composi | | | | | | T 0 1 1 1 1 0 0 | | | te | D200 | | 1 . 6 11 | | | TextureCompositeColorMode0Or | X | <b>✓</b> | Texture | B388 | X | bitfield | X | | | | | Composi | | | | | | | | | te | | | | | | TextureCompositeAlphaMode0And | X | ~ | Texture | B390 | X | bitfield | X | | | | | Composi | | | | | | | | | te | | | | | | TextureCompositeAlphaMode0Or | X | <b>~</b> | Texture | B398 | X | bitfield | X | | | | | Composi | | | | | | | | | te | | | | | | TextureCompositeColorMode1And | X | <b>✓</b> | Texture | B3A0 | X | bitfield | X | | | | | Composi | | | | | | | | | te | | | | | | TextureCompositeColorMode1Or | X | <b>/</b> | Texture | B3A8 | X | bitfield | X | | | | | Composi | | | | | | | | | te | | | | | | TextureCompositeAlphaMode1And | X | / | Texture | B3B0 | X | bitfield | X | | | | | Composi | | | | | | | | | te | | | | | | Name | Read<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com- | |-----------------------------------------|--------------|----------|--------------------|--------|----------------|---------------------|---------------------------------------| | TextureCompositeAlphaMode1Or | | ~ | Texture | B3B8 | x | bitfield | mand | | 1 exture composite Aiphawoue 101 | X | | Composi | | A | bittieta | × | | TextureIndexMode0And | \ <u>\</u> | . 1 | te<br>Texture | B3C0 | X | bitfield | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | 1 extureriidexiviode0Aiid | × | <b>~</b> | Index | DSCO | X | bittieid | × | | TextureIndexMode0Or | × | <b>V</b> | Texture | B3C8 | X | bitfield | × | | | | | Index | | | | | | TextureIndexMode1And | × | <b>~</b> | Texture | B3D0 | X | bitfield | × | | TextureIndexMode1Or | · · | . 1 | Index<br>Texture | B3D8 | X | bitfield | V | | Textureriidexiviode101 | × | ~ | Index | DJD6 | A | Ditticia | X | | StencilDataAnd | × | <b>/</b> | Stencil | B3E0 | X | bitfield | × | | StencilDataOr | × | <b>/</b> | Stencil | B3E8 | x | bitfield | X | | TextureReadMode0 | ~ | <b>/</b> | Texture | B400 | X | bitfield | × | | W | | | Read | D 400 | | 1::0:11 | | | TextureReadMode1 | <b>'</b> | ~ | Texture<br>Read | B408 | X | bitfield | × | | TextureMapSize | <b>/</b> | <b>/</b> | Texture | B428 | X | integer | × | | | | | Read | | | 8 | | | HeadPhysicalPage Allocation[03] | ~ | <b>/</b> | Texture | B480 | X | integer | × | | // 'IDI | | | Read | DAAG | | • | | | TailPhysicalPage Allocation[03] | <b>'</b> | <b>~</b> | Texture<br>Read | B4A0 | X | integer | × | | PhysicalPageAllocationTableAddr | <b>/</b> | <b>/</b> | Texture | B4C0 | x | integer | × | | ,· | | | Read | | | 8 | | | BasePageOfWorking Set | ~ | <b>/</b> | Texture | B4C8 | X | integer | X | | T THE TOTAL PARTY | | | Read | D (D) | | • | | | LogicalTexturePage TableAddr | <b>~</b> | ~ | Texture<br>Read | B4D0 | X | integer | × | | LogicalTexturePage TableLength | <b>/</b> | <b>/</b> | Texture | B4D8 | X | integer | X | | | | | Read | | | 0 | | | BasePageOfWorking SetHost | ~ | <b>✓</b> | Texture | B4E0 | X | integer | × | | LBDestReadMode | 4 | | Read | D500 | | | | | LBDestReadEnables | <b>V</b> | <b>V</b> | LB Read<br>LB Read | | X<br>X | integer<br>bitfield | X | | LBDestReadEnables LBDestReadBufferAddr | <b>V</b> | <b>V</b> | LB Read | | X | integer | X | | LBDestReadBufferOffset | <b>V</b> | <b>V</b> | LB Read | | X | integer | | | LBSourceReadMode | <b>V</b> | <b>V</b> | LB Read | | X | integer | × | | LBSourceReadBufferAddr | <b>V</b> | <b>V</b> | LB Read | | X | integer | × | | LBSourceReadBufferOffset | <b>V</b> | <b>V</b> | LB Read | | X | bitfield | × | | GIDMode | <b>V</b> | <b>V</b> | LB Read | | X | bitfield | × | | LBWriteBufferAddr | <b>V</b> | <b>V</b> | LB Write | | X | integer | X | | LBWriteBufferOffset | <b>V</b> | <b>V</b> | LB Write | | X | integer | X | | LBClearDataL | <b>V</b> | <b>V</b> | LB Read | | X | integer | × | | LBClearDataU | <b>V</b> | <b>V</b> | LB Read | | X | integer | X | | LBDestReadModeAnd | X | <b>V</b> | LB Read | | X | bitfield | X | | LBDestReadModeOr | X | <b>V</b> | LB Read | | X | bitfield | X | | LBDestReadEnables And | × | <b>/</b> | LB Read | B590 | x | bitfield | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |----------------------|----------|----------|--------------|--------|-------|----------|------| | | back | | Name | | Value | | mand | | LBDestReadEnables Or | × | <b>/</b> | LB Read | B598 | X | bitfield | X | | LBSourceReadMode And | × | ~ | LB Read | B5A0 | X | bitfield | X | | LBSourceReadModeOr | X | <b>/</b> | LB Read | B5A8 | X | bitfield | X | | GIDModeAnd | X | <b>/</b> | LB Read | B5B0 | X | bitfield | X | | GIDModeOr | X | <b>/</b> | LB Read | B5B8 | X | bitfield | X | | ReadMonitorModeAnd | X | <b>~</b> | Delta | B5C0 | X | bitfield | X | | ReadMonitorModeOr | X | <b>~</b> | Delta | B5C8 | X | bitfield | X | | RectanglePosition | ~ | ~ | 2D Set<br>Up | B600 | X | integer | × | | GlyphPosition | ~ | <b>~</b> | 2D Set<br>Up | B608 | X | integer | X | | RenderPatchOffset | ~ | <b>'</b> | 2D Set<br>Up | B610 | X | bitfield | X | | Config2D | X | <b>/</b> | Global | B618 | X | bitfield | X | | Packed8Pixels | × | ~ | 2D Set<br>Up | B630 | x | integer | ~ | | Packed16Pixels | × | ~ | 2D Set<br>Up | B638 | x | integer | ~ | | Render2D | × | <b>'</b> | 2D Set<br>Up | B640 | X | bitfield | X | | Render2DGlyph | × | <b>'</b> | 2D Set<br>Up | B648 | X | bitfield | X | | DownloadTarget | ~ | <b>'</b> | 2D Set<br>Up | B650 | X | | ~ | | DownloadGlyphWidth | ~ | <b>'</b> | 2D Set<br>Up | B658 | x | integer | X | | GlyphData | × | <b>'</b> | 2D Set<br>Up | B660 | x | integer | X | | Packed4Pixels | × | <b>'</b> | 2D Set<br>Up | B668 | x | integer | ~ | | RLData | ~ | <b>'</b> | 2D Set<br>Up | B670 | x | integer | × | | RLCount | × | <b>'</b> | 2D Set<br>Up | B678 | X | integer | X | | IndexBaseAddress | <b>✓</b> | <b>/</b> | Host In | B700 | X | integer | X | | VertexBaseAddress | <b>✓</b> | <b>/</b> | Host In | B708 | X | integer | X | | IndexedTriangleList | × | <b>/</b> | Host In | B710 | X | integer | X | | IndexedTriangleFan | × | <b>'</b> | Host In | B718 | x | integer | X | | IndexedTriangleStrip | × | <b>'</b> | Host In | B720 | X | integer | X | | IndexedLineList | × | <b>/</b> | Host In | B728 | X | integer | X | | IndexedLineStrip | × | <b>/</b> | Host In | B730 | X | integer | × | | IndexedPointList | × | <b>'</b> | Host In | B738 | X | integer | × | | IndexedPolygon | × | <b>'</b> | Host In | B740 | X | integer | X | | VertexTriangleList | × | <b>'</b> | Host In | B748 | X | integer | X | | VertexTriangleFan | × | <b>'</b> | Host In | B750 | X | integer | X | | VertexTriangleStrip | × | <b>'</b> | Host In | B758 | X | integer | X | | VertexLineList | × | <b>'</b> | Host In | B760 | X | integer | X | | VertexLineStrip | × | <b>✓</b> | Host In | B768 | X | integer | X | | Name | Read | Write | Unit | Offset | Reset | Format | Com- | |-------------------------|----------|----------|---------|--------|-------|----------|----------| | | back | | Name | | Value | | mand | | VertexPointList | X | ~ | Host In | B770 | x | integer | X | | VertexPolygon | X | <b>/</b> | Host In | B778 | X | integer | X | | <b>DMAMemoryControl</b> | <b>/</b> | <b>/</b> | Host In | B780 | X | bitfield | X | | VertexValid | <b>/</b> | <b>/</b> | Host In | B788 | X | integer | X | | VertexFormat | <b>/</b> | / | Host In | B790 | X | integer | X | | VertexControl | V | ~ | Host In | B798 | X | bitfield | X | | RetainedRender | V | ~ | Host In | B7A0 | X | bitfield | <b>/</b> | | IndexedVertex | X | ~ | Host In | B7A8 | X | integer | X | | IndexedDoubleVertex | X | ~ | Host In | B7B0 | X | integer | X | | Vertex0 | X | ~ | Host In | B7B8 | X | integer | X | | Vertex1 | X | ~ | Host In | B7C0 | X | integer | X | | Vertex2 | X | ~ | Host In | B7C8 | X | integer | X | | VertexData0 | X | ~ | Host In | B7D0 | X | integer | X | | VertexData1 | X | ~ | Host In | B7D8 | X | integer | X | | VertexData2 | X | ~ | Host In | B7E0 | X | integer | X | | VertexData | × | ~ | Host In | B7E8 | X | integer | X | | VertexTagList[015] | V | ~ | Host In | B800 | X | bitfield | X | | VertexTagList[1631] | V | ~ | Host In | B880 | X | bitfield | X | ## INDEX | Area Stippling | 5-11 | |--------------------|--------------------------| | AreaStippleMode | 5-11 | | BorderColor | 5-16 | | CFGCommand | 5-43 | | context data | 5-24 | | ContextData | 5-24 | | DMACount | .5-42, 5-43, <b>5-90</b> | | DMAFeedback | | | DMAOutputAddress | 5-43, 5-45 | | DrawTriangle | 5-135, 5-136 | | EndOfFeedback | <i>5-43</i> , 5-62 | | FilterMode | 5-45, <b>5-62</b> | | Graphics Registers | 5-1 | | LineStippleMode | 5 107 | | Directippiemode | 3-10/ | | Point Size Table | 5-2 | |--------------------------------------------|---------| | Register Cross Reference | 6-1 | | Registers Alphabetically Sorted | 6-1 | | Registers Sorted by Offset | 6-22 | | Render | 5-49 | | RestoreContext | 5-24 | | Stencil | . 5-145 | | StencilData | . 5-146 | | Table 1 – Update Method if Stencil Test fa | ails 5 | | 147 | | | Table 2 - Unsigned Comparison Function. | . 5-147 | | UpdateLineStippleCounters | . 5-107 | | W/:1 | 5 145 |