| <?xml version="1.0" encoding="UTF-8"?> |
| <database xmlns="http://nouveau.freedesktop.org/" |
| xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
| xsi:schemaLocation="http://nouveau.freedesktop.org/ rules-ng.xsd"> |
| |
| <enum name="chip" bare="yes"> |
| <value name="A2XX"/> |
| <value name="A3XX"/> |
| <value name="A4XX"/> |
| <value name="A5XX"/> |
| <value name="A6XX"/> |
| </enum> |
| |
| <enum name="adreno_pa_su_sc_draw"> |
| <value name="PC_DRAW_POINTS" value="0"/> |
| <value name="PC_DRAW_LINES" value="1"/> |
| <value name="PC_DRAW_TRIANGLES" value="2"/> |
| </enum> |
| |
| <enum name="adreno_compare_func"> |
| <value name="FUNC_NEVER" value="0"/> |
| <value name="FUNC_LESS" value="1"/> |
| <value name="FUNC_EQUAL" value="2"/> |
| <value name="FUNC_LEQUAL" value="3"/> |
| <value name="FUNC_GREATER" value="4"/> |
| <value name="FUNC_NOTEQUAL" value="5"/> |
| <value name="FUNC_GEQUAL" value="6"/> |
| <value name="FUNC_ALWAYS" value="7"/> |
| </enum> |
| |
| <enum name="adreno_stencil_op"> |
| <value name="STENCIL_KEEP" value="0"/> |
| <value name="STENCIL_ZERO" value="1"/> |
| <value name="STENCIL_REPLACE" value="2"/> |
| <value name="STENCIL_INCR_CLAMP" value="3"/> |
| <value name="STENCIL_DECR_CLAMP" value="4"/> |
| <value name="STENCIL_INVERT" value="5"/> |
| <value name="STENCIL_INCR_WRAP" value="6"/> |
| <value name="STENCIL_DECR_WRAP" value="7"/> |
| </enum> |
| |
| <enum name="adreno_rb_blend_factor"> |
| <value name="FACTOR_ZERO" value="0"/> |
| <value name="FACTOR_ONE" value="1"/> |
| <value name="FACTOR_SRC_COLOR" value="4"/> |
| <value name="FACTOR_ONE_MINUS_SRC_COLOR" value="5"/> |
| <value name="FACTOR_SRC_ALPHA" value="6"/> |
| <value name="FACTOR_ONE_MINUS_SRC_ALPHA" value="7"/> |
| <value name="FACTOR_DST_COLOR" value="8"/> |
| <value name="FACTOR_ONE_MINUS_DST_COLOR" value="9"/> |
| <value name="FACTOR_DST_ALPHA" value="10"/> |
| <value name="FACTOR_ONE_MINUS_DST_ALPHA" value="11"/> |
| <value name="FACTOR_CONSTANT_COLOR" value="12"/> |
| <value name="FACTOR_ONE_MINUS_CONSTANT_COLOR" value="13"/> |
| <value name="FACTOR_CONSTANT_ALPHA" value="14"/> |
| <value name="FACTOR_ONE_MINUS_CONSTANT_ALPHA" value="15"/> |
| <value name="FACTOR_SRC_ALPHA_SATURATE" value="16"/> |
| <value name="FACTOR_SRC1_COLOR" value="20"/> |
| <value name="FACTOR_ONE_MINUS_SRC1_COLOR" value="21"/> |
| <value name="FACTOR_SRC1_ALPHA" value="22"/> |
| <value name="FACTOR_ONE_MINUS_SRC1_ALPHA" value="23"/> |
| </enum> |
| |
| <bitset name="adreno_rb_stencilrefmask" inline="yes"> |
| <bitfield name="STENCILREF" low="0" high="7" type="hex"/> |
| <bitfield name="STENCILMASK" low="8" high="15" type="hex"/> |
| <bitfield name="STENCILWRITEMASK" low="16" high="23" type="hex"/> |
| </bitset> |
| |
| <enum name="adreno_rb_surface_endian"> |
| <value name="ENDIAN_NONE" value="0"/> |
| <value name="ENDIAN_8IN16" value="1"/> |
| <value name="ENDIAN_8IN32" value="2"/> |
| <value name="ENDIAN_16IN32" value="3"/> |
| <value name="ENDIAN_8IN64" value="4"/> |
| <value name="ENDIAN_8IN128" value="5"/> |
| </enum> |
| |
| <enum name="adreno_rb_dither_mode"> |
| <value name="DITHER_DISABLE" value="0"/> |
| <value name="DITHER_ALWAYS" value="1"/> |
| <value name="DITHER_IF_ALPHA_OFF" value="2"/> |
| </enum> |
| |
| <enum name="adreno_rb_depth_format"> |
| <value name="DEPTHX_16" value="0"/> |
| <value name="DEPTHX_24_8" value="1"/> |
| <value name="DEPTHX_32" value="2"/> |
| </enum> |
| |
| <enum name="adreno_rb_copy_control_mode"> |
| <value name="RB_COPY_RESOLVE" value="1"/> |
| <value name="RB_COPY_CLEAR" value="2"/> |
| <value name="RB_COPY_DEPTH_STENCIL" value="5"/> <!-- not sure if this is part of MODE or another bitfield?? --> |
| </enum> |
| |
| <bitset name="adreno_reg_xy" inline="yes"> |
| <bitfield name="WINDOW_OFFSET_DISABLE" pos="31" type="boolean"/> |
| <bitfield name="X" low="0" high="14" type="uint"/> |
| <bitfield name="Y" low="16" high="30" type="uint"/> |
| </bitset> |
| |
| <bitset name="adreno_cp_protect" inline="yes"> |
| <bitfield name="BASE_ADDR" low="0" high="16"/> |
| <bitfield name="MASK_LEN" low="24" high="28"/> |
| <bitfield name="TRAP_WRITE" pos="29"/> |
| <bitfield name="TRAP_READ" pos="30"/> |
| </bitset> |
| |
| <domain name="AXXX" width="32"> |
| <brief>Registers in common between a2xx and a3xx</brief> |
| |
| <reg32 offset="0x01c0" name="CP_RB_BASE"/> |
| <reg32 offset="0x01c1" name="CP_RB_CNTL"> |
| <bitfield name="BUFSZ" low="0" high="5"/> |
| <bitfield name="BLKSZ" low="8" high="13"/> |
| <bitfield name="BUF_SWAP" low="16" high="17"/> |
| <bitfield name="POLL_EN" pos="20" type="boolean"/> |
| <bitfield name="NO_UPDATE" pos="27" type="boolean"/> |
| <bitfield name="RPTR_WR_EN" pos="31" type="boolean"/> |
| </reg32> |
| <reg32 offset="0x01c3" name="CP_RB_RPTR_ADDR"> |
| <bitfield name="SWAP" low="0" high="1" type="uint"/> |
| <bitfield name="ADDR" low="2" high="31" shr="2"/> |
| </reg32> |
| <reg32 offset="0x01c4" name="CP_RB_RPTR" type="uint"/> |
| <reg32 offset="0x01c5" name="CP_RB_WPTR" type="uint"/> |
| <reg32 offset="0x01c6" name="CP_RB_WPTR_DELAY"/> |
| <reg32 offset="0x01c7" name="CP_RB_RPTR_WR"/> |
| <reg32 offset="0x01c8" name="CP_RB_WPTR_BASE"/> |
| <reg32 offset="0x01d5" name="CP_QUEUE_THRESHOLDS"> |
| <bitfield name="CSQ_IB1_START" low="0" high="3" type="uint"/> |
| <bitfield name="CSQ_IB2_START" low="8" high="11" type="uint"/> |
| <bitfield name="CSQ_ST_START" low="16" high="19" type="uint"/> |
| </reg32> |
| <reg32 offset="0x01d6" name="CP_MEQ_THRESHOLDS"> |
| <bitfield name="MEQ_END" low="16" high="20" type="uint"/> |
| <bitfield name="ROQ_END" low="24" high="28" type="uint"/> |
| </reg32> |
| <reg32 offset="0x01d7" name="CP_CSQ_AVAIL"> |
| <bitfield name="RING" low="0" high="6" type="uint"/> |
| <bitfield name="IB1" low="8" high="14" type="uint"/> |
| <bitfield name="IB2" low="16" high="22" type="uint"/> |
| </reg32> |
| <reg32 offset="0x01d8" name="CP_STQ_AVAIL"> |
| <bitfield name="ST" low="0" high="6" type="uint"/> |
| </reg32> |
| <reg32 offset="0x01d9" name="CP_MEQ_AVAIL"> |
| <bitfield name="MEQ" low="0" high="4" type="uint"/> |
| </reg32> |
| <reg32 offset="0x01dc" name="SCRATCH_UMSK"> |
| <bitfield name="UMSK" low="0" high="7" type="uint"/> |
| <bitfield name="SWAP" low="16" high="17" type="uint"/> |
| </reg32> |
| <reg32 offset="0x01dd" name="SCRATCH_ADDR"/> |
| <reg32 offset="0x01ea" name="CP_ME_RDADDR"/> |
| |
| <reg32 offset="0x01ec" name="CP_STATE_DEBUG_INDEX"/> |
| <reg32 offset="0x01ed" name="CP_STATE_DEBUG_DATA"/> |
| <reg32 offset="0x01f2" name="CP_INT_CNTL"> |
| <bitfield name="SW_INT_MASK" pos="19" type="boolean"/> |
| <bitfield name="T0_PACKET_IN_IB_MASK" pos="23" type="boolean"/> |
| <bitfield name="OPCODE_ERROR_MASK" pos="24" type="boolean"/> |
| <bitfield name="PROTECTED_MODE_ERROR_MASK" pos="25" type="boolean"/> |
| <bitfield name="RESERVED_BIT_ERROR_MASK" pos="26" type="boolean"/> |
| <bitfield name="IB_ERROR_MASK" pos="27" type="boolean"/> |
| <bitfield name="IB2_INT_MASK" pos="29" type="boolean"/> |
| <bitfield name="IB1_INT_MASK" pos="30" type="boolean"/> |
| <bitfield name="RB_INT_MASK" pos="31" type="boolean"/> |
| </reg32> |
| <reg32 offset="0x01f3" name="CP_INT_STATUS"/> |
| <reg32 offset="0x01f4" name="CP_INT_ACK"/> |
| <reg32 offset="0x01f6" name="CP_ME_CNTL"> |
| <bitfield name="BUSY" pos="29" type="boolean"/> |
| <bitfield name="HALT" pos="28" type="boolean"/> |
| </reg32> |
| <reg32 offset="0x01f7" name="CP_ME_STATUS"/> |
| <reg32 offset="0x01f8" name="CP_ME_RAM_WADDR"/> |
| <reg32 offset="0x01f9" name="CP_ME_RAM_RADDR"/> |
| <reg32 offset="0x01fa" name="CP_ME_RAM_DATA"/> |
| <reg32 offset="0x01fc" name="CP_DEBUG"> |
| <bitfield name="PREDICATE_DISABLE" pos="23" type="boolean"/> |
| <bitfield name="PROG_END_PTR_ENABLE" pos="24" type="boolean"/> |
| <bitfield name="MIU_128BIT_WRITE_ENABLE" pos="25" type="boolean"/> |
| <bitfield name="PREFETCH_PASS_NOPS" pos="26" type="boolean"/> |
| <bitfield name="DYNAMIC_CLK_DISABLE" pos="27" type="boolean"/> |
| <bitfield name="PREFETCH_MATCH_DISABLE" pos="28" type="boolean"/> |
| <bitfield name="SIMPLE_ME_FLOW_CONTROL" pos="30" type="boolean"/> |
| <bitfield name="MIU_WRITE_PACK_DISABLE" pos="31" type="boolean"/> |
| </reg32> |
| <reg32 offset="0x01fd" name="CP_CSQ_RB_STAT"> |
| <bitfield name="RPTR" low="0" high="6" type="uint"/> |
| <bitfield name="WPTR" low="16" high="22" type="uint"/> |
| </reg32> |
| <reg32 offset="0x01fe" name="CP_CSQ_IB1_STAT"> |
| <bitfield name="RPTR" low="0" high="6" type="uint"/> |
| <bitfield name="WPTR" low="16" high="22" type="uint"/> |
| </reg32> |
| <reg32 offset="0x01ff" name="CP_CSQ_IB2_STAT"> |
| <bitfield name="RPTR" low="0" high="6" type="uint"/> |
| <bitfield name="WPTR" low="16" high="22" type="uint"/> |
| </reg32> |
| |
| <reg32 offset="0x0440" name="CP_NON_PREFETCH_CNTRS"/> |
| <reg32 offset="0x0443" name="CP_STQ_ST_STAT"/> |
| <reg32 offset="0x044d" name="CP_ST_BASE"/> |
| <reg32 offset="0x044e" name="CP_ST_BUFSZ"/> |
| <reg32 offset="0x044f" name="CP_MEQ_STAT"/> |
| <reg32 offset="0x0452" name="CP_MIU_TAG_STAT"/> |
| <reg32 offset="0x0454" name="CP_BIN_MASK_LO"/> |
| <reg32 offset="0x0455" name="CP_BIN_MASK_HI"/> |
| <reg32 offset="0x0456" name="CP_BIN_SELECT_LO"/> |
| <reg32 offset="0x0457" name="CP_BIN_SELECT_HI"/> |
| <reg32 offset="0x0458" name="CP_IB1_BASE"/> |
| <reg32 offset="0x0459" name="CP_IB1_BUFSZ"/> |
| <reg32 offset="0x045a" name="CP_IB2_BASE"/> |
| <reg32 offset="0x045b" name="CP_IB2_BUFSZ"/> |
| <reg32 offset="0x047f" name="CP_STAT"> |
| <bitfield pos="31" name="CP_BUSY"/> |
| <bitfield pos="30" name="VS_EVENT_FIFO_BUSY"/> |
| <bitfield pos="29" name="PS_EVENT_FIFO_BUSY"/> |
| <bitfield pos="28" name="CF_EVENT_FIFO_BUSY"/> |
| <bitfield pos="27" name="RB_EVENT_FIFO_BUSY"/> |
| <bitfield pos="26" name="ME_BUSY"/> |
| <bitfield pos="25" name="MIU_WR_C_BUSY"/> |
| <bitfield pos="23" name="CP_3D_BUSY"/> |
| <bitfield pos="22" name="CP_NRT_BUSY"/> |
| <bitfield pos="21" name="RBIU_SCRATCH_BUSY"/> |
| <bitfield pos="20" name="RCIU_ME_BUSY"/> |
| <bitfield pos="19" name="RCIU_PFP_BUSY"/> |
| <bitfield pos="18" name="MEQ_RING_BUSY"/> |
| <bitfield pos="17" name="PFP_BUSY"/> |
| <bitfield pos="16" name="ST_QUEUE_BUSY"/> |
| <bitfield pos="13" name="INDIRECT2_QUEUE_BUSY"/> |
| <bitfield pos="12" name="INDIRECTS_QUEUE_BUSY"/> |
| <bitfield pos="11" name="RING_QUEUE_BUSY"/> |
| <bitfield pos="10" name="CSF_BUSY"/> |
| <bitfield pos="9" name="CSF_ST_BUSY"/> |
| <bitfield pos="8" name="EVENT_BUSY"/> |
| <bitfield pos="7" name="CSF_INDIRECT2_BUSY"/> |
| <bitfield pos="6" name="CSF_INDIRECTS_BUSY"/> |
| <bitfield pos="5" name="CSF_RING_BUSY"/> |
| <bitfield pos="4" name="RCIU_BUSY"/> |
| <bitfield pos="3" name="RBIU_BUSY"/> |
| <bitfield pos="2" name="MIU_RD_RETURN_BUSY"/> |
| <bitfield pos="1" name="MIU_RD_REQ_BUSY"/> |
| <bitfield pos="0" name="MIU_WR_BUSY"/> |
| </reg32> |
| <reg32 offset="0x0578" name="CP_SCRATCH_REG0" type="uint"/> |
| <reg32 offset="0x0579" name="CP_SCRATCH_REG1" type="uint"/> |
| <reg32 offset="0x057a" name="CP_SCRATCH_REG2" type="uint"/> |
| <reg32 offset="0x057b" name="CP_SCRATCH_REG3" type="uint"/> |
| <reg32 offset="0x057c" name="CP_SCRATCH_REG4" type="uint"/> |
| <reg32 offset="0x057d" name="CP_SCRATCH_REG5" type="uint"/> |
| <reg32 offset="0x057e" name="CP_SCRATCH_REG6" type="uint"/> |
| <reg32 offset="0x057f" name="CP_SCRATCH_REG7" type="uint"/> |
| |
| <reg32 offset="0x0600" name="CP_ME_VS_EVENT_SRC"/> |
| <reg32 offset="0x0601" name="CP_ME_VS_EVENT_ADDR"/> |
| <reg32 offset="0x0602" name="CP_ME_VS_EVENT_DATA"/> |
| <reg32 offset="0x0603" name="CP_ME_VS_EVENT_ADDR_SWM"/> |
| <reg32 offset="0x0604" name="CP_ME_VS_EVENT_DATA_SWM"/> |
| <reg32 offset="0x0605" name="CP_ME_PS_EVENT_SRC"/> |
| <reg32 offset="0x0606" name="CP_ME_PS_EVENT_ADDR"/> |
| <reg32 offset="0x0607" name="CP_ME_PS_EVENT_DATA"/> |
| <reg32 offset="0x0608" name="CP_ME_PS_EVENT_ADDR_SWM"/> |
| <reg32 offset="0x0609" name="CP_ME_PS_EVENT_DATA_SWM"/> |
| <reg32 offset="0x060a" name="CP_ME_CF_EVENT_SRC"/> |
| <reg32 offset="0x060b" name="CP_ME_CF_EVENT_ADDR"/> |
| <reg32 offset="0x060c" name="CP_ME_CF_EVENT_DATA" type="uint"/> |
| <reg32 offset="0x060d" name="CP_ME_NRT_ADDR"/> |
| <reg32 offset="0x060e" name="CP_ME_NRT_DATA"/> |
| <reg32 offset="0x0612" name="CP_ME_VS_FETCH_DONE_SRC"/> |
| <reg32 offset="0x0613" name="CP_ME_VS_FETCH_DONE_ADDR"/> |
| <reg32 offset="0x0614" name="CP_ME_VS_FETCH_DONE_DATA"/> |
| |
| </domain> |
| |
| <!-- |
| Common between A3xx and A4xx: |
| --> |
| |
| <enum name="a3xx_regid"> |
| <value name="REGID_UNUSED" value="0xfc"/> |
| </enum> |
| |
| <enum name="a3xx_rop_code"> |
| <value name="ROP_CLEAR" value="0"/> |
| <value name="ROP_NOR" value="1"/> |
| <value name="ROP_AND_INVERTED" value="2"/> |
| <value name="ROP_COPY_INVERTED" value="3"/> |
| <value name="ROP_AND_REVERSE" value="4"/> |
| <value name="ROP_INVERT" value="5"/> |
| <value name="ROP_XOR" value="6"/> |
| <value name="ROP_NAND" value="7"/> |
| <value name="ROP_AND" value="8"/> |
| <value name="ROP_EQUIV" value="9"/> |
| <value name="ROP_NOOP" value="10"/> |
| <value name="ROP_OR_INVERTED" value="11"/> |
| <value name="ROP_COPY" value="12"/> |
| <value name="ROP_OR_REVERSE" value="13"/> |
| <value name="ROP_OR" value="14"/> |
| <value name="ROP_SET" value="15"/> |
| </enum> |
| |
| <enum name="a3xx_render_mode"> |
| <value name="RB_RENDERING_PASS" value="0"/> |
| <value name="RB_TILING_PASS" value="1"/> |
| <value name="RB_RESOLVE_PASS" value="2"/> |
| <value name="RB_COMPUTE_PASS" value="3"/> |
| </enum> |
| |
| <enum name="a3xx_msaa_samples"> |
| <value name="MSAA_ONE" value="0"/> |
| <value name="MSAA_TWO" value="1"/> |
| <value name="MSAA_FOUR" value="2"/> |
| <value name="MSAA_EIGHT" value="3"/> |
| </enum> |
| |
| <enum name="a3xx_threadmode"> |
| <value value="0" name="MULTI"/> |
| <value value="1" name="SINGLE"/> |
| </enum> |
| |
| <enum name="a3xx_instrbuffermode"> |
| <!-- |
| When shader size goes above ~128 or so, blob switches to '0' |
| and doesn't emit shader in cmdstream. When either is '0' it |
| doesn't get emitted via CP_LOAD_STATE. When only one is |
| '0' the other gets size 256-others_size. So I think that: |
| BUFFER => execute out of state memory |
| CACHE => use available state memory as local cache |
| NOTE that when CACHE mode, also set CACHEINVALID flag! |
| |
| TODO check if that 256 size is same for all a3xx |
| --> |
| <value value="0" name="CACHE"/> |
| <value value="1" name="BUFFER"/> |
| </enum> |
| |
| <enum name="a3xx_threadsize"> |
| <value value="0" name="TWO_QUADS"/> |
| <value value="1" name="FOUR_QUADS"/> |
| </enum> |
| |
| <enum name="a3xx_color_swap"> |
| <value name="WZYX" value="0"/> |
| <value name="WXYZ" value="1"/> |
| <value name="ZYXW" value="2"/> |
| <value name="XYZW" value="3"/> |
| </enum> |
| |
| <enum name="a3xx_rb_blend_opcode"> |
| <value name="BLEND_DST_PLUS_SRC" value="0"/> |
| <value name="BLEND_SRC_MINUS_DST" value="1"/> |
| <value name="BLEND_DST_MINUS_SRC" value="2"/> |
| <value name="BLEND_MIN_DST_SRC" value="3"/> |
| <value name="BLEND_MAX_DST_SRC" value="4"/> |
| </enum> |
| |
| <enum name="a4xx_tess_spacing"> |
| <value name="EQUAL_SPACING" value="0"/> |
| <value name="ODD_SPACING" value="2"/> |
| <value name="EVEN_SPACING" value="3"/> |
| </enum> |
| |
| </database> |
| |