Clone of mesa.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

gen75.xml 172KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065
  1. <?xml version="1.0" ?>
  2. <genxml name="HSW" gen="7.5">
  3. <enum name="3D_Prim_Topo_Type" prefix="3DPRIM">
  4. <value name="POINTLIST" value="1"/>
  5. <value name="LINELIST" value="2"/>
  6. <value name="LINESTRIP" value="3"/>
  7. <value name="TRILIST" value="4"/>
  8. <value name="TRISTRIP" value="5"/>
  9. <value name="TRIFAN" value="6"/>
  10. <value name="QUADLIST" value="7"/>
  11. <value name="QUADSTRIP" value="8"/>
  12. <value name="LINELIST_ADJ" value="9"/>
  13. <value name="LINESTRIP_ADJ" value="10"/>
  14. <value name="TRILIST_ADJ" value="11"/>
  15. <value name="TRISTRIP_ADJ" value="12"/>
  16. <value name="TRISTRIP_REVERSE" value="13"/>
  17. <value name="POLYGON" value="14"/>
  18. <value name="RECTLIST" value="15"/>
  19. <value name="LINELOOP" value="16"/>
  20. <value name="POINTLIST _BF" value="17"/>
  21. <value name="LINESTRIP_CONT" value="18"/>
  22. <value name="LINESTRIP_BF" value="19"/>
  23. <value name="LINESTRIP_CONT_BF" value="20"/>
  24. <value name="TRIFAN_NOSTIPPLE" value="22"/>
  25. <value name="PATCHLIST_1" value="32"/>
  26. <value name="PATCHLIST_2" value="33"/>
  27. <value name="PATCHLIST_3" value="34"/>
  28. <value name="PATCHLIST_4" value="35"/>
  29. <value name="PATCHLIST_5" value="36"/>
  30. <value name="PATCHLIST_6" value="37"/>
  31. <value name="PATCHLIST_7" value="38"/>
  32. <value name="PATCHLIST_8" value="39"/>
  33. <value name="PATCHLIST_9" value="40"/>
  34. <value name="PATCHLIST_10" value="41"/>
  35. <value name="PATCHLIST_11" value="42"/>
  36. <value name="PATCHLIST_12" value="43"/>
  37. <value name="PATCHLIST_13" value="44"/>
  38. <value name="PATCHLIST_14" value="45"/>
  39. <value name="PATCHLIST_15" value="46"/>
  40. <value name="PATCHLIST_16" value="47"/>
  41. <value name="PATCHLIST_17" value="48"/>
  42. <value name="PATCHLIST_18" value="49"/>
  43. <value name="PATCHLIST_19" value="50"/>
  44. <value name="PATCHLIST_20" value="51"/>
  45. <value name="PATCHLIST_21" value="52"/>
  46. <value name="PATCHLIST_22" value="53"/>
  47. <value name="PATCHLIST_23" value="54"/>
  48. <value name="PATCHLIST_24" value="55"/>
  49. <value name="PATCHLIST_25" value="56"/>
  50. <value name="PATCHLIST_26" value="57"/>
  51. <value name="PATCHLIST_27" value="58"/>
  52. <value name="PATCHLIST_28" value="59"/>
  53. <value name="PATCHLIST_29" value="60"/>
  54. <value name="PATCHLIST_30" value="61"/>
  55. <value name="PATCHLIST_31" value="62"/>
  56. <value name="PATCHLIST_32" value="63"/>
  57. </enum>
  58. <enum name="3D_Vertex_Component_Control" prefix="VFCOMP">
  59. <value name="NOSTORE" value="0"/>
  60. <value name="STORE_SRC" value="1"/>
  61. <value name="STORE_0" value="2"/>
  62. <value name="STORE_1_FP" value="3"/>
  63. <value name="STORE_1_INT" value="4"/>
  64. <value name="STORE_VID" value="5"/>
  65. <value name="STORE_IID" value="6"/>
  66. <value name="STORE_PID" value="7"/>
  67. </enum>
  68. <enum name="3D_Stencil_Operation" prefix="STENCILOP">
  69. <value name="KEEP" value="0"/>
  70. <value name="ZERO" value="1"/>
  71. <value name="REPLACE" value="2"/>
  72. <value name="INCRSAT" value="3"/>
  73. <value name="DECRSAT" value="4"/>
  74. <value name="INCR" value="5"/>
  75. <value name="DECR" value="6"/>
  76. <value name="INVERT" value="7"/>
  77. </enum>
  78. <enum name="3D_Color_Buffer_Blend_Factor" prefix="BLENDFACTOR">
  79. <value name="ONE" value="1"/>
  80. <value name="SRC_COLOR" value="2"/>
  81. <value name="SRC_ALPHA" value="3"/>
  82. <value name="DST_ALPHA" value="4"/>
  83. <value name="DST_COLOR" value="5"/>
  84. <value name="SRC_ALPHA_SATURATE" value="6"/>
  85. <value name="CONST_COLOR" value="7"/>
  86. <value name="CONST_ALPHA" value="8"/>
  87. <value name="SRC1_COLOR" value="9"/>
  88. <value name="SRC1_ALPHA" value="10"/>
  89. <value name="ZERO" value="17"/>
  90. <value name="INV_SRC_COLOR" value="18"/>
  91. <value name="INV_SRC_ALPHA" value="19"/>
  92. <value name="INV_DST_ALPHA" value="20"/>
  93. <value name="INV_DST_COLOR" value="21"/>
  94. <value name="INV_CONST_COLOR" value="23"/>
  95. <value name="INV_CONST_ALPHA" value="24"/>
  96. <value name="INV_SRC1_COLOR" value="25"/>
  97. <value name="INV_SRC1_ALPHA" value="26"/>
  98. </enum>
  99. <enum name="3D_Color_Buffer_Blend_Function" prefix="BLENDFUNCTION">
  100. <value name="ADD" value="0"/>
  101. <value name="SUBTRACT" value="1"/>
  102. <value name="REVERSE_SUBTRACT" value="2"/>
  103. <value name="MIN" value="3"/>
  104. <value name="MAX" value="4"/>
  105. </enum>
  106. <enum name="3D_Compare_Function" prefix="COMPAREFUNCTION">
  107. <value name="ALWAYS" value="0"/>
  108. <value name="NEVER" value="1"/>
  109. <value name="LESS" value="2"/>
  110. <value name="EQUAL" value="3"/>
  111. <value name="LEQUAL" value="4"/>
  112. <value name="GREATER" value="5"/>
  113. <value name="NOTEQUAL" value="6"/>
  114. <value name="GEQUAL" value="7"/>
  115. </enum>
  116. <enum name="3D_Logic_Op_Function" prefix="LOGICOP">
  117. <value name="CLEAR" value="0"/>
  118. <value name="NOR" value="1"/>
  119. <value name="AND_INVERTED" value="2"/>
  120. <value name="COPY_INVERTED" value="3"/>
  121. <value name="AND_REVERSE" value="4"/>
  122. <value name="INVERT" value="5"/>
  123. <value name="XOR" value="6"/>
  124. <value name="NAND" value="7"/>
  125. <value name="AND" value="8"/>
  126. <value name="EQUIV" value="9"/>
  127. <value name="NOOP" value="10"/>
  128. <value name="OR_INVERTED" value="11"/>
  129. <value name="COPY" value="12"/>
  130. <value name="OR_REVERSE" value="13"/>
  131. <value name="OR" value="14"/>
  132. <value name="SET" value="15"/>
  133. </enum>
  134. <enum name="Shader Channel Select" prefix="SCS">
  135. <value name="ZERO" value="0"/>
  136. <value name="ONE" value="1"/>
  137. <value name="RED" value="4"/>
  138. <value name="GREEN" value="5"/>
  139. <value name="BLUE" value="6"/>
  140. <value name="ALPHA" value="7"/>
  141. </enum>
  142. <enum name="Texture Coordinate Mode" prefix="TCM">
  143. <value name="WRAP" value="0"/>
  144. <value name="MIRROR" value="1"/>
  145. <value name="CLAMP" value="2"/>
  146. <value name="CUBE" value="3"/>
  147. <value name="CLAMP_BORDER" value="4"/>
  148. <value name="MIRROR_ONCE" value="5"/>
  149. </enum>
  150. <struct name="MEMORY_OBJECT_CONTROL_STATE" length="1">
  151. <field name="LLC/eLLC Cacheability Control (LLCCC)" start="1" end="2" type="uint"/>
  152. <field name="L3 Cacheability Control (L3CC)" start="0" end="0" type="uint"/>
  153. </struct>
  154. <struct name="3DSTATE_CONSTANT_BODY" length="6">
  155. <group count="4" start="0" size="16">
  156. <field name="Read Length" start="0" end="15" type="uint"/>
  157. </group>
  158. <field name="Constant Buffer Object Control State" start="64" end="68" type="MEMORY_OBJECT_CONTROL_STATE"/>
  159. <group count="4" start="64" size="32">
  160. <field name="Buffer" start="5" end="31" type="address"/>
  161. </group>
  162. </struct>
  163. <struct name="BINDING_TABLE_EDIT_ENTRY" length="1">
  164. <field name="Binding Table Index" start="16" end="23" type="uint"/>
  165. <field name="Surface State Pointer" start="0" end="15" type="offset"/>
  166. </struct>
  167. <struct name="GATHER_CONSTANT_ENTRY" length="1">
  168. <field name="Constant Buffer Offset" start="8" end="15" type="offset"/>
  169. <field name="Channel Mask" start="4" end="7" type="uint"/>
  170. <field name="Binding Table Index Offset" start="0" end="3" type="uint"/>
  171. </struct>
  172. <struct name="VERTEX_BUFFER_STATE" length="4">
  173. <field name="Vertex Buffer Index" start="26" end="31" type="uint"/>
  174. <field name="Buffer Access Type" start="20" end="20" type="uint">
  175. <value name="VERTEXDATA" value="0"/>
  176. <value name="INSTANCEDATA" value="1"/>
  177. </field>
  178. <field name="Vertex Buffer Memory Object Control State" start="16" end="19" type="MEMORY_OBJECT_CONTROL_STATE"/>
  179. <field name="Vertex Buffer MOCS" start="16" end="19" type="uint"/>
  180. <field name="Address Modify Enable" start="14" end="14" type="bool"/>
  181. <field name="Null Vertex Buffer" start="13" end="13" type="bool"/>
  182. <field name="Vertex Fetch Invalidate" start="12" end="12" type="bool" default="0"/>
  183. <field name="Buffer Pitch" start="0" end="11" type="uint"/>
  184. <field name="Buffer Starting Address" start="32" end="63" type="address"/>
  185. <field name="End Address" start="64" end="95" type="address"/>
  186. <field name="Instance Data Step Rate" start="96" end="127" type="uint"/>
  187. </struct>
  188. <struct name="VERTEX_ELEMENT_STATE" length="2">
  189. <field name="Vertex Buffer Index" start="26" end="31" type="uint"/>
  190. <field name="Valid" start="25" end="25" type="bool"/>
  191. <field name="Source Element Format" start="16" end="24" type="uint"/>
  192. <field name="Edge Flag Enable" start="15" end="15" type="bool"/>
  193. <field name="Source Element Offset" start="0" end="11" type="uint"/>
  194. <field name="Component 0 Control" start="60" end="62" type="3D_Vertex_Component_Control"/>
  195. <field name="Component 1 Control" start="56" end="58" type="3D_Vertex_Component_Control"/>
  196. <field name="Component 2 Control" start="52" end="54" type="3D_Vertex_Component_Control"/>
  197. <field name="Component 3 Control" start="48" end="50" type="3D_Vertex_Component_Control"/>
  198. </struct>
  199. <struct name="SO_DECL" length="1">
  200. <field name="Output Buffer Slot" start="12" end="13" type="uint"/>
  201. <field name="Hole Flag" start="11" end="11" type="uint"/>
  202. <field name="Register Index" start="4" end="9" type="uint"/>
  203. <field name="Component Mask" start="0" end="3" type="uint" default="0"/>
  204. </struct>
  205. <struct name="SO_DECL_ENTRY" length="2">
  206. <field name="Stream 3 Decl" start="48" end="63" type="SO_DECL"/>
  207. <field name="Stream 2 Decl" start="32" end="47" type="SO_DECL"/>
  208. <field name="Stream 1 Decl" start="16" end="31" type="SO_DECL"/>
  209. <field name="Stream 0 Decl" start="0" end="15" type="SO_DECL"/>
  210. </struct>
  211. <struct name="SF_OUTPUT_ATTRIBUTE_DETAIL" length="1">
  212. <field name="Component Override W" start="15" end="15" type="bool"/>
  213. <field name="Component Override Z" start="14" end="14" type="bool"/>
  214. <field name="Component Override Y" start="13" end="13" type="bool"/>
  215. <field name="Component Override X" start="12" end="12" type="bool"/>
  216. <field name="Swizzle Control Mode" start="11" end="11" type="uint"/>
  217. <field name="Constant Source" start="9" end="10" type="uint">
  218. <value name="CONST_0000" value="0"/>
  219. <value name="CONST_0001_FLOAT" value="1"/>
  220. <value name="CONST_1111_FLOAT" value="2"/>
  221. <value name="PRIM_ID" value="3"/>
  222. </field>
  223. <field name="Swizzle Select" start="6" end="7" type="uint">
  224. <value name="INPUTATTR" value="0"/>
  225. <value name="INPUTATTR_FACING" value="1"/>
  226. <value name="INPUTATTR_W" value="2"/>
  227. <value name="INPUTATTR_FACING_W" value="3"/>
  228. </field>
  229. <field name="Source Attribute" start="0" end="4" type="uint"/>
  230. </struct>
  231. <struct name="SCISSOR_RECT" length="2">
  232. <field name="Scissor Rectangle Y Min" start="16" end="31" type="uint"/>
  233. <field name="Scissor Rectangle X Min" start="0" end="15" type="uint"/>
  234. <field name="Scissor Rectangle Y Max" start="48" end="63" type="uint"/>
  235. <field name="Scissor Rectangle X Max" start="32" end="47" type="uint"/>
  236. </struct>
  237. <struct name="SF_CLIP_VIEWPORT" length="16">
  238. <field name="Viewport Matrix Element m00" start="0" end="31" type="float"/>
  239. <field name="Viewport Matrix Element m11" start="32" end="63" type="float"/>
  240. <field name="Viewport Matrix Element m22" start="64" end="95" type="float"/>
  241. <field name="Viewport Matrix Element m30" start="96" end="127" type="float"/>
  242. <field name="Viewport Matrix Element m31" start="128" end="159" type="float"/>
  243. <field name="Viewport Matrix Element m32" start="160" end="191" type="float"/>
  244. <field name="X Min Clip Guardband" start="256" end="287" type="float"/>
  245. <field name="X Max Clip Guardband" start="288" end="319" type="float"/>
  246. <field name="Y Min Clip Guardband" start="320" end="351" type="float"/>
  247. <field name="Y Max Clip Guardband" start="352" end="383" type="float"/>
  248. </struct>
  249. <struct name="BLEND_STATE_ENTRY" length="2">
  250. <field name="Color Buffer Blend Enable" start="31" end="31" type="bool"/>
  251. <field name="Independent Alpha Blend Enable" start="30" end="30" type="bool"/>
  252. <field name="Alpha Blend Function" start="26" end="28" type="3D_Color_Buffer_Blend_Function"/>
  253. <field name="Source Alpha Blend Factor" start="20" end="24" type="3D_Color_Buffer_Blend_Factor"/>
  254. <field name="Destination Alpha Blend Factor" start="15" end="19" type="3D_Color_Buffer_Blend_Factor"/>
  255. <field name="Color Blend Function" start="11" end="13" type="3D_Color_Buffer_Blend_Function"/>
  256. <field name="Source Blend Factor" start="5" end="9" type="3D_Color_Buffer_Blend_Factor"/>
  257. <field name="Destination Blend Factor" start="0" end="4" type="3D_Color_Buffer_Blend_Factor"/>
  258. <field name="AlphaToCoverage Enable" start="63" end="63" type="bool"/>
  259. <field name="AlphaToOne Enable" start="62" end="62" type="bool"/>
  260. <field name="AlphaToCoverage Dither Enable" start="61" end="61" type="bool"/>
  261. <field name="Write Disable Alpha" start="59" end="59" type="bool"/>
  262. <field name="Write Disable Red" start="58" end="58" type="bool"/>
  263. <field name="Write Disable Green" start="57" end="57" type="bool"/>
  264. <field name="Write Disable Blue" start="56" end="56" type="bool"/>
  265. <field name="Logic Op Enable" start="54" end="54" type="bool"/>
  266. <field name="Logic Op Function" start="50" end="53" type="3D_Logic_Op_Function"/>
  267. <field name="Alpha Test Enable" start="48" end="48" type="bool"/>
  268. <field name="Alpha Test Function" start="45" end="47" type="3D_Compare_Function"/>
  269. <field name="Color Dither Enable" start="44" end="44" type="bool"/>
  270. <field name="X Dither Offset" start="42" end="43" type="uint"/>
  271. <field name="Y Dither Offset" start="40" end="41" type="uint"/>
  272. <field name="Color Clamp Range" start="34" end="35" type="uint">
  273. <value name="COLORCLAMP_UNORM" value="0"/>
  274. <value name="COLORCLAMP_SNORM" value="1"/>
  275. <value name="COLORCLAMP_RTFORMAT" value="2"/>
  276. </field>
  277. <field name="Pre-Blend Color Clamp Enable" start="33" end="33" type="bool"/>
  278. <field name="Post-Blend Color Clamp Enable" start="32" end="32" type="bool"/>
  279. </struct>
  280. <struct name="BLEND_STATE" length="0">
  281. <group count="0" start="0" size="64">
  282. <field name="Entry" start="0" end="63" type="BLEND_STATE_ENTRY"/>
  283. </group>
  284. </struct>
  285. <struct name="CC_VIEWPORT" length="2">
  286. <field name="Minimum Depth" start="0" end="31" type="float"/>
  287. <field name="Maximum Depth" start="32" end="63" type="float"/>
  288. </struct>
  289. <struct name="COLOR_CALC_STATE" length="6">
  290. <field name="Stencil Reference Value" start="24" end="31" type="uint"/>
  291. <field name="Backface Stencil Reference Value" start="16" end="23" type="uint"/>
  292. <field name="Round Disable Function Disable" start="15" end="15" type="bool"/>
  293. <field name="Alpha Test Format" start="0" end="0" type="uint">
  294. <value name="ALPHATEST_UNORM8" value="0"/>
  295. <value name="ALPHATEST_FLOAT32" value="1"/>
  296. </field>
  297. <field name="Alpha Reference Value As UNORM8" start="32" end="63" type="uint"/>
  298. <field name="Alpha Reference Value As FLOAT32" start="32" end="63" type="float"/>
  299. <field name="Blend Constant Color Red" start="64" end="95" type="float"/>
  300. <field name="Blend Constant Color Green" start="96" end="127" type="float"/>
  301. <field name="Blend Constant Color Blue" start="128" end="159" type="float"/>
  302. <field name="Blend Constant Color Alpha" start="160" end="191" type="float"/>
  303. </struct>
  304. <struct name="DEPTH_STENCIL_STATE" length="3">
  305. <field name="Stencil Test Enable" start="31" end="31" type="bool"/>
  306. <field name="Stencil Test Function" start="28" end="30" type="3D_Compare_Function"/>
  307. <field name="Stencil Fail Op" start="25" end="27" type="3D_Stencil_Operation"/>
  308. <field name="Stencil Pass Depth Fail Op" start="22" end="24" type="3D_Stencil_Operation"/>
  309. <field name="Stencil Pass Depth Pass Op" start="19" end="21" type="3D_Stencil_Operation"/>
  310. <field name="Stencil Buffer Write Enable" start="18" end="18" type="bool"/>
  311. <field name="Double Sided Stencil Enable" start="15" end="15" type="bool"/>
  312. <field name="Backface Stencil Test Function" start="12" end="14" type="3D_Compare_Function"/>
  313. <field name="Backface Stencil Fail Op" start="9" end="11" type="3D_Stencil_Operation"/>
  314. <field name="Backface Stencil Pass Depth Fail Op" start="6" end="8" type="3D_Stencil_Operation"/>
  315. <field name="Backface Stencil Pass Depth Pass Op" start="3" end="5" type="3D_Stencil_Operation"/>
  316. <field name="Stencil Test Mask" start="56" end="63" type="uint"/>
  317. <field name="Stencil Write Mask" start="48" end="55" type="uint"/>
  318. <field name="Backface Stencil Test Mask" start="40" end="47" type="uint"/>
  319. <field name="Backface Stencil Write Mask" start="32" end="39" type="uint"/>
  320. <field name="Depth Test Enable" start="95" end="95" type="bool"/>
  321. <field name="Depth Test Function" start="91" end="93" type="3D_Compare_Function"/>
  322. <field name="Depth Buffer Write Enable" start="90" end="90" type="bool"/>
  323. </struct>
  324. <struct name="INTERFACE_DESCRIPTOR_DATA" length="8">
  325. <field name="Kernel Start Pointer" start="6" end="31" type="offset"/>
  326. <field name="Single Program Flow" start="50" end="50" type="bool"/>
  327. <field name="Thread Priority" start="49" end="49" type="uint">
  328. <value name="Normal Priority" value="0"/>
  329. <value name="High Priority" value="1"/>
  330. </field>
  331. <field name="Floating Point Mode" start="48" end="48" type="uint">
  332. <value name="IEEE-754" value="0"/>
  333. <value name="Alternate" value="1"/>
  334. </field>
  335. <field name="Illegal Opcode Exception Enable" start="45" end="45" type="bool"/>
  336. <field name="Mask Stack Exception Enable" start="43" end="43" type="bool"/>
  337. <field name="Software Exception Enable" start="39" end="39" type="bool"/>
  338. <field name="Sampler State Pointer" start="69" end="95" type="offset"/>
  339. <field name="Sampler Count" start="66" end="68" type="uint">
  340. <value name="No samplers used" value="0"/>
  341. <value name="Between 1 and 4 samplers used" value="1"/>
  342. <value name="Between 5 and 8 samplers used" value="2"/>
  343. <value name="Between 9 and 12 samplers used" value="3"/>
  344. <value name="Between 13 and 16 samplers used" value="4"/>
  345. </field>
  346. <field name="Binding Table Pointer" start="101" end="111" type="offset"/>
  347. <field name="Binding Table Entry Count" start="96" end="100" type="uint"/>
  348. <field name="Constant URB Entry Read Length" start="144" end="159" type="uint"/>
  349. <field name="Rounding Mode" start="182" end="183" type="uint">
  350. <value name="RTNE" value="0"/>
  351. <value name="RU" value="1"/>
  352. <value name="RD" value="2"/>
  353. <value name="RTZ" value="3"/>
  354. </field>
  355. <field name="Barrier Enable" start="181" end="181" type="bool"/>
  356. <field name="Shared Local Memory Size" start="176" end="180" type="uint"/>
  357. <field name="Number of Threads in GPGPU Thread Group" start="160" end="167" type="uint"/>
  358. <field name="Cross-Thread Constant Data Read Length" start="192" end="199" type="uint"/>
  359. </struct>
  360. <struct name="PALETTE_ENTRY" length="1">
  361. <field name="Alpha" start="24" end="31" type="uint"/>
  362. <field name="Red" start="16" end="23" type="uint"/>
  363. <field name="Green" start="8" end="15" type="uint"/>
  364. <field name="Blue" start="0" end="7" type="uint"/>
  365. </struct>
  366. <struct name="BINDING_TABLE_STATE" length="1">
  367. <field name="Surface State Pointer" start="5" end="31" type="offset"/>
  368. </struct>
  369. <struct name="RENDER_SURFACE_STATE" length="8">
  370. <field name="Surface Type" start="29" end="31" type="uint">
  371. <value name="SURFTYPE_1D" value="0"/>
  372. <value name="SURFTYPE_2D" value="1"/>
  373. <value name="SURFTYPE_3D" value="2"/>
  374. <value name="SURFTYPE_CUBE" value="3"/>
  375. <value name="SURFTYPE_BUFFER" value="4"/>
  376. <value name="SURFTYPE_STRBUF" value="5"/>
  377. <value name="SURFTYPE_NULL" value="7"/>
  378. </field>
  379. <field name="Surface Array" start="28" end="28" type="bool"/>
  380. <field name="Surface Format" start="18" end="26" type="uint"/>
  381. <field name="Surface Vertical Alignment" start="16" end="17" type="uint">
  382. <value name="VALIGN_2" value="0"/>
  383. <value name="VALIGN_4" value="1"/>
  384. </field>
  385. <field name="Surface Horizontal Alignment" start="15" end="15" type="uint">
  386. <value name="HALIGN_4" value="0"/>
  387. <value name="HALIGN_8" value="1"/>
  388. </field>
  389. <field name="Tiled Surface" start="14" end="14" type="bool"/>
  390. <field name="Tile Walk" start="13" end="13" type="uint">
  391. <value name="TILEWALK_XMAJOR" value="0"/>
  392. <value name="TILEWALK_YMAJOR" value="1"/>
  393. </field>
  394. <field name="Vertical Line Stride" start="12" end="12" type="uint"/>
  395. <field name="Vertical Line Stride Offset" start="11" end="11" type="uint"/>
  396. <field name="Surface Array Spacing" start="10" end="10" type="uint">
  397. <value name="ARYSPC_FULL" value="0"/>
  398. <value name="ARYSPC_LOD0" value="1"/>
  399. </field>
  400. <field name="Render Cache Read Write Mode" start="8" end="8" type="uint"/>
  401. <field name="Media Boundary Pixel Mode" start="6" end="7" type="uint">
  402. <value name="NORMAL_MODE" value="0"/>
  403. <value name="PROGRESSIVE_FRAME" value="2"/>
  404. <value name="INTERLACED_FRAME" value="3"/>
  405. </field>
  406. <field name="Cube Face Enable - Positive Z" start="0" end="0" type="bool"/>
  407. <field name="Cube Face Enable - Negative Z" start="1" end="1" type="bool"/>
  408. <field name="Cube Face Enable - Positive Y" start="2" end="2" type="bool"/>
  409. <field name="Cube Face Enable - Negative Y" start="3" end="3" type="bool"/>
  410. <field name="Cube Face Enable - Positive X" start="4" end="4" type="bool"/>
  411. <field name="Cube Face Enable - Negative X" start="5" end="5" type="bool"/>
  412. <field name="Surface Base Address" start="32" end="63" type="address"/>
  413. <field name="Height" start="80" end="93" type="uint"/>
  414. <field name="Width" start="64" end="77" type="uint"/>
  415. <field name="Depth" start="117" end="127" type="uint"/>
  416. <field name="Integer Surface Format" start="114" end="116" type="uint"/>
  417. <field name="Surface Pitch" start="96" end="113" type="uint"/>
  418. <field name="Render Target Rotation" start="157" end="158" type="uint">
  419. <value name="RTROTATE_0DEG" value="0"/>
  420. <value name="RTROTATE_90DEG" value="1"/>
  421. <value name="RTROTATE_270DEG" value="3"/>
  422. </field>
  423. <field name="Minimum Array Element" start="146" end="156" type="uint"/>
  424. <field name="Render Target View Extent" start="135" end="145" type="uint"/>
  425. <field name="Multisampled Surface Storage Format" start="134" end="134" type="uint">
  426. <value name="MSFMT_MSS" value="0"/>
  427. <value name="MSFMT_DEPTH_STENCIL" value="1"/>
  428. </field>
  429. <field name="Number of Multisamples" start="131" end="133" type="uint">
  430. <value name="MULTISAMPLECOUNT_1" value="0"/>
  431. <value name="MULTISAMPLECOUNT_4" value="2"/>
  432. <value name="MULTISAMPLECOUNT_8" value="3"/>
  433. </field>
  434. <field name="Multisample Position Palette Index" start="128" end="130" type="uint"/>
  435. <field name="Strbuf Minimum Array Element" start="128" end="154" type="uint"/>
  436. <field name="X Offset" start="185" end="191" type="uint"/>
  437. <field name="Y Offset" start="180" end="183" type="uint"/>
  438. <field name="Surface Object Control State" start="176" end="179" type="MEMORY_OBJECT_CONTROL_STATE"/>
  439. <field name="MOCS" start="176" end="179" type="uint"/>
  440. <field name="Surface Min LOD" start="164" end="167" type="uint"/>
  441. <field name="MIP Count / LOD" start="160" end="163" type="uint"/>
  442. <field name="Append Counter Address" start="198" end="223" type="address"/>
  443. <field name="Append Counter Enable" start="193" end="193" type="bool"/>
  444. <field name="Auxiliary Surface Base Address" start="204" end="223" type="address"/>
  445. <field name="Auxiliary Surface Pitch" start="195" end="203" type="uint"/>
  446. <field name="MCS Enable" start="192" end="192" type="bool"/>
  447. <field name="Reserved: MBZ" start="222" end="223" type="uint"/>
  448. <field name="X Offset for UV Plane" start="208" end="221" type="uint"/>
  449. <field name="Y Offset for UV Plane" start="192" end="205" type="uint"/>
  450. <field name="Red Clear Color" start="255" end="255" type="uint" />
  451. <field name="Green Clear Color" start="254" end="254" type="uint" />
  452. <field name="Blue Clear Color" start="253" end="253" type="uint" />
  453. <field name="Alpha Clear Color" start="252" end="252" type="uint" />
  454. <field name="Shader Channel Select Red" start="249" end="251" type="Shader Channel Select"/>
  455. <field name="Shader Channel Select Green" start="246" end="248" type="Shader Channel Select"/>
  456. <field name="Shader Channel Select Blue" start="243" end="245" type="Shader Channel Select"/>
  457. <field name="Shader Channel Select Alpha" start="240" end="242" type="Shader Channel Select"/>
  458. <field name="Resource Min LOD" start="224" end="235" type="u4.8"/>
  459. </struct>
  460. <struct name="SAMPLER_BORDER_COLOR_STATE" length="20">
  461. <field name="Border Color Float Red" start="0" end="31" type="float"/>
  462. <field name="Border Color Float Green" start="32" end="63" type="float"/>
  463. <field name="Border Color Float Blue" start="64" end="95" type="float"/>
  464. <field name="Border Color Float Alpha" start="96" end="127" type="float"/>
  465. <field name="Border Color 8bit Red" start="512" end="519" type="uint"/>
  466. <field name="Border Color 8bit Green" start="520" end="527" type="uint"/>
  467. <field name="Border Color 8bit Blue" start="528" end="535" type="uint"/>
  468. <field name="Border Color 8bit Alpha" start="536" end="543" type="uint"/>
  469. <field name="Border Color 16bit Red" start="512" end="527" type="uint"/>
  470. <field name="Border Color 16bit Green" start="528" end="543" type="uint"/>
  471. <field name="Border Color 16bit Blue" start="576" end="591" type="uint"/>
  472. <field name="Border Color 16bit Alpha" start="592" end="607" type="uint"/>
  473. <field name="Border Color 32bit Red" start="512" end="543" type="uint"/>
  474. <field name="Border Color 32bit Green" start="544" end="575" type="uint"/>
  475. <field name="Border Color 32bit Blue" start="576" end="607" type="uint"/>
  476. <field name="Border Color 32bit Alpha" start="608" end="639" type="uint"/>
  477. </struct>
  478. <struct name="SAMPLER_STATE" length="4">
  479. <field name="Sampler Disable" start="31" end="31" type="bool"/>
  480. <field name="Texture Border Color Mode" start="29" end="29" type="uint">
  481. <value name="DX10/OGL" value="0"/>
  482. <value name="DX9" value="1"/>
  483. </field>
  484. <field name="LOD PreClamp Enable" start="28" end="28" type="uint" prefix="CLAMP_ENABLE">
  485. <value name="OGL" value="1"/>
  486. </field>
  487. <field name="Base Mip Level" start="22" end="26" type="u4.1"/>
  488. <field name="Mip Mode Filter" start="20" end="21" type="uint" prefix="MIPFILTER">
  489. <value name="NONE" value="0"/>
  490. <value name="NEAREST" value="1"/>
  491. <value name="LINEAR" value="3"/>
  492. </field>
  493. <field name="Mag Mode Filter" start="17" end="19" type="uint" prefix="MAPFILTER">
  494. <value name="NEAREST" value="0"/>
  495. <value name="LINEAR" value="1"/>
  496. <value name="ANISOTROPIC" value="2"/>
  497. <value name="MONO" value="6"/>
  498. </field>
  499. <field name="Min Mode Filter" start="14" end="16" type="uint" prefix="MAPFILTER">
  500. <value name="NEAREST" value="0"/>
  501. <value name="LINEAR" value="1"/>
  502. <value name="ANISOTROPIC" value="2"/>
  503. <value name="MONO" value="6"/>
  504. </field>
  505. <field name="Texture LOD Bias" start="1" end="13" type="s4.8"/>
  506. <field name="Anisotropic Algorithm" start="0" end="0" type="uint">
  507. <value name="LEGACY" value="0"/>
  508. <value name="EWA Approximation" value="1"/>
  509. </field>
  510. <field name="Min LOD" start="52" end="63" type="u4.8"/>
  511. <field name="Max LOD" start="40" end="51" type="u4.8"/>
  512. <field name="Shadow Function" start="33" end="35" type="uint">
  513. <value name="PREFILTEROP ALWAYS" value="0"/>
  514. <value name="PREFILTEROP NEVER" value="1"/>
  515. <value name="PREFILTEROP LESS" value="2"/>
  516. <value name="PREFILTEROP EQUAL" value="3"/>
  517. <value name="PREFILTEROP LEQUAL" value="4"/>
  518. <value name="PREFILTEROP GREATER" value="5"/>
  519. <value name="PREFILTEROP NOTEQUAL" value="6"/>
  520. <value name="PREFILTEROP GEQUAL" value="7"/>
  521. </field>
  522. <field name="Cube Surface Control Mode" start="32" end="32" type="uint">
  523. <value name="PROGRAMMED" value="0"/>
  524. <value name="OVERRIDE" value="1"/>
  525. </field>
  526. <field name="Border Color Pointer" start="69" end="95" type="offset"/>
  527. <field name="ChromaKey Enable" start="121" end="121" type="bool"/>
  528. <field name="ChromaKey Index" start="119" end="120" type="uint"/>
  529. <field name="ChromaKey Mode" start="118" end="118" type="uint">
  530. <value name="KEYFILTER_KILL_ON_ANY_MATCH" value="0"/>
  531. <value name="KEYFILTER_REPLACE_BLACK" value="1"/>
  532. </field>
  533. <field name="Maximum Anisotropy" start="115" end="117" type="uint">
  534. <value name="RATIO 2:1" value="0"/>
  535. <value name="RATIO 4:1" value="1"/>
  536. <value name="RATIO 6:1" value="2"/>
  537. <value name="RATIO 8:1" value="3"/>
  538. <value name="RATIO 10:1" value="4"/>
  539. <value name="RATIO 12:1" value="5"/>
  540. <value name="RATIO 14:1" value="6"/>
  541. <value name="RATIO 16:1" value="7"/>
  542. </field>
  543. <field name="R Address Min Filter Rounding Enable" start="109" end="109" type="bool"/>
  544. <field name="R Address Mag Filter Rounding Enable" start="110" end="110" type="bool"/>
  545. <field name="V Address Min Filter Rounding Enable" start="111" end="111" type="bool"/>
  546. <field name="V Address Mag Filter Rounding Enable" start="112" end="112" type="bool"/>
  547. <field name="U Address Min Filter Rounding Enable" start="113" end="113" type="bool"/>
  548. <field name="U Address Mag Filter Rounding Enable" start="114" end="114" type="bool"/>
  549. <field name="Trilinear Filter Quality" start="107" end="108" type="uint">
  550. <value name="FULL" value="0"/>
  551. <value name="TRIQUAL_HIGH/MAG_CLAMP_MIPFILTER" value="1"/>
  552. <value name="MED" value="2"/>
  553. <value name="LOW" value="3"/>
  554. </field>
  555. <field name="Non-normalized Coordinate Enable" start="106" end="106" type="bool"/>
  556. <field name="TCX Address Control Mode" start="102" end="104" type="Texture Coordinate Mode"/>
  557. <field name="TCY Address Control Mode" start="99" end="101" type="Texture Coordinate Mode"/>
  558. <field name="TCZ Address Control Mode" start="96" end="98" type="Texture Coordinate Mode"/>
  559. </struct>
  560. <struct name="MI_MATH_ALU_INSTRUCTION" length="1">
  561. <field name="ALU Opcode" start="20" end="31" type="uint" prefix="MI_ALU">
  562. <value name="NOOP" value="0x000"/>
  563. <value name="LOAD" value="0x080"/>
  564. <value name="LOADINV" value="0x480"/>
  565. <value name="LOAD0" value="0x081"/>
  566. <value name="LOAD1" value="0x481"/>
  567. <value name="ADD" value="0x100"/>
  568. <value name="SUB" value="0x101"/>
  569. <value name="AND" value="0x102"/>
  570. <value name="OR" value="0x103"/>
  571. <value name="XOR" value="0x104"/>
  572. <value name="STORE" value="0x180"/>
  573. <value name="STOREINV" value="0x580"/>
  574. </field>
  575. <field name="Operand 1" start="10" end="19" type="uint" prefix="MI_ALU">
  576. <value name="REG0" value="0x00"/>
  577. <value name="REG1" value="0x01"/>
  578. <value name="REG2" value="0x02"/>
  579. <value name="REG3" value="0x03"/>
  580. <value name="REG4" value="0x04"/>
  581. <value name="REG5" value="0x05"/>
  582. <value name="REG6" value="0x06"/>
  583. <value name="REG7" value="0x07"/>
  584. <value name="REG8" value="0x08"/>
  585. <value name="REG9" value="0x09"/>
  586. <value name="REG10" value="0x0a"/>
  587. <value name="REG11" value="0x0b"/>
  588. <value name="REG12" value="0x0c"/>
  589. <value name="REG13" value="0x0d"/>
  590. <value name="REG14" value="0x0e"/>
  591. <value name="REG15" value="0x0f"/>
  592. <value name="SRCA" value="0x20"/>
  593. <value name="SRCB" value="0x21"/>
  594. <value name="ACCU" value="0x31"/>
  595. <value name="ZF" value="0x32"/>
  596. <value name="CF" value="0x33"/>
  597. </field>
  598. <field name="Operand 2" start="0" end="9" type="uint" prefix="MI_ALU">
  599. <value name="REG0" value="0x00"/>
  600. <value name="REG1" value="0x01"/>
  601. <value name="REG2" value="0x02"/>
  602. <value name="REG3" value="0x03"/>
  603. <value name="REG4" value="0x04"/>
  604. <value name="REG5" value="0x05"/>
  605. <value name="REG6" value="0x06"/>
  606. <value name="REG7" value="0x07"/>
  607. <value name="REG8" value="0x08"/>
  608. <value name="REG9" value="0x09"/>
  609. <value name="REG10" value="0x0a"/>
  610. <value name="REG11" value="0x0b"/>
  611. <value name="REG12" value="0x0c"/>
  612. <value name="REG13" value="0x0d"/>
  613. <value name="REG14" value="0x0e"/>
  614. <value name="REG15" value="0x0f"/>
  615. <value name="SRCA" value="0x20"/>
  616. <value name="SRCB" value="0x21"/>
  617. <value name="ACCU" value="0x31"/>
  618. <value name="ZF" value="0x32"/>
  619. <value name="CF" value="0x33"/>
  620. </field>
  621. </struct>
  622. <instruction name="3DPRIMITIVE" bias="2" length="7">
  623. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  624. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  625. <field name="3D Command Opcode" start="24" end="26" type="uint" default="3"/>
  626. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="0"/>
  627. <field name="Indirect Parameter Enable" start="10" end="10" type="bool"/>
  628. <field name="UAV Coherency Required" start="9" end="9" type="bool"/>
  629. <field name="Predicate Enable" start="8" end="8" type="bool"/>
  630. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  631. <field name="End Offset Enable" start="41" end="41" type="bool"/>
  632. <field name="Vertex Access Type" start="40" end="40" type="uint">
  633. <value name="SEQUENTIAL" value="0"/>
  634. <value name="RANDOM" value="1"/>
  635. </field>
  636. <field name="Primitive Topology Type" start="32" end="37" type="3D_Prim_Topo_Type"/>
  637. <field name="Vertex Count Per Instance" start="64" end="95" type="uint"/>
  638. <field name="Start Vertex Location" start="96" end="127" type="uint"/>
  639. <field name="Instance Count" start="128" end="159" type="uint"/>
  640. <field name="Start Instance Location" start="160" end="191" type="uint"/>
  641. <field name="Base Vertex Location" start="192" end="223" type="int"/>
  642. </instruction>
  643. <instruction name="3DSTATE_AA_LINE_PARAMETERS" bias="2" length="3">
  644. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  645. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  646. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  647. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="10"/>
  648. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  649. <field name="AA Coverage Bias" start="48" end="55" type="u0.8"/>
  650. <field name="AA Coverage Slope" start="32" end="39" type="u0.8"/>
  651. <field name="AA Coverage EndCap Bias" start="80" end="87" type="u0.8"/>
  652. <field name="AA Coverage EndCap Slope" start="64" end="71" type="u0.8"/>
  653. </instruction>
  654. <instruction name="3DSTATE_BINDING_TABLE_EDIT_DS" bias="2">
  655. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  656. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  657. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  658. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="70"/>
  659. <field name="DWord Length" start="0" end="8" type="uint" default="0"/>
  660. <field name="Binding Table Block Clear" start="48" end="63" type="uint"/>
  661. <field name="Binding Table Edit Target" start="32" end="33" type="uint">
  662. <value name="All Cores" value="3"/>
  663. <value name="Core 1" value="2"/>
  664. <value name="Core 0" value="1"/>
  665. </field>
  666. <group count="0" start="64" size="32">
  667. <field name="Entry [n]" start="0" end="31" type="BINDING_TABLE_EDIT_ENTRY"/>
  668. </group>
  669. </instruction>
  670. <instruction name="3DSTATE_BINDING_TABLE_EDIT_GS" bias="2">
  671. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  672. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  673. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  674. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="68"/>
  675. <field name="DWord Length" start="0" end="8" type="uint" default="0"/>
  676. <field name="Binding Table Block Clear" start="48" end="63" type="uint"/>
  677. <field name="Binding Table Edit Target" start="32" end="33" type="uint">
  678. <value name="All Cores" value="3"/>
  679. <value name="Core 1" value="2"/>
  680. <value name="Core 0" value="1"/>
  681. </field>
  682. <group count="0" start="64" size="32">
  683. <field name="Entry [n]" start="0" end="31" type="BINDING_TABLE_EDIT_ENTRY"/>
  684. </group>
  685. </instruction>
  686. <instruction name="3DSTATE_BINDING_TABLE_EDIT_HS" bias="2">
  687. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  688. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  689. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  690. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="69"/>
  691. <field name="DWord Length" start="0" end="8" type="uint" default="0"/>
  692. <field name="Binding Table Block Clear" start="48" end="63" type="uint"/>
  693. <field name="Binding Table Edit Target" start="32" end="33" type="uint">
  694. <value name="All Cores" value="3"/>
  695. <value name="Core 1" value="2"/>
  696. <value name="Core 0" value="1"/>
  697. </field>
  698. <group count="0" start="64" size="32">
  699. <field name="Entry [n]" start="0" end="31" type="BINDING_TABLE_EDIT_ENTRY"/>
  700. </group>
  701. </instruction>
  702. <instruction name="3DSTATE_BINDING_TABLE_EDIT_PS" bias="2">
  703. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  704. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  705. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  706. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="71"/>
  707. <field name="DWord Length" start="0" end="8" type="uint" default="0"/>
  708. <field name="Binding Table Block Clear" start="48" end="63" type="uint"/>
  709. <field name="Binding Table Edit Target" start="32" end="33" type="uint">
  710. <value name="All Cores" value="3"/>
  711. <value name="Core 1" value="2"/>
  712. <value name="Core 0" value="1"/>
  713. </field>
  714. <group count="0" start="64" size="32">
  715. <field name="Entry [n]" start="0" end="31" type="BINDING_TABLE_EDIT_ENTRY"/>
  716. </group>
  717. </instruction>
  718. <instruction name="3DSTATE_BINDING_TABLE_EDIT_VS" bias="2">
  719. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  720. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  721. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  722. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="67"/>
  723. <field name="DWord Length" start="0" end="8" type="uint" default="0"/>
  724. <field name="Binding Table Block Clear" start="48" end="63" type="uint"/>
  725. <field name="Binding Table Edit Target" start="32" end="33" type="uint">
  726. <value name="All Cores" value="3"/>
  727. <value name="Core 1" value="2"/>
  728. <value name="Core 0" value="1"/>
  729. </field>
  730. <group count="0" start="64" size="32">
  731. <field name="Entry [n]" start="0" end="31" type="BINDING_TABLE_EDIT_ENTRY"/>
  732. </group>
  733. </instruction>
  734. <instruction name="3DSTATE_BINDING_TABLE_POINTERS_DS" bias="2" length="2">
  735. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  736. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  737. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  738. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="40"/>
  739. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  740. <field name="Pointer to DS Binding Table" start="37" end="47" type="offset"/>
  741. </instruction>
  742. <instruction name="3DSTATE_BINDING_TABLE_POINTERS_GS" bias="2" length="2">
  743. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  744. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  745. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  746. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="41"/>
  747. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  748. <field name="Pointer to GS Binding Table" start="37" end="47" type="offset"/>
  749. </instruction>
  750. <instruction name="3DSTATE_BINDING_TABLE_POINTERS_HS" bias="2" length="2">
  751. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  752. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  753. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  754. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="39"/>
  755. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  756. <field name="Pointer to HS Binding Table" start="37" end="47" type="offset"/>
  757. </instruction>
  758. <instruction name="3DSTATE_BINDING_TABLE_POINTERS_PS" bias="2" length="2">
  759. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  760. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  761. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  762. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="42"/>
  763. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  764. <field name="Pointer to PS Binding Table" start="37" end="47" type="offset"/>
  765. </instruction>
  766. <instruction name="3DSTATE_BINDING_TABLE_POINTERS_VS" bias="2" length="2">
  767. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  768. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  769. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  770. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="38"/>
  771. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  772. <field name="Pointer to VS Binding Table" start="37" end="47" type="offset"/>
  773. </instruction>
  774. <instruction name="3DSTATE_BINDING_TABLE_POOL_ALLOC" bias="2" length="3">
  775. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  776. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  777. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  778. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="25"/>
  779. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  780. <field name="Binding Table Pool Base Address" start="44" end="63" type="address"/>
  781. <field name="Binding Table Pool Enable" start="43" end="43" type="uint"/>
  782. <field name="Surface Object Control State" start="39" end="42" type="MEMORY_OBJECT_CONTROL_STATE"/>
  783. <field name="Binding Table Pool Upper Bound" start="76" end="95" type="address"/>
  784. </instruction>
  785. <instruction name="3DSTATE_BLEND_STATE_POINTERS" bias="2" length="2">
  786. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  787. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  788. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  789. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="36"/>
  790. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  791. <field name="Blend State Pointer" start="38" end="63" type="offset"/>
  792. <field start="32" end="32" type="mbo"/>
  793. </instruction>
  794. <instruction name="3DSTATE_CC_STATE_POINTERS" bias="2" length="2">
  795. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  796. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  797. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  798. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="14"/>
  799. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  800. <field name="Color Calc State Pointer" start="38" end="63" type="offset"/>
  801. <field start="32" end="32" type="mbo"/>
  802. </instruction>
  803. <instruction name="3DSTATE_CHROMA_KEY" bias="2" length="4">
  804. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  805. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  806. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  807. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="4"/>
  808. <field name="DWord Length" start="0" end="7" type="uint" default="2"/>
  809. <field name="ChromaKey Table Index" start="62" end="63" type="uint"/>
  810. <field name="ChromaKey Low Value" start="64" end="95" type="uint"/>
  811. <field name="ChromaKey High Value" start="96" end="127" type="uint"/>
  812. </instruction>
  813. <instruction name="3DSTATE_CLEAR_PARAMS" bias="2" length="3">
  814. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  815. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  816. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  817. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="4"/>
  818. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  819. <field name="Depth Clear Value" start="32" end="63" type="uint"/>
  820. <field name="Depth Clear Value Valid" start="64" end="64" type="bool"/>
  821. </instruction>
  822. <instruction name="3DSTATE_CLIP" bias="2" length="4">
  823. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  824. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  825. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  826. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="18"/>
  827. <field name="DWord Length" start="0" end="7" type="uint" default="2"/>
  828. <field name="Front Winding" start="52" end="52" type="uint"/>
  829. <field name="Vertex Sub Pixel Precision Select" start="51" end="51" type="uint"/>
  830. <field name="Early Cull Enable" start="50" end="50" type="bool"/>
  831. <field name="Cull Mode" start="48" end="49" type="uint" prefix="CULLMODE">
  832. <value name="BOTH" value="0"/>
  833. <value name="NONE" value="1"/>
  834. <value name="FRONT" value="2"/>
  835. <value name="BACK" value="3"/>
  836. </field>
  837. <field name="Statistics Enable" start="42" end="42" type="bool"/>
  838. <field name="User Clip Distance Cull Test Enable Bitmask" start="32" end="39" type="uint"/>
  839. <field name="Clip Enable" start="95" end="95" type="bool"/>
  840. <field name="API Mode" start="94" end="94" type="uint">
  841. <value name="APIMODE_OGL" value="0"/>
  842. <value name="APIMODE_D3D" value="1"/>
  843. </field>
  844. <field name="Viewport XY Clip Test Enable" start="92" end="92" type="bool"/>
  845. <field name="Viewport Z Clip Test Enable" start="91" end="91" type="bool"/>
  846. <field name="Guardband Clip Test Enable" start="90" end="90" type="bool"/>
  847. <field name="User Clip Distance Clip Test Enable Bitmask" start="80" end="87" type="uint"/>
  848. <field name="Clip Mode" start="77" end="79" type="uint">
  849. <value name="CLIPMODE_NORMAL" value="0"/>
  850. <value name="CLIPMODE_REJECT_ALL" value="3"/>
  851. <value name="CLIPMODE_ACCEPT_ALL" value="4"/>
  852. </field>
  853. <field name="Perspective Divide Disable" start="73" end="73" type="bool"/>
  854. <field name="Non-Perspective Barycentric Enable" start="72" end="72" type="bool"/>
  855. <field name="Triangle Strip/List Provoking Vertex Select" start="68" end="69" type="uint">
  856. <value name="Vertex 0" value="0"/>
  857. <value name="Vertex 1" value="1"/>
  858. <value name="Vertex 2" value="2"/>
  859. </field>
  860. <field name="Line Strip/List Provoking Vertex Select" start="66" end="67" type="uint">
  861. <value name="Vertex 0" value="0"/>
  862. <value name="Vertex 1" value="1"/>
  863. </field>
  864. <field name="Triangle Fan Provoking Vertex Select" start="64" end="65" type="uint">
  865. <value name="Vertex 0" value="0"/>
  866. <value name="Vertex 1" value="1"/>
  867. <value name="Vertex 2" value="2"/>
  868. </field>
  869. <field name="Minimum Point Width" start="113" end="123" type="u8.3"/>
  870. <field name="Maximum Point Width" start="102" end="112" type="u8.3"/>
  871. <field name="Force Zero RTA Index Enable" start="101" end="101" type="bool"/>
  872. <field name="Maximum VP Index" start="96" end="99" type="uint"/>
  873. </instruction>
  874. <instruction name="3DSTATE_CONSTANT_DS" bias="2" length="7">
  875. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  876. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  877. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  878. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="26"/>
  879. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  880. <field name="Constant Body" start="32" end="223" type="3DSTATE_CONSTANT_BODY"/>
  881. </instruction>
  882. <instruction name="3DSTATE_CONSTANT_GS" bias="2" length="7">
  883. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  884. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  885. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  886. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="22"/>
  887. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  888. <field name="Constant Body" start="32" end="223" type="3DSTATE_CONSTANT_BODY"/>
  889. </instruction>
  890. <instruction name="3DSTATE_CONSTANT_HS" bias="2" length="7">
  891. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  892. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  893. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  894. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="25"/>
  895. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  896. <field name="Constant Body" start="32" end="223" type="3DSTATE_CONSTANT_BODY"/>
  897. </instruction>
  898. <instruction name="3DSTATE_CONSTANT_PS" bias="2" length="7">
  899. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  900. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  901. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  902. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="23"/>
  903. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  904. <field name="Constant Body" start="32" end="223" type="3DSTATE_CONSTANT_BODY"/>
  905. </instruction>
  906. <instruction name="3DSTATE_CONSTANT_VS" bias="2" length="7">
  907. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  908. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  909. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  910. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="21"/>
  911. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  912. <field name="Constant Body" start="32" end="223" type="3DSTATE_CONSTANT_BODY"/>
  913. </instruction>
  914. <instruction name="3DSTATE_DEPTH_BUFFER" bias="2" length="7">
  915. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  916. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  917. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  918. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="5"/>
  919. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  920. <field name="Surface Type" start="61" end="63" type="uint">
  921. <value name="SURFTYPE_1D" value="0"/>
  922. <value name="SURFTYPE_2D" value="1"/>
  923. <value name="SURFTYPE_3D" value="2"/>
  924. <value name="SURFTYPE_CUBE" value="3"/>
  925. <value name="SURFTYPE_NULL" value="7"/>
  926. </field>
  927. <field name="Depth Write Enable" start="60" end="60" type="bool"/>
  928. <field name="Stencil Write Enable" start="59" end="59" type="bool"/>
  929. <field name="Hierarchical Depth Buffer Enable" start="54" end="54" type="bool"/>
  930. <field name="Surface Format" start="50" end="52" type="uint">
  931. <value name="D32_FLOAT" value="1"/>
  932. <value name="D24_UNORM_X8_UINT" value="3"/>
  933. <value name="D16_UNORM" value="5"/>
  934. </field>
  935. <field name="Surface Pitch" start="32" end="49" type="uint"/>
  936. <field name="Surface Base Address" start="64" end="95" type="address"/>
  937. <field name="Height" start="114" end="127" type="uint"/>
  938. <field name="Width" start="100" end="113" type="uint"/>
  939. <field name="LOD" start="96" end="99" type="uint"/>
  940. <field name="Depth" start="149" end="159" type="uint">
  941. <value name="SURFTYPE_CUBE (must be zero)" value="0"/>
  942. </field>
  943. <field name="Minimum Array Element" start="138" end="148" type="uint"/>
  944. <field name="Depth Buffer Object Control State" start="128" end="131" type="MEMORY_OBJECT_CONTROL_STATE"/>
  945. <field name="Depth Buffer MOCS" start="128" end="131" type="uint"/>
  946. <field name="Depth Coordinate Offset Y" start="176" end="191" type="int"/>
  947. <field name="Depth Coordinate Offset X" start="160" end="175" type="int"/>
  948. <field name="Render Target View Extent" start="213" end="223" type="uint"/>
  949. </instruction>
  950. <instruction name="3DSTATE_DEPTH_STENCIL_STATE_POINTERS" bias="2" length="2">
  951. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  952. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  953. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  954. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="37"/>
  955. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  956. <field name="Pointer to DEPTH_STENCIL_STATE" start="38" end="63" type="offset"/>
  957. <field start="32" end="32" type="mbo"/>
  958. </instruction>
  959. <instruction name="3DSTATE_DRAWING_RECTANGLE" bias="2" length="4">
  960. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  961. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  962. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  963. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="0"/>
  964. <field name="Core Mode Select" start="14" end="15" type="uint">
  965. <value name="Legacy" value="0"/>
  966. <value name="Core 0 Enabled" value="1"/>
  967. <value name="Core 1 Enabled" value="2"/>
  968. </field>
  969. <field name="DWord Length" start="0" end="7" type="uint" default="2"/>
  970. <field name="Clipped Drawing Rectangle Y Min" start="48" end="63" type="uint"/>
  971. <field name="Clipped Drawing Rectangle X Min" start="32" end="47" type="uint"/>
  972. <field name="Clipped Drawing Rectangle Y Max" start="80" end="95" type="uint"/>
  973. <field name="Clipped Drawing Rectangle X Max" start="64" end="79" type="uint"/>
  974. <field name="Drawing Rectangle Origin Y" start="112" end="127" type="int"/>
  975. <field name="Drawing Rectangle Origin X" start="96" end="111" type="int"/>
  976. </instruction>
  977. <instruction name="3DSTATE_DS" bias="2" length="6">
  978. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  979. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  980. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  981. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="29"/>
  982. <field name="DWord Length" start="0" end="7" type="uint" default="4"/>
  983. <field name="Kernel Start Pointer" start="38" end="63" type="offset"/>
  984. <field name="Single Domain Point Dispatch" start="95" end="95" type="uint"/>
  985. <field name="Vector Mask Enable" start="94" end="94" type="bool"/>
  986. <field name="Sampler Count" start="91" end="93" type="uint">
  987. <value name="No Samplers" value="0"/>
  988. <value name="1-4 Samplers" value="1"/>
  989. <value name="5-8 Samplers" value="2"/>
  990. <value name="9-12 Samplers" value="3"/>
  991. <value name="13-16 Samplers" value="4"/>
  992. </field>
  993. <field name="Binding Table Entry Count" start="82" end="89" type="uint"/>
  994. <field name="Thread Dispatch Priority" start="81" end="81" type="uint">
  995. <value name="High" value="1"/>
  996. </field>
  997. <field name="Floating Point Mode" start="80" end="80" type="uint">
  998. <value name="IEEE-754" value="0"/>
  999. <value name="Alternate" value="1"/>
  1000. </field>
  1001. <field name="Accesses UAV" start="78" end="78" type="bool"/>
  1002. <field name="Illegal Opcode Exception Enable" start="77" end="77" type="bool"/>
  1003. <field name="Software Exception Enable" start="71" end="71" type="bool"/>
  1004. <field name="Scratch Space Base Pointer" start="106" end="127" type="address"/>
  1005. <field name="Per-Thread Scratch Space" start="96" end="99" type="uint"/>
  1006. <field name="Dispatch GRF Start Register For URB Data" start="148" end="152" type="uint"/>
  1007. <field name="Patch URB Entry Read Length" start="139" end="145" type="uint"/>
  1008. <field name="Patch URB Entry Read Offset" start="132" end="137" type="uint"/>
  1009. <field name="Maximum Number of Threads" start="181" end="189" type="uint"/>
  1010. <field name="Statistics Enable" start="170" end="170" type="bool"/>
  1011. <field name="Compute W Coordinate Enable" start="162" end="162" type="bool"/>
  1012. <field name="DS Cache Disable" start="161" end="161" type="bool"/>
  1013. <field name="Enable" start="160" end="160" type="bool"/>
  1014. </instruction>
  1015. <instruction name="3DSTATE_GATHER_CONSTANT_DS" bias="2">
  1016. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1017. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1018. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1019. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="55"/>
  1020. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1021. <field name="Constant Buffer Valid" start="48" end="63" type="uint"/>
  1022. <field name="Constant Buffer Binding Table Block" start="44" end="47" type="uint"/>
  1023. <field name="Gather Buffer Offset" start="70" end="86" type="offset"/>
  1024. <group count="0" start="96" size="32">
  1025. <field name="Entry_0" start="0" end="15" type="GATHER_CONSTANT_ENTRY"/>
  1026. <field name="Entry_1" start="16" end="31" type="GATHER_CONSTANT_ENTRY"/>
  1027. </group>
  1028. </instruction>
  1029. <instruction name="3DSTATE_GATHER_CONSTANT_GS" bias="2">
  1030. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1031. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1032. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1033. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="53"/>
  1034. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1035. <field name="Constant Buffer Valid" start="48" end="63" type="uint"/>
  1036. <field name="Constant Buffer Binding Table Block" start="44" end="47" type="uint"/>
  1037. <field name="Gather Buffer Offset" start="70" end="86" type="offset"/>
  1038. <group count="0" start="96" size="32">
  1039. <field name="Entry_0" start="0" end="15" type="GATHER_CONSTANT_ENTRY"/>
  1040. <field name="Entry_1" start="16" end="31" type="GATHER_CONSTANT_ENTRY"/>
  1041. </group>
  1042. </instruction>
  1043. <instruction name="3DSTATE_GATHER_CONSTANT_HS" bias="2">
  1044. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1045. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1046. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1047. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="54"/>
  1048. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1049. <field name="Constant Buffer Valid" start="48" end="63" type="uint"/>
  1050. <field name="Constant Buffer Binding Table Block" start="44" end="47" type="uint"/>
  1051. <field name="Gather Buffer Offset" start="70" end="86" type="offset"/>
  1052. <group count="0" start="96" size="32">
  1053. <field name="Entry_0" start="0" end="15" type="GATHER_CONSTANT_ENTRY"/>
  1054. <field name="Entry_1" start="16" end="31" type="GATHER_CONSTANT_ENTRY"/>
  1055. </group>
  1056. </instruction>
  1057. <instruction name="3DSTATE_GATHER_CONSTANT_PS" bias="2">
  1058. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1059. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1060. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1061. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="56"/>
  1062. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1063. <field name="Constant Buffer Valid" start="48" end="63" type="uint"/>
  1064. <field name="Constant Buffer Binding Table Block" start="44" end="47" type="uint"/>
  1065. <field name="Gather Buffer Offset" start="70" end="86" type="offset"/>
  1066. <field name="Constant Buffer Dx9 Enable" start="68" end="68" type="bool"/>
  1067. <group count="0" start="96" size="32">
  1068. <field name="Entry_0" start="0" end="15" type="GATHER_CONSTANT_ENTRY"/>
  1069. <field name="Entry_1" start="16" end="31" type="GATHER_CONSTANT_ENTRY"/>
  1070. </group>
  1071. </instruction>
  1072. <instruction name="3DSTATE_GATHER_CONSTANT_VS" bias="2">
  1073. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1074. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1075. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1076. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="52"/>
  1077. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1078. <field name="Constant Buffer Valid" start="48" end="63" type="uint"/>
  1079. <field name="Constant Buffer Binding Table Block" start="44" end="47" type="uint"/>
  1080. <field name="Gather Buffer Offset" start="70" end="86" type="offset"/>
  1081. <field name="Constant Buffer Dx9 Enable" start="68" end="68" type="bool"/>
  1082. <group count="0" start="96" size="32">
  1083. <field name="Entry_0" start="0" end="15" type="GATHER_CONSTANT_ENTRY"/>
  1084. <field name="Entry_1" start="16" end="31" type="GATHER_CONSTANT_ENTRY"/>
  1085. </group>
  1086. </instruction>
  1087. <instruction name="3DSTATE_GATHER_POOL_ALLOC" bias="2" length="3">
  1088. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1089. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1090. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1091. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="26"/>
  1092. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1093. <field name="Gather Pool Base Address" start="44" end="63" type="address"/>
  1094. <field name="Gather Pool Enable" start="43" end="43" type="bool"/>
  1095. <field start="36" end="37" type="mbo"/>
  1096. <field name="Memory Object Control State" start="32" end="35" type="MEMORY_OBJECT_CONTROL_STATE"/>
  1097. <field name="Gather Pool Upper Bound" start="76" end="95" type="address"/>
  1098. </instruction>
  1099. <instruction name="3DSTATE_GS" bias="2" length="7">
  1100. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1101. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1102. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1103. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="17"/>
  1104. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  1105. <field name="Kernel Start Pointer" start="38" end="63" type="offset"/>
  1106. <field name="Single Program Flow" start="95" end="95" type="bool"/>
  1107. <field name="Vector Mask Enable" start="94" end="94" type="bool"/>
  1108. <field name="Sampler Count" start="91" end="93" type="uint">
  1109. <value name="No Samplers" value="0"/>
  1110. <value name="1-4 Samplers" value="1"/>
  1111. <value name="5-8 Samplers" value="2"/>
  1112. <value name="9-12 Samplers" value="3"/>
  1113. <value name="13-16 Samplers" value="4"/>
  1114. </field>
  1115. <field name="Binding Table Entry Count" start="82" end="89" type="uint"/>
  1116. <field name="Thread Priority" start="81" end="81" type="uint">
  1117. <value name="Normal Priority" value="0"/>
  1118. <value name="High Priority" value="1"/>
  1119. </field>
  1120. <field name="Floating Point Mode" start="80" end="80" type="uint">
  1121. <value name="IEEE-754" value="0"/>
  1122. <value name="Alternate" value="1"/>
  1123. </field>
  1124. <field name="Illegal Opcode Exception Enable" start="77" end="77" type="bool"/>
  1125. <field name="GS accesses UAV" start="76" end="76" type="uint"/>
  1126. <field name="Mask Stack Exception Enable" start="75" end="75" type="bool"/>
  1127. <field name="Software Exception Enable" start="71" end="71" type="bool"/>
  1128. <field name="Scratch Space Base Pointer" start="106" end="127" type="address"/>
  1129. <field name="Per-Thread Scratch Space" start="96" end="99" type="uint"/>
  1130. <field name="Output Vertex Size" start="151" end="156" type="uint"/>
  1131. <field name="Output Topology" start="145" end="150" type="3D_Prim_Topo_Type"/>
  1132. <field name="Vertex URB Entry Read Length" start="139" end="144" type="uint"/>
  1133. <field name="Include Vertex Handles" start="138" end="138" type="bool"/>
  1134. <field name="Vertex URB Entry Read Offset" start="132" end="137" type="uint"/>
  1135. <field name="Dispatch GRF Start Register For URB Data" start="128" end="131" type="uint"/>
  1136. <field name="Maximum Number of Threads" start="184" end="191" type="uint"/>
  1137. <field name="Control Data Header Size" start="180" end="183" type="uint"/>
  1138. <field name="Instance Control" start="175" end="179" type="uint"/>
  1139. <field name="Default StreamID" start="173" end="174" type="uint"/>
  1140. <field name="Dispatch Mode" start="171" end="172" type="uint" prefix="DISPATCH_MODE">
  1141. <value name="SINGLE" value="0"/>
  1142. <value name="DUAL_INSTANCE" value="1"/>
  1143. <value name="DUAL_OBJECT" value="2"/>
  1144. </field>
  1145. <field name="Statistics Enable" start="170" end="170" type="uint"/>
  1146. <field name="GS Invocations Increment Value" start="165" end="169" type="uint"/>
  1147. <field name="Include Primitive ID" start="164" end="164" type="bool"/>
  1148. <field name="Hint" start="163" end="163" type="uint"/>
  1149. <field name="Reorder Mode" start="162" end="162" type="uint">
  1150. <value name="LEADING" value="0"/>
  1151. <value name="TRAILING" value="1"/>
  1152. </field>
  1153. <field name="Discard Adjacency" start="161" end="161" type="bool"/>
  1154. <field name="Enable" start="160" end="160" type="bool"/>
  1155. <field name="Control Data Format" start="223" end="223" type="uint">
  1156. <value name="GSCTL_CUT" value="0"/>
  1157. <value name="GSCTL_SID" value="1"/>
  1158. </field>
  1159. <field name="Semaphore Handle" start="192" end="204" type="offset"/>
  1160. </instruction>
  1161. <instruction name="3DSTATE_HIER_DEPTH_BUFFER" bias="2" length="3">
  1162. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1163. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1164. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1165. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="7"/>
  1166. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1167. <field name="Hierarchical Depth Buffer Object Control State" start="57" end="60" type="MEMORY_OBJECT_CONTROL_STATE"/>
  1168. <field name="Hierarchical Depth Buffer MOCS" start="57" end="60" type="uint"/>
  1169. <field name="Surface Pitch" start="32" end="48" type="uint"/>
  1170. <field name="Surface Base Address" start="64" end="95" type="address"/>
  1171. </instruction>
  1172. <instruction name="3DSTATE_HS" bias="2" length="7">
  1173. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1174. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1175. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1176. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="27"/>
  1177. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  1178. <field name="Sampler Count" start="59" end="61" type="uint">
  1179. <value name="No Samplers" value="0"/>
  1180. <value name="1-4 Samplers" value="1"/>
  1181. <value name="5-8 Samplers" value="2"/>
  1182. <value name="9-12 Samplers" value="3"/>
  1183. <value name="13-16 Samplers" value="4"/>
  1184. </field>
  1185. <field name="Binding Table Entry Count" start="50" end="57" type="uint"/>
  1186. <field name="Thread Dispatch Priority" start="49" end="49" type="uint">
  1187. <value name="High" value="1"/>
  1188. </field>
  1189. <field name="Floating Point Mode" start="48" end="48" type="uint">
  1190. <value name="IEEE-754" value="0"/>
  1191. <value name="Alternate" value="1"/>
  1192. </field>
  1193. <field name="Illegal Opcode Exception Enable" start="45" end="45" type="bool"/>
  1194. <field name="Software Exception Enable" start="44" end="44" type="bool"/>
  1195. <field name="Maximum Number of Threads" start="32" end="39" type="uint"/>
  1196. <field name="Enable" start="95" end="95" type="bool"/>
  1197. <field name="Statistics Enable" start="93" end="93" type="bool"/>
  1198. <field name="Instance Count" start="64" end="67" type="uint"/>
  1199. <field name="Kernel Start Pointer" start="102" end="127" type="offset"/>
  1200. <field name="Scratch Space Base Pointer" start="138" end="159" type="address"/>
  1201. <field name="Per-Thread Scratch Space" start="128" end="131" type="uint"/>
  1202. <field name="Single Program Flow" start="187" end="187" type="bool"/>
  1203. <field name="Vector Mask Enable" start="186" end="186" type="bool"/>
  1204. <field name="HS accesses UAV" start="185" end="185" type="bool"/>
  1205. <field name="Include Vertex Handles" start="184" end="184" type="bool"/>
  1206. <field name="Dispatch GRF Start Register For URB Data" start="179" end="183" type="uint"/>
  1207. <field name="Vertex URB Entry Read Length" start="171" end="176" type="uint"/>
  1208. <field name="Vertex URB Entry Read Offset" start="164" end="169" type="uint"/>
  1209. <field name="Semaphore Handle" start="192" end="204" type="offset"/>
  1210. </instruction>
  1211. <instruction name="3DSTATE_INDEX_BUFFER" bias="2" length="3">
  1212. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1213. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1214. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1215. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="10"/>
  1216. <field name="Memory Object Control State" start="12" end="15" type="MEMORY_OBJECT_CONTROL_STATE"/>
  1217. <field name="IndexBufferMOCS" start="12" end="15" type="uint"/>
  1218. <field name="Index Format" start="8" end="9" type="uint" prefix="INDEX">
  1219. <value name="BYTE" value="0"/>
  1220. <value name="WORD" value="1"/>
  1221. <value name="DWORD" value="2"/>
  1222. </field>
  1223. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1224. <field name="Buffer Starting Address" start="32" end="63" type="address"/>
  1225. <field name="Buffer Ending Address" start="64" end="95" type="address"/>
  1226. </instruction>
  1227. <instruction name="3DSTATE_LINE_STIPPLE" bias="2" length="3">
  1228. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1229. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1230. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1231. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="8"/>
  1232. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1233. <field name="Modify Enable (Current Repeat Counter, Current Stipple Index)" start="63" end="63" type="bool"/>
  1234. <field name="Current Repeat Counter" start="53" end="61" type="uint"/>
  1235. <field name="Current Stipple Index" start="48" end="51" type="uint"/>
  1236. <field name="Line Stipple Pattern" start="32" end="47" type="uint"/>
  1237. <field name="Line Stipple Inverse Repeat Count" start="79" end="95" type="u1.16"/>
  1238. <field name="Line Stipple Repeat Count" start="64" end="72" type="uint"/>
  1239. </instruction>
  1240. <instruction name="3DSTATE_MONOFILTER_SIZE" bias="2" length="2">
  1241. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1242. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1243. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1244. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="17"/>
  1245. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1246. <field name="Monochrome Filter Width" start="35" end="37" type="uint"/>
  1247. <field name="Monochrome Filter Height" start="32" end="34" type="uint"/>
  1248. </instruction>
  1249. <instruction name="3DSTATE_MULTISAMPLE" bias="2" length="4">
  1250. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1251. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1252. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1253. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="13"/>
  1254. <field name="DWord Length" start="0" end="7" type="uint" default="2"/>
  1255. <field name="Multi Sample Enable" start="37" end="37" type="bool"/>
  1256. <field name="Pixel Location" start="36" end="36" type="uint">
  1257. <value name="CENTER" value="0"/>
  1258. <value name="UL_CORNER" value="1"/>
  1259. </field>
  1260. <field name="Number of Multisamples" start="33" end="35" type="uint">
  1261. <value name="NUMSAMPLES_1" value="0"/>
  1262. <value name="NUMSAMPLES_4" value="2"/>
  1263. <value name="NUMSAMPLES_8" value="3"/>
  1264. </field>
  1265. <field name="Sample3 X Offset" start="92" end="95" type="u0.4"/>
  1266. <field name="Sample3 Y Offset" start="88" end="91" type="u0.4"/>
  1267. <field name="Sample2 X Offset" start="84" end="87" type="u0.4"/>
  1268. <field name="Sample2 Y Offset" start="80" end="83" type="u0.4"/>
  1269. <field name="Sample1 X Offset" start="76" end="79" type="u0.4"/>
  1270. <field name="Sample1 Y Offset" start="72" end="75" type="u0.4"/>
  1271. <field name="Sample0 X Offset" start="68" end="71" type="u0.4"/>
  1272. <field name="Sample0 Y Offset" start="64" end="67" type="u0.4"/>
  1273. <field name="Sample7 X Offset" start="124" end="127" type="u0.4"/>
  1274. <field name="Sample7 Y Offset" start="120" end="123" type="u0.4"/>
  1275. <field name="Sample6 X Offset" start="116" end="119" type="u0.4"/>
  1276. <field name="Sample6 Y Offset" start="112" end="115" type="u0.4"/>
  1277. <field name="Sample5 X Offset" start="108" end="111" type="u0.4"/>
  1278. <field name="Sample5 Y Offset" start="104" end="107" type="u0.4"/>
  1279. <field name="Sample4 X Offset" start="100" end="103" type="u0.4"/>
  1280. <field name="Sample4 Y Offset" start="96" end="99" type="u0.4"/>
  1281. </instruction>
  1282. <instruction name="3DSTATE_POLY_STIPPLE_OFFSET" bias="2" length="2">
  1283. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1284. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1285. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1286. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="6"/>
  1287. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1288. <field name="Polygon Stipple X Offset" start="40" end="44" type="uint"/>
  1289. <field name="Polygon Stipple Y Offset" start="32" end="36" type="uint"/>
  1290. </instruction>
  1291. <instruction name="3DSTATE_POLY_STIPPLE_PATTERN" bias="2" length="33">
  1292. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1293. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1294. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1295. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="7"/>
  1296. <field name="DWord Length" start="0" end="7" type="uint" default="31"/>
  1297. <group count="32" start="32" size="32">
  1298. <field name="Pattern Row" start="0" end="31" type="uint"/>
  1299. </group>
  1300. </instruction>
  1301. <instruction name="3DSTATE_PS" bias="2" length="8">
  1302. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1303. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1304. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1305. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="32"/>
  1306. <field name="DWord Length" start="0" end="7" type="uint" default="6"/>
  1307. <field name="Kernel Start Pointer 0" start="38" end="63" type="offset"/>
  1308. <field name="Single Program Flow" start="95" end="95" type="bool"/>
  1309. <field name="Vector Mask Enable" start="94" end="94" type="bool"/>
  1310. <field name="Sampler Count" start="91" end="93" type="uint"/>
  1311. <field name="Denormal Mode" start="90" end="90" type="uint">
  1312. <value name="FTZ" value="0"/>
  1313. <value name="RET" value="1"/>
  1314. </field>
  1315. <field name="Binding Table Entry Count" start="82" end="89" type="uint"/>
  1316. <field name="Thread Priority" start="81" end="81" type="uint">
  1317. <value name="High" value="1"/>
  1318. </field>
  1319. <field name="Floating Point Mode" start="80" end="80" type="uint">
  1320. <value name="IEEE-754" value="0"/>
  1321. <value name="Alternate" value="1"/>
  1322. </field>
  1323. <field name="Rounding Mode" start="78" end="79" type="uint">
  1324. <value name="RTNE" value="0"/>
  1325. <value name="RU" value="1"/>
  1326. <value name="RD" value="2"/>
  1327. <value name="RTZ" value="3"/>
  1328. </field>
  1329. <field name="Illegal Opcode Exception Enable" start="77" end="77" type="bool"/>
  1330. <field name="Mask Stack Exception Enable" start="75" end="75" type="bool"/>
  1331. <field name="Software Exception Enable" start="71" end="71" type="bool"/>
  1332. <field name="Scratch Space Base Pointer" start="106" end="127" type="address"/>
  1333. <field name="Per Thread Scratch Space" start="96" end="99" type="uint"/>
  1334. <field name="Maximum Number of Threads" start="151" end="159" type="uint"/>
  1335. <field name="Sample Mask" start="140" end="147" type="uint"/>
  1336. <field name="Push Constant Enable" start="139" end="139" type="bool"/>
  1337. <field name="Attribute Enable" start="138" end="138" type="bool"/>
  1338. <field name="oMask Present to RenderTarget" start="137" end="137" type="bool"/>
  1339. <field name="Render Target Fast Clear Enable" start="136" end="136" type="bool"/>
  1340. <field name="Dual Source Blend Enable" start="135" end="135" type="bool"/>
  1341. <field name="Render Target Resolve Enable" start="134" end="134" type="bool"/>
  1342. <field name="PS Accesses UAV" start="133" end="133" type="bool"/>
  1343. <field name="Position XY Offset Select" start="131" end="132" type="uint">
  1344. <value name="POSOFFSET_NONE" value="0"/>
  1345. <value name="POSOFFSET_CENTROID" value="2"/>
  1346. <value name="POSOFFSET_SAMPLE" value="3"/>
  1347. </field>
  1348. <field name="32 Pixel Dispatch Enable" start="130" end="130" type="bool"/>
  1349. <field name="16 Pixel Dispatch Enable" start="129" end="129" type="bool"/>
  1350. <field name="8 Pixel Dispatch Enable" start="128" end="128" type="bool"/>
  1351. <field name="Dispatch GRF Start Register For Constant/Setup Data 0" start="176" end="182" type="uint"/>
  1352. <field name="Dispatch GRF Start Register For Constant/Setup Data 1" start="168" end="174" type="uint"/>
  1353. <field name="Dispatch GRF Start Register For Constant/Setup Data 2" start="160" end="166" type="uint"/>
  1354. <field name="Kernel Start Pointer 1" start="198" end="223" type="offset"/>
  1355. <field name="Kernel Start Pointer 2" start="230" end="255" type="offset"/>
  1356. </instruction>
  1357. <instruction name="3DSTATE_PUSH_CONSTANT_ALLOC_DS" bias="2" length="2">
  1358. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1359. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1360. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1361. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="20"/>
  1362. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1363. <field name="Constant Buffer Offset" start="48" end="52" type="uint"/>
  1364. <field name="Constant Buffer Size" start="32" end="37" type="uint"/>
  1365. </instruction>
  1366. <instruction name="3DSTATE_PUSH_CONSTANT_ALLOC_GS" bias="2" length="2">
  1367. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1368. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1369. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1370. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="21"/>
  1371. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1372. <field name="Constant Buffer Offset" start="48" end="52" type="uint"/>
  1373. <field name="Constant Buffer Size" start="32" end="37" type="uint"/>
  1374. </instruction>
  1375. <instruction name="3DSTATE_PUSH_CONSTANT_ALLOC_HS" bias="2" length="2">
  1376. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1377. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1378. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1379. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="19"/>
  1380. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1381. <field name="Constant Buffer Offset" start="48" end="52" type="uint"/>
  1382. <field name="Constant Buffer Size" start="32" end="37" type="uint"/>
  1383. </instruction>
  1384. <instruction name="3DSTATE_PUSH_CONSTANT_ALLOC_PS" bias="2" length="2">
  1385. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1386. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1387. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1388. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="22"/>
  1389. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1390. <field name="Constant Buffer Offset" start="48" end="52" type="uint"/>
  1391. <field name="Constant Buffer Size" start="32" end="37" type="uint"/>
  1392. </instruction>
  1393. <instruction name="3DSTATE_PUSH_CONSTANT_ALLOC_VS" bias="2" length="2">
  1394. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1395. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1396. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1397. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="18"/>
  1398. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1399. <field name="Constant Buffer Offset" start="48" end="52" type="uint"/>
  1400. <field name="Constant Buffer Size" start="32" end="37" type="uint"/>
  1401. </instruction>
  1402. <instruction name="3DSTATE_RAST_MULTISAMPLE" bias="2" length="6">
  1403. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1404. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1405. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1406. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="14"/>
  1407. <field name="DWord Length" start="0" end="7" type="uint" default="4"/>
  1408. <field name="Number of Rasterization Multisamples" start="33" end="35" type="uint" prefix="NRM">
  1409. <value name="NUMRASTSAMPLES_1" value="0"/>
  1410. <value name="NUMRASTSAMPLES_2" value="1"/>
  1411. <value name="NUMRASTSAMPLES_4" value="2"/>
  1412. <value name="NUMRASTSAMPLES_8" value="3"/>
  1413. <value name="NUMRASTSAMPLES_16" value="4"/>
  1414. </field>
  1415. <field name="Sample3 X Offset" start="92" end="95" type="u0.4"/>
  1416. <field name="Sample3 Y Offset" start="88" end="91" type="u0.4"/>
  1417. <field name="Sample2 X Offset" start="84" end="87" type="u0.4"/>
  1418. <field name="Sample2 Y Offset" start="80" end="83" type="u0.4"/>
  1419. <field name="Sample1 X Offset" start="76" end="79" type="u0.4"/>
  1420. <field name="Sample1 Y Offset" start="72" end="75" type="u0.4"/>
  1421. <field name="Sample0 X Offset" start="68" end="71" type="u0.4"/>
  1422. <field name="Sample0 Y Offset" start="64" end="67" type="u0.4"/>
  1423. <field name="Sample7 X Offset" start="124" end="127" type="u0.4"/>
  1424. <field name="Sample7 Y Offset" start="120" end="123" type="u0.4"/>
  1425. <field name="Sample6 X Offset" start="116" end="119" type="u0.4"/>
  1426. <field name="Sample6 Y Offset" start="112" end="115" type="u0.4"/>
  1427. <field name="Sample5 X Offset" start="108" end="111" type="u0.4"/>
  1428. <field name="Sample5 Y Offset" start="104" end="107" type="u0.4"/>
  1429. <field name="Sample4 X Offset" start="100" end="103" type="u0.4"/>
  1430. <field name="Sample4 Y Offset" start="96" end="99" type="u0.4"/>
  1431. <field name="Sample11 X Offset" start="156" end="159" type="u0.4"/>
  1432. <field name="Sample11 Y Offset" start="152" end="155" type="u0.4"/>
  1433. <field name="Sample10 X Offset" start="148" end="151" type="u0.4"/>
  1434. <field name="Sample10 Y Offset" start="144" end="147" type="u0.4"/>
  1435. <field name="Sample9 X Offset" start="140" end="143" type="u0.4"/>
  1436. <field name="Sample9 Y Offset" start="136" end="139" type="u0.4"/>
  1437. <field name="Sample8 X Offset" start="132" end="135" type="u0.4"/>
  1438. <field name="Sample8 Y Offset" start="128" end="131" type="u0.4"/>
  1439. <field name="Sample15 X Offset" start="188" end="191" type="u0.4"/>
  1440. <field name="Sample15 Y Offset" start="184" end="187" type="u0.4"/>
  1441. <field name="Sample14 X Offset" start="180" end="183" type="u0.4"/>
  1442. <field name="Sample14 Y Offset" start="176" end="179" type="u0.4"/>
  1443. <field name="Sample13 X Offset" start="172" end="175" type="u0.4"/>
  1444. <field name="Sample13 Y Offset" start="168" end="171" type="u0.4"/>
  1445. <field name="Sample12 X Offset" start="164" end="167" type="u0.4"/>
  1446. <field name="Sample12 Y Offset" start="160" end="163" type="u0.4"/>
  1447. </instruction>
  1448. <instruction name="3DSTATE_SAMPLER_PALETTE_LOAD0" bias="2">
  1449. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1450. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1451. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1452. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="2"/>
  1453. <field name="DWord Length" start="0" end="7" type="uint"/>
  1454. <group count="0" start="32" size="32">
  1455. <field name="Entry" start="0" end="31" type="PALETTE_ENTRY"/>
  1456. </group>
  1457. </instruction>
  1458. <instruction name="3DSTATE_SAMPLER_PALETTE_LOAD1" bias="2">
  1459. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1460. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1461. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1462. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="12"/>
  1463. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1464. <group count="0" start="32" size="32">
  1465. <field name="Palette Alpha[0:N-1]" start="24" end="31" type="uint"/>
  1466. <field name="Palette Red[0:N-1]" start="16" end="23" type="uint"/>
  1467. <field name="Palette Green[0:N-1]" start="8" end="15" type="uint"/>
  1468. <field name="Palette Blue[0:N-1]" start="0" end="7" type="uint"/>
  1469. </group>
  1470. </instruction>
  1471. <instruction name="3DSTATE_SAMPLER_STATE_POINTERS_DS" bias="2" length="2">
  1472. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1473. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1474. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1475. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="45"/>
  1476. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1477. <field name="Pointer to DS Sampler State" start="37" end="63" type="offset"/>
  1478. </instruction>
  1479. <instruction name="3DSTATE_SAMPLER_STATE_POINTERS_GS" bias="2" length="2">
  1480. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1481. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1482. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1483. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="46"/>
  1484. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1485. <field name="Pointer to GS Sampler State" start="37" end="63" type="offset"/>
  1486. </instruction>
  1487. <instruction name="3DSTATE_SAMPLER_STATE_POINTERS_HS" bias="2" length="2">
  1488. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1489. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1490. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1491. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="44"/>
  1492. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1493. <field name="Pointer to HS Sampler State" start="37" end="63" type="offset"/>
  1494. </instruction>
  1495. <instruction name="3DSTATE_SAMPLER_STATE_POINTERS_PS" bias="2" length="2">
  1496. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1497. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1498. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1499. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="47"/>
  1500. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1501. <field name="Pointer to PS Sampler State" start="37" end="63" type="offset"/>
  1502. </instruction>
  1503. <instruction name="3DSTATE_SAMPLER_STATE_POINTERS_VS" bias="2" length="2">
  1504. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1505. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1506. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1507. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="43"/>
  1508. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1509. <field name="Pointer to VS Sampler State" start="37" end="63" type="offset"/>
  1510. </instruction>
  1511. <instruction name="3DSTATE_SAMPLE_MASK" bias="2" length="2">
  1512. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1513. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1514. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1515. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="24"/>
  1516. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1517. <field name="Sample Mask" start="32" end="39" type="uint"/>
  1518. </instruction>
  1519. <instruction name="3DSTATE_SBE" bias="2" length="14">
  1520. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1521. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1522. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1523. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="31"/>
  1524. <field name="DWord Length" start="0" end="7" type="uint" default="12"/>
  1525. <field name="Attribute Swizzle Control Mode" start="60" end="60" type="uint"/>
  1526. <field name="Number of SF Output Attributes" start="54" end="59" type="uint"/>
  1527. <field name="Attribute Swizzle Enable" start="53" end="53" type="bool"/>
  1528. <field name="Point Sprite Texture Coordinate Origin" start="52" end="52" type="uint">
  1529. <value name="UPPERLEFT" value="0"/>
  1530. <value name="LOWERLEFT" value="1"/>
  1531. </field>
  1532. <field name="Vertex URB Entry Read Length" start="43" end="47" type="uint"/>
  1533. <field name="Vertex URB Entry Read Offset" start="36" end="41" type="uint"/>
  1534. <group count="16" start="64" size="16">
  1535. <field name="Attribute" start="0" end="15" type="SF_OUTPUT_ATTRIBUTE_DETAIL"/>
  1536. </group>
  1537. <field name="Point Sprite Texture Coordinate Enable" start="320" end="351" type="uint"/>
  1538. <field name="Constant Interpolation Enable" start="352" end="383" type="uint"/>
  1539. <field name="Attribute 7 WrapShortest Enables" start="412" end="415" type="uint"/>
  1540. <field name="Attribute 6 WrapShortest Enables" start="408" end="411" type="uint"/>
  1541. <field name="Attribute 5 WrapShortest Enables" start="404" end="407" type="uint"/>
  1542. <field name="Attribute 4 WrapShortest Enables" start="400" end="403" type="uint"/>
  1543. <field name="Attribute 3 WrapShortest Enables" start="396" end="399" type="uint"/>
  1544. <field name="Attribute 2 WrapShortest Enables" start="392" end="395" type="uint"/>
  1545. <field name="Attribute 1 WrapShortest Enables" start="388" end="391" type="uint"/>
  1546. <field name="Attribute 0 WrapShortest Enables" start="384" end="387" type="uint"/>
  1547. <field name="Attribute 15 WrapShortest Enables" start="444" end="447" type="uint"/>
  1548. <field name="Attribute 14 WrapShortest Enables" start="440" end="443" type="uint"/>
  1549. <field name="Attribute 13 WrapShortest Enables" start="436" end="439" type="uint"/>
  1550. <field name="Attribute 12 WrapShortest Enables" start="432" end="435" type="uint"/>
  1551. <field name="Attribute 11 WrapShortest Enables" start="428" end="431" type="uint"/>
  1552. <field name="Attribute 10 WrapShortest Enables" start="424" end="427" type="uint"/>
  1553. <field name="Attribute 9 WrapShortest Enables" start="420" end="423" type="uint"/>
  1554. <field name="Attribute 8 WrapShortest Enables" start="416" end="419" type="uint"/>
  1555. </instruction>
  1556. <instruction name="3DSTATE_SCISSOR_STATE_POINTERS" bias="2" length="2">
  1557. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1558. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1559. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1560. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="15"/>
  1561. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1562. <field name="Scissor Rect Pointer" start="37" end="63" type="offset"/>
  1563. </instruction>
  1564. <instruction name="3DSTATE_SF" bias="2" length="7">
  1565. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1566. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1567. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1568. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="19"/>
  1569. <field name="DWord Length" start="0" end="7" type="uint" default="5"/>
  1570. <field name="Depth Buffer Surface Format" start="44" end="46" type="uint">
  1571. <value name="D32_FLOAT_S8X24_UINT" value="0"/>
  1572. <value name="D32_FLOAT" value="1"/>
  1573. <value name="D24_UNORM_S8_UINT" value="2"/>
  1574. <value name="D24_UNORM_X8_UINT" value="3"/>
  1575. <value name="D16_UNORM" value="5"/>
  1576. </field>
  1577. <field name="Legacy Global Depth Bias Enable" start="43" end="43" type="bool"/>
  1578. <field name="Statistics Enable" start="42" end="42" type="bool"/>
  1579. <field name="Global Depth Offset Enable Solid" start="41" end="41" type="bool"/>
  1580. <field name="Global Depth Offset Enable Wireframe" start="40" end="40" type="bool"/>
  1581. <field name="Global Depth Offset Enable Point" start="39" end="39" type="bool"/>
  1582. <field name="FrontFace Fill Mode" start="37" end="38" type="uint" prefix="FILL_MODE">
  1583. <value name="SOLID" value="0"/>
  1584. <value name="WIREFRAME" value="1"/>
  1585. <value name="POINT" value="2"/>
  1586. </field>
  1587. <field name="BackFace Fill Mode" start="35" end="36" type="uint" prefix="FILL_MODE">
  1588. <value name="SOLID" value="0"/>
  1589. <value name="WIREFRAME" value="1"/>
  1590. <value name="POINT" value="2"/>
  1591. </field>
  1592. <field name="Viewport Transform Enable" start="33" end="33" type="bool"/>
  1593. <field name="Front Winding" start="32" end="32" type="uint"/>
  1594. <field name="Anti-Aliasing Enable" start="95" end="95" type="bool"/>
  1595. <field name="Cull Mode" start="93" end="94" type="uint" prefix="CULLMODE">
  1596. <value name="BOTH" value="0"/>
  1597. <value name="NONE" value="1"/>
  1598. <value name="FRONT" value="2"/>
  1599. <value name="BACK" value="3"/>
  1600. </field>
  1601. <field name="Line Width" start="82" end="91" type="u3.7"/>
  1602. <field name="Line End Cap Antialiasing Region Width" start="80" end="81" type="uint">
  1603. <value name="0.5 pixels" value="0"/>
  1604. <value name="1.0 pixels" value="1"/>
  1605. <value name="2.0 pixels" value="2"/>
  1606. <value name="4.0 pixels" value="3"/>
  1607. </field>
  1608. <field name="Line Stipple Enable" start="78" end="78" type="bool"/>
  1609. <field name="Scissor Rectangle Enable" start="75" end="75" type="bool"/>
  1610. <field name="RT Independent Rasterization Enable" start="74" end="74" type="bool"/>
  1611. <field name="Multisample Rasterization Mode" start="72" end="73" type="uint"/>
  1612. <field name="Last Pixel Enable" start="127" end="127" type="bool"/>
  1613. <field name="Triangle Strip/List Provoking Vertex Select" start="125" end="126" type="uint">
  1614. <value name="Vertex 0" value="0"/>
  1615. <value name="Vertex 1" value="1"/>
  1616. <value name="Vertex 2" value="2"/>
  1617. </field>
  1618. <field name="Line Strip/List Provoking Vertex Select" start="123" end="124" type="uint"/>
  1619. <field name="Triangle Fan Provoking Vertex Select" start="121" end="122" type="uint">
  1620. <value name="Vertex 0" value="0"/>
  1621. <value name="Vertex 1" value="1"/>
  1622. <value name="Vertex 2" value="2"/>
  1623. </field>
  1624. <field name="AA Line Distance Mode" start="110" end="110" type="uint">
  1625. <value name="AALINEDISTANCE_TRUE" value="1"/>
  1626. </field>
  1627. <field name="Vertex Sub Pixel Precision Select" start="108" end="108" type="uint"/>
  1628. <field name="Point Width Source" start="107" end="107" type="uint">
  1629. <value name="Vertex" value="0"/>
  1630. <value name="State" value="1"/>
  1631. </field>
  1632. <field name="Point Width" start="96" end="106" type="u8.3"/>
  1633. <field name="Global Depth Offset Constant" start="128" end="159" type="float"/>
  1634. <field name="Global Depth Offset Scale" start="160" end="191" type="float"/>
  1635. <field name="Global Depth Offset Clamp" start="192" end="223" type="float"/>
  1636. </instruction>
  1637. <instruction name="3DSTATE_SO_BUFFER" bias="2" length="4">
  1638. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1639. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1640. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1641. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="24"/>
  1642. <field name="DWord Length" start="0" end="7" type="uint" default="2"/>
  1643. <field name="SO Buffer Index" start="61" end="62" type="uint"/>
  1644. <field name="SO Buffer Object Control State" start="57" end="60" type="MEMORY_OBJECT_CONTROL_STATE"/>
  1645. <field name="SO Buffer MOCS" start="57" end="60" type="uint"/>
  1646. <field name="Surface Pitch" start="32" end="43" type="uint"/>
  1647. <field name="Surface Base Address" start="66" end="95" type="address"/>
  1648. <field name="Surface End Address" start="98" end="127" type="address"/>
  1649. </instruction>
  1650. <instruction name="3DSTATE_SO_DECL_LIST" bias="2">
  1651. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1652. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1653. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1654. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="23"/>
  1655. <field name="DWord Length" start="0" end="8" type="uint"/>
  1656. <field name="Stream to Buffer Selects [3]" start="44" end="47" type="uint"/>
  1657. <field name="Stream to Buffer Selects [2]" start="40" end="43" type="uint"/>
  1658. <field name="Stream to Buffer Selects [1]" start="36" end="39" type="uint"/>
  1659. <field name="Stream to Buffer Selects [0]" start="32" end="35" type="uint"/>
  1660. <field name="Num Entries [3]" start="88" end="95" type="uint"/>
  1661. <field name="Num Entries [2]" start="80" end="87" type="uint"/>
  1662. <field name="Num Entries [1]" start="72" end="79" type="uint"/>
  1663. <field name="Num Entries [0]" start="64" end="71" type="uint"/>
  1664. <group count="0" start="96" size="64">
  1665. <field name="Entry" start="0" end="63" type="SO_DECL_ENTRY"/>
  1666. </group>
  1667. </instruction>
  1668. <instruction name="3DSTATE_STENCIL_BUFFER" bias="2" length="3">
  1669. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1670. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1671. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1672. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="6"/>
  1673. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1674. <field name="Stencil Buffer Enable" start="63" end="63" type="bool"/>
  1675. <field name="Stencil Buffer Object Control State" start="57" end="60" type="MEMORY_OBJECT_CONTROL_STATE"/>
  1676. <field name="Stencil Buffer MOCS" start="57" end="60" type="uint"/>
  1677. <field name="Surface Pitch" start="32" end="48" type="uint"/>
  1678. <field name="Surface Base Address" start="64" end="95" type="address"/>
  1679. </instruction>
  1680. <instruction name="3DSTATE_STREAMOUT" bias="2" length="3">
  1681. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1682. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1683. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1684. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="30"/>
  1685. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1686. <field name="SO Function Enable" start="63" end="63" type="bool"/>
  1687. <field name="Rendering Disable" start="62" end="62" type="bool"/>
  1688. <field name="Render Stream Select" start="59" end="60" type="uint"/>
  1689. <field name="Reorder Mode" start="58" end="58" type="uint">
  1690. <value name="LEADING" value="0"/>
  1691. <value name="TRAILING" value="1"/>
  1692. </field>
  1693. <field name="SO Statistics Enable" start="57" end="57" type="bool"/>
  1694. <field name="SO Buffer Enable [3]" start="43" end="43" type="bool"/>
  1695. <field name="SO Buffer Enable [2]" start="42" end="42" type="bool"/>
  1696. <field name="SO Buffer Enable [1]" start="41" end="41" type="bool"/>
  1697. <field name="SO Buffer Enable [0]" start="40" end="40" type="bool"/>
  1698. <field name="Stream 3 Vertex Read Offset" start="93" end="93" type="uint"/>
  1699. <field name="Stream 3 Vertex Read Length" start="88" end="92" type="uint"/>
  1700. <field name="Stream 2 Vertex Read Offset" start="85" end="85" type="uint"/>
  1701. <field name="Stream 2 Vertex Read Length" start="80" end="84" type="uint"/>
  1702. <field name="Stream 1 Vertex Read Offset" start="77" end="77" type="uint"/>
  1703. <field name="Stream 1 Vertex Read Length" start="72" end="76" type="uint"/>
  1704. <field name="Stream 0 Vertex Read Offset" start="69" end="69" type="uint"/>
  1705. <field name="Stream 0 Vertex Read Length" start="64" end="68" type="uint"/>
  1706. </instruction>
  1707. <instruction name="3DSTATE_TE" bias="2" length="4">
  1708. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1709. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1710. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1711. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="28"/>
  1712. <field name="DWord Length" start="0" end="7" type="uint" default="2"/>
  1713. <field name="Partitioning" start="44" end="45" type="uint">
  1714. <value name="INTEGER" value="0"/>
  1715. <value name="ODD_FRACTIONAL" value="1"/>
  1716. <value name="EVEN_FRACTIONAL" value="2"/>
  1717. </field>
  1718. <field name="Output Topology" start="40" end="41" type="uint" prefix="OUTPUT">
  1719. <value name="POINT" value="0"/>
  1720. <value name="LINE" value="1"/>
  1721. <value name="TRI_CW" value="2"/>
  1722. <value name="TRI_CCW" value="3"/>
  1723. </field>
  1724. <field name="TE Domain" start="36" end="37" type="uint">
  1725. <value name="QUAD" value="0"/>
  1726. <value name="TRI" value="1"/>
  1727. <value name="ISOLINE" value="2"/>
  1728. </field>
  1729. <field name="TE Mode" start="33" end="34" type="uint">
  1730. <value name="HW_TESS" value="0"/>
  1731. <value name="SW_TESS" value="1"/>
  1732. </field>
  1733. <field name="TE Enable" start="32" end="32" type="bool"/>
  1734. <field name="Maximum Tessellation Factor Odd" start="64" end="95" type="float"/>
  1735. <field name="Maximum Tessellation Factor Not Odd" start="96" end="127" type="float"/>
  1736. </instruction>
  1737. <instruction name="3DSTATE_URB_DS" bias="2" length="2">
  1738. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1739. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1740. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1741. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="50"/>
  1742. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1743. <field name="DS URB Starting Address" start="57" end="62" type="uint"/>
  1744. <field name="DS URB Entry Allocation Size" start="48" end="56" type="uint"/>
  1745. <field name="DS Number of URB Entries" start="32" end="47" type="uint"/>
  1746. </instruction>
  1747. <instruction name="3DSTATE_URB_GS" bias="2" length="2">
  1748. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1749. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1750. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1751. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="51"/>
  1752. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1753. <field name="GS URB Starting Address" start="57" end="62" type="uint"/>
  1754. <field name="GS URB Entry Allocation Size" start="48" end="56" type="uint"/>
  1755. <field name="GS Number of URB Entries" start="32" end="47" type="uint"/>
  1756. </instruction>
  1757. <instruction name="3DSTATE_URB_HS" bias="2" length="2">
  1758. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1759. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1760. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1761. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="49"/>
  1762. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1763. <field name="HS URB Starting Address" start="57" end="62" type="uint"/>
  1764. <field name="HS URB Entry Allocation Size" start="48" end="56" type="uint"/>
  1765. <field name="HS Number of URB Entries" start="32" end="47" type="uint"/>
  1766. </instruction>
  1767. <instruction name="3DSTATE_URB_VS" bias="2" length="2">
  1768. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1769. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1770. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1771. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="48"/>
  1772. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1773. <field name="VS URB Starting Address" start="57" end="62" type="uint"/>
  1774. <field name="VS URB Entry Allocation Size" start="48" end="56" type="uint"/>
  1775. <field name="VS Number of URB Entries" start="32" end="47" type="uint"/>
  1776. </instruction>
  1777. <instruction name="3DSTATE_VERTEX_BUFFERS" bias="2">
  1778. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1779. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1780. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1781. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="8"/>
  1782. <field name="DWord Length" start="0" end="7" type="uint" default="3"/>
  1783. <group count="0" start="32" size="128">
  1784. <field name="Vertex Buffer State" start="0" end="127" type="VERTEX_BUFFER_STATE"/>
  1785. </group>
  1786. </instruction>
  1787. <instruction name="3DSTATE_VERTEX_ELEMENTS" bias="2">
  1788. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1789. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1790. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1791. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="9"/>
  1792. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1793. <group count="0" start="32" size="64">
  1794. <field name="Element" start="0" end="63" type="VERTEX_ELEMENT_STATE"/>
  1795. </group>
  1796. </instruction>
  1797. <instruction name="3DSTATE_VF" bias="2" length="2">
  1798. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1799. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1800. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1801. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="12"/>
  1802. <field name="Indexed Draw Cut Index Enable" start="8" end="8" type="bool"/>
  1803. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1804. <field name="Cut Index" start="32" end="63" type="uint"/>
  1805. </instruction>
  1806. <instruction name="3DSTATE_VF_STATISTICS" bias="1" length="1">
  1807. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1808. <field name="Command SubType" start="27" end="28" type="uint" default="1"/>
  1809. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1810. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="11"/>
  1811. <field name="Statistics Enable" start="0" end="0" type="bool"/>
  1812. </instruction>
  1813. <instruction name="3DSTATE_VIEWPORT_STATE_POINTERS_CC" bias="2" length="2">
  1814. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1815. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1816. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1817. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="35"/>
  1818. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1819. <field name="CC Viewport Pointer" start="37" end="63" type="offset"/>
  1820. </instruction>
  1821. <instruction name="3DSTATE_VIEWPORT_STATE_POINTERS_SF_CLIP" bias="2" length="2">
  1822. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1823. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1824. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1825. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="33"/>
  1826. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1827. <field name="SF Clip Viewport Pointer" start="38" end="63" type="offset"/>
  1828. </instruction>
  1829. <instruction name="3DSTATE_VS" bias="2" length="6">
  1830. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1831. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1832. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1833. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="16"/>
  1834. <field name="DWord Length" start="0" end="7" type="uint" default="4"/>
  1835. <field name="Kernel Start Pointer" start="38" end="63" type="offset"/>
  1836. <field name="Single Vertex Dispatch" start="95" end="95" type="bool"/>
  1837. <field name="Vector Mask Enable" start="94" end="94" type="bool"/>
  1838. <field name="Sampler Count" start="91" end="93" type="uint">
  1839. <value name="No Samplers" value="0"/>
  1840. <value name="1-4 Samplers" value="1"/>
  1841. <value name="5-8 Samplers" value="2"/>
  1842. <value name="9-12 Samplers" value="3"/>
  1843. <value name="13-16 Samplers" value="4"/>
  1844. </field>
  1845. <field name="Binding Table Entry Count" start="82" end="89" type="uint"/>
  1846. <field name="Thread Priority" start="81" end="81" type="uint">
  1847. <value name="Normal Priority" value="0"/>
  1848. <value name="High Priority" value="1"/>
  1849. </field>
  1850. <field name="Floating Point Mode" start="80" end="80" type="uint">
  1851. <value name="IEEE-754" value="0"/>
  1852. <value name="Alternate" value="1"/>
  1853. </field>
  1854. <field name="Illegal Opcode Exception Enable" start="77" end="77" type="bool"/>
  1855. <field name="VS accesses UAV" start="76" end="76" type="bool"/>
  1856. <field name="Software Exception Enable" start="71" end="71" type="bool"/>
  1857. <field name="Scratch Space Base Pointer" start="106" end="127" type="address"/>
  1858. <field name="Per-Thread Scratch Space" start="96" end="99" type="uint"/>
  1859. <field name="Dispatch GRF Start Register For URB Data" start="148" end="152" type="uint"/>
  1860. <field name="Vertex URB Entry Read Length" start="139" end="144" type="uint"/>
  1861. <field name="Vertex URB Entry Read Offset" start="132" end="137" type="uint"/>
  1862. <field name="Maximum Number of Threads" start="183" end="191" type="uint"/>
  1863. <field name="Statistics Enable" start="170" end="170" type="bool"/>
  1864. <field name="Vertex Cache Disable" start="161" end="161" type="bool"/>
  1865. <field name="Enable" start="160" end="160" type="bool"/>
  1866. </instruction>
  1867. <instruction name="3DSTATE_WM" bias="2" length="3">
  1868. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1869. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  1870. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  1871. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="20"/>
  1872. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  1873. <field name="Statistics Enable" start="63" end="63" type="bool"/>
  1874. <field name="Depth Buffer Clear" start="62" end="62" type="bool"/>
  1875. <field name="Thread Dispatch Enable" start="61" end="61" type="bool"/>
  1876. <field name="Depth Buffer Resolve Enable" start="60" end="60" type="bool"/>
  1877. <field name="Hierarchical Depth Buffer Resolve Enable" start="59" end="59" type="bool"/>
  1878. <field name="Legacy Diamond Line Rasterization" start="58" end="58" type="bool"/>
  1879. <field name="Pixel Shader Kills Pixel" start="57" end="57" type="bool"/>
  1880. <field name="Pixel Shader Computed Depth Mode" start="55" end="56" type="uint">
  1881. <value name="PSCDEPTH_OFF" value="0"/>
  1882. <value name="PSCDEPTH_ON" value="1"/>
  1883. <value name="PSCDEPTH_ON_GE" value="2"/>
  1884. <value name="PSCDEPTH_ON_LE" value="3"/>
  1885. </field>
  1886. <field name="Early Depth/Stencil Control" start="53" end="54" type="uint">
  1887. <value name="EDSC_NORMAL" value="0"/>
  1888. <value name="EDSC_PSEXEC" value="1"/>
  1889. <value name="EDSC_PREPS" value="2"/>
  1890. </field>
  1891. <field name="Pixel Shader Uses Source Depth" start="52" end="52" type="bool"/>
  1892. <field name="Pixel Shader Uses Source W" start="51" end="51" type="bool"/>
  1893. <field name="Position ZW Interpolation Mode" start="49" end="50" type="uint">
  1894. <value name="INTERP_PIXEL" value="0"/>
  1895. <value name="INTERP_CENTROID" value="2"/>
  1896. <value name="INTERP_SAMPLE" value="3"/>
  1897. </field>
  1898. <field name="Barycentric Interpolation Mode" start="43" end="48" type="uint">
  1899. <value name="BIM_PERSPECTIVE_PIXEL" value="1"/>
  1900. <value name="BIM_PERSPECTIVE_CENTROID" value ="2"/>
  1901. <value name="BIM_PERSPECTIVE_SAMPLE" value="4"/>
  1902. <value name="BIM_LINEAR_PIXEL" value="8"/>
  1903. <value name="BIM_LINEAR_CENTROID" value="16"/>
  1904. <value name="BIM_LINEAR_SAMPLE" value="32"/>
  1905. </field>
  1906. <field name="Pixel Shader Uses Input Coverage Mask" start="42" end="42" type="bool"/>
  1907. <field name="Line End Cap Antialiasing Region Width" start="40" end="41" type="uint"/>
  1908. <field name="Line Antialiasing Region Width" start="38" end="39" type="uint">
  1909. <value name="0.5 pixels" value="0"/>
  1910. <value name="1.0 pixels" value="1"/>
  1911. <value name="2.0 pixels" value="2"/>
  1912. <value name="4.0 pixels" value="3"/>
  1913. </field>
  1914. <field name="RT Independent Rasterization Enable" start="37" end="37" type="bool"/>
  1915. <field name="Polygon Stipple Enable" start="36" end="36" type="bool"/>
  1916. <field name="Line Stipple Enable" start="35" end="35" type="bool"/>
  1917. <field name="Point Rasterization Rule" start="34" end="34" type="uint">
  1918. <value name="RASTRULE_UPPER_LEFT" value="0"/>
  1919. <value name="RASTRULE_UPPER_RIGHT" value="1"/>
  1920. </field>
  1921. <field name="Multisample Rasterization Mode" start="32" end="33" type="uint">
  1922. <value name="MSRASTMODE_OFF_PIXEL" value="0"/>
  1923. <value name="MSRASTMODE_OFF_PATTERN" value="1"/>
  1924. <value name="MSRASTMODE_ON_PIXEL" value="2"/>
  1925. <value name="MSRASTMODE_ON_PATTERN" value="3"/>
  1926. </field>
  1927. <field name="Multisample Dispatch Mode" start="95" end="95" type="uint">
  1928. <value name="MSDISPMODE_PERSAMPLE" value="0"/>
  1929. <value name="MSDISPMODE_PERPIXEL" value="1"/>
  1930. </field>
  1931. <field name="PS UAV-only" start="94" end="94" type="uint">
  1932. <value name="OFF" value="0"/>
  1933. <value name="ON" value="1"/>
  1934. </field>
  1935. </instruction>
  1936. <instruction name="GPGPU_CSR_BASE_ADDRESS" bias="2" length="2">
  1937. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1938. <field name="Command SubType" start="27" end="28" type="uint" default="0"/>
  1939. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  1940. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="4"/>
  1941. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  1942. <field name="GPGPU CSR Base Address" start="44" end="63" type="address"/>
  1943. </instruction>
  1944. <instruction name="GPGPU_OBJECT" bias="2" length="8">
  1945. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1946. <field name="Pipeline" start="27" end="28" type="uint" default="2"/>
  1947. <field name="Media Command Opcode" start="24" end="26" type="uint" default="1"/>
  1948. <field name="SubOpcode" start="16" end="23" type="uint" default="4"/>
  1949. <field name="Predicate Enable" start="8" end="8" type="bool"/>
  1950. <field name="DWord Length" start="0" end="7" type="uint" default="6"/>
  1951. <field name="Shared Local Memory Fixed Offset" start="39" end="39" type="uint"/>
  1952. <field name="Interface Descriptor Offset" start="32" end="37" type="uint"/>
  1953. <field name="Shared Local Memory Offset" start="92" end="95" type="uint"/>
  1954. <field name="End of Thread Group" start="88" end="88" type="uint"/>
  1955. <field name="Slice Destination Select" start="83" end="83" type="uint">
  1956. <value name="Slice 0" value="0"/>
  1957. <value name="Slice 1" value="1"/>
  1958. </field>
  1959. <field name="Half-Slice Destination Select" start="81" end="82" type="uint">
  1960. <value name="Half-Slice 1" value="2"/>
  1961. <value name="Half-Slice 0" value="1"/>
  1962. <value name="Either Half-Slice" value="0"/>
  1963. </field>
  1964. <field name="Indirect Data Length" start="64" end="80" type="uint"/>
  1965. <field name="Indirect Data Start Address" start="96" end="127" type="offset"/>
  1966. <field name="Thread Group ID X" start="128" end="159" type="uint"/>
  1967. <field name="Thread Group ID Y" start="160" end="191" type="uint"/>
  1968. <field name="Thread Group ID Z" start="192" end="223" type="uint"/>
  1969. <field name="Execution Mask" start="224" end="255" type="uint"/>
  1970. </instruction>
  1971. <instruction name="GPGPU_WALKER" bias="2" length="11">
  1972. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1973. <field name="Pipeline" start="27" end="28" type="uint" default="2"/>
  1974. <field name="Media Command Opcode" start="24" end="26" type="uint" default="1"/>
  1975. <field name="SubOpcode A" start="16" end="23" type="uint" default="5"/>
  1976. <field name="Indirect Parameter Enable" start="10" end="10" type="bool"/>
  1977. <field name="Predicate Enable" start="8" end="8" type="bool"/>
  1978. <field name="DWord Length" start="0" end="7" type="uint" default="9"/>
  1979. <field name="Interface Descriptor Offset" start="32" end="37" type="uint"/>
  1980. <field name="SIMD Size" start="94" end="95" type="uint">
  1981. <value name="SIMD8" value="0"/>
  1982. <value name="SIMD16" value="1"/>
  1983. <value name="SIMD32" value="2"/>
  1984. </field>
  1985. <field name="Thread Depth Counter Maximum" start="80" end="85" type="uint"/>
  1986. <field name="Thread Height Counter Maximum" start="72" end="77" type="uint"/>
  1987. <field name="Thread Width Counter Maximum" start="64" end="69" type="uint"/>
  1988. <field name="Thread Group ID Starting X" start="96" end="127" type="uint"/>
  1989. <field name="Thread Group ID X Dimension" start="128" end="159" type="uint"/>
  1990. <field name="Thread Group ID Starting Y" start="160" end="191" type="uint"/>
  1991. <field name="Thread Group ID Y Dimension" start="192" end="223" type="uint"/>
  1992. <field name="Thread Group ID Starting Z" start="224" end="255" type="uint"/>
  1993. <field name="Thread Group ID Z Dimension" start="256" end="287" type="uint"/>
  1994. <field name="Right Execution Mask" start="288" end="319" type="uint"/>
  1995. <field name="Bottom Execution Mask" start="320" end="351" type="uint"/>
  1996. </instruction>
  1997. <instruction name="MEDIA_CURBE_LOAD" bias="2" length="4">
  1998. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  1999. <field name="Pipeline" start="27" end="28" type="uint" default="2"/>
  2000. <field name="Media Command Opcode" start="24" end="26" type="uint" default="0"/>
  2001. <field name="SubOpcode" start="16" end="23" type="uint" default="1"/>
  2002. <field name="DWord Length" start="0" end="15" type="uint" default="2"/>
  2003. <field name="CURBE Total Data Length" start="64" end="80" type="uint"/>
  2004. <field name="CURBE Data Start Address" start="96" end="127" type="uint"/>
  2005. </instruction>
  2006. <instruction name="MEDIA_INTERFACE_DESCRIPTOR_LOAD" bias="2" length="4">
  2007. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2008. <field name="Pipeline" start="27" end="28" type="uint" default="2"/>
  2009. <field name="Media Command Opcode" start="24" end="26" type="uint" default="0"/>
  2010. <field name="SubOpcode" start="16" end="23" type="uint" default="2"/>
  2011. <field name="DWord Length" start="0" end="15" type="uint" default="2"/>
  2012. <field name="Interface Descriptor Total Length" start="64" end="80" type="uint"/>
  2013. <field name="Interface Descriptor Data Start Address" start="96" end="127" type="offset"/>
  2014. </instruction>
  2015. <instruction name="MEDIA_OBJECT" bias="2">
  2016. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2017. <field name="Media Command Pipeline" start="27" end="28" type="uint" default="2"/>
  2018. <field name="Media Command Opcode" start="24" end="26" type="uint" default="1"/>
  2019. <field name="Media Command Sub-Opcode" start="16" end="23" type="uint" default="0"/>
  2020. <field name="DWord Length" start="0" end="15" type="uint" default="4"/>
  2021. <field name="Interface Descriptor Offset" start="32" end="37" type="uint"/>
  2022. <field name="Children Present" start="95" end="95" type="bool"/>
  2023. <field name="Thread Synchronization" start="88" end="88" type="uint">
  2024. <value name="No thread synchronization" value="0"/>
  2025. <value name="Thread dispatch is synchronized by the 'spawn root thread' message" value="1"/>
  2026. </field>
  2027. <field name="Use Scoreboard" start="85" end="85" type="uint">
  2028. <value name="Not using scoreboard" value="0"/>
  2029. <value name="Using scoreboard" value="1"/>
  2030. </field>
  2031. <field name="Slice Destination Select" start="83" end="83" type="uint">
  2032. <value name="Slice 0" value="0"/>
  2033. <value name="Slice 1" value="1"/>
  2034. <value name="Either Slice" value="0"/>
  2035. </field>
  2036. <field name="Half-Slice Destination Select" start="81" end="82" type="uint">
  2037. <value name="Half-Slice 1" value="2"/>
  2038. <value name="Half-Slice 0" value="1"/>
  2039. <value name="Either half-slice" value="0"/>
  2040. </field>
  2041. <field name="Indirect Data Length" start="64" end="80" type="uint"/>
  2042. <field name="Indirect Data Start Address" start="96" end="127" type="address"/>
  2043. <field name="Scoredboard Y" start="144" end="152" type="uint"/>
  2044. <field name="Scoreboard X" start="128" end="136" type="uint"/>
  2045. <field name="Scoreboard Color" start="176" end="179" type="uint"/>
  2046. <field name="Scoreboard Mask" start="160" end="167" type="uint"/>
  2047. <group count="0" start="192" size="32">
  2048. <field name="Inline Data" start="0" end="31" type="uint"/>
  2049. </group>
  2050. </instruction>
  2051. <instruction name="MEDIA_OBJECT_PRT" bias="2" length="16">
  2052. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2053. <field name="Pipeline" start="27" end="28" type="uint" default="2"/>
  2054. <field name="Media Command Opcode" start="24" end="26" type="uint" default="1"/>
  2055. <field name="SubOpcode" start="16" end="23" type="uint" default="2"/>
  2056. <field name="DWord Length" start="0" end="15" type="uint" default="14"/>
  2057. <field name="Interface Descriptor Offset" start="32" end="37" type="uint"/>
  2058. <field name="Children Present" start="95" end="95" type="bool"/>
  2059. <field name="PRT_Fence Needed" start="87" end="87" type="bool"/>
  2060. <field name="PRT_FenceType" start="86" end="86" type="uint">
  2061. <value name="Root thread queue" value="0"/>
  2062. <value name="VFE state flush" value="1"/>
  2063. </field>
  2064. <group count="12" start="128" size="32">
  2065. <field name="Inline Data" start="0" end="31" type="uint"/>
  2066. </group>
  2067. </instruction>
  2068. <instruction name="MEDIA_OBJECT_WALKER" bias="2">
  2069. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2070. <field name="Pipeline" start="27" end="28" type="uint" default="2"/>
  2071. <field name="Media Command Opcode" start="24" end="26" type="uint" default="1"/>
  2072. <field name="SubOpcode" start="16" end="23" type="uint" default="3"/>
  2073. <field name="DWord Length" start="0" end="15" type="uint" default="15"/>
  2074. <field name="Interface Descriptor Offset" start="32" end="37" type="uint"/>
  2075. <field name="Children Present" start="95" end="95" type="uint"/>
  2076. <field name="Thread Synchronization" start="88" end="88" type="uint">
  2077. <value name="No thread synchronization" value="0"/>
  2078. <value name="Thread dispatch is synchronized by the 'spawn root thread' message" value="1"/>
  2079. </field>
  2080. <field name="Use Scoreboard" start="85" end="85" type="uint">
  2081. <value name="Not using scoreboard" value="0"/>
  2082. <value name="Using scoreboard" value="1"/>
  2083. </field>
  2084. <field name="Indirect Data Length" start="64" end="80" type="uint"/>
  2085. <field name="Indirect Data Start Address" start="96" end="127" type="offset"/>
  2086. <field name="Scoreboard Mask" start="160" end="167" type="uint"/>
  2087. <field name="Dual Mode" start="223" end="223" type="uint"/>
  2088. <field name="Repel" start="222" end="222" type="uint"/>
  2089. <field name="Quad Mode" start="221" end="221" type="uint"/>
  2090. <field name="Color Count Minus One" start="216" end="219" type="uint"/>
  2091. <field name="Middle Loop Extra Steps" start="208" end="212" type="uint"/>
  2092. <field name="Local Mid-Loop Unit Y" start="204" end="205" type="int"/>
  2093. <field name="Mid-Loop Unit X" start="200" end="201" type="int"/>
  2094. <field name="Global Loop Exec Count" start="240" end="249" type="uint"/>
  2095. <field name="Local Loop Exec Count" start="224" end="233" type="uint"/>
  2096. <field name="Block Resolution Y" start="272" end="280" type="uint"/>
  2097. <field name="Block Resolution X" start="256" end="264" type="uint"/>
  2098. <field name="Local Start Y" start="304" end="312" type="uint"/>
  2099. <field name="Local Start X" start="288" end="296" type="uint"/>
  2100. <field name="Local Outer Loop Stride Y" start="368" end="377" type="int"/>
  2101. <field name="Local Outer Loop Stride X" start="352" end="361" type="int"/>
  2102. <field name="Local Inner Loop Unit Y" start="400" end="409" type="int"/>
  2103. <field name="Local Inner Loop Unit X" start="384" end="393" type="int"/>
  2104. <field name="Global Resolution Y" start="432" end="440" type="uint"/>
  2105. <field name="Global Resolution X" start="416" end="424" type="uint"/>
  2106. <field name="Global Start Y" start="464" end="473" type="int"/>
  2107. <field name="Global Start X" start="448" end="457" type="int"/>
  2108. <field name="Global Outer Loop Stride Y" start="496" end="505" type="int"/>
  2109. <field name="Global Outer Loop Stride X" start="480" end="489" type="int"/>
  2110. <field name="Global Inner Loop Unit Y" start="528" end="537" type="int"/>
  2111. <field name="Global Inner Loop Unit X" start="512" end="521" type="int"/>
  2112. <group count="0" start="544" size="32">
  2113. <field name="Inline Data" start="0" end="31" type="uint"/>
  2114. </group>
  2115. </instruction>
  2116. <instruction name="MEDIA_STATE_FLUSH" bias="2" length="2">
  2117. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2118. <field name="Pipeline" start="27" end="28" type="uint" default="2"/>
  2119. <field name="Media Command Opcode" start="24" end="26" type="uint" default="0"/>
  2120. <field name="SubOpcode" start="16" end="23" type="uint" default="4"/>
  2121. <field name="DWord Length" start="0" end="15" type="uint" default="0"/>
  2122. <field name="Disable Preemption" start="40" end="40" type="bool"/>
  2123. <field name="Flush to GO" start="39" end="39" type="bool"/>
  2124. <field name="Watermark Required" start="38" end="38" type="uint"/>
  2125. <field name="Interface Descriptor Offset" start="32" end="37" type="uint"/>
  2126. </instruction>
  2127. <instruction name="MEDIA_VFE_STATE" bias="2" length="8">
  2128. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2129. <field name="Pipeline" start="27" end="28" type="uint" default="2"/>
  2130. <field name="Media Command Opcode" start="24" end="26" type="uint" default="0"/>
  2131. <field name="SubOpcode" start="16" end="23" type="uint" default="0"/>
  2132. <field name="DWord Length" start="0" end="15" type="uint" default="6"/>
  2133. <field name="Scratch Space Base Pointer" start="42" end="63" type="address"/>
  2134. <field name="Stack Size" start="36" end="39" type="uint"/>
  2135. <field name="Per Thread Scratch Space" start="32" end="35" type="uint"/>
  2136. <field name="Maximum Number of Threads" start="80" end="95" type="uint"/>
  2137. <field name="Number of URB Entries" start="72" end="79" type="uint"/>
  2138. <field name="Reset Gateway Timer" start="71" end="71" type="uint">
  2139. <value name="Maintaining the existing timestamp state" value="0"/>
  2140. <value name="Resetting relative timer and latching the global timestamp" value="1"/>
  2141. </field>
  2142. <field name="Bypass Gateway Control" start="70" end="70" type="uint">
  2143. <value name="Maintaining OpenGateway/ForwardMsg/CloseGateway protocol (legacy mode)" value="0"/>
  2144. <value name="Bypassing OpenGateway/CloseGateway protocol" value="1"/>
  2145. </field>
  2146. <field name="GPGPU Mode" start="66" end="66" type="uint"/>
  2147. <field name="Half-Slice Disable" start="96" end="97" type="uint"/>
  2148. <field name="URB Entry Allocation Size" start="144" end="159" type="uint"/>
  2149. <field name="CURBE Allocation Size" start="128" end="143" type="uint"/>
  2150. <field name="Scoreboard Enable" start="191" end="191" type="uint">
  2151. <value name="Scoreboard disabled" value="0"/>
  2152. <value name="Scoreboard enabled" value="1"/>
  2153. </field>
  2154. <field name="Scoreboard Type" start="190" end="190" type="uint">
  2155. <value name="Stalling Scoreboard" value="0"/>
  2156. <value name="Non-Stalling Scoreboard" value="1"/>
  2157. </field>
  2158. <field name="Scoreboard Mask" start="160" end="167" type="uint"/>
  2159. <field name="Scoreboard 3 Delta Y" start="220" end="223" type="int"/>
  2160. <field name="Scoreboard 3 Delta X" start="216" end="219" type="int"/>
  2161. <field name="Scoreboard 2 Delta Y" start="212" end="215" type="int"/>
  2162. <field name="Scoreboard 2 Delta X" start="208" end="211" type="int"/>
  2163. <field name="Scoreboard 1 Delta Y" start="204" end="207" type="int"/>
  2164. <field name="Scoreboard 1 Delta X" start="200" end="203" type="int"/>
  2165. <field name="Scoreboard 0 Delta Y" start="196" end="199" type="int"/>
  2166. <field name="Scoreboard 0 Delta X" start="192" end="195" type="int"/>
  2167. <field name="Scoreboard 7 Delta Y" start="252" end="255" type="int"/>
  2168. <field name="Scoreboard 7 Delta X" start="248" end="251" type="int"/>
  2169. <field name="Scoreboard 6 Delta Y" start="244" end="247" type="int"/>
  2170. <field name="Scoreboard 6 Delta X" start="240" end="243" type="int"/>
  2171. <field name="Scoreboard 5 Delta Y" start="236" end="239" type="int"/>
  2172. <field name="Scoreboard 5 Delta X" start="232" end="235" type="int"/>
  2173. <field name="Scoreboard 4 Delta Y" start="228" end="231" type="int"/>
  2174. <field name="Scoreboard 4 Delta X" start="224" end="227" type="int"/>
  2175. </instruction>
  2176. <instruction name="MI_ARB_CHECK" bias="1" length="1">
  2177. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2178. <field name="MI Command Opcode" start="23" end="28" type="uint" default="5"/>
  2179. </instruction>
  2180. <instruction name="MI_ARB_ON_OFF" bias="1" length="1">
  2181. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2182. <field name="MI Command Opcode" start="23" end="28" type="uint" default="8"/>
  2183. <field name="Arbitration Enable" start="0" end="0" type="bool"/>
  2184. </instruction>
  2185. <instruction name="MI_BATCH_BUFFER_END" bias="1" length="1">
  2186. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2187. <field name="MI Command Opcode" start="23" end="28" type="uint" default="10"/>
  2188. </instruction>
  2189. <instruction name="MI_BATCH_BUFFER_START" bias="2" length="2">
  2190. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2191. <field name="MI Command Opcode" start="23" end="28" type="uint" default="49"/>
  2192. <field name="2nd Level Batch Buffer" start="22" end="22" type="uint">
  2193. <value name="1st level batch" value="0"/>
  2194. <value name="2nd level batch" value="1"/>
  2195. </field>
  2196. <field name="Add Offset Enable" start="16" end="16" type="bool"/>
  2197. <field name="Predication Enable" start="15" end="15" type="bool"/>
  2198. <field name="Non-Privileged" start="13" end="13" type="bool"/>
  2199. <field name="Clear Command Buffer Enable" start="11" end="11" type="bool"/>
  2200. <field name="Resource Streamer Enable" start="10" end="10" type="bool"/>
  2201. <field name="Address Space Indicator" start="8" end="8" type="uint" prefix="ASI">
  2202. <value name="GGTT" value="0"/>
  2203. <value name="PPGTT" value="1"/>
  2204. </field>
  2205. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  2206. <field name="Batch Buffer Start Address" start="34" end="63" type="address"/>
  2207. </instruction>
  2208. <instruction name="MI_CLFLUSH" bias="2">
  2209. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2210. <field name="MI Command Opcode" start="23" end="28" type="uint" default="39"/>
  2211. <field name="Use Global GTT" start="22" end="22" type="bool"/>
  2212. <field name="DWord Length" start="0" end="9" type="uint" default="1"/>
  2213. <field name="Page Base Address" start="44" end="63" type="address"/>
  2214. <field name="Starting Cacheline Offset" start="38" end="43" type="uint"/>
  2215. <field name="Page Base Address High" start="64" end="79" type="address"/>
  2216. <group count="0" start="96" size="32">
  2217. <field name="DW Representing a Half Cache Line" start="0" end="31" type="uint"/>
  2218. </group>
  2219. </instruction>
  2220. <instruction name="MI_CONDITIONAL_BATCH_BUFFER_END" bias="2" length="2">
  2221. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2222. <field name="MI Command Opcode" start="23" end="28" type="uint" default="54"/>
  2223. <field name="Use Global GTT" start="22" end="22" type="bool"/>
  2224. <field name="Compare Semaphore" start="21" end="21" type="uint" default="0"/>
  2225. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  2226. <field name="Compare Data Dword" start="32" end="63" type="uint"/>
  2227. <field name="Compare Address" start="67" end="95" type="address"/>
  2228. </instruction>
  2229. <instruction name="MI_FLUSH" bias="1" length="1">
  2230. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2231. <field name="MI Command Opcode" start="23" end="28" type="uint" default="4"/>
  2232. <field name="Indirect State Pointers Disable" start="5" end="5" type="bool"/>
  2233. <field name="Generic Media State Clear" start="4" end="4" type="bool"/>
  2234. <field name="Global Snapshot Count Reset" start="3" end="3" type="uint">
  2235. <value name="Don't Reset" value="0"/>
  2236. <value name="Reset" value="1"/>
  2237. </field>
  2238. <field name="Render Cache Flush Inhibit" start="2" end="2" type="uint">
  2239. <value name="Flush" value="0"/>
  2240. <value name="Don't Flush" value="1"/>
  2241. </field>
  2242. <field name="State/Instruction Cache Invalidate" start="1" end="1" type="uint">
  2243. <value name="Don't Invalidate" value="0"/>
  2244. <value name="Invalidate" value="1"/>
  2245. </field>
  2246. </instruction>
  2247. <instruction name="MI_LOAD_REGISTER_IMM" bias="2" length="3">
  2248. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2249. <field name="MI Command Opcode" start="23" end="28" type="uint" default="34"/>
  2250. <field name="Byte Write Disables" start="8" end="11" type="uint"/>
  2251. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  2252. <field name="Register Offset" start="34" end="54" type="offset"/>
  2253. <field name="Data DWord" start="64" end="95" type="uint"/>
  2254. </instruction>
  2255. <instruction name="MI_LOAD_REGISTER_MEM" bias="2" length="3">
  2256. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2257. <field name="MI Command Opcode" start="23" end="28" type="uint" default="41"/>
  2258. <field name="Use Global GTT" start="22" end="22" type="bool"/>
  2259. <field name="Async Mode Enable" start="21" end="21" type="bool"/>
  2260. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  2261. <field name="Register Address" start="34" end="54" type="offset"/>
  2262. <field name="Memory Address" start="66" end="95" type="address"/>
  2263. </instruction>
  2264. <instruction name="MI_LOAD_REGISTER_REG" bias="2" length="3">
  2265. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2266. <field name="MI Command Opcode" start="23" end="28" type="uint" default="42"/>
  2267. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  2268. <field name="Source Register Address" start="34" end="54" type="offset"/>
  2269. <field name="Destination Register Address" start="66" end="86" type="offset"/>
  2270. </instruction>
  2271. <instruction name="MI_LOAD_SCAN_LINES_EXCL" bias="2" length="2">
  2272. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2273. <field name="MI Command Opcode" start="23" end="28" type="uint" default="19"/>
  2274. <field name="Display (Plane) Select" start="19" end="21" type="uint">
  2275. <value name="Display Plane A" value="0"/>
  2276. <value name="Display Plane B" value="1"/>
  2277. <value name="Display Plane C" value="4"/>
  2278. </field>
  2279. <field name="DWord Length" start="0" end="5" type="uint" default="0"/>
  2280. <field name="Start Scan Line Number" start="48" end="60" type="uint"/>
  2281. <field name="End Scan Line Number" start="32" end="44" type="uint"/>
  2282. </instruction>
  2283. <instruction name="MI_LOAD_SCAN_LINES_INCL" bias="2" length="2">
  2284. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2285. <field name="MI Command Opcode" start="23" end="28" type="uint" default="18"/>
  2286. <field name="Display (Plane) Select" start="19" end="21" type="uint">
  2287. <value name="Display Plane A" value="0"/>
  2288. <value name="Display Plane B" value="1"/>
  2289. <value name="Display Plane C" value="4"/>
  2290. </field>
  2291. <field name="DWord Length" start="0" end="5" type="uint" default="0"/>
  2292. <field name="Start Scan Line Number" start="48" end="60" type="uint"/>
  2293. <field name="End Scan Line Number" start="32" end="44" type="uint"/>
  2294. </instruction>
  2295. <instruction name="MI_LOAD_URB_MEM" bias="2" length="3">
  2296. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2297. <field name="MI Command Opcode" start="23" end="28" type="uint" default="44"/>
  2298. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  2299. <field name="URB Address" start="34" end="46" type="uint"/>
  2300. <field name="Memory Address" start="70" end="95" type="address"/>
  2301. </instruction>
  2302. <instruction name="MI_MATH" bias="2">
  2303. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2304. <field name="MI Command Opcode" start="23" end="28" type="uint" default="26"/>
  2305. <field name="DWord Length" start="0" end="5" type="uint" default="0"/>
  2306. <group count="0" start="32" size="32">
  2307. <field name="Instruction" start="0" end="31" type="MI_MATH_ALU_INSTRUCTION"/>
  2308. </group>
  2309. </instruction>
  2310. <instruction name="MI_NOOP" bias="1" length="1">
  2311. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2312. <field name="MI Command Opcode" start="23" end="28" type="uint" default="0"/>
  2313. <field name="Identification Number Register Write Enable" start="22" end="22" type="bool"/>
  2314. <field name="Identification Number" start="0" end="21" type="uint"/>
  2315. </instruction>
  2316. <instruction name="MI_PREDICATE" bias="1" length="1">
  2317. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2318. <field name="MI Command Opcode" start="23" end="28" type="uint" default="12"/>
  2319. <field name="Load Operation" start="6" end="7" type="uint" prefix="LOAD">
  2320. <value name="KEEP" value="0"/>
  2321. <value name="LOAD" value="2"/>
  2322. <value name="LOADINV" value="3"/>
  2323. </field>
  2324. <field name="Combine Operation" start="3" end="4" type="uint" prefix="COMBINE">
  2325. <value name="SET" value="0"/>
  2326. <value name="AND" value="1"/>
  2327. <value name="OR" value="2"/>
  2328. <value name="XOR" value="3"/>
  2329. </field>
  2330. <field name="Compare Operation" start="0" end="1" type="uint" prefix="COMPARE">
  2331. <value name="SRCS_EQUAL" value="2"/>
  2332. <value name="DELTAS_EQUAL" value="3"/>
  2333. </field>
  2334. </instruction>
  2335. <instruction name="MI_REPORT_HEAD" bias="1" length="1">
  2336. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2337. <field name="MI Command Opcode" start="23" end="28" type="uint" default="7"/>
  2338. </instruction>
  2339. <instruction name="MI_REPORT_PERF_COUNT" bias="2" length="3">
  2340. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2341. <field name="MI Command Opcode" start="23" end="28" type="uint" default="40"/>
  2342. <field name="DWord Length" start="0" end="5" type="uint" default="1"/>
  2343. <field name="Memory Address" start="38" end="63" type="address"/>
  2344. <field name="Core Mode Enable" start="36" end="36" type="uint"/>
  2345. <field name="Use Global GTT" start="32" end="32" type="bool"/>
  2346. <field name="Report ID" start="64" end="95" type="uint"/>
  2347. </instruction>
  2348. <instruction name="MI_RS_CONTEXT" bias="1" length="1">
  2349. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2350. <field name="MI Command Opcode" start="23" end="28" type="uint" default="15"/>
  2351. <field name="Resource Streamer Save" start="0" end="0" type="uint" prefix="RS">
  2352. <value name="Restore" value="0"/>
  2353. <value name="Save" value="1"/>
  2354. </field>
  2355. </instruction>
  2356. <instruction name="MI_RS_CONTROL" bias="1" length="1">
  2357. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2358. <field name="MI Command Opcode" start="23" end="28" type="uint" default="6"/>
  2359. <field name="Resource Streamer Control" start="0" end="0" type="uint" prefix="RS">
  2360. <value name="Stop" value="0"/>
  2361. <value name="Start" value="1"/>
  2362. </field>
  2363. </instruction>
  2364. <instruction name="MI_RS_STORE_DATA_IMM" bias="2" length="4">
  2365. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2366. <field name="MI Command Opcode" start="23" end="28" type="uint" default="43"/>
  2367. <field name="DWord Length" start="0" end="7" type="uint" default="2"/>
  2368. <field name="Destination Address" start="66" end="95" type="address"/>
  2369. <field name="Core Mode Enable" start="64" end="64" type="uint"/>
  2370. <field name="Data DWord 0" start="96" end="127" type="uint"/>
  2371. </instruction>
  2372. <instruction name="MI_SEMAPHORE_MBOX" bias="2" length="3">
  2373. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2374. <field name="MI Command Opcode" start="23" end="28" type="uint" default="22"/>
  2375. <field name="Register Select" start="16" end="17" type="uint">
  2376. <value name="RVSYNC" value="0"/>
  2377. <value name="RVESYNC" value="1"/>
  2378. <value name="RBSYNC" value="2"/>
  2379. <value name="Use General Register Select" value="3"/>
  2380. </field>
  2381. <field name="General Register Select" start="8" end="13" type="uint"/>
  2382. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  2383. <field name="Semaphore Data Dword" start="32" end="63" type="uint"/>
  2384. </instruction>
  2385. <instruction name="MI_SET_CONTEXT" bias="2" length="2">
  2386. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2387. <field name="MI Command Opcode" start="23" end="28" type="uint" default="24"/>
  2388. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  2389. <field name="Logical Context Address" start="44" end="63" type="address"/>
  2390. <field name="Reserved, Must be 1" start="40" end="40" type="uint"/>
  2391. <field name="Core Mode Enable" start="36" end="36" type="bool"/>
  2392. <field name="Resource Streamer State Save Enable" start="35" end="35" type="bool"/>
  2393. <field name="Resource Streamer State Restore Enable" start="34" end="34" type="bool"/>
  2394. <field name="Force Restore" start="33" end="33" type="uint"/>
  2395. <field name="Restore Inhibit" start="32" end="32" type="uint"/>
  2396. </instruction>
  2397. <instruction name="MI_SET_PREDICATE" bias="1" length="1">
  2398. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2399. <field name="MI Command Opcode" start="23" end="28" type="uint" default="1"/>
  2400. <field name="PREDICATE ENABLE" start="0" end="1" type="bool" default="6"/>
  2401. </instruction>
  2402. <instruction name="MI_STORE_DATA_IMM" bias="2" length="4">
  2403. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2404. <field name="MI Command Opcode" start="23" end="28" type="uint" default="32"/>
  2405. <field name="Use Global GTT" start="22" end="22" type="bool"/>
  2406. <field name="DWord Length" start="0" end="5" type="uint" default="2"/>
  2407. <field name="Address" start="66" end="95" type="address"/>
  2408. <field name="Core Mode Enable" start="64" end="64" type="uint"/>
  2409. <field name="Immediate Data" start="96" end="159" type="uint"/>
  2410. </instruction>
  2411. <instruction name="MI_STORE_DATA_INDEX" bias="2" length="3">
  2412. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2413. <field name="MI Command Opcode" start="23" end="28" type="uint" default="33"/>
  2414. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  2415. <field name="Offset" start="34" end="43" type="uint"/>
  2416. <field name="Data DWord 0" start="64" end="95" type="uint"/>
  2417. <field name="Data DWord 1" start="96" end="127" type="uint"/>
  2418. </instruction>
  2419. <instruction name="MI_STORE_REGISTER_MEM" bias="2" length="3">
  2420. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2421. <field name="MI Command Opcode" start="23" end="28" type="uint" default="36"/>
  2422. <field name="Use Global GTT" start="22" end="22" type="bool"/>
  2423. <field name="Predicate Enable" start="21" end="21" type="bool"/>
  2424. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  2425. <field name="Register Address" start="34" end="54" type="offset"/>
  2426. <field name="Memory Address" start="66" end="95" type="address"/>
  2427. </instruction>
  2428. <instruction name="MI_STORE_URB_MEM" bias="2" length="3">
  2429. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2430. <field name="MI Command Opcode" start="23" end="28" type="uint" default="45"/>
  2431. <field name="DWord Length" start="0" end="7" type="uint" default="1"/>
  2432. <field name="URB Address" start="34" end="46" type="uint"/>
  2433. <field name="Memory Address" start="70" end="95" type="address"/>
  2434. </instruction>
  2435. <instruction name="MI_SUSPEND_FLUSH" bias="1" length="1">
  2436. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2437. <field name="MI Command Opcode" start="23" end="28" type="uint" default="11"/>
  2438. <field name="Suspend Flush" start="0" end="0" type="bool"/>
  2439. </instruction>
  2440. <instruction name="MI_TOPOLOGY_FILTER" bias="1" length="1">
  2441. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2442. <field name="MI Command Opcode" start="23" end="28" type="uint" default="13"/>
  2443. <field name="Topology Filter Value" start="0" end="5" type="3D_Prim_Topo_Type"/>
  2444. </instruction>
  2445. <instruction name="MI_URB_ATOMIC_ALLOC" bias="1" length="1">
  2446. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2447. <field name="MI Command Opcode" start="23" end="28" type="uint" default="9"/>
  2448. <field name="URB Atomic Storage Offset" start="12" end="19" type="uint"/>
  2449. <field name="URB Atomic Storage Size" start="0" end="8" type="uint"/>
  2450. </instruction>
  2451. <instruction name="MI_URB_CLEAR" bias="2" length="2">
  2452. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2453. <field name="MI Command Opcode" start="23" end="28" type="uint" default="25"/>
  2454. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  2455. <field name="URB Clear Length" start="48" end="61" type="uint"/>
  2456. <field name="URB Address" start="32" end="46" type="offset"/>
  2457. </instruction>
  2458. <instruction name="MI_USER_INTERRUPT" bias="1" length="1">
  2459. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2460. <field name="MI Command Opcode" start="23" end="28" type="uint" default="2"/>
  2461. </instruction>
  2462. <instruction name="MI_WAIT_FOR_EVENT" bias="1" length="1">
  2463. <field name="Command Type" start="29" end="31" type="uint" default="0"/>
  2464. <field name="MI Command Opcode" start="23" end="28" type="uint" default="3"/>
  2465. <field name="Display Pipe C Horizontal Blank Wait Enable" start="22" end="22" type="bool"/>
  2466. <field name="Display Pipe C Vertical Blank Wait Enable" start="21" end="21" type="bool"/>
  2467. <field name="Display Sprite C Flip Pending Wait Enable" start="20" end="20" type="bool"/>
  2468. <field name="Condition Code Wait Select" start="16" end="19" type="uint">
  2469. <value name="Not enabled" value="0"/>
  2470. </field>
  2471. <field name="Display Plane C Flip Pending Wait Enable" start="15" end="15" type="bool"/>
  2472. <field name="Display Pipe C Scan Line Wait Enable" start="14" end="14" type="bool"/>
  2473. <field name="Display Pipe B Horizontal Blank Wait Enable" start="13" end="13" type="bool"/>
  2474. <field name="Display Pipe B Vertical Blank Wait Enable" start="11" end="11" type="bool"/>
  2475. <field name="Display Sprite B Flip Pending Wait Enable" start="10" end="10" type="bool"/>
  2476. <field name="Display Plane B Flip Pending Wait Enable" start="9" end="9" type="bool"/>
  2477. <field name="Display Pipe B Scan Line Wait Enable" start="8" end="8" type="bool"/>
  2478. <field name="Display Pipe A Horizontal Blank Wait Enable" start="5" end="5" type="bool"/>
  2479. <field name="Display Pipe A Vertical Blank Wait Enable" start="3" end="3" type="bool"/>
  2480. <field name="Display Sprite A Flip Pending Wait Enable" start="2" end="2" type="bool"/>
  2481. <field name="Display Plane A Flip Pending Wait Enable" start="1" end="1" type="bool"/>
  2482. <field name="Display Pipe A Scan Line Wait Enable" start="0" end="0" type="bool"/>
  2483. </instruction>
  2484. <instruction name="PIPELINE_SELECT" bias="1" length="1">
  2485. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2486. <field name="Command SubType" start="27" end="28" type="uint" default="1"/>
  2487. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  2488. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="4"/>
  2489. <field name="Pipeline Selection" start="0" end="1" type="uint">
  2490. <value name="3D" value="0"/>
  2491. <value name="Media" value="1"/>
  2492. <value name="GPGPU" value="2"/>
  2493. </field>
  2494. </instruction>
  2495. <instruction name="PIPE_CONTROL" bias="2" length="5">
  2496. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2497. <field name="Command SubType" start="27" end="28" type="uint" default="3"/>
  2498. <field name="3D Command Opcode" start="24" end="26" type="uint" default="2"/>
  2499. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="0"/>
  2500. <field name="DWord Length" start="0" end="7" type="uint" default="3"/>
  2501. <field name="Destination Address Type" start="56" end="56" type="uint" prefix="DAT">
  2502. <value name="PPGTT" value="0"/>
  2503. <value name="GGTT" value="1"/>
  2504. </field>
  2505. <field name="LRI Post Sync Operation" start="55" end="55" type="uint">
  2506. <value name="No LRI Operation" value="0"/>
  2507. <value name="MMIO Write Immediate Data" value="1"/>
  2508. </field>
  2509. <field name="Store Data Index" start="53" end="53" type="uint"/>
  2510. <field name="Command Streamer Stall Enable" start="52" end="52" type="bool"/>
  2511. <field name="Global Snapshot Count Reset" start="51" end="51" type="bool"/>
  2512. <field name="TLB Invalidate" start="50" end="50" type="bool"/>
  2513. <field name="Generic Media State Clear" start="48" end="48" type="bool"/>
  2514. <field name="Post Sync Operation" start="46" end="47" type="uint">
  2515. <value name="No Write" value="0"/>
  2516. <value name="Write Immediate Data" value="1"/>
  2517. <value name="Write PS Depth Count" value="2"/>
  2518. <value name="Write Timestamp" value="3"/>
  2519. </field>
  2520. <field name="Depth Stall Enable" start="45" end="45" type="bool"/>
  2521. <field name="Render Target Cache Flush Enable" start="44" end="44" type="bool"/>
  2522. <field name="Instruction Cache Invalidate Enable" start="43" end="43" type="bool"/>
  2523. <field name="Texture Cache Invalidation Enable" start="42" end="42" type="bool"/>
  2524. <field name="Indirect State Pointers Disable" start="41" end="41" type="bool"/>
  2525. <field name="Notify Enable" start="40" end="40" type="bool"/>
  2526. <field name="Pipe Control Flush Enable" start="39" end="39" type="bool"/>
  2527. <field name="DC Flush Enable" start="37" end="37" type="bool"/>
  2528. <field name="VF Cache Invalidation Enable" start="36" end="36" type="bool"/>
  2529. <field name="Constant Cache Invalidation Enable" start="35" end="35" type="bool"/>
  2530. <field name="State Cache Invalidation Enable" start="34" end="34" type="bool"/>
  2531. <field name="Stall At Pixel Scoreboard" start="33" end="33" type="bool"/>
  2532. <field name="Depth Cache Flush Enable" start="32" end="32" type="bool"/>
  2533. <field name="Address" start="66" end="95" type="address"/>
  2534. <field name="Immediate Data" start="96" end="159" type="uint"/>
  2535. </instruction>
  2536. <instruction name="STATE_BASE_ADDRESS" bias="2" length="10">
  2537. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2538. <field name="Command SubType" start="27" end="28" type="uint" default="0"/>
  2539. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  2540. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="1"/>
  2541. <field name="DWord Length" start="0" end="7" type="uint" default="8"/>
  2542. <field name="General State Base Address" start="44" end="63" type="address"/>
  2543. <field name="General State Memory Object Control State" start="40" end="43" type="MEMORY_OBJECT_CONTROL_STATE"/>
  2544. <field name="Stateless Data Port Access Memory Object Control State" start="36" end="39" type="MEMORY_OBJECT_CONTROL_STATE"/>
  2545. <field name="General State Base Address Modify Enable" start="32" end="32" type="bool"/>
  2546. <field name="Surface State Base Address" start="76" end="95" type="address"/>
  2547. <field name="Surface State Memory Object Control State" start="72" end="75" type="MEMORY_OBJECT_CONTROL_STATE"/>
  2548. <field name="Surface State Base Address Modify Enable" start="64" end="64" type="bool"/>
  2549. <field name="Dynamic State Base Address" start="108" end="127" type="address"/>
  2550. <field name="Dynamic State Memory Object Control State" start="104" end="107" type="MEMORY_OBJECT_CONTROL_STATE"/>
  2551. <field name="Dynamic State Base Address Modify Enable" start="96" end="96" type="bool"/>
  2552. <field name="Indirect Object Base Address" start="140" end="159" type="address"/>
  2553. <field name="Indirect Object Memory Object Control State" start="136" end="139" type="MEMORY_OBJECT_CONTROL_STATE"/>
  2554. <field name="Indirect Object Base Address Modify Enable" start="128" end="128" type="bool"/>
  2555. <field name="Instruction Base Address" start="172" end="191" type="address"/>
  2556. <field name="Instruction Memory Object Control State" start="168" end="171" type="MEMORY_OBJECT_CONTROL_STATE"/>
  2557. <field name="Instruction Base Address Modify Enable" start="160" end="160" type="bool"/>
  2558. <field name="General State Access Upper Bound" start="204" end="223" type="address"/>
  2559. <field name="General State Access Upper Bound Modify Enable" start="192" end="192" type="bool"/>
  2560. <field name="Dynamic State Access Upper Bound" start="236" end="255" type="address"/>
  2561. <field name="Dynamic State Access Upper Bound Modify Enable" start="224" end="224" type="bool"/>
  2562. <field name="Indirect Object Access Upper Bound" start="268" end="287" type="address"/>
  2563. <field name="Indirect Object Access Upper Bound Modify Enable" start="256" end="256" type="bool"/>
  2564. <field name="Instruction Access Upper Bound" start="300" end="319" type="address"/>
  2565. <field name="Instruction Access Upper Bound Modify Enable" start="288" end="288" type="bool"/>
  2566. </instruction>
  2567. <instruction name="STATE_PREFETCH" bias="2" length="2">
  2568. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2569. <field name="Command SubType" start="27" end="28" type="uint" default="0"/>
  2570. <field name="3D Command Opcode" start="24" end="26" type="uint" default="0"/>
  2571. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="3"/>
  2572. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  2573. <field name="Prefetch Pointer" start="38" end="63" type="address"/>
  2574. <field name="Prefetch Count" start="32" end="34" type="uint"/>
  2575. </instruction>
  2576. <instruction name="STATE_SIP" bias="2" length="2">
  2577. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2578. <field name="Command SubType" start="27" end="28" type="uint" default="0"/>
  2579. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  2580. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="2"/>
  2581. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  2582. <field name="System Instruction Pointer" start="36" end="63" type="offset"/>
  2583. </instruction>
  2584. <instruction name="SWTESS_BASE_ADDRESS" bias="2" length="2">
  2585. <field name="Command Type" start="29" end="31" type="uint" default="3"/>
  2586. <field name="Command SubType" start="27" end="28" type="uint" default="0"/>
  2587. <field name="3D Command Opcode" start="24" end="26" type="uint" default="1"/>
  2588. <field name="3D Command Sub Opcode" start="16" end="23" type="uint" default="3"/>
  2589. <field name="DWord Length" start="0" end="7" type="uint" default="0"/>
  2590. <field name="SW Tessellation Base Address" start="44" end="63" type="address"/>
  2591. <field name="SW Tessellation Memory Object Control State" start="40" end="43" type="MEMORY_OBJECT_CONTROL_STATE"/>
  2592. </instruction>
  2593. <register name="IA_VERTICES_COUNT" length="2" num="0x2310">
  2594. <field name="IA Vertices Count Report" start="0" end="63" type="uint"/>
  2595. </register>
  2596. <register name="IA_PRIMITIVES_COUNT" length="2" num="0x2318">
  2597. <field name="IA Primitives Count Report" start="0" end="63" type="uint"/>
  2598. </register>
  2599. <register name="VS_INVOCATION_COUNT" length="2" num="0x2320">
  2600. <field name="VS Invocation Count Report" start="0" end="63" type="uint"/>
  2601. </register>
  2602. <register name="HS_INVOCATION_COUNT" length="2" num="0x2300">
  2603. <field name="HS Invocation Count Report" start="0" end="63" type="uint"/>
  2604. </register>
  2605. <register name="DS_INVOCATION_COUNT" length="2" num="0x2308">
  2606. <field name="DS Invocation Count Report" start="0" end="63" type="uint"/>
  2607. </register>
  2608. <register name="GS_INVOCATION_COUNT" length="2" num="0x2328">
  2609. <field name="GS Invocation Count Report" start="0" end="63" type="uint"/>
  2610. </register>
  2611. <register name="GS_PRIMITIVES_COUNT" length="2" num="0x2330">
  2612. <field name="GS Primitives Count Report" start="0" end="63" type="uint"/>
  2613. </register>
  2614. <register name="CL_INVOCATION_COUNT" length="2" num="0x2338">
  2615. <field name="CL Invocation Count Report" start="0" end="63" type="uint"/>
  2616. </register>
  2617. <register name="CL_PRIMITIVES_COUNT" length="2" num="0x2340">
  2618. <field name="CL Primitives Count Report" start="0" end="63" type="uint"/>
  2619. </register>
  2620. <register name="PS_INVOCATION_COUNT" length="2" num="0x2348">
  2621. <field name="PS Invocation Count Report" start="0" end="63" type="uint"/>
  2622. </register>
  2623. <register name="CS_INVOCATION_COUNT" length="2" num="0x2290">
  2624. <field name="CS Invocation Count Report" start="0" end="63" type="uint"/>
  2625. </register>
  2626. <register name="BCS_INSTDONE" length="1" num="0x2206c">
  2627. <field name="Ring Enable" start="0" end="0" type="bool"/>
  2628. <field name="Blitter IDLE" start="1" end="1" type="bool" default="1"/>
  2629. <field name="GAB IDLE" start="2" end="2" type="bool" default="1"/>
  2630. <field name="BCS Done" start="3" end="3" type="bool" default="1"/>
  2631. </register>
  2632. <register name="INSTDONE_1" length="1" num="0x206c">
  2633. <field name="PRB0 Ring Enable" start="0" end="0" type="bool"/>
  2634. <field name="VFG Done" start="1" end="1" type="bool"/>
  2635. <field name="VS Done" start="2" end="2" type="bool"/>
  2636. <field name="HS Done" start="3" end="3" type="bool"/>
  2637. <field name="TE Done" start="4" end="4" type="bool"/>
  2638. <field name="DS Done" start="5" end="5" type="bool"/>
  2639. <field name="GS Done" start="6" end="6" type="bool"/>
  2640. <field name="SOL Done" start="7" end="7" type="bool"/>
  2641. <field name="CL Done" start="8" end="8" type="bool"/>
  2642. <field name="SF Done" start="9" end="9" type="bool"/>
  2643. <field name="TDG Done" start="12" end="12" type="bool"/>
  2644. <field name="URBM Done" start="13" end="13" type="bool"/>
  2645. <field name="SVG Done" start="14" end="14" type="bool"/>
  2646. <field name="GAFS Done" start="15" end="15" type="bool"/>
  2647. <field name="VFE Done" start="16" end="16" type="bool"/>
  2648. <field name="TSG Done" start="17" end="17" type="bool"/>
  2649. <field name="GAFM Done" start="18" end="18" type="bool"/>
  2650. <field name="GAM Done" start="19" end="19" type="bool"/>
  2651. <field name="RS Done" start="20" end="20" type="bool"/>
  2652. <field name="CS Done" start="21" end="21" type="bool"/>
  2653. <field name="SDE Done" start="22" end="22" type="bool"/>
  2654. <field name="RCCFBC CS Done" start="23" end="23" type="bool"/>
  2655. </register>
  2656. <register name="VCS_INSTDONE" length="1" num="0x1206c">
  2657. <field name="Ring Enable" start="0" end="0" type="bool"/>
  2658. <field name="USB Done" start="1" end="1" type="uint" default="1"/>
  2659. <field name="QRC Done" start="2" end="2" type="uint" default="1"/>
  2660. <field name="SEC Done" start="3" end="3" type="uint" default="1"/>
  2661. <field name="MPC Done" start="4" end="4" type="uint" default="1"/>
  2662. <field name="VFT Done" start="5" end="5" type="uint" default="1"/>
  2663. <field name="BSP Done" start="6" end="6" type="uint" default="1"/>
  2664. <field name="VLF Done" start="7" end="7" type="uint" default="1"/>
  2665. <field name="VOP Done" start="8" end="8" type="uint" default="1"/>
  2666. <field name="VMC Done" start="9" end="9" type="uint" default="1"/>
  2667. <field name="VIP Done" start="10" end="10" type="uint" default="1"/>
  2668. <field name="VIT Done" start="11" end="11" type="uint" default="1"/>
  2669. <field name="VDS Done" start="12" end="12" type="uint" default="1"/>
  2670. <field name="VMX Done" start="13" end="13" type="uint" default="1"/>
  2671. <field name="VCP Done" start="14" end="14" type="uint" default="1"/>
  2672. <field name="VCD Done" start="15" end="15" type="uint" default="1"/>
  2673. <field name="VAD Done" start="16" end="16" type="uint" default="1"/>
  2674. <field name="VMD Done" start="17" end="17" type="uint" default="1"/>
  2675. <field name="VIS Done" start="18" end="18" type="uint" default="1"/>
  2676. <field name="VAC Done" start="19" end="19" type="uint" default="1"/>
  2677. <field name="VAM Done" start="20" end="20" type="uint" default="1"/>
  2678. <field name="JPG Done" start="21" end="21" type="uint" default="1"/>
  2679. <field name="VBP Done" start="22" end="22" type="uint" default="1"/>
  2680. <field name="VHR Done" start="23" end="23" type="uint" default="1"/>
  2681. <field name="VCI Done" start="24" end="24" type="uint" default="1"/>
  2682. <field name="VCR Done" start="25" end="25" type="uint" default="1"/>
  2683. <field name="VIN Done" start="26" end="26" type="uint" default="1"/>
  2684. <field name="VPR Done" start="27" end="27" type="uint" default="1"/>
  2685. <field name="VTQ Done" start="28" end="28" type="uint" default="1"/>
  2686. <field name="Reserved" start="29" end="29" type="uint" default="1"/>
  2687. <field name="VCS Done" start="30" end="30" type="uint" default="1"/>
  2688. <field name="GAC Done" start="31" end="31" type="uint" default="1"/>
  2689. </register>
  2690. <register name="VECS_INSTDONE" length="1" num="0x1a06c">
  2691. <field name="Ring Enable" start="0" end="0" type="bool"/>
  2692. <field name="VECS Done" start="30" end="30" type="uint" default="1"/>
  2693. <field name="GAM Done" start="31" end="31" type="uint" default="1"/>
  2694. </register>
  2695. <register name="L3SQCREG1" length="1" num="0xb010">
  2696. <field name="Convert DC_UC" start="24" end="24" type="uint"/>
  2697. <field name="Convert IS_UC" start="25" end="25" type="uint"/>
  2698. <field name="Convert C_UC" start="26" end="26" type="uint"/>
  2699. <field name="Convert T_UC" start="27" end="27" type="uint"/>
  2700. </register>
  2701. <register name="L3CNTLREG2" length="1" num="0xb020">
  2702. <field name="SLM Enable" start="0" end="0" type="uint"/>
  2703. <field name="URB Allocation" start="1" end="6" type="uint"/>
  2704. <field name="URB Low Bandwidth" start="7" end="7" type="uint"/>
  2705. <field name="RO Allocation" start="14" end="19" type="uint"/>
  2706. <field name="RO Low Bandwidth" start="20" end="20" type="uint"/>
  2707. <field name="DC Allocation" start="21" end="26" type="uint"/>
  2708. <field name="DC Low Bandwidth" start="27" end="27" type="uint"/>
  2709. </register>
  2710. <register name="L3CNTLREG3" length="1" num="0xb024">
  2711. <field name="IS Allocation" start="1" end="6" type="uint"/>
  2712. <field name="IS Low Bandwidth" start="7" end="7" type="uint"/>
  2713. <field name="C Allocation" start="8" end="13" type="uint"/>
  2714. <field name="C Low Bandwidth" start="14" end="14" type="uint"/>
  2715. <field name="T Allocation" start="15" end="20" type="uint"/>
  2716. <field name="T Low Bandwidth" start="21" end="21" type="uint"/>
  2717. </register>
  2718. <register name="SCRATCH1" length="1" num="0xb038">
  2719. <field name="L3 Atomic Disable" start="27" end="27" type="uint"/>
  2720. </register>
  2721. <register name="CHICKEN3" length="1" num="0xe49c">
  2722. <field name="L3 Atomic Disable" start="6" end="6" type="uint"/>
  2723. <field name="L3 Atomic Disable Mask" start="22" end="22" type="uint"/>
  2724. </register>
  2725. <register name="SO_WRITE_OFFSET0" length="1" num="0x5280">
  2726. <field name="Write Offset" start="2" end="31" type="offset"/>
  2727. </register>
  2728. <register name="SO_WRITE_OFFSET1" length="1" num="0x5284">
  2729. <field name="Write Offset" start="2" end="31" type="offset"/>
  2730. </register>
  2731. <register name="SO_WRITE_OFFSET2" length="1" num="0x5288">
  2732. <field name="Write Offset" start="2" end="31" type="offset"/>
  2733. </register>
  2734. <register name="SO_WRITE_OFFSET3" length="1" num="0x528c">
  2735. <field name="Write Offset" start="2" end="31" type="offset"/>
  2736. </register>
  2737. <register name="GFX_ARB_ERROR_RPT" length="1" num="0x40a0">
  2738. <field name="TLB Page Fault Error" start="0" end="0" type="bool"/>
  2739. <field name="Context Page Fault Error" start="1" end="1" type="bool"/>
  2740. <field name="Invalid Page Directory entry error" start="2" end="2" type="bool"/>
  2741. <field name="Hardware Status Page Fault Error" start="3" end="3" type="bool"/>
  2742. <field name="TLB Page VTD Translation Error" start="4" end="4" type="bool"/>
  2743. <field name="Context Page VTD Translation Error" start="5" end="5" type="bool"/>
  2744. <field name="Page Directory Entry VTD Translation Error" start="6" end="6" type="bool"/>
  2745. <field name="Hardware Status Page VTD Translation Error" start="7" end="7" type="bool"/>
  2746. <field name="Unloaded PD Error" start="8" end="8" type="bool"/>
  2747. <field name="Pending Page Faults" start="9" end="15" type="uint"/>
  2748. </register>
  2749. <register name="ERR_INT" length="1" num="0x44040">
  2750. <field name="Primary A GTT Fault Status" start="0" end="0" type="bool"/>
  2751. <field name="Primary B GTT Fault Status" start="1" end="1" type="bool"/>
  2752. <field name="Sprite A GTT Fault Status" start="2" end="2" type="bool"/>
  2753. <field name="Sprite B GTT Fault Status" start="3" end="3" type="bool"/>
  2754. <field name="Cursor A GTT Fault Status" start="4" end="4" type="bool"/>
  2755. <field name="Cursor B GTT Fault Status" start="5" end="5" type="bool"/>
  2756. <field name="Invalid page table entry data" start="6" end="6" type="bool"/>
  2757. <field name="Invalid GTT page table entry" start="7" end="7" type="bool"/>
  2758. </register>
  2759. <register name="BCS_FAULT_REG" length="1" num="0x4294">
  2760. <field name="Valid Bit" start="0" end="0" type="bool"/>
  2761. <field name="Fault Type" start="1" end="2" type="uint">
  2762. <value name="Page Fault" value="0"/>
  2763. <value name="Invalid PD Fault" value="1"/>
  2764. <value name="Unloaded PD Fault" value="2"/>
  2765. <value name="Invalid and Unloaded PD fault" value="3"/>
  2766. </field>
  2767. <field name= "SRCID of Fault" start="3" end="10" type="uint"/>
  2768. <field name="GTTSEL" start="11" end="1" type="uint">
  2769. <value name="PPGTT" value="0"/>
  2770. <value name="GGTT" value="1"/>
  2771. </field>
  2772. <field name="Virtual Address of Fault" start="12" end="31" type="address"/>
  2773. </register>
  2774. <register name="RCS_FAULT_REG" length="1" num="0x4094">
  2775. <field name="Valid Bit" start="0" end="0" type="bool"/>
  2776. <field name="Fault Type" start="1" end="2" type="uint">
  2777. <value name="Page Fault" value="0"/>
  2778. <value name="Invalid PD Fault" value="1"/>
  2779. <value name="Unloaded PD Fault" value="2"/>
  2780. <value name="Invalid and Unloaded PD fault" value="3"/>
  2781. </field>
  2782. <field name= "SRCID of Fault" start="3" end="10" type="uint"/>
  2783. <field name="GTTSEL" start="11" end="1" type="uint">
  2784. <value name="PPGTT" value="0"/>
  2785. <value name="GGTT" value="1"/>
  2786. </field>
  2787. <field name="Virtual Address of Fault" start="12" end="31" type="address"/>
  2788. </register>
  2789. <register name="VECS_FAULT_REG" length="1" num="0x4394">
  2790. <field name="Valid Bit" start="0" end="0" type="bool"/>
  2791. <field name="Fault Type" start="1" end="2" type="uint">
  2792. <value name="Page Fault" value="0"/>
  2793. <value name="Invalid PD Fault" value="1"/>
  2794. <value name="Unloaded PD Fault" value="2"/>
  2795. <value name="Invalid and Unloaded PD fault" value="3"/>
  2796. </field>
  2797. <field name= "SRCID of Fault" start="3" end="10" type="uint"/>
  2798. <field name="GTTSEL" start="11" end="1" type="uint">
  2799. <value name="PPGTT" value="0"/>
  2800. <value name="GGTT" value="1"/>
  2801. </field>
  2802. <field name="Virtual Address of Fault" start="12" end="31" type="address"/>
  2803. </register>
  2804. <register name="VCS_FAULT_REG" length="1" num="0x4194">
  2805. <field name="Valid Bit" start="0" end="0" type="bool"/>
  2806. <field name="Fault Type" start="1" end="2" type="uint">
  2807. <value name="Page Fault" value="0"/>
  2808. <value name="Invalid PD Fault" value="1"/>
  2809. <value name="Unloaded PD Fault" value="2"/>
  2810. <value name="Invalid and Unloaded PD fault" value="3"/>
  2811. </field>
  2812. <field name= "SRCID of Fault" start="3" end="10" type="uint"/>
  2813. <field name="GTTSEL" start="11" end="1" type="uint">
  2814. <value name="PPGTT" value="0"/>
  2815. <value name="GGTT" value="1"/>
  2816. </field>
  2817. <field name="Virtual Address of Fault" start="12" end="31" type="address"/>
  2818. </register>
  2819. <register name="BCS_RING_BUFFER_CTL" length="1" num="0x2203c">
  2820. <field name="Ring Buffer Enable" start="0" end="0" type="bool"/>
  2821. <field name="Automatic Report Head Pointer" start="1" end="2" type="uint">
  2822. <value name="MI_AUTOREPORT_OFF" value="0"/>
  2823. <value name="MI_AUTOREPORT_64KB" value="1"/>
  2824. <value name="MI_AUTOREPORT_4KB" value="2"/>
  2825. <value name="MI_AUTOREPORT_128KB" value="3"/>
  2826. </field>
  2827. <field name="Disable Register Accesses" start="8" end="8" type="bool"/>
  2828. <field name="Semaphore Wait" start="10" end="10" type="bool"/>
  2829. <field name="RBWait" start="11" end="11" type="bool"/>
  2830. <field name="Buffer Length (in pages - 1)" start="12" end="20" type="uint"/>
  2831. </register>
  2832. <register name="RCS_RING_BUFFER_CTL" length="1" num="0x203c">
  2833. <field name="Ring Buffer Enable" start="0" end="0" type="bool"/>
  2834. <field name="Automatic Report Head Pointer" start="1" end="2" type="uint">
  2835. <value name="MI_AUTOREPORT_OFF" value="0"/>
  2836. <value name="MI_AUTOREPORT_64KBMI_AUTOREPORT_4KB" value="1"/>
  2837. <value name="MI_AUTOREPORT_128KB" value="3"/>
  2838. </field>
  2839. <field name="Semaphore Wait" start="10" end="10" type="bool"/>
  2840. <field name="RBWait" start="11" end="11" type="bool"/>
  2841. <field name="Buffer Length (in pages - 1)" start="12" end="20" type="uint"/>
  2842. </register>
  2843. <register name="VECS_RING_BUFFER_CTL" length="1" num="0x1A03c">
  2844. <field name="Ring Buffer Enable" start="0" end="0" type="bool"/>
  2845. <field name="Automatic Report Head Pointer" start="1" end="2" type="uint">
  2846. <value name="MI_AUTOREPORT_OFF" value="0"/>
  2847. <value name="MI_AUTOREPORT_64KB" value="1"/>
  2848. <value name="MI_AUTOREPORT_4KB" value="2"/>
  2849. <value name="MI_AUTOREPORT_128KB" value="3"/>
  2850. </field>
  2851. <field name="Disable Register Accesses" start="8" end="8" type="bool"/>
  2852. <field name="Semaphore Wait" start="10" end="10" type="bool"/>
  2853. <field name="RBWait" start="11" end="11" type="bool"/>
  2854. <field name="Buffer Length (in pages - 1)" start="12" end="20" type="uint"/>
  2855. </register>
  2856. <register name="VCS_RING_BUFFER_CTL" length="1" num="0x1203c">
  2857. <field name="Ring Buffer Enable" start="0" end="0" type="bool"/>
  2858. <field name="Automatic Report Head Pointer" start="1" end="2" type="uint">
  2859. <value name="MI_AUTOREPORT_OFF" value="0"/>
  2860. <value name="MI_AUTOREPORT_64KB" value="1"/>
  2861. <value name="MI_AUTOREPORT_4KB" value="2"/>
  2862. <value name="MI_AUTOREPORT_128KB" value="3"/>
  2863. </field>
  2864. <field name="Disable Register Accesses" start="8" end="8" type="bool"/>
  2865. <field name="Semaphore Wait" start="10" end="10" type="bool"/>
  2866. <field name="RBWait" start="11" end="11" type="bool"/>
  2867. <field name="Buffer Length (in pages - 1)" start="12" end="20" type="uint"/>
  2868. </register>
  2869. </genxml>