<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://www.3dbrew.org/w/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Cruel</id>
	<title>3dbrew - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://www.3dbrew.org/w/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Cruel"/>
	<link rel="alternate" type="text/html" href="https://www.3dbrew.org/wiki/Special:Contributions/Cruel"/>
	<updated>2026-04-14T20:02:43Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.43.1</generator>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=SMDH&amp;diff=18322</id>
		<title>SMDH</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=SMDH&amp;diff=18322"/>
		<updated>2016-09-29T16:37:21Z</updated>

		<summary type="html">&lt;p&gt;Cruel: /* Flags */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;This page describes the format of the icon stored at [[NCCH#CXI|CXI]] ExeFS:/icon and [[CIA]] icons.&lt;br /&gt;
The size of icons is 0x36c0 bytes. The CXI icon is displayed by [[Home Menu]] and [[System Settings]](3DS Software Management), while [[CIA#Meta|CIA icons]] are dummies and not yet utilised by Dev 3DS&#039; (as of rev 47586).&lt;br /&gt;
&lt;br /&gt;
== Format ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  OFFSET&lt;br /&gt;
!  SIZE&lt;br /&gt;
!  DESCRIPTION&lt;br /&gt;
|-&lt;br /&gt;
|  0x00&lt;br /&gt;
|  0x04 &lt;br /&gt;
|  Magic &#039;SMDH&#039;&lt;br /&gt;
|- &lt;br /&gt;
|  0x04&lt;br /&gt;
|  0x02 &lt;br /&gt;
|  Version&lt;br /&gt;
|- &lt;br /&gt;
|  0x06&lt;br /&gt;
|  0x02 &lt;br /&gt;
|  Reserved&lt;br /&gt;
|-&lt;br /&gt;
|  0x8&lt;br /&gt;
|  0x2000&lt;br /&gt;
|  16 application titles structs, each 0x200 bytes&lt;br /&gt;
|-&lt;br /&gt;
| 0x2008&lt;br /&gt;
| 0x30&lt;br /&gt;
| Application Settings&lt;br /&gt;
|-&lt;br /&gt;
| 0x2038&lt;br /&gt;
| 0x8&lt;br /&gt;
| Reserved &lt;br /&gt;
|-&lt;br /&gt;
| 0x2040&lt;br /&gt;
| 0x1680&lt;br /&gt;
| Icon graphics&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Application Titles ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  START&lt;br /&gt;
!  SIZE&lt;br /&gt;
!  DESCRIPTION&lt;br /&gt;
|-&lt;br /&gt;
|  0x00&lt;br /&gt;
|  0x80&lt;br /&gt;
|  Short Description&lt;br /&gt;
|- &lt;br /&gt;
|  0x80&lt;br /&gt;
|  0x100 &lt;br /&gt;
|  Long Description&lt;br /&gt;
|- &lt;br /&gt;
|  0x180&lt;br /&gt;
|  0x80 &lt;br /&gt;
|  Publisher&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
All encoded in UTF-16.&lt;br /&gt;
There are 16 app title structs(currently only 12 are used), each one for separate languages.&lt;br /&gt;
&lt;br /&gt;
The languages by order of appearance:&lt;br /&gt;
&lt;br /&gt;
* 1st: Japanese title name&lt;br /&gt;
* 2nd: English title name&lt;br /&gt;
* 3rd: French title name&lt;br /&gt;
* 4th: German title name&lt;br /&gt;
* 5th: Italian title name&lt;br /&gt;
* 6th: Spanish title name&lt;br /&gt;
* 7th: Simplified Chinese title name&lt;br /&gt;
* 8th: Korean title name&lt;br /&gt;
* 9th: Dutch title name&lt;br /&gt;
* 10th: Portuguese title name&lt;br /&gt;
* 11th: Russian title name&lt;br /&gt;
* 12th: Traditional Chinese title name&lt;br /&gt;
&lt;br /&gt;
== Application Settings ==&lt;br /&gt;
&lt;br /&gt;
Most of these flags are only used by the [[Home Menu]]. All of these are represented in SMDH files in little endian. But when documented below, the tables represent values in big endian.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  START&lt;br /&gt;
!  SIZE&lt;br /&gt;
!  DESCRIPTION&lt;br /&gt;
|-&lt;br /&gt;
|  0x2008&lt;br /&gt;
|  0x10&lt;br /&gt;
|  Region Specific Game Ratings (For use with Parental Controls)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2018&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Region Lockout&lt;br /&gt;
|-  &lt;br /&gt;
|  0x201C&lt;br /&gt;
|  0xC &lt;br /&gt;
|  Match Maker IDs (Online Play)&lt;br /&gt;
|-    &lt;br /&gt;
|  0x2028&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Flags&lt;br /&gt;
|-    &lt;br /&gt;
|  0x202C&lt;br /&gt;
|  0x2 &lt;br /&gt;
|  EULA Version&lt;br /&gt;
|-    &lt;br /&gt;
|  0x202E&lt;br /&gt;
|  0x2 &lt;br /&gt;
|  Reserved&lt;br /&gt;
|-  &lt;br /&gt;
|  0x2030&lt;br /&gt;
|  0x4 &lt;br /&gt;
|  &#039;Optimal Animation Default Frame&#039; (for BNR)&lt;br /&gt;
|-    &lt;br /&gt;
|  0x2034&lt;br /&gt;
|  0x4 &lt;br /&gt;
|  CEC (StreetPass) ID (So the Home Menu knows which application icon to show the &#039;Green&#039; CEC notification for)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Region Specific Game Age Ratings ===&lt;br /&gt;
&lt;br /&gt;
These flags tell the 3DS the &#039;Age Rating&#039; of the software for the below regions:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  START&lt;br /&gt;
!  SIZE&lt;br /&gt;
!  DESCRIPTION&lt;br /&gt;
|-&lt;br /&gt;
|  0x2008&lt;br /&gt;
|  0x1&lt;br /&gt;
|  CERO (Japan)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2009&lt;br /&gt;
|  0x1&lt;br /&gt;
|  ESRB (USA)&lt;br /&gt;
|-&lt;br /&gt;
|  0x200A&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Reserved&lt;br /&gt;
|-&lt;br /&gt;
|  0x200B&lt;br /&gt;
|  0x1&lt;br /&gt;
|  USK (German)&lt;br /&gt;
|-&lt;br /&gt;
|  0x200C&lt;br /&gt;
|  0x1&lt;br /&gt;
|  PEGI GEN (Europe)&lt;br /&gt;
|-&lt;br /&gt;
|  0x200D&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Reserved&lt;br /&gt;
|-&lt;br /&gt;
|  0x200E&lt;br /&gt;
|  0x1&lt;br /&gt;
|  PEGI PRT (Portugal)&lt;br /&gt;
|-&lt;br /&gt;
|  0x200F&lt;br /&gt;
|  0x1&lt;br /&gt;
|  PEGI BBFC (England)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2010&lt;br /&gt;
|  0x1&lt;br /&gt;
|  COB (Australia)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2011&lt;br /&gt;
|  0x1&lt;br /&gt;
|  GRB (South Korea)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2012&lt;br /&gt;
|  0x1&lt;br /&gt;
|  CGSRR (Taiwan)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2013&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Reserved&lt;br /&gt;
|-&lt;br /&gt;
|  0x2014&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Reserved&lt;br /&gt;
|-&lt;br /&gt;
|  0x2015&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Reserved&lt;br /&gt;
|-&lt;br /&gt;
|  0x2016&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Reserved&lt;br /&gt;
|-&lt;br /&gt;
|  0x2017&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Reserved&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Active ratings have a bitmask of 0x80, and inactive ratings have no bitmask at all. Ratings without the 0x80 bitmask are ignored. 0x40 bitmask indicates Rating Pending. 0x20 bitmask indicates No Age Restriction.&lt;br /&gt;
Age limits are set by adding the minimal age to 0x80 (for example, limiting to 12 years and up would give a bitmask of 0x8C)&lt;br /&gt;
&lt;br /&gt;
=== Region Lockout ===&lt;br /&gt;
&lt;br /&gt;
This u32 flag is what the Home Menu uses to determine the [[Home Menu#Region Lockout|Region Lockout]] of a title.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  REGION&lt;br /&gt;
!  BITMASK&lt;br /&gt;
|-&lt;br /&gt;
|  Japan&lt;br /&gt;
|  0x01&lt;br /&gt;
|-&lt;br /&gt;
|  North America&lt;br /&gt;
|  0x02 &lt;br /&gt;
|-&lt;br /&gt;
|  Europe&lt;br /&gt;
|  0x04 &lt;br /&gt;
|-&lt;br /&gt;
|  Australia&lt;br /&gt;
|  0x08 &lt;br /&gt;
|-&lt;br /&gt;
|  China&lt;br /&gt;
|  0x10 &lt;br /&gt;
|-&lt;br /&gt;
|  Korea&lt;br /&gt;
|  0x20 &lt;br /&gt;
|-&lt;br /&gt;
|  Taiwan &lt;br /&gt;
|  0x40 &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Regions are &#039;included&#039; in region lock by setting their bitmask value. Nintendo defines region free as 0x7fffffff. Early in the 3DS&#039; development, Nintendo grouped the Australian and Europe markets together. Nintendo defines market Europe as having the combined bitmasks of Europe and Australia. No 3DS&#039; which check the Australia bitmask have been seen (Australia uses the European 3DS model).&lt;br /&gt;
&lt;br /&gt;
=== Match Maker IDs ===&lt;br /&gt;
&lt;br /&gt;
These IDs are an application&#039;s online gaming IDs.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  START&lt;br /&gt;
!  SIZE&lt;br /&gt;
!  DESCRIPTION&lt;br /&gt;
|-&lt;br /&gt;
|  0x201C&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Match Maker ID&lt;br /&gt;
|- &lt;br /&gt;
|  0x2020&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Match Maker BIT ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Flags ===&lt;br /&gt;
The u32 is used for storing flags as bit-masks.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  FLAG&lt;br /&gt;
!  BITMASK VALUE&lt;br /&gt;
|-&lt;br /&gt;
|  Visibility Flag (Required for visibility on the Home Menu)&lt;br /&gt;
|  0x0001&lt;br /&gt;
|-&lt;br /&gt;
|  [[Home Menu#Auto-Boot_Function|Auto-boot]] this gamecard title&lt;br /&gt;
|  0x0002&lt;br /&gt;
|-&lt;br /&gt;
|  Allow use of 3D? (For use with parental Controls. An application can use the 3D affect, even when this flag isn&#039;t set)&lt;br /&gt;
|  0x0004&lt;br /&gt;
|-&lt;br /&gt;
|  Require accepting CTR EULA before being launched by Home (see below)&lt;br /&gt;
|  0x0008&lt;br /&gt;
|-&lt;br /&gt;
|  Autosave on exit? (see below)&lt;br /&gt;
|  0x0010&lt;br /&gt;
|-&lt;br /&gt;
|  Uses an [[Extended Banner]]?&lt;br /&gt;
|  0x0020&lt;br /&gt;
|-&lt;br /&gt;
|  [[SMDH#Region Specific Game Age Ratings|Region game rating]] required&lt;br /&gt;
|  0x0040&lt;br /&gt;
|-&lt;br /&gt;
|  Uses save data? (see below)&lt;br /&gt;
|  0x0080&lt;br /&gt;
|-&lt;br /&gt;
|  Application usage is to be recorded. If this is not set, it causes the application&#039;s usage to be omitted from the Home Menu&#039;s [[Home_Menu#Cache.dat &amp;amp; CacheD.dat|icon cache]], as well as in [[????????|other places]].&lt;br /&gt;
|  0x0100&lt;br /&gt;
|-&lt;br /&gt;
|  Disables [[SD Savedata Backups]] for this title. This is in addition to [[NS CFA|the blacklist]].&lt;br /&gt;
|  0x0400&lt;br /&gt;
|-&lt;br /&gt;
|  New 3DS exclusive title. Shows an error if used on Old 3DS.&lt;br /&gt;
|  0x1000&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
====Effect of SaveData and AutoSave====&lt;br /&gt;
&lt;br /&gt;
These options have no effect on the performance of the application itself: they&#039;re used to select an appropriate warning when closing an application from [[Home Menu|Home]].&lt;br /&gt;
&lt;br /&gt;
* Both off: &amp;quot;Closing software&amp;quot; (no warning if quitting directly with X)&lt;br /&gt;
* SaveData: &amp;quot;Do you want to close [...]? (Unsaved data will be lost.)&amp;quot;&lt;br /&gt;
* AutoSave: ?&lt;br /&gt;
* Both on:  &amp;quot;Saving data and closing software...&amp;quot; (no warning if quitting directly with X)&lt;br /&gt;
&lt;br /&gt;
=== EULA Version ===&lt;br /&gt;
This is the EULA version which is checked when the Accept EULA flag is set, the version is compared to one stored in the 3DS. If the SMDH version is greater, then the user will be prompted to accept the EULA.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  START&lt;br /&gt;
!  SIZE&lt;br /&gt;
!  DESCRIPTION&lt;br /&gt;
|-&lt;br /&gt;
|  0x202C&lt;br /&gt;
|  0x01&lt;br /&gt;
|  EULA Version Minor&lt;br /&gt;
|-&lt;br /&gt;
|  0x202D&lt;br /&gt;
|  0x01&lt;br /&gt;
|  EULA Version Major&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== &#039;Optimal Animation Default Frame&#039; (for BNR) ===&lt;br /&gt;
&lt;br /&gt;
This is a float, indicating the preferred (or &#039;most representative&#039;) frame for the banner animation.&lt;br /&gt;
&lt;br /&gt;
=== CEC (StreetPass) ID ===&lt;br /&gt;
&lt;br /&gt;
This u32 represents the application CEC ID. This is likely loaded by applications for use with the CEC services as well.&lt;br /&gt;
&lt;br /&gt;
== Icon graphics ==&lt;br /&gt;
&lt;br /&gt;
At offset 0x2040, there are two icons:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  START&lt;br /&gt;
!  SIZE&lt;br /&gt;
!  DESCRIPTION&lt;br /&gt;
|-&lt;br /&gt;
|  0x2040&lt;br /&gt;
|  0x480&lt;br /&gt;
|  Small - 24x24 (shown on top screen when pausing the app)&lt;br /&gt;
|- &lt;br /&gt;
|  0x24C0&lt;br /&gt;
|  0x1200 &lt;br /&gt;
|  Large - 48x48 icon (the general icon)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Both of the icons are encoded in RGB565 meaning 16bpp. Although both icons are known to be RGB565, developers have the option of encoding icons (and banners) with the following encodings :&lt;br /&gt;
&lt;br /&gt;
* RGBA8&lt;br /&gt;
* RGB8&lt;br /&gt;
* RGBA5551&lt;br /&gt;
* RGB565&lt;br /&gt;
* RGBA4&lt;br /&gt;
* LA8&lt;br /&gt;
* HILO8&lt;br /&gt;
* L8&lt;br /&gt;
* A8&lt;br /&gt;
* LA4&lt;br /&gt;
* L4&lt;br /&gt;
* ETC1&lt;br /&gt;
* ETC1A4&lt;br /&gt;
&lt;br /&gt;
This does not necessarily mean the other encodings will be used, it is just that those are the options when compiling. Like we&#039;ve seen with Super Mario 3D Land Nintendo has changed save file encryption, and likewise they can encode icons and banners differently &#039;&#039;should they choose to&#039;&#039;. Currently we&#039;ve seen just RGB565 so don&#039;t be fooled if an icon doesn&#039;t show up right! It is probably one of these formats above. Although we will probably not see other formats used for a while it&#039;s nice to know they have an opportunity to change.&lt;br /&gt;
&lt;br /&gt;
The data is encoded in tiles (starting from size 8x8, continuing recursively).&lt;br /&gt;
&lt;br /&gt;
If the buffer is like this:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  0&lt;br /&gt;
!  1&lt;br /&gt;
!  2&lt;br /&gt;
!  3&lt;br /&gt;
!  4&lt;br /&gt;
!  5&lt;br /&gt;
!  6&lt;br /&gt;
!  7&lt;br /&gt;
!  8&lt;br /&gt;
!  9&lt;br /&gt;
!  10&lt;br /&gt;
!  11&lt;br /&gt;
!  12&lt;br /&gt;
!  13&lt;br /&gt;
!  14&lt;br /&gt;
!  15&lt;br /&gt;
!  16&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Then the image would look like this:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  x=0&lt;br /&gt;
!  x=1&lt;br /&gt;
!  x=2&lt;br /&gt;
!  x=3&lt;br /&gt;
!  x=4&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 1&lt;br /&gt;
| 4&lt;br /&gt;
| 5&lt;br /&gt;
| 16&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 3&lt;br /&gt;
| 6&lt;br /&gt;
| 7&lt;br /&gt;
| ...&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| 9&lt;br /&gt;
| 12&lt;br /&gt;
| 13&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| 11&lt;br /&gt;
| 14&lt;br /&gt;
| 15&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Tools ==&lt;br /&gt;
&lt;br /&gt;
[[CiTRUS]] - (GUI)(Windows Only) Generating ICN files&lt;br /&gt;
&lt;br /&gt;
[[3DSExplorer]] - (GUI)(Windows Only) Parsing ICN files&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=HTTP_Services&amp;diff=17859</id>
		<title>HTTP Services</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=HTTP_Services&amp;diff=17859"/>
		<updated>2016-07-30T23:49:58Z</updated>

		<summary type="html">&lt;p&gt;Cruel: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:Services]]&lt;br /&gt;
= HTTP service &amp;quot;http:C&amp;quot; =&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Command Header&lt;br /&gt;
!  Available since system-version&lt;br /&gt;
!  Available from service-sessions&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010044&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:Initialize|Initialize]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020082&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:CreateContext|CreateContext]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00030040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| All&lt;br /&gt;
| [[HTTPC:CloseContext|CloseContext]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00040040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:CancelConnection|CancelConnection]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00050040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:GetRequestState|GetRequestState]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00060040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:GetDownloadSizeState|GetDownloadSizeState]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00070040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:GetRequestError|GetRequestError]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00080042&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:InitializeConnectionSession|InitializeConnectionSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00090040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:BeginRequest|BeginRequest]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x000A0040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:BeginRequestAsync|BeginRequestAsync]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x000B0082&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:ReceiveData|ReceiveData]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x000C0102&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:ReceiveDataTimeout|ReceiveDataTimeout]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x000D0146&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:SetProxy|SetProxy]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x000E0040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:SetProxyDefault|SetProxyDefault]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x000F00C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:SetBasicAuthorization|SetBasicAuthorization]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00100080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Context-only&lt;br /&gt;
| [[HTTPC:SetSocketBufferSize|SetSocketBufferSize]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x001100C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:AddRequestHeader|AddRequestHeader]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x001200C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:AddPostDataAscii|AddPostDataAscii]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x001300C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| AddPostDataBinary&lt;br /&gt;
|-&lt;br /&gt;
| 0x00140082&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:AddPostDataRaw|AddPostDataRaw]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00150080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| SetPostDataType(u8 enum)&lt;br /&gt;
|-&lt;br /&gt;
| 0x001600C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| SendPostDataAscii&lt;br /&gt;
|-&lt;br /&gt;
| 0x00170144&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| SendPostDataAsciiTimeout&lt;br /&gt;
|-&lt;br /&gt;
| 0x001800C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| SendPostDataBinary&lt;br /&gt;
|-&lt;br /&gt;
| 0x00190144&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| SendPostDataBinaryTimeout&lt;br /&gt;
|-&lt;br /&gt;
| 0x001A0082&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| SendPostDataRaw&lt;br /&gt;
|-&lt;br /&gt;
| 0x001B0102&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:SendPOSTDataTimeout|SendPOSTDataRawTimeout]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x001C0080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| SetPostDataEncoding&lt;br /&gt;
|-&lt;br /&gt;
| 0x001D0040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:NotifyFinishSendPostData|NotifyFinishSendPostData]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x001E00C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:GetResponseHeader|GetResponseHeader]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x001F0144&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:GetResponseHeaderTimeout|GetResponseHeaderTimeout]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00200082&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:GetResponseData|GetResponseData]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00210102&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| GetResponseDataTimeout&lt;br /&gt;
|-&lt;br /&gt;
| 0x00220040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:GetResponseStatusCode|GetResponseStatusCode]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x002300C0&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:GetResponseStatusCodeTimeout|GetResponseStatusCodeTimeout]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00240082&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:AddTrustedRootCA|AddTrustedRootCA]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00250080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:AddDefaultCert|AddDefaultCert]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00260080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:SelectRootCertChain|SelectRootCertChain]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x002700C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| [[HTTPC:SetClientCert|SetClientCert]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00280080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Context-only&lt;br /&gt;
| [[HTTPC:SetClientCertDefault|SetClientCertDefault]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00290080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Context-only&lt;br /&gt;
| [[HTTPC:SetClientCertContext|SetClientCertContext]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x002A0040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| All&lt;br /&gt;
| (u32 contexthandle) GetSSLError? This loads a value from state, this doesn&#039;t seem to use any sslc command.&lt;br /&gt;
|-&lt;br /&gt;
| 0x002B0080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Context-only&lt;br /&gt;
| [[HTTPC:SetSSLOpt|SetSSLOpt]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x002C0080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Context-only&lt;br /&gt;
| [[HTTPC:SetSSLClearOpt|SetSSLClearOpt]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x002D0000&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:CreateRootCertChain|CreateRootCertChain]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x002E0040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:DestroyRootCertChain|DestroyRootCertChain]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x002F0082&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:RootCertChainAddCert|RootCertChainAddCert]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00300080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:RootCertChainAddDefaultCert|RootCertChainAddDefaultCert]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00310080&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:RootCertChainRemoveCert|RootCertChainRemoveCert]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00320084&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:OpenClientCertContext|OpenClientCertContext]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00330040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:OpenDefaultClientCertContext|OpenDefaultClientCertContext]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00340040&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| [[HTTPC:CloseClientCertContext|CloseClientCertContext]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00350186&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| Main-only&lt;br /&gt;
| SetDefaultProxy&lt;br /&gt;
|-&lt;br /&gt;
| 0x00360000&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| &lt;br /&gt;
| ClearDNSCache&lt;br /&gt;
|-&lt;br /&gt;
| 0x00370080&lt;br /&gt;
| [[2.0.0-2|2.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| SetKeepAlive (bool)&lt;br /&gt;
|-&lt;br /&gt;
| 0x003800C0&lt;br /&gt;
| [[3.0.0-5|3.0.0-X]].&lt;br /&gt;
| &lt;br /&gt;
| SetPostDataTypeSize (u8 enum, u32 size) (similar to SetPostDataType)&lt;br /&gt;
|-&lt;br /&gt;
| 0x00390000&lt;br /&gt;
| [[3.0.0-5|3.0.0-X]].&lt;br /&gt;
| &lt;br /&gt;
| Finalize&lt;br /&gt;
|-&lt;br /&gt;
| 0x003A0080&lt;br /&gt;
| [[8.0.0-18|8.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x003B0082&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x003C0080&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x003D0080&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x003E0000&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x003F0040&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x00400082&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x00410080&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x00420080&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=TLS Root CAs=&lt;br /&gt;
Initially a HTTP context will not trust &#039;&#039;any&#039;&#039; root-CAs at all. Which root-CAs to trust must be &#039;&#039;explicitly&#039;&#039; specified via the add-root-CA service command(s).&lt;br /&gt;
&lt;br /&gt;
RootCertChains can be used to easily select a particular chain of trusted root-CAs with multiple HTTP contexts, without having to re-send each of the root-CA commands for each HTTP context. The maximum number of RootCertChains that can exist for an user-process, is only 2.&lt;br /&gt;
&lt;br /&gt;
When using the context-specific RootCA commands such as [[HTTPC:AddTrustedRootCA]] where [[HTTPC:SelectRootCertChain]] was already used, the cert will just be added to the selected RootCertChain.&lt;br /&gt;
&lt;br /&gt;
=ClientCert Contexts=&lt;br /&gt;
These are basically the same as RootCertChains except for TLS client cert+privk. The maximum number of ClientCert-contexts that can exist for an user-process, is only 2.&lt;br /&gt;
&lt;br /&gt;
= Error codes =&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Error code&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0xd8a0a03c&lt;br /&gt;
| Failed to verify the HTTPS server&#039;s TLS certificate.&lt;br /&gt;
|-&lt;br /&gt;
| 0xd8a0a046&lt;br /&gt;
| This is returned by [[HTTPC:Initialize]] when no network connection is available(or at least when wifi is disabled via Home Menu on New3DS).&lt;br /&gt;
|-&lt;br /&gt;
| 0xd8a0a066&lt;br /&gt;
| This indicates that the context handle is wrong.&lt;br /&gt;
|-&lt;br /&gt;
| 0xd820a069&lt;br /&gt;
| This is returned when the call times out (with any call with a timeout arg)&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=IDBE&amp;diff=17655</id>
		<title>IDBE</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=IDBE&amp;diff=17655"/>
		<updated>2016-07-10T01:08:10Z</updated>

		<summary type="html">&lt;p&gt;Cruel: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;IDBE is Nintendo&#039;s title icon database. Entries contain title icon, region, and name (in various languages). Similar to the [[SMDH]]. All game titles are on the server (excluding DSiWare?), including demos and updates.&lt;br /&gt;
&lt;br /&gt;
== URLs ==&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;https://idbe-ctr.cdn.nintendo.net&amp;lt;/nowiki&amp;gt;/icondata/&#039;&#039;&#039;%02X&#039;&#039;&#039;/&#039;&#039;&#039;%016llX&#039;&#039;&#039;.idbe&lt;br /&gt;
&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;https://idbe-ctr.cdn.nintendo.net&amp;lt;/nowiki&amp;gt;/icondata/&#039;&#039;&#039;%02X&#039;&#039;&#039;/&#039;&#039;&#039;%016llX&#039;&#039;&#039;-&#039;&#039;&#039;%d&#039;&#039;&#039;.idbe&lt;br /&gt;
&#039;&#039;&#039;%02X&#039;&#039;&#039; seems to always be 0x10 (?)&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;%016llX&#039;&#039;&#039; is the title id.&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;%d&#039;&#039;&#039; is an optional title version.&lt;br /&gt;
== Encryption ==&lt;br /&gt;
The icon database is encrypted with AES-128 CBC. All icons use the same IV and one of 4 possible keys (as specified by the key index in the header).&lt;br /&gt;
&lt;br /&gt;
The IV/keys are likely hardcoded on the 3DS, but not sure where. [http://wiiubrew.org/wiki/Nn_idbe.rpl#Encryption They are also on the WiiU].&lt;br /&gt;
== Data ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Offset&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Size&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Description&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 0x0||0x1||? (usually zero)&lt;br /&gt;
|-&lt;br /&gt;
| 0x1||0x1||Key index&lt;br /&gt;
|-&lt;br /&gt;
| 0x2||0x36D0||Encrypted data&lt;br /&gt;
|}&lt;br /&gt;
=== Encrypted Data ===&lt;br /&gt;
Icon data is uncompressed RGB565.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Offset&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Size&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Description&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 0x0||0x20||SHA256 hash&lt;br /&gt;
|-&lt;br /&gt;
| 0x20||0x10||?&lt;br /&gt;
|-&lt;br /&gt;
| 0x30||0x4||[[SMDH#Region_Lockout|Region lockout]] (u32 little endian)&lt;br /&gt;
|-&lt;br /&gt;
| 0x34||0x1C||?&lt;br /&gt;
|-&lt;br /&gt;
| 0x50 + &#039;&#039;i&#039;&#039; * 0x200||0x200||[[SMDH#Application_Titles|Title struct]] where &#039;&#039;i&#039;&#039; = language index&lt;br /&gt;
|-&lt;br /&gt;
| 0x2050||0x480||24x24 Icon data&lt;br /&gt;
|-&lt;br /&gt;
| 0x24D0||0x1200||48x48 Icon data&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=IDBE&amp;diff=17653</id>
		<title>IDBE</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=IDBE&amp;diff=17653"/>
		<updated>2016-07-10T00:36:51Z</updated>

		<summary type="html">&lt;p&gt;Cruel: Created page with &amp;quot;IDBE is Nintendo&amp;#039;s title icon database. Entries contain title icon, region, and name (in various languages). All game titles are on the server (excluding DSiWare?), including...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;IDBE is Nintendo&#039;s title icon database. Entries contain title icon, region, and name (in various languages). All game titles are on the server (excluding DSiWare?), including demos and updates.&lt;br /&gt;
&lt;br /&gt;
== URLs ==&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;https://idbe-ctr.cdn.nintendo.net&amp;lt;/nowiki&amp;gt;/icondata/&#039;&#039;&#039;%02X&#039;&#039;&#039;/&#039;&#039;&#039;%016llX&#039;&#039;&#039;.idbe&lt;br /&gt;
&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;https://idbe-ctr.cdn.nintendo.net&amp;lt;/nowiki&amp;gt;/icondata/&#039;&#039;&#039;%02X&#039;&#039;&#039;/&#039;&#039;&#039;%016llX&#039;&#039;&#039;-&#039;&#039;&#039;%d&#039;&#039;&#039;.idbe&lt;br /&gt;
&#039;&#039;&#039;%02X&#039;&#039;&#039; seems to always be 0x10 (?)&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;%016llX&#039;&#039;&#039; is the title id.&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;%d&#039;&#039;&#039; is an optional title version.&lt;br /&gt;
== Encryption ==&lt;br /&gt;
The icon database is encrypted with AES-128 CBC. All icons use the same IV and one of 4 possible keys (as specified by the key index in the header).&lt;br /&gt;
&lt;br /&gt;
The IV/keys are likely hardcoded on the 3DS, but not sure where. [http://wiiubrew.org/wiki/Nn_idbe.rpl#Encryption They are also on the WiiU].&lt;br /&gt;
== Data ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Offset&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Size&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Description&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 0x0||0x1||? (usually zero)&lt;br /&gt;
|-&lt;br /&gt;
| 0x1||0x1||Key index&lt;br /&gt;
|-&lt;br /&gt;
| 0x2||0x36D0||Encrypted data&lt;br /&gt;
|}&lt;br /&gt;
=== Encrypted Data ===&lt;br /&gt;
Icon data is uncompressed RGB565.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Offset&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Size&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Description&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 0x0||0x20||SHA256 Checksum&lt;br /&gt;
|-&lt;br /&gt;
| 0x20||0x10||?&lt;br /&gt;
|-&lt;br /&gt;
| 0x30||0x4||Region bit flags (u32 little endian)&lt;br /&gt;
|-&lt;br /&gt;
| 0x34||0x1C||?&lt;br /&gt;
|-&lt;br /&gt;
| 0x50 + &#039;&#039;i&#039;&#039; * 0x200||0x200||[[#Language Chunk|Language chunk]] where &#039;&#039;i&#039;&#039; = language index&lt;br /&gt;
|-&lt;br /&gt;
| 0x2050||0x480||24x24 Icon data&lt;br /&gt;
|-&lt;br /&gt;
| 0x24D0||0x1200||48x48 Icon data&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Language Chunk ==&lt;br /&gt;
Data in these chunks use UTF-16 encoding.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Offset&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Size&#039;&#039;&#039;&lt;br /&gt;
| align=&amp;quot;center&amp;quot; style=&amp;quot;background:#f0f0f0;&amp;quot;|&#039;&#039;&#039;Description&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 0x0||0x80||Short title&lt;br /&gt;
|-&lt;br /&gt;
| 0x80||0x100||Long title&lt;br /&gt;
|-&lt;br /&gt;
| 0x180||0x80||Publisher&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Other:SecretPage&amp;diff=17508</id>
		<title>Other:SecretPage</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Other:SecretPage&amp;diff=17508"/>
		<updated>2016-06-12T21:48:07Z</updated>

		<summary type="html">&lt;p&gt;Cruel: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Welcome to the Secret Page!&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Rules&#039;&#039;&#039;:&lt;br /&gt;
&lt;br /&gt;
# Don&#039;t talk about the secret page&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=17250</id>
		<title>GPU/Internal Registers</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=17250"/>
		<updated>2016-05-03T04:33:19Z</updated>

		<summary type="html">&lt;p&gt;Cruel: /* GPUREG_TEXUNITi_PARAM */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GPU]]&lt;br /&gt;
&lt;br /&gt;
== Overview ==&lt;br /&gt;
&lt;br /&gt;
GPU internal registers are written to through GPU commands. They are used to control the GPU&#039;s behavior, that is to say tell it to draw stuff and how we want it drawn.&lt;br /&gt;
&lt;br /&gt;
Each command is at least 8 bytes wide. The first word is the command parameter and the second word constitutes the command header. Optionally, more parameter words may follow (potentially including a padding word to align commands to multiples of 8 bytes).&lt;br /&gt;
&lt;br /&gt;
In the simplest case, a command is exactly 8 bytes wide. You can think of such a command as writing the parameter word to an internal register (the index of which is given in the command header). The more general case where more than one parameter word is given is equivalent to multiple simple commands (one for each parameter word). If consecutive writing mode is enabled in the command header, the current command index will be incremented after each parameter write. Otherwise, the parameters will be consecutively written to the same register.&lt;br /&gt;
&lt;br /&gt;
For example, the sequence &amp;quot;0xAAAAAAAA 0x802F011C 0xBBBBBBBB 0xCCCCCCCC&amp;quot; is equivalent to a call to commands 0xF011C with parameter 0xAAAAAAAA, 0xF011D with parameter 0xBBBBBBBB and 0xF011E with parameter 0xCCCCCCCC. If consecutive writing mode were disabled, the command would be equivalent to three consecutive calls to 0xF011C (once with parameter 0xAAAAAAAA, once with 0xBBBBBBBB, and finally with 0xCCCCCCCC).&lt;br /&gt;
&lt;br /&gt;
Invalid GPU command parameters including NaN floats can cause the GPU to hang, which then causes the GSP module to hang as well.&lt;br /&gt;
&lt;br /&gt;
The size of GPU command buffers must be 0x10-byte aligned; the lower 3 bits of the size are cleared. A common pitfall is having the finalization command (write to register 0x0010) not executed because it was the last 8 bytes of a non-0x10 byte aligned command buffer, and having the GPU hang as a result.&lt;br /&gt;
&lt;br /&gt;
=== Command Header ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| Command ID&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Parameter mask&lt;br /&gt;
|-&lt;br /&gt;
| 20-30&lt;br /&gt;
| Number of extra parameters (may be zero)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Consecutive writing mode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter masking ===&lt;br /&gt;
&lt;br /&gt;
Using a value other than 0xF, parts of a word in internal GPU memory can be updated without touching the other bits of it. For example, setting bit 16 to zero indicates that the least significant byte of the parameter will not be overwritten, setting bit 17 to zero indicates that the parameter&#039;s second LSB will not be overwritten, etc. This means that for instance commands 0x00010107 and 0x00020107 refer to the same thing but write different parts of the parameter.&lt;br /&gt;
&lt;br /&gt;
=== Types ===&lt;br /&gt;
&lt;br /&gt;
There are three main types of registers :&lt;br /&gt;
* configuration registers, which directly map to various rendering properties (for example: [[#GPUREG_FACECULLING_CONFIG|GPUREG_FACECULLING_CONFIG]])&lt;br /&gt;
* data transfer registers, which can be seen as FIFOs that let us send sequential chunks of data to the GPU, such as shader code or 1D samplers (for example: [[#GPUREG_SH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]])&lt;br /&gt;
* action triggering registers, which tell the GPU to do something, like draw a primitive (for example: [[#GPUREG_DRAWARRAYS|GPUREG_DRAWARRAYS]])&lt;br /&gt;
&lt;br /&gt;
=== Aliases ===&lt;br /&gt;
&lt;br /&gt;
It is possible for multiple register (sequential) IDs to correspond to the same register. This is done to leverage the consecutive writing mode for GPU commands, which makes it possible for a single command to write data to multiple sequential register IDs. For example, register IDs 02C1 through 02C8 all correspond to [[#GPUREG_VSH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA&#039;&#039;i&#039;&#039;]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_INDEX|GPUREG_VSH_FLOATUNIFORM_INDEX]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA&#039;&#039;i&#039;&#039;]]&lt;br /&gt;
&lt;br /&gt;
=== Data Types ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Name&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| signed&lt;br /&gt;
| Signed integer&lt;br /&gt;
|-&lt;br /&gt;
| unsigned&lt;br /&gt;
| Unsigned integer&lt;br /&gt;
|-&lt;br /&gt;
| floatX.Y.Z&lt;br /&gt;
| Floating-point number with X sign bits, Y exponent bits, and Z mantissa bits&lt;br /&gt;
|-&lt;br /&gt;
| fixedX.Y.Z&lt;br /&gt;
| Fixed-point number with X sign bits, Y integer bits, and Z fractional bits&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Register list ==&lt;br /&gt;
&lt;br /&gt;
=== Miscellaneous registers (0x000-0x03F) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register ID&lt;br /&gt;
! Register name&lt;br /&gt;
! Notes&lt;br /&gt;
! Official Name&lt;br /&gt;
|-&lt;br /&gt;
| 0000&lt;br /&gt;
| [[#GPUREG_0000|GPUREG_0000]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0001&lt;br /&gt;
| [[#GPUREG_0001|GPUREG_0001]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0002&lt;br /&gt;
| [[#GPUREG_0002|GPUREG_0002]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0003&lt;br /&gt;
| [[#GPUREG_0003|GPUREG_0003]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0004&lt;br /&gt;
| [[#GPUREG_0004|GPUREG_0004]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0005&lt;br /&gt;
| [[#GPUREG_0005|GPUREG_0005]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0006&lt;br /&gt;
| [[#GPUREG_0006|GPUREG_0006]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0007&lt;br /&gt;
| [[#GPUREG_0007|GPUREG_0007]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0008&lt;br /&gt;
| [[#GPUREG_0008|GPUREG_0008]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0009&lt;br /&gt;
| [[#GPUREG_0009|GPUREG_0009]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 000A&lt;br /&gt;
| [[#GPUREG_000A|GPUREG_000A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 000B&lt;br /&gt;
| [[#GPUREG_000B|GPUREG_000B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 000C&lt;br /&gt;
| [[#GPUREG_000C|GPUREG_000C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 000D&lt;br /&gt;
| [[#GPUREG_000D|GPUREG_000D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 000E&lt;br /&gt;
| [[#GPUREG_000E|GPUREG_000E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 000F&lt;br /&gt;
| [[#GPUREG_000F|GPUREG_000F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0010&lt;br /&gt;
| [[#GPUREG_FINALIZE|GPUREG_FINALIZE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_INTERRUPT&lt;br /&gt;
|-&lt;br /&gt;
| 0011&lt;br /&gt;
| [[#GPUREG_0011|GPUREG_0011]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0012&lt;br /&gt;
| [[#GPUREG_0012|GPUREG_0012]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0013&lt;br /&gt;
| [[#GPUREG_0013|GPUREG_0013]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0014&lt;br /&gt;
| [[#GPUREG_0014|GPUREG_0014]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0015&lt;br /&gt;
| [[#GPUREG_0015|GPUREG_0015]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0016&lt;br /&gt;
| [[#GPUREG_0016|GPUREG_0016]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0017&lt;br /&gt;
| [[#GPUREG_0017|GPUREG_0017]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0018&lt;br /&gt;
| [[#GPUREG_0018|GPUREG_0018]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0019&lt;br /&gt;
| [[#GPUREG_0019|GPUREG_0019]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 001A&lt;br /&gt;
| [[#GPUREG_001A|GPUREG_001A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 001B&lt;br /&gt;
| [[#GPUREG_001B|GPUREG_001B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 001C&lt;br /&gt;
| [[#GPUREG_001C|GPUREG_001C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 001D&lt;br /&gt;
| [[#GPUREG_001D|GPUREG_001D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 001E&lt;br /&gt;
| [[#GPUREG_001E|GPUREG_001E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 001F&lt;br /&gt;
| [[#GPUREG_001F|GPUREG_001F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0020&lt;br /&gt;
| [[#GPUREG_0020|GPUREG_0020]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0021&lt;br /&gt;
| [[#GPUREG_0021|GPUREG_0021]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0022&lt;br /&gt;
| [[#GPUREG_0022|GPUREG_0022]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0023&lt;br /&gt;
| [[#GPUREG_0023|GPUREG_0023]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0024&lt;br /&gt;
| [[#GPUREG_0024|GPUREG_0024]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0025&lt;br /&gt;
| [[#GPUREG_0025|GPUREG_0025]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0026&lt;br /&gt;
| [[#GPUREG_0026|GPUREG_0026]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0027&lt;br /&gt;
| [[#GPUREG_0027|GPUREG_0027]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0028&lt;br /&gt;
| [[#GPUREG_0028|GPUREG_0028]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0029&lt;br /&gt;
| [[#GPUREG_0029|GPUREG_0029]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 002A&lt;br /&gt;
| [[#GPUREG_002A|GPUREG_002A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 002B&lt;br /&gt;
| [[#GPUREG_002B|GPUREG_002B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 002C&lt;br /&gt;
| [[#GPUREG_002C|GPUREG_002C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 002D&lt;br /&gt;
| [[#GPUREG_002D|GPUREG_002D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 002E&lt;br /&gt;
| [[#GPUREG_002E|GPUREG_002E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 002F&lt;br /&gt;
| [[#GPUREG_002F|GPUREG_002F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0030&lt;br /&gt;
| [[#GPUREG_0030|GPUREG_0030]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0031&lt;br /&gt;
| [[#GPUREG_0031|GPUREG_0031]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0032&lt;br /&gt;
| [[#GPUREG_0032|GPUREG_0032]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0033&lt;br /&gt;
| [[#GPUREG_0033|GPUREG_0033]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0034&lt;br /&gt;
| [[#GPUREG_0034|GPUREG_0034]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0035&lt;br /&gt;
| [[#GPUREG_0035|GPUREG_0035]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0036&lt;br /&gt;
| [[#GPUREG_0036|GPUREG_0036]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0037&lt;br /&gt;
| [[#GPUREG_0037|GPUREG_0037]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0038&lt;br /&gt;
| [[#GPUREG_0038|GPUREG_0038]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0039&lt;br /&gt;
| [[#GPUREG_0039|GPUREG_0039]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 003A&lt;br /&gt;
| [[#GPUREG_003A|GPUREG_003A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 003B&lt;br /&gt;
| [[#GPUREG_003B|GPUREG_003B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 003C&lt;br /&gt;
| [[#GPUREG_003C|GPUREG_003C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 003D&lt;br /&gt;
| [[#GPUREG_003D|GPUREG_003D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 003E&lt;br /&gt;
| [[#GPUREG_003E|GPUREG_003E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 003F&lt;br /&gt;
| [[#GPUREG_003F|GPUREG_003F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Rasterizer registers (0x040-0x07F) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register ID&lt;br /&gt;
! Register name&lt;br /&gt;
! Notes&lt;br /&gt;
! Official Name&lt;br /&gt;
|-&lt;br /&gt;
| 0040&lt;br /&gt;
| [[#GPUREG_FACECULLING_CONFIG|GPUREG_FACECULLING_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_CULL_FACE&lt;br /&gt;
|-&lt;br /&gt;
| 0041&lt;br /&gt;
| [[#GPUREG_VIEWPORT_WIDTH|GPUREG_VIEWPORT_WIDTH]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_VIEWPORT_WIDTH1&lt;br /&gt;
|-&lt;br /&gt;
| 0042&lt;br /&gt;
| [[#GPUREG_VIEWPORT_INVW|GPUREG_VIEWPORT_INVW]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_VIEWPORT_WIDTH2&lt;br /&gt;
|-&lt;br /&gt;
| 0043&lt;br /&gt;
| [[#GPUREG_VIEWPORT_HEIGHT|GPUREG_VIEWPORT_HEIGHT]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_VIEWPORT_HEIGHT1&lt;br /&gt;
|-&lt;br /&gt;
| 0044&lt;br /&gt;
| [[#GPUREG_VIEWPORT_INVH|GPUREG_VIEWPORT_INVH]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_VIEWPORT_HEIGHT2&lt;br /&gt;
|-&lt;br /&gt;
| 0045&lt;br /&gt;
| [[#GPUREG_0045|GPUREG_0045]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0046&lt;br /&gt;
| [[#GPUREG_0046|GPUREG_0046]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0047&lt;br /&gt;
| [[#GPUREG_FRAGOP_CLIP|GPUREG_FRAGOP_CLIP]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_FRAGOP_CLIP_DATAi|GPUREG_FRAGOP_CLIP_DATA0]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAGOP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_FRAGOP_CLIP_DATAi|GPUREG_FRAGOP_CLIP_DATA1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_FRAGOP_CLIP_DATAi|GPUREG_FRAGOP_CLIP_DATA2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_FRAGOP_CLIP_DATAi|GPUREG_FRAGOP_CLIP_DATA3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_CLIP_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 004C&lt;br /&gt;
| [[#GPUREG_004C|GPUREG_004C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 004D&lt;br /&gt;
| [[#GPUREG_DEPTHMAP_SCALE|GPUREG_DEPTHMAP_SCALE]]&lt;br /&gt;
| As f24&lt;br /&gt;
|PICA_REG_FRAGOP_WSCALE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 004E&lt;br /&gt;
| [[#GPUREG_DEPTHMAP_OFFSET|GPUREG_DEPTHMAP_OFFSET]]&lt;br /&gt;
| As f24&lt;br /&gt;
|PICA_REG_FRAGOP_WSCALE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004F&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_TOTAL|GPUREG_SH_OUTMAP_TOTAL]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_REG_NUM0 / PICA_REG_VS_OUT_REG_NUM0&lt;br /&gt;
|-&lt;br /&gt;
| 0050&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_Oi|GPUREG_SH_OUTMAP_O0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_ATTR0 / PICA_REG_VS_OUT_ATTR0&lt;br /&gt;
|-&lt;br /&gt;
| 0051&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_Oi|GPUREG_SH_OUTMAP_O1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_ATTR1 / PICA_REG_VS_OUT_ATTR1&lt;br /&gt;
|-&lt;br /&gt;
| 0052&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_Oi|GPUREG_SH_OUTMAP_O2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_ATTR2 / PICA_REG_VS_OUT_ATTR2&lt;br /&gt;
|-&lt;br /&gt;
| 0053&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_Oi|GPUREG_SH_OUTMAP_O3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_ATTR3 / PICA_REG_VS_OUT_ATTR3&lt;br /&gt;
|-&lt;br /&gt;
| 0054&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_Oi|GPUREG_SH_OUTMAP_O4]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_ATTR4 / PICA_REG_VS_OUT_ATTR4&lt;br /&gt;
|-&lt;br /&gt;
| 0055&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_Oi|GPUREG_SH_OUTMAP_O5]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_ATTR5 / PICA_REG_VS_OUT_ATTR5&lt;br /&gt;
|-&lt;br /&gt;
| 0056&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_Oi|GPUREG_SH_OUTMAP_O6]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_ATTR6 / PICA_REG_VS_OUT_ATTR6&lt;br /&gt;
|-&lt;br /&gt;
| 0057&lt;br /&gt;
| [[#GPUREG_0057|GPUREG_0057]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0058&lt;br /&gt;
| [[#GPUREG_0058|GPUREG_0058]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0059&lt;br /&gt;
| [[#GPUREG_0059|GPUREG_0059]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 005A&lt;br /&gt;
| [[#GPUREG_005A|GPUREG_005A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 005B&lt;br /&gt;
| [[#GPUREG_005B|GPUREG_005B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 005C&lt;br /&gt;
| [[#GPUREG_005C|GPUREG_005C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 005D&lt;br /&gt;
| [[#GPUREG_005D|GPUREG_005D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 005E&lt;br /&gt;
| [[#GPUREG_005E|GPUREG_005E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 005F&lt;br /&gt;
| [[#GPUREG_005F|GPUREG_005F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0060&lt;br /&gt;
| [[#GPUREG_0060|GPUREG_0060]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0061&lt;br /&gt;
| [[#GPUREG_EARLYDEPTH_FUNC|GPUREG_EARLYDEPTH_FUNC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_EARLYDEPTH_TEST1|GPUREG_EARLYDEPTH_TEST1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_EARLYDEPTH_CLEAR|GPUREG_EARLYDEPTH_CLEAR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_EARLY_DEPTH_CLEAR&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_SH_OUTATTR_MODE|GPUREG_SH_OUTATTR_MODE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_OUT_ATTR_MODE / PICA_REG_VS_OUT_ATTR_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0065&lt;br /&gt;
| [[#GPUREG_SCISSORTEST_MODE|GPUREG_SCISSORTEST_MODE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_SCISSOR&lt;br /&gt;
|-&lt;br /&gt;
| 0066&lt;br /&gt;
| [[#GPUREG_SCISSORTEST_POS|GPUREG_SCISSORTEST_POS]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_SCISSOR_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0067&lt;br /&gt;
| [[#GPUREG_SCISSORTEST_DIM|GPUREG_SCISSORTEST_DIM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_SCISSOR_SIZE&lt;br /&gt;
|-&lt;br /&gt;
| 0068&lt;br /&gt;
| [[#GPUREG_VIEWPORT_XY|GPUREG_VIEWPORT_XY]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_VIEWPORT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0069&lt;br /&gt;
| [[#GPUREG_0069|GPUREG_0069]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 006A&lt;br /&gt;
| [[#GPUREG_EARLYDEPTH_DATA|GPUREG_EARLYDEPTH_DATA]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_DATA&lt;br /&gt;
|-&lt;br /&gt;
| 006B&lt;br /&gt;
| [[#GPUREG_006B|GPUREG_006B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 006C&lt;br /&gt;
| [[#GPUREG_006C|GPUREG_006C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 006D&lt;br /&gt;
| [[#GPUREG_DEPTHMAP_ENABLE|GPUREG_DEPTHMAP_ENABLE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_RENDERBUF_DIM|GPUREG_RENDERBUF_DIM]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_SH_OUTATTR_CLOCK|GPUREG_SH_OUTATTR_CLOCK]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_OUT_ATTR_CLK / PICA_REG_VS_OUT_ATTR_CLK&lt;br /&gt;
|-&lt;br /&gt;
| 0070&lt;br /&gt;
| [[#GPUREG_0070|GPUREG_0070]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0071&lt;br /&gt;
| [[#GPUREG_0071|GPUREG_0071]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0072&lt;br /&gt;
| [[#GPUREG_0072|GPUREG_0072]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0073&lt;br /&gt;
| [[#GPUREG_0073|GPUREG_0073]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0074&lt;br /&gt;
| [[#GPUREG_0074|GPUREG_0074]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0075&lt;br /&gt;
| [[#GPUREG_0075|GPUREG_0075]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0076&lt;br /&gt;
| [[#GPUREG_0076|GPUREG_0076]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0077&lt;br /&gt;
| [[#GPUREG_0077|GPUREG_0077]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0078&lt;br /&gt;
| [[#GPUREG_0078|GPUREG_0078]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0079&lt;br /&gt;
| [[#GPUREG_0079|GPUREG_0079]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 007A&lt;br /&gt;
| [[#GPUREG_007A|GPUREG_007A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 007B&lt;br /&gt;
| [[#GPUREG_007B|GPUREG_007B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 007C&lt;br /&gt;
| [[#GPUREG_007C|GPUREG_007C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 007D&lt;br /&gt;
| [[#GPUREG_007D|GPUREG_007D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 007E&lt;br /&gt;
| [[#GPUREG_007E|GPUREG_007E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 007F&lt;br /&gt;
| [[#GPUREG_007F|GPUREG_007F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Texturing registers (0x080-0x0FF) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register ID&lt;br /&gt;
! Register name&lt;br /&gt;
! Notes&lt;br /&gt;
! Official Name&lt;br /&gt;
|-&lt;br /&gt;
| 0080&lt;br /&gt;
| [[#GPUREG_TEXUNIT_CONFIG|GPUREG_TEXUNIT_CONFIG]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNITi_BORDER_COLOR|GPUREG_TEXUNIT0_BORDER_COLOR]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE0_BORDER_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0082&lt;br /&gt;
| [[#GPUREG_TEXUNITi_DIM|GPUREG_TEXUNIT0_DIM]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE0_SIZE&lt;br /&gt;
|-&lt;br /&gt;
| 0083&lt;br /&gt;
| [[#GPUREG_TEXUNITi_PARAM|GPUREG_TEXUNIT0_PARAM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_WRAP_FILTER&lt;br /&gt;
|-&lt;br /&gt;
| 0084&lt;br /&gt;
| [[#GPUREG_TEXUNITi_LOD|GPUREG_TEXUNIT0_LOD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNITi_ADDRi|GPUREG_TEXUNIT0_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_TEXUNITi_ADDRi|GPUREG_TEXUNIT0_ADDR2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_TEXUNITi_ADDRi|GPUREG_TEXUNIT0_ADDR3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_TEXUNITi_ADDRi|GPUREG_TEXUNIT0_ADDR4]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_TEXUNITi_ADDRi|GPUREG_TEXUNIT0_ADDR5]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_TEXUNITi_ADDRi|GPUREG_TEXUNIT0_ADDR6]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_TEXUNITi_SHADOW|GPUREG_TEXUNIT0_SHADOW]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_SHADOW&lt;br /&gt;
|-&lt;br /&gt;
| 008C&lt;br /&gt;
| [[#GPUREG_008C|GPUREG_008C]]&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 008D&lt;br /&gt;
| [[#GPUREG_008D|GPUREG_008D]]&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 008E&lt;br /&gt;
| [[#GPUREG_TEXUNITi_TYPE|GPUREG_TEXUNIT0_TYPE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_FORMAT&lt;br /&gt;
|-&lt;br /&gt;
| 008F&lt;br /&gt;
| [[#GPUREG_LIGHTING_ENABLE0|GPUREG_LIGHTING_ENABLE0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_EN0&lt;br /&gt;
|-&lt;br /&gt;
| 0090&lt;br /&gt;
| [[#GPUREG_0090|GPUREG_0090]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0091&lt;br /&gt;
| [[#GPUREG_TEXUNITi_BORDER_COLOR|GPUREG_TEXUNIT1_BORDER_COLOR]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE1_BORDER_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0092&lt;br /&gt;
| [[#GPUREG_TEXUNITi_DIM|GPUREG_TEXUNIT1_DIM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_SIZE&lt;br /&gt;
|-&lt;br /&gt;
| 0093&lt;br /&gt;
| [[#GPUREG_TEXUNITi_PARAM|GPUREG_TEXUNIT1_PARAM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_WRAP_FILTER&lt;br /&gt;
|-&lt;br /&gt;
| 0094&lt;br /&gt;
| [[#GPUREG_TEXUNITi_LOD|GPUREG_TEXUNIT1_LOD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNITi_ADDRi|GPUREG_TEXUNIT1_ADDR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNITi_TYPE|GPUREG_TEXUNIT1_TYPE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_FORMAT&lt;br /&gt;
|-&lt;br /&gt;
| 0097&lt;br /&gt;
| [[#GPUREG_0097|GPUREG_0097]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0098&lt;br /&gt;
| [[#GPUREG_0098|GPUREG_0098]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0099&lt;br /&gt;
| [[#GPUREG_TEXUNITi_BORDER_COLOR|GPUREG_TEXUNIT2_BORDER_COLOR]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_BORDER_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 009A&lt;br /&gt;
| [[#GPUREG_TEXUNITi_DIM|GPUREG_TEXUNIT2_DIM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE2_SIZE&lt;br /&gt;
|-&lt;br /&gt;
| 009B&lt;br /&gt;
| [[#GPUREG_TEXUNITi_PARAM|GPUREG_TEXUNIT2_PARAM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE2_WRAP_FILTER&lt;br /&gt;
|-&lt;br /&gt;
| 009C&lt;br /&gt;
| [[#GPUREG_TEXUNITi_LOD|GPUREG_TEXUNIT2_LOD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNITi_ADDRi|GPUREG_TEXUNIT2_ADDR]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNITi_TYPE|GPUREG_TEXUNIT2_TYPE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE2_FORMAT&lt;br /&gt;
|-&lt;br /&gt;
| 009F&lt;br /&gt;
| [[#GPUREG_009F|GPUREG_009F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A0&lt;br /&gt;
| [[#GPUREG_00A0|GPUREG_00A0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A1&lt;br /&gt;
| [[#GPUREG_00A1|GPUREG_00A1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A2&lt;br /&gt;
| [[#GPUREG_00A2|GPUREG_00A2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A3&lt;br /&gt;
| [[#GPUREG_00A3|GPUREG_00A3]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A4&lt;br /&gt;
| [[#GPUREG_00A4|GPUREG_00A4]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A5&lt;br /&gt;
| [[#GPUREG_00A5|GPUREG_00A5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A6&lt;br /&gt;
| [[#GPUREG_00A6|GPUREG_00A6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A7&lt;br /&gt;
| [[#GPUREG_00A7|GPUREG_00A7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00A8&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROCTEX0|GPUREG_TEXUNIT3_PROCTEX0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROCTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROCTEX1|GPUREG_TEXUNIT3_PROCTEX1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROCTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROCTEX2|GPUREG_TEXUNIT3_PROCTEX2]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROCTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROCTEX3|GPUREG_TEXUNIT3_PROCTEX3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROCTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROCTEX4|GPUREG_TEXUNIT3_PROCTEX4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROCTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROCTEX5|GPUREG_TEXUNIT3_PROCTEX5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROCTEX5&lt;br /&gt;
|-&lt;br /&gt;
| 00AE&lt;br /&gt;
| [[#GPUREG_00AE|GPUREG_00AE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00AF&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT|GPUREG_PROCTEX_LUT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT_DATAi|GPUREG_PROCTEX_LUT_DATA0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT_DATAi|GPUREG_PROCTEX_LUT_DATA1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT_DATAi|GPUREG_PROCTEX_LUT_DATA2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT_DATAi|GPUREG_PROCTEX_LUT_DATA3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT_DATAi|GPUREG_PROCTEX_LUT_DATA4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT_DATAi|GPUREG_PROCTEX_LUT_DATA5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT_DATAi|GPUREG_PROCTEX_LUT_DATA6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_PROCTEX_LUT_DATAi|GPUREG_PROCTEX_LUT_DATA7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROCTEX_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00B8&lt;br /&gt;
| [[#GPUREG_00B8|GPUREG_00B8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00B9&lt;br /&gt;
| [[#GPUREG_00B9|GPUREG_00B9]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00BA&lt;br /&gt;
| [[#GPUREG_00BA|GPUREG_00BA]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00BB&lt;br /&gt;
| [[#GPUREG_00BB|GPUREG_00BB]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00BC&lt;br /&gt;
| [[#GPUREG_00BC|GPUREG_00BC]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00BD&lt;br /&gt;
| [[#GPUREG_00BD|GPUREG_00BD]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00BE&lt;br /&gt;
| [[#GPUREG_00BE|GPUREG_00BE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00BF&lt;br /&gt;
| [[#GPUREG_00BF|GPUREG_00BF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00C0&lt;br /&gt;
| [[#GPUREG_TEXENVi_SOURCE|GPUREG_TEXENV0_SOURCE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_0&lt;br /&gt;
|-&lt;br /&gt;
| 00C1&lt;br /&gt;
| [[#GPUREG_TEXENVi_OPERAND|GPUREG_TEXENV0_OPERAND]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_0_OPERAND&lt;br /&gt;
|-&lt;br /&gt;
| 00C2&lt;br /&gt;
| [[#GPUREG_TEXENVi_COMBINER|GPUREG_TEXENV0_COMBINER]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_0_COMBINE&lt;br /&gt;
|-&lt;br /&gt;
| 00C3&lt;br /&gt;
| [[#GPUREG_TEXENVi_COLOR|GPUREG_TEXENV0_COLOR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_0_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 00C4&lt;br /&gt;
| [[#GPUREG_TEXENVi_SCALE|GPUREG_TEXENV0_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_0_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 00C5&lt;br /&gt;
| [[#GPUREG_00C5|GPUREG_00C5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00C6&lt;br /&gt;
| [[#GPUREG_00C6|GPUREG_00C6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00C7&lt;br /&gt;
| [[#GPUREG_00C7|GPUREG_00C7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00C8&lt;br /&gt;
| [[#GPUREG_TEXENVi_SOURCE|GPUREG_TEXENV1_SOURCE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_1&lt;br /&gt;
|-&lt;br /&gt;
| 00C9&lt;br /&gt;
| [[#GPUREG_TEXENVi_OPERAND|GPUREG_TEXENV1_OPERAND]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_1_OPERAND&lt;br /&gt;
|-&lt;br /&gt;
| 00CA&lt;br /&gt;
| [[#GPUREG_TEXENVi_COMBINER|GPUREG_TEXENV1_COMBINER]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_1_COMBINE&lt;br /&gt;
|-&lt;br /&gt;
| 00CB&lt;br /&gt;
| [[#GPUREG_TEXENVi_COLOR|GPUREG_TEXENV1_COLOR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_1_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 00CC&lt;br /&gt;
| [[#GPUREG_TEXENVi_SCALE|GPUREG_TEXENV1_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_1_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 00CD&lt;br /&gt;
| [[#GPUREG_00CD|GPUREG_00CD]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00CE&lt;br /&gt;
| [[#GPUREG_00CE|GPUREG_00CE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00CF&lt;br /&gt;
| [[#GPUREG_00CF|GPUREG_00CF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00D0&lt;br /&gt;
| [[#GPUREG_TEXENVi_SOURCE|GPUREG_TEXENV2_SOURCE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_2&lt;br /&gt;
|-&lt;br /&gt;
| 00D1&lt;br /&gt;
| [[#GPUREG_TEXENVi_OPERAND|GPUREG_TEXENV2_OPERAND]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_2_OPERAND&lt;br /&gt;
|-&lt;br /&gt;
| 00D2&lt;br /&gt;
| [[#GPUREG_TEXENVi_COMBINER|GPUREG_TEXENV2_COMBINER]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_2_COMBINE&lt;br /&gt;
|-&lt;br /&gt;
| 00D3&lt;br /&gt;
| [[#GPUREG_TEXENVi_COLOR|GPUREG_TEXENV2_COLOR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_2_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 00D4&lt;br /&gt;
| [[#GPUREG_TEXENVi_SCALE|GPUREG_TEXENV2_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_2_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 00D5&lt;br /&gt;
| [[#GPUREG_00D5|GPUREG_00D5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00D6&lt;br /&gt;
| [[#GPUREG_00D6|GPUREG_00D6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00D7&lt;br /&gt;
| [[#GPUREG_00D7|GPUREG_00D7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00D8&lt;br /&gt;
| [[#GPUREG_TEXENVi_SOURCE|GPUREG_TEXENV3_SOURCE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_3&lt;br /&gt;
|-&lt;br /&gt;
| 00D9&lt;br /&gt;
| [[#GPUREG_TEXENVi_OPERAND|GPUREG_TEXENV3_OPERAND]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_3_OPERAND&lt;br /&gt;
|-&lt;br /&gt;
| 00DA&lt;br /&gt;
| [[#GPUREG_TEXENVi_COMBINER|GPUREG_TEXENV3_COMBINER]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_3_COMBINE&lt;br /&gt;
|-&lt;br /&gt;
| 00DB&lt;br /&gt;
| [[#GPUREG_TEXENVi_COLOR|GPUREG_TEXENV3_COLOR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_3_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 00DC&lt;br /&gt;
| [[#GPUREG_TEXENVi_SCALE|GPUREG_TEXENV3_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_3_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 00DD&lt;br /&gt;
| [[#GPUREG_00DD|GPUREG_00DD]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00DE&lt;br /&gt;
| [[#GPUREG_00DE|GPUREG_00DE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00DF&lt;br /&gt;
| [[#GPUREG_00DF|GPUREG_00DF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00E0&lt;br /&gt;
| [[#GPUREG_TEXENV_UPDATE_BUFFER|GPUREG_TEXENV_UPDATE_BUFFER]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_FOG_MODE / PICA_REG_TEX_ENV_BUF_INPUT&lt;br /&gt;
|-&lt;br /&gt;
| 00E1&lt;br /&gt;
| [[#GPUREG_FOG_COLOR|GPUREG_FOG_COLOR]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 00E2&lt;br /&gt;
| [[#GPUREG_00E2|GPUREG_00E2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00E3&lt;br /&gt;
| [[#GPUREG_00E3|GPUREG_00E3]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00E4&lt;br /&gt;
| [[#GPUREG_GAS_ATTENUATION|GPUREG_GAS_ATTENUATION]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_GAS_ACCMAX|GPUREG_GAS_ACCMAX]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_FOG_LUT_INDEX|GPUREG_FOG_LUT_INDEX]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 00E7&lt;br /&gt;
| [[#GPUREG_00E7|GPUREG_00E7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00E8&lt;br /&gt;
| [[#GPUREG_FOG_LUT_DATAi|GPUREG_FOG_LUT_DATA0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_FOG_LUT_DATAi|GPUREG_FOG_LUT_DATA1]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_FOG_LUT_DATAi|GPUREG_FOG_LUT_DATA2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_FOG_LUT_DATAi|GPUREG_FOG_LUT_DATA3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_FOG_LUT_DATAi|GPUREG_FOG_LUT_DATA4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_FOG_LUT_DATAi|GPUREG_FOG_LUT_DATA5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_FOG_LUT_DATAi|GPUREG_FOG_LUT_DATA6]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_FOG_LUT_DATAi|GPUREG_FOG_LUT_DATA7]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENVi_SOURCE|GPUREG_TEXENV4_SOURCE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_4&lt;br /&gt;
|-&lt;br /&gt;
| 00F1&lt;br /&gt;
| [[#GPUREG_TEXENVi_OPERAND|GPUREG_TEXENV4_OPERAND]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_4_OPERAND&lt;br /&gt;
|-&lt;br /&gt;
| 00F2&lt;br /&gt;
| [[#GPUREG_TEXENVi_COMBINER|GPUREG_TEXENV4_COMBINER]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_4_COMBINE&lt;br /&gt;
|-&lt;br /&gt;
| 00F3&lt;br /&gt;
| [[#GPUREG_TEXENVi_COLOR|GPUREG_TEXENV4_COLOR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_4_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 00F4&lt;br /&gt;
| [[#GPUREG_TEXENVi_SCALE|GPUREG_TEXENV4_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_4_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 00F5&lt;br /&gt;
| [[#GPUREG_00F5|GPUREG_00F5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00F6&lt;br /&gt;
| [[#GPUREG_00F6|GPUREG_00F6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00F7&lt;br /&gt;
| [[#GPUREG_00F7|GPUREG_00F7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00F8&lt;br /&gt;
| [[#GPUREG_TEXENVi_SOURCE|GPUREG_TEXENV5_SOURCE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_5&lt;br /&gt;
|-&lt;br /&gt;
| 00F9&lt;br /&gt;
| [[#GPUREG_TEXENVi_OPERAND|GPUREG_TEXENV5_OPERAND]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_5_OPERAND&lt;br /&gt;
|-&lt;br /&gt;
| 00FA&lt;br /&gt;
| [[#GPUREG_TEXENVi_COMBINER|GPUREG_TEXENV5_COMBINER]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_5_COMBINE&lt;br /&gt;
|-&lt;br /&gt;
| 00FB&lt;br /&gt;
| [[#GPUREG_TEXENVi_COLOR|GPUREG_TEXENV5_COLOR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_5_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 00FC&lt;br /&gt;
| [[#GPUREG_TEXENVi_SCALE|GPUREG_TEXENV5_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEX_ENV_5_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 00FD&lt;br /&gt;
| [[#GPUREG_TEXENV_BUFFER_COLOR|GPUREG_TEXENV_BUFFER_COLOR]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEX_ENV_BUF_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 00FE&lt;br /&gt;
| [[#GPUREG_00FE|GPUREG_00FE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 00FF&lt;br /&gt;
| [[#GPUREG_00FF|GPUREG_00FF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Framebuffer registers (0x100-0x13F) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register ID&lt;br /&gt;
! Register name&lt;br /&gt;
! Notes&lt;br /&gt;
! Official Name&lt;br /&gt;
|-&lt;br /&gt;
| 0100&lt;br /&gt;
| [[#GPUREG_COLOR_OPERATION|GPUREG_COLOR_OPERATION]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_FUNC|GPUREG_BLEND_FUNC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGIC_OP|GPUREG_LOGIC_OP]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_LOGIC_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0103&lt;br /&gt;
| [[#GPUREG_BLEND_COLOR|GPUREG_BLEND_COLOR]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0104&lt;br /&gt;
| [[#GPUREG_FRAGOP_ALPHA_TEST|GPUREG_FRAGOP_ALPHA_TEST]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAGOP_ALPHA_TEST&lt;br /&gt;
|-&lt;br /&gt;
| 0105&lt;br /&gt;
| [[#GPUREG_STENCIL_TEST|GPUREG_STENCIL_TEST]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_TEST&lt;br /&gt;
|-&lt;br /&gt;
| 0106&lt;br /&gt;
| [[#GPUREG_STENCIL_OP|GPUREG_STENCIL_OP]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTH_COLOR_MASK|GPUREG_DEPTH_COLOR_MASK]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_DEPTH_COLOR_MASK&lt;br /&gt;
|-&lt;br /&gt;
| 0108&lt;br /&gt;
| [[#GPUREG_0108|GPUREG_0108]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0109&lt;br /&gt;
| [[#GPUREG_0109|GPUREG_0109]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 010A&lt;br /&gt;
| [[#GPUREG_010A|GPUREG_010A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 010B&lt;br /&gt;
| [[#GPUREG_010B|GPUREG_010B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 010C&lt;br /&gt;
| [[#GPUREG_010C|GPUREG_010C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 010D&lt;br /&gt;
| [[#GPUREG_010D|GPUREG_010D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 010E&lt;br /&gt;
| [[#GPUREG_010E|GPUREG_010E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 010F&lt;br /&gt;
| [[#GPUREG_010F|GPUREG_010F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0110&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_INVALIDATE|GPUREG_FRAMEBUFFER_INVALIDATE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_BUFFER_CLEAR0&lt;br /&gt;
|-&lt;br /&gt;
| 0111&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_FLUSH|GPUREG_FRAMEBUFFER_FLUSH]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_BUFFER_CLEAR1&lt;br /&gt;
|-&lt;br /&gt;
| 0112&lt;br /&gt;
| [[#GPUREG_COLORBUFFER_READ|GPUREG_COLORBUFFER_READ]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_COLOR_BUFFER_READ&lt;br /&gt;
|-&lt;br /&gt;
| 0113&lt;br /&gt;
| [[#GPUREG_COLORBUFFER_WRITE|GPUREG_COLORBUFFER_WRITE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_COLOR_BUFFER_WRITE&lt;br /&gt;
|-&lt;br /&gt;
| 0114&lt;br /&gt;
| [[#GPUREG_DEPTHBUFFER_READ|GPUREG_DEPTHBUFFER_READ]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_DEPTH_STENCIL_READ&lt;br /&gt;
|-&lt;br /&gt;
| 0115&lt;br /&gt;
| [[#GPUREG_DEPTHBUFFER_WRITE|GPUREG_DEPTHBUFFER_WRITE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_DEPTH_STENCIL_WRITE&lt;br /&gt;
|-&lt;br /&gt;
| 0116&lt;br /&gt;
| [[#GPUREG_DEPTHBUFFER_FORMAT|GPUREG_DEPTHBUFFER_FORMAT]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_RENDER_BUF_DEPTH_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0117&lt;br /&gt;
| [[#GPUREG_COLORBUFFER_FORMAT|GPUREG_COLORBUFFER_FORMAT]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_RENDER_BUF_COLOR_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0118&lt;br /&gt;
| [[#GPUREG_EARLYDEPTH_TEST2|GPUREG_EARLYDEPTH_TEST2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST2&lt;br /&gt;
|-&lt;br /&gt;
| 0119&lt;br /&gt;
| [[#GPUREG_0119|GPUREG_0119]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 011A&lt;br /&gt;
| [[#GPUREG_011A|GPUREG_011A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 011B&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_BLOCK32|GPUREG_FRAMEBUFFER_BLOCK32]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_RENDER_BLOCK_FORMAT&lt;br /&gt;
|-&lt;br /&gt;
| 011C&lt;br /&gt;
| [[#GPUREG_DEPTHBUFFER_LOC|GPUREG_DEPTHBUFFER_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_RENDER_BUF_DEPTH_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 011D&lt;br /&gt;
| [[#GPUREG_COLORBUFFER_LOC|GPUREG_COLORBUFFER_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_RENDER_BUF_COLOR_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 011E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM|GPUREG_FRAMEBUFFER_DIM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION0&lt;br /&gt;
|-&lt;br /&gt;
| 011F&lt;br /&gt;
| [[#GPUREG_011F|GPUREG_011F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0120&lt;br /&gt;
| [[#GPUREG_GAS_LIGHT_XY|GPUREG_GAS_LIGHT_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_GAS_LIGHT_Z|GPUREG_GAS_LIGHT_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_GAS_LIGHT_Z_COLOR|GPUREG_GAS_LIGHT_Z_COLOR]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_GAS_LUT_INDEX|GPUREG_GAS_LUT_INDEX]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_GAS_LUT_DATA|GPUREG_GAS_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_DATA&lt;br /&gt;
|-&lt;br /&gt;
| 0125&lt;br /&gt;
| [[#GPUREG_0125|GPUREG_0125]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0126&lt;br /&gt;
| [[#GPUREG_GAS_DELTAZ_DEPTH|GPUREG_GAS_DELTAZ_DEPTH]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_DELTAZ_DEPTH&lt;br /&gt;
|-&lt;br /&gt;
| 0127&lt;br /&gt;
| [[#GPUREG_0127|GPUREG_0127]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0128&lt;br /&gt;
| [[#GPUREG_0128|GPUREG_0128]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0129&lt;br /&gt;
| [[#GPUREG_0129|GPUREG_0129]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 012A&lt;br /&gt;
| [[#GPUREG_012A|GPUREG_012A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 012B&lt;br /&gt;
| [[#GPUREG_012B|GPUREG_012B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 012C&lt;br /&gt;
| [[#GPUREG_012C|GPUREG_012C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 012D&lt;br /&gt;
| [[#GPUREG_012D|GPUREG_012D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 012E&lt;br /&gt;
| [[#GPUREG_012E|GPUREG_012E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 012F&lt;br /&gt;
| [[#GPUREG_012F|GPUREG_012F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0130&lt;br /&gt;
| [[#GPUREG_FRAGOP_SHADOW|GPUREG_FRAGOP_SHADOW]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_SHADOW&lt;br /&gt;
|-&lt;br /&gt;
| 0131&lt;br /&gt;
| [[#GPUREG_0131|GPUREG_0131]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0132&lt;br /&gt;
| [[#GPUREG_0132|GPUREG_0132]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0133&lt;br /&gt;
| [[#GPUREG_0133|GPUREG_0133]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0134&lt;br /&gt;
| [[#GPUREG_0134|GPUREG_0134]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0135&lt;br /&gt;
| [[#GPUREG_0135|GPUREG_0135]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0136&lt;br /&gt;
| [[#GPUREG_0136|GPUREG_0136]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0137&lt;br /&gt;
| [[#GPUREG_0137|GPUREG_0137]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0138&lt;br /&gt;
| [[#GPUREG_0138|GPUREG_0138]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0139&lt;br /&gt;
| [[#GPUREG_0139|GPUREG_0139]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 013A&lt;br /&gt;
| [[#GPUREG_013A|GPUREG_013A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 013B&lt;br /&gt;
| [[#GPUREG_013B|GPUREG_013B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 013C&lt;br /&gt;
| [[#GPUREG_013C|GPUREG_013C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 013D&lt;br /&gt;
| [[#GPUREG_013D|GPUREG_013D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 013E&lt;br /&gt;
| [[#GPUREG_013E|GPUREG_013E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 013F&lt;br /&gt;
| [[#GPUREG_013F|GPUREG_013F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Fragment lighting registers (0x140-0x1FF) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register ID&lt;br /&gt;
! Register name&lt;br /&gt;
! Notes&lt;br /&gt;
! Official Name&lt;br /&gt;
|-&lt;br /&gt;
| 0140&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR0|GPUREG_LIGHT0_SPECULAR0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_SPECULAR0 / PICA_REG_FRAG_LIGHT_START&lt;br /&gt;
|-&lt;br /&gt;
| 0141&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR1|GPUREG_LIGHT0_SPECULAR1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_SPECULAR1&lt;br /&gt;
|-&lt;br /&gt;
| 0142&lt;br /&gt;
| [[#GPUREG_LIGHTi_DIFFUSE|GPUREG_LIGHT0_DIFFUSE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_DIFFUSE&lt;br /&gt;
|-&lt;br /&gt;
| 0143&lt;br /&gt;
| [[#GPUREG_LIGHTi_AMBIENT|GPUREG_LIGHT0_AMBIENT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 0144&lt;br /&gt;
| [[#GPUREG_LIGHTi_XY|GPUREG_LIGHT0_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_POSITION_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0145&lt;br /&gt;
| [[#GPUREG_LIGHTi_Z|GPUREG_LIGHT0_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_POSITION_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0146&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_XY|GPUREG_LIGHT0_SPOTDIR_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_SPOT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0147&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_Z|GPUREG_LIGHT0_SPOTDIR_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_SPOT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0148&lt;br /&gt;
| [[#GPUREG_0148|GPUREG_0148]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0149&lt;br /&gt;
| [[#GPUREG_LIGHTi_CONFIG|GPUREG_LIGHT0_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_TYPE&lt;br /&gt;
|-&lt;br /&gt;
| 014A&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_BIAS|GPUREG_LIGHT0_ATTENUATION_BIAS]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_DIST_ATTN_BIAS&lt;br /&gt;
|-&lt;br /&gt;
| 014B&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_SCALE|GPUREG_LIGHT0_ATTENUATION_SCALE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT0_DIST_ATTN_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 014C&lt;br /&gt;
| [[#GPUREG_014C|GPUREG_014C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 014D&lt;br /&gt;
| [[#GPUREG_014D|GPUREG_014D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 014E&lt;br /&gt;
| [[#GPUREG_014E|GPUREG_014E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 014F&lt;br /&gt;
| [[#GPUREG_014F|GPUREG_014F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0150&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR0|GPUREG_LIGHT1_SPECULAR0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_SPECULAR0&lt;br /&gt;
|-&lt;br /&gt;
| 0151&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR1|GPUREG_LIGHT1_SPECULAR1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_SPECULAR1&lt;br /&gt;
|-&lt;br /&gt;
| 0152&lt;br /&gt;
| [[#GPUREG_LIGHTi_DIFFUSE|GPUREG_LIGHT1_DIFFUSE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_DIFFUSE&lt;br /&gt;
|-&lt;br /&gt;
| 0153&lt;br /&gt;
| [[#GPUREG_LIGHTi_AMBIENT|GPUREG_LIGHT1_AMBIENT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 0154&lt;br /&gt;
| [[#GPUREG_LIGHTi_XY|GPUREG_LIGHT1_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_POSITION_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0155&lt;br /&gt;
| [[#GPUREG_LIGHTi_Z|GPUREG_LIGHT1_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_POSITION_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0156&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_XY|GPUREG_LIGHT1_SPOTDIR_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_SPOT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0157&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_Z|GPUREG_LIGHT1_SPOTDIR_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_SPOT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0158&lt;br /&gt;
| [[#GPUREG_0158|GPUREG_0158]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0159&lt;br /&gt;
| [[#GPUREG_LIGHTi_CONFIG|GPUREG_LIGHT1_CONFIG]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_TYPE&lt;br /&gt;
|-&lt;br /&gt;
| 015A&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_BIAS|GPUREG_LIGHT1_ATTENUATION_BIAS]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_DIST_ATTN_BIAS&lt;br /&gt;
|-&lt;br /&gt;
| 015B&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_SCALE|GPUREG_LIGHT1_ATTENUATION_SCALE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT1_DIST_ATTN_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 015C&lt;br /&gt;
| [[#GPUREG_015C|GPUREG_015C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 015D&lt;br /&gt;
| [[#GPUREG_015D|GPUREG_015D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 015E&lt;br /&gt;
| [[#GPUREG_015E|GPUREG_015E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 015F&lt;br /&gt;
| [[#GPUREG_015F|GPUREG_015F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0160&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR0|GPUREG_LIGHT2_SPECULAR0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_SPECULAR0&lt;br /&gt;
|-&lt;br /&gt;
| 0161&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR1|GPUREG_LIGHT2_SPECULAR1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_SPECULAR1&lt;br /&gt;
|-&lt;br /&gt;
| 0162&lt;br /&gt;
| [[#GPUREG_LIGHTi_DIFFUSE|GPUREG_LIGHT2_DIFFUSE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_DIFFUSE&lt;br /&gt;
|-&lt;br /&gt;
| 0163&lt;br /&gt;
| [[#GPUREG_LIGHTi_AMBIENT|GPUREG_LIGHT2_AMBIENT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 0164&lt;br /&gt;
| [[#GPUREG_LIGHTi_XY|GPUREG_LIGHT2_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_POSITION_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0165&lt;br /&gt;
| [[#GPUREG_LIGHTi_Z|GPUREG_LIGHT2_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_POSITION_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0166&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_XY|GPUREG_LIGHT2_SPOTDIR_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_SPOT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0167&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_Z|GPUREG_LIGHT2_SPOTDIR_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_SPOT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0168&lt;br /&gt;
| [[#GPUREG_0168|GPUREG_0168]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0169&lt;br /&gt;
| [[#GPUREG_LIGHTi_CONFIG|GPUREG_LIGHT2_CONFIG]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_TYPE&lt;br /&gt;
|-&lt;br /&gt;
| 016A&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_BIAS|GPUREG_LIGHT2_ATTENUATION_BIAS]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_DIST_ATTN_BIAS&lt;br /&gt;
|-&lt;br /&gt;
| 016B&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_SCALE|GPUREG_LIGHT2_ATTENUATION_SCALE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT2_DIST_ATTN_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 016C&lt;br /&gt;
| [[#GPUREG_016C|GPUREG_016C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 016D&lt;br /&gt;
| [[#GPUREG_016D|GPUREG_016D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 016E&lt;br /&gt;
| [[#GPUREG_016E|GPUREG_016E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 016F&lt;br /&gt;
| [[#GPUREG_016F|GPUREG_016F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0170&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR0|GPUREG_LIGHT3_SPECULAR0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_SPECULAR0&lt;br /&gt;
|-&lt;br /&gt;
| 0171&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR1|GPUREG_LIGHT3_SPECULAR1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_SPECULAR1&lt;br /&gt;
|-&lt;br /&gt;
| 0172&lt;br /&gt;
| [[#GPUREG_LIGHTi_DIFFUSE|GPUREG_LIGHT3_DIFFUSE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_DIFFUSE&lt;br /&gt;
|-&lt;br /&gt;
| 0173&lt;br /&gt;
| [[#GPUREG_LIGHTi_AMBIENT|GPUREG_LIGHT3_AMBIENT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 0174&lt;br /&gt;
| [[#GPUREG_LIGHTi_XY|GPUREG_LIGHT3_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_POSITION_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0175&lt;br /&gt;
| [[#GPUREG_LIGHTi_Z|GPUREG_LIGHT3_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_POSITION_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0176&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_XY|GPUREG_LIGHT3_SPOTDIR_XY]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_SPOT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0177&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_Z|GPUREG_LIGHT3_SPOTDIR_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_SPOT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0178&lt;br /&gt;
| [[#GPUREG_0178|GPUREG_0178]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0179&lt;br /&gt;
| [[#GPUREG_LIGHTi_CONFIG|GPUREG_LIGHT3_CONFIG]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_TYPE&lt;br /&gt;
|-&lt;br /&gt;
| 017A&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_BIAS|GPUREG_LIGHT3_ATTENUATION_BIAS]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_DIST_ATTN_BIAS&lt;br /&gt;
|-&lt;br /&gt;
| 017B&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_SCALE|GPUREG_LIGHT3_ATTENUATION_SCALE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT3_DIST_ATTN_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 017C&lt;br /&gt;
| [[#GPUREG_017C|GPUREG_017C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 017D&lt;br /&gt;
| [[#GPUREG_017D|GPUREG_017D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 017E&lt;br /&gt;
| [[#GPUREG_017E|GPUREG_017E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 017F&lt;br /&gt;
| [[#GPUREG_017F|GPUREG_017F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0180&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR0|GPUREG_LIGHT4_SPECULAR0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_SPECULAR0&lt;br /&gt;
|-&lt;br /&gt;
| 0181&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR1|GPUREG_LIGHT4_SPECULAR1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_SPECULAR1&lt;br /&gt;
|-&lt;br /&gt;
| 0182&lt;br /&gt;
| [[#GPUREG_LIGHTi_DIFFUSE|GPUREG_LIGHT4_DIFFUSE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_DIFFUSE&lt;br /&gt;
|-&lt;br /&gt;
| 0183&lt;br /&gt;
| [[#GPUREG_LIGHTi_AMBIENT|GPUREG_LIGHT4_AMBIENT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 0184&lt;br /&gt;
| [[#GPUREG_LIGHTi_XY|GPUREG_LIGHT4_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_POSITION_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0185&lt;br /&gt;
| [[#GPUREG_LIGHTi_Z|GPUREG_LIGHT4_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_POSITION_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0186&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_XY|GPUREG_LIGHT4_SPOTDIR_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_SPOT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0187&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_Z|GPUREG_LIGHT4_SPOTDIR_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_SPOT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0188&lt;br /&gt;
| [[#GPUREG_0188|GPUREG_0188]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0189&lt;br /&gt;
| [[#GPUREG_LIGHTi_CONFIG|GPUREG_LIGHT4_CONFIG]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_TYPE&lt;br /&gt;
|-&lt;br /&gt;
| 018A&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_BIAS|GPUREG_LIGHT4_ATTENUATION_BIAS]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_DIST_ATTN_BIAS&lt;br /&gt;
|-&lt;br /&gt;
| 018B&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_SCALE|GPUREG_LIGHT4_ATTENUATION_SCALE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT4_DIST_ATTN_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 018C&lt;br /&gt;
| [[#GPUREG_018C|GPUREG_018C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 018D&lt;br /&gt;
| [[#GPUREG_018D|GPUREG_018D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 018E&lt;br /&gt;
| [[#GPUREG_018E|GPUREG_018E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 018F&lt;br /&gt;
| [[#GPUREG_018F|GPUREG_018F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0190&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR0|GPUREG_LIGHT5_SPECULAR0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_SPECULAR0&lt;br /&gt;
|-&lt;br /&gt;
| 0191&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR1|GPUREG_LIGHT5_SPECULAR1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_SPECULAR1&lt;br /&gt;
|-&lt;br /&gt;
| 0192&lt;br /&gt;
| [[#GPUREG_LIGHTi_DIFFUSE|GPUREG_LIGHT5_DIFFUSE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_DIFFUSE&lt;br /&gt;
|-&lt;br /&gt;
| 0193&lt;br /&gt;
| [[#GPUREG_LIGHTi_AMBIENT|GPUREG_LIGHT5_AMBIENT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 0194&lt;br /&gt;
| [[#GPUREG_LIGHTi_XY|GPUREG_LIGHT5_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_POSITION_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0195&lt;br /&gt;
| [[#GPUREG_LIGHTi_Z|GPUREG_LIGHT5_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_POSITION_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0196&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_XY|GPUREG_LIGHT5_SPOTDIR_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_SPOT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0197&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_Z|GPUREG_LIGHT5_SPOTDIR_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_SPOT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0198&lt;br /&gt;
| [[#GPUREG_0198|GPUREG_0198]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0199&lt;br /&gt;
| [[#GPUREG_LIGHTi_CONFIG|GPUREG_LIGHT5_CONFIG]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_TYPE&lt;br /&gt;
|-&lt;br /&gt;
| 019A&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_BIAS|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_DIST_ATTN_BIAS&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_SCALE|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT5_DIST_ATTN_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 019C&lt;br /&gt;
| [[#GPUREG_019C|GPUREG_019C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019D&lt;br /&gt;
| [[#GPUREG_019D|GPUREG_019D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019E&lt;br /&gt;
| [[#GPUREG_019E|GPUREG_019E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019F&lt;br /&gt;
| [[#GPUREG_019F|GPUREG_019F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01A0&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR0|GPUREG_LIGHT6_SPECULAR0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_SPECULAR0&lt;br /&gt;
|-&lt;br /&gt;
| 01A1&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR1|GPUREG_LIGHT6_SPECULAR1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_SPECULAR1&lt;br /&gt;
|-&lt;br /&gt;
| 01A2&lt;br /&gt;
| [[#GPUREG_LIGHTi_DIFFUSE|GPUREG_LIGHT6_DIFFUSE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_DIFFUSE&lt;br /&gt;
|-&lt;br /&gt;
| 01A3&lt;br /&gt;
| [[#GPUREG_LIGHTi_AMBIENT|GPUREG_LIGHT6_AMBIENT]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 01A4&lt;br /&gt;
| [[#GPUREG_LIGHTi_XY|GPUREG_LIGHT6_XY]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_POSITION_XY&lt;br /&gt;
|-&lt;br /&gt;
| 01A5&lt;br /&gt;
| [[#GPUREG_LIGHTi_Z|GPUREG_LIGHT6_Z]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_POSITION_Z&lt;br /&gt;
|-&lt;br /&gt;
| 01A6&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_XY|GPUREG_LIGHT6_SPOTDIR_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_SPOT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 01A7&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_Z|GPUREG_LIGHT6_SPOTDIR_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_SPOT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 01A8&lt;br /&gt;
| [[#GPUREG_01A8|GPUREG_01A8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01A9&lt;br /&gt;
| [[#GPUREG_LIGHTi_CONFIG|GPUREG_LIGHT6_CONFIG]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_TYPE&lt;br /&gt;
|-&lt;br /&gt;
| 01AA&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_BIAS|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_DIST_ATTN_BIAS&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_SCALE|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT6_DIST_ATTN_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 01AC&lt;br /&gt;
| [[#GPUREG_01AC|GPUREG_01AC]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AD&lt;br /&gt;
| [[#GPUREG_01AD|GPUREG_01AD]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AE&lt;br /&gt;
| [[#GPUREG_01AE|GPUREG_01AE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AF&lt;br /&gt;
| [[#GPUREG_01AF|GPUREG_01AF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01B0&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR0|GPUREG_LIGHT7_SPECULAR0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_SPECULAR0&lt;br /&gt;
|-&lt;br /&gt;
| 01B1&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPECULAR1|GPUREG_LIGHT7_SPECULAR1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_SPECULAR1&lt;br /&gt;
|-&lt;br /&gt;
| 01B2&lt;br /&gt;
| [[#GPUREG_LIGHTi_DIFFUSE|GPUREG_LIGHT7_DIFFUSE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_DIFFUSE&lt;br /&gt;
|-&lt;br /&gt;
| 01B3&lt;br /&gt;
| [[#GPUREG_LIGHTi_AMBIENT|GPUREG_LIGHT7_AMBIENT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 01B4&lt;br /&gt;
| [[#GPUREG_LIGHTi_XY|GPUREG_LIGHT7_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_POSITION_XY&lt;br /&gt;
|-&lt;br /&gt;
| 01B5&lt;br /&gt;
| [[#GPUREG_LIGHTi_Z|GPUREG_LIGHT7_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_POSITION_Z&lt;br /&gt;
|-&lt;br /&gt;
| 01B6&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_XY|GPUREG_LIGHT7_SPOTDIR_XY]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_SPOT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 01B7&lt;br /&gt;
| [[#GPUREG_LIGHTi_SPOTDIR_Z|GPUREG_LIGHT7_SPOTDIR_Z]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_SPOT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 01B8&lt;br /&gt;
| [[#GPUREG_01B8|GPUREG_01B8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01B9&lt;br /&gt;
| [[#GPUREG_LIGHTi_CONFIG|GPUREG_LIGHT7_CONFIG]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_TYPE&lt;br /&gt;
|-&lt;br /&gt;
| 01BA&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_BIAS|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_DIST_ATTN_BIAS&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_LIGHTi_ATTENUATION_SCALE|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_LIGHT7_DIST_ATTN_SCALE&lt;br /&gt;
|-&lt;br /&gt;
| 01BC&lt;br /&gt;
| [[#GPUREG_01BC|GPUREG_01BC]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BD&lt;br /&gt;
| [[#GPUREG_01BD|GPUREG_01BD]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BE&lt;br /&gt;
| [[#GPUREG_01BE|GPUREG_01BE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BF&lt;br /&gt;
| [[#GPUREG_01BF|GPUREG_01BF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01C0&lt;br /&gt;
| [[#GPUREG_LIGHTING_AMBIENT|GPUREG_LIGHTING_AMBIENT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_AMBIENT&lt;br /&gt;
|-&lt;br /&gt;
| 01C1&lt;br /&gt;
| [[#GPUREG_01C1|GPUREG_01C1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01C2&lt;br /&gt;
| [[#GPUREG_LIGHTING_NUM_LIGHTS|GPUREG_LIGHTING_NUM_LIGHTS]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_SRC_NUM&lt;br /&gt;
|-&lt;br /&gt;
| 01C3&lt;br /&gt;
| [[#GPUREG_LIGHTING_CONFIG0|GPUREG_LIGHTING_CONFIG0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_FUNC_MODE0&lt;br /&gt;
|-&lt;br /&gt;
| 01C4&lt;br /&gt;
| [[#GPUREG_LIGHTING_CONFIG1|GPUREG_LIGHTING_CONFIG1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_FUNC_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 01C5&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_INDEX|GPUREG_LIGHTING_LUT_INDEX]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 01C6&lt;br /&gt;
| [[#GPUREG_LIGHTING_ENABLE1|GPUREG_LIGHTING_ENABLE1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_EN1&lt;br /&gt;
|-&lt;br /&gt;
| 01C7&lt;br /&gt;
| [[#GPUREG_01C7|GPUREG_01C7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01C8&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_DATAi|GPUREG_LIGHTING_LUT_DATA0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 01C9&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_DATAi|GPUREG_LIGHTING_LUT_DATA1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 01CA&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_DATAi|GPUREG_LIGHTING_LUT_DATA2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 01CB&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_DATAi|GPUREG_LIGHTING_LUT_DATA3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 01CC&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_DATAi|GPUREG_LIGHTING_LUT_DATA4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 01CD&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_DATAi|GPUREG_LIGHTING_LUT_DATA5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 01CE&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_DATAi|GPUREG_LIGHTING_LUT_DATA6]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 01CF&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUT_DATAi|GPUREG_LIGHTING_LUT_DATA7]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 01D0&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUTINPUT_ABS|GPUREG_LIGHTING_LUTINPUT_ABS]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_ABSLUTINPUT&lt;br /&gt;
|-&lt;br /&gt;
| 01D1&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUTINPUT_SELECT|GPUREG_LIGHTING_LUTINPUT_SELECT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUTINPUT&lt;br /&gt;
|-&lt;br /&gt;
| 01D2&lt;br /&gt;
| [[#GPUREG_LIGHTING_LUTINPUT_SCALE|GPUREG_LIGHTING_LUTINPUT_SCALE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUTSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 01D3&lt;br /&gt;
| [[#GPUREG_01D3|GPUREG_01D3]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01D4&lt;br /&gt;
| [[#GPUREG_01D4|GPUREG_01D4]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01D5&lt;br /&gt;
| [[#GPUREG_01D5|GPUREG_01D5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01D6&lt;br /&gt;
| [[#GPUREG_01D6|GPUREG_01D6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01D7&lt;br /&gt;
| [[#GPUREG_01D7|GPUREG_01D7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01D8&lt;br /&gt;
| [[#GPUREG_01D8|GPUREG_01D8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01D9&lt;br /&gt;
| [[#GPUREG_LIGHTING_LIGHT_PERMUTATION|GPUREG_LIGHTING_LIGHT_PERMUTATION]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_SRC_EN_ID&lt;br /&gt;
|-&lt;br /&gt;
| 01DA&lt;br /&gt;
| [[#GPUREG_01DA|GPUREG_01DA]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01DB&lt;br /&gt;
| [[#GPUREG_01DB|GPUREG_01DB]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01DC&lt;br /&gt;
| [[#GPUREG_01DC|GPUREG_01DC]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01DD&lt;br /&gt;
| [[#GPUREG_01DD|GPUREG_01DD]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01DE&lt;br /&gt;
| [[#GPUREG_01DE|GPUREG_01DE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01DF&lt;br /&gt;
| [[#GPUREG_01DF|GPUREG_01DF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E0&lt;br /&gt;
| [[#GPUREG_01E0|GPUREG_01E0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E1&lt;br /&gt;
| [[#GPUREG_01E1|GPUREG_01E1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E2&lt;br /&gt;
| [[#GPUREG_01E2|GPUREG_01E2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E3&lt;br /&gt;
| [[#GPUREG_01E3|GPUREG_01E3]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E4&lt;br /&gt;
| [[#GPUREG_01E4|GPUREG_01E4]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E5&lt;br /&gt;
| [[#GPUREG_01E5|GPUREG_01E5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E6&lt;br /&gt;
| [[#GPUREG_01E6|GPUREG_01E6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E7&lt;br /&gt;
| [[#GPUREG_01E7|GPUREG_01E7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E8&lt;br /&gt;
| [[#GPUREG_01E8|GPUREG_01E8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01E9&lt;br /&gt;
| [[#GPUREG_01E9|GPUREG_01E9]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01EA&lt;br /&gt;
| [[#GPUREG_01EA|GPUREG_01EA]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01EB&lt;br /&gt;
| [[#GPUREG_01EB|GPUREG_01EB]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01EC&lt;br /&gt;
| [[#GPUREG_01EC|GPUREG_01EC]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01ED&lt;br /&gt;
| [[#GPUREG_01ED|GPUREG_01ED]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01EE&lt;br /&gt;
| [[#GPUREG_01EE|GPUREG_01EE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01EF&lt;br /&gt;
| [[#GPUREG_01EF|GPUREG_01EF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F0&lt;br /&gt;
| [[#GPUREG_01F0|GPUREG_01F0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F1&lt;br /&gt;
| [[#GPUREG_01F1|GPUREG_01F1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F2&lt;br /&gt;
| [[#GPUREG_01F2|GPUREG_01F2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F3&lt;br /&gt;
| [[#GPUREG_01F3|GPUREG_01F3]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F4&lt;br /&gt;
| [[#GPUREG_01F4|GPUREG_01F4]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F5&lt;br /&gt;
| [[#GPUREG_01F5|GPUREG_01F5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F6&lt;br /&gt;
| [[#GPUREG_01F6|GPUREG_01F6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F7&lt;br /&gt;
| [[#GPUREG_01F7|GPUREG_01F7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F8&lt;br /&gt;
| [[#GPUREG_01F8|GPUREG_01F8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01F9&lt;br /&gt;
| [[#GPUREG_01F9|GPUREG_01F9]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01FA&lt;br /&gt;
| [[#GPUREG_01FA|GPUREG_01FA]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01FB&lt;br /&gt;
| [[#GPUREG_01FB|GPUREG_01FB]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01FC&lt;br /&gt;
| [[#GPUREG_01FC|GPUREG_01FC]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01FD&lt;br /&gt;
| [[#GPUREG_01FD|GPUREG_01FD]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01FE&lt;br /&gt;
| [[#GPUREG_01FE|GPUREG_01FE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01FF&lt;br /&gt;
| [[#GPUREG_01FF|GPUREG_01FF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Geometry pipeline registers (0x200-0x27F) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register ID&lt;br /&gt;
! Register name&lt;br /&gt;
! Notes&lt;br /&gt;
! Official Name&lt;br /&gt;
|-&lt;br /&gt;
| 0200&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERS_LOC|GPUREG_ATTRIBBUFFERS_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VTX_ATTR_ARRAYS_BASE_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0201&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERS_FORMAT_LOW|GPUREG_ATTRIBBUFFERS_FORMAT_LOW]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VTX_ATTR_ARRAYS0&lt;br /&gt;
|-&lt;br /&gt;
| 0202&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VTX_ATTR_ARRAYS1&lt;br /&gt;
|-&lt;br /&gt;
| 0203&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER0_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_LOAD_ARRAY0_ATTR_OFFSET&lt;br /&gt;
|-&lt;br /&gt;
| 0204&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER0_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_LOAD_ARRAY0_ELEMENT0&lt;br /&gt;
|-&lt;br /&gt;
| 0205&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER0_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_LOAD_ARRAY0_ELEMENT1&lt;br /&gt;
|-&lt;br /&gt;
| 0206&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFERi_CONFIG2|GPUREG_ATTRIBBUFFER11_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0227&lt;br /&gt;
| [[#GPUREG_INDEXBUFFER_CONFIG|GPUREG_INDEXBUFFER_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_INDEX_ARRAY_ADDR_OFFSET&lt;br /&gt;
|-&lt;br /&gt;
| 0228&lt;br /&gt;
| [[#GPUREG_NUMVERTICES|GPUREG_NUMVERTICES]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_DRAW_VERTEX_NUM&lt;br /&gt;
|-&lt;br /&gt;
| 0229&lt;br /&gt;
| [[#GPUREG_GEOSTAGE_CONFIG|GPUREG_GEOSTAGE_CONFIG]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_DRAW_MODE0&lt;br /&gt;
|-&lt;br /&gt;
| 022A&lt;br /&gt;
| [[#GPUREG_VERTEX_OFFSET|GPUREG_VERTEX_OFFSET]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_DRAW_VERTEX_OFFSET&lt;br /&gt;
|-&lt;br /&gt;
| 022B&lt;br /&gt;
| [[#GPUREG_022B|GPUREG_022B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 022C&lt;br /&gt;
| [[#GPUREG_022C|GPUREG_022C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 022D&lt;br /&gt;
| [[#GPUREG_POST_VERTEX_CACHE_NUM|GPUREG_POST_VERTEX_CACHE_NUM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_POST_VERTEX_CACHE_NUM&lt;br /&gt;
|-&lt;br /&gt;
| 022E&lt;br /&gt;
| [[#GPUREG_DRAWARRAYS|GPUREG_DRAWARRAYS]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_START_DRAW_ARRAY&lt;br /&gt;
|-&lt;br /&gt;
| 022F&lt;br /&gt;
| [[#GPUREG_DRAWELEMENTS|GPUREG_DRAWELEMENTS]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_START_DRAW_ELEMENT&lt;br /&gt;
|-&lt;br /&gt;
| 0230&lt;br /&gt;
| [[#GPUREG_0230|GPUREG_0230]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0231&lt;br /&gt;
| [[#GPUREG_VTX_FUNC|GPUREG_VTX_FUNC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VTX_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0232&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_INDEX|GPUREG_FIXEDATTRIB_INDEX]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR&lt;br /&gt;
|-&lt;br /&gt;
| 0233&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATAi|GPUREG_FIXEDATTRIB_DATA0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATAi|GPUREG_FIXEDATTRIB_DATA1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATAi|GPUREG_FIXEDATTRIB_DATA2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0236&lt;br /&gt;
| [[#GPUREG_0236|GPUREG_0236]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0237&lt;br /&gt;
| [[#GPUREG_0237|GPUREG_0237]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0238&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE0|GPUREG_CMDBUF_SIZE0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_COMMAND_BUF_SIZE_CH0&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_COMMAND_BUF_SIZE_CH1&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_COMMAND_BUF_ADDR_CH0&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_COMMAND_BUF_ADDR_CH1&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_COMMAND_BUF_KICK_CH0&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_COMMAND_BUF_KICK_CH1&lt;br /&gt;
|-&lt;br /&gt;
| 023E&lt;br /&gt;
| [[#GPUREG_023E|GPUREG_023E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023F&lt;br /&gt;
| [[#GPUREG_023F|GPUREG_023F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0240&lt;br /&gt;
| [[#GPUREG_0240|GPUREG_0240]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0241&lt;br /&gt;
| [[#GPUREG_0241|GPUREG_0241]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0242&lt;br /&gt;
| [[#GPUREG_VSH_NUM_ATTR|GPUREG_VSH_NUM_ATTR]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_ATTR_NUM1&lt;br /&gt;
|-&lt;br /&gt;
| 0243&lt;br /&gt;
| [[#GPUREG_0243|GPUREG_0243]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0244&lt;br /&gt;
| [[#GPUREG_VSH_COM_MODE|GPUREG_VSH_COM_MODE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_START_DRAW_FUNC0|GPUREG_START_DRAW_FUNC0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_START_DRAW_FUNC0&lt;br /&gt;
|-&lt;br /&gt;
| 0246&lt;br /&gt;
| [[#GPUREG_0246|GPUREG_0246]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0247&lt;br /&gt;
| [[#GPUREG_0247|GPUREG_0247]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0248&lt;br /&gt;
| [[#GPUREG_0248|GPUREG_0248]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0249&lt;br /&gt;
| [[#GPUREG_0249|GPUREG_0249]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 024A&lt;br /&gt;
| [[#GPUREG_VSH_OUTMAP_TOTAL1|GPUREG_VSH_OUTMAP_TOTAL1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM1&lt;br /&gt;
|-&lt;br /&gt;
| 024B&lt;br /&gt;
| [[#GPUREG_024B|GPUREG_024B]]&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 024C&lt;br /&gt;
| [[#GPUREG_024C|GPUREG_024C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 024D&lt;br /&gt;
| [[#GPUREG_024D|GPUREG_024D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 024E&lt;br /&gt;
| [[#GPUREG_024E|GPUREG_024E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 024F&lt;br /&gt;
| [[#GPUREG_024F|GPUREG_024F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0250&lt;br /&gt;
| [[#GPUREG_0250|GPUREG_0250]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0251&lt;br /&gt;
| [[#GPUREG_VSH_OUTMAP_TOTAL2|GPUREG_VSH_OUTMAP_TOTAL2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_GSH_MISC0|GPUREG_GSH_MISC0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_GEOSTAGE_CONFIG2|GPUREG_GEOSTAGE_CONFIG2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_GSH_MISC1|GPUREG_GSH_MISC1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG1&lt;br /&gt;
|-&lt;br /&gt;
| 0255&lt;br /&gt;
| [[#GPUREG_0255|GPUREG_0255]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0256&lt;br /&gt;
| [[#GPUREG_0256|GPUREG_0256]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0257&lt;br /&gt;
| [[#GPUREG_0257|GPUREG_0257]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0258&lt;br /&gt;
| [[#GPUREG_0258|GPUREG_0258]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0259&lt;br /&gt;
| [[#GPUREG_0259|GPUREG_0259]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 025A&lt;br /&gt;
| [[#GPUREG_025A|GPUREG_025A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 025B&lt;br /&gt;
| [[#GPUREG_025B|GPUREG_025B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 025C&lt;br /&gt;
| [[#GPUREG_025C|GPUREG_025C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 025D&lt;br /&gt;
| [[#GPUREG_025D|GPUREG_025D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 025E&lt;br /&gt;
| [[#GPUREG_PRIMITIVE_CONFIG|GPUREG_PRIMITIVE_CONFIG]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_GS_OUT_REG_NUM3 / PICA_REG_DRAW_MODE2 / PICA_REG_VS_OUT_REG_NUM3&lt;br /&gt;
|-&lt;br /&gt;
| 025F&lt;br /&gt;
| [[#GPUREG_RESTART_PRIMITIVE|GPUREG_RESTART_PRIMITIVE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_START_DRAW_FUNC1&lt;br /&gt;
|-&lt;br /&gt;
| 0260&lt;br /&gt;
| [[#GPUREG_0260|GPUREG_0260]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0261&lt;br /&gt;
| [[#GPUREG_0261|GPUREG_0261]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0262&lt;br /&gt;
| [[#GPUREG_0262|GPUREG_0262]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0263&lt;br /&gt;
| [[#GPUREG_0263|GPUREG_0263]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0264&lt;br /&gt;
| [[#GPUREG_0264|GPUREG_0264]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0265&lt;br /&gt;
| [[#GPUREG_0265|GPUREG_0265]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0266&lt;br /&gt;
| [[#GPUREG_0266|GPUREG_0266]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0267&lt;br /&gt;
| [[#GPUREG_0267|GPUREG_0267]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0268&lt;br /&gt;
| [[#GPUREG_0268|GPUREG_0268]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0269&lt;br /&gt;
| [[#GPUREG_0269|GPUREG_0269]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 026A&lt;br /&gt;
| [[#GPUREG_026A|GPUREG_026A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 026B&lt;br /&gt;
| [[#GPUREG_026B|GPUREG_026B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 026C&lt;br /&gt;
| [[#GPUREG_026C|GPUREG_026C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 026D&lt;br /&gt;
| [[#GPUREG_026D|GPUREG_026D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 026E&lt;br /&gt;
| [[#GPUREG_026E|GPUREG_026E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 026F&lt;br /&gt;
| [[#GPUREG_026F|GPUREG_026F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0270&lt;br /&gt;
| [[#GPUREG_0270|GPUREG_0270]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0271&lt;br /&gt;
| [[#GPUREG_0271|GPUREG_0271]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0272&lt;br /&gt;
| [[#GPUREG_0272|GPUREG_0272]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0273&lt;br /&gt;
| [[#GPUREG_0273|GPUREG_0273]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0274&lt;br /&gt;
| [[#GPUREG_0274|GPUREG_0274]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0275&lt;br /&gt;
| [[#GPUREG_0275|GPUREG_0275]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0276&lt;br /&gt;
| [[#GPUREG_0276|GPUREG_0276]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0277&lt;br /&gt;
| [[#GPUREG_0277|GPUREG_0277]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0278&lt;br /&gt;
| [[#GPUREG_0278|GPUREG_0278]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0279&lt;br /&gt;
| [[#GPUREG_0279|GPUREG_0279]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 027A&lt;br /&gt;
| [[#GPUREG_027A|GPUREG_027A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 027B&lt;br /&gt;
| [[#GPUREG_027B|GPUREG_027B]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 027C&lt;br /&gt;
| [[#GPUREG_027C|GPUREG_027C]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 027D&lt;br /&gt;
| [[#GPUREG_027D|GPUREG_027D]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 027E&lt;br /&gt;
| [[#GPUREG_027E|GPUREG_027E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 027F&lt;br /&gt;
| [[#GPUREG_027F|GPUREG_027F]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Shader registers (0x280-0x2DF) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register ID&lt;br /&gt;
! Register name&lt;br /&gt;
! Notes&lt;br /&gt;
! Official Name&lt;br /&gt;
|-&lt;br /&gt;
! colspan=4 | Geometry shader&lt;br /&gt;
|-&lt;br /&gt;
| 0280&lt;br /&gt;
| [[#GPUREG_SH_BOOLUNIFORM|GPUREG_GSH_BOOLUNIFORM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_BOOL&lt;br /&gt;
|-&lt;br /&gt;
| 0281&lt;br /&gt;
| [[#GPUREG_SH_INTUNIFORM_Ii|GPUREG_GSH_INTUNIFORM_I0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_INT0&lt;br /&gt;
|-&lt;br /&gt;
| 0282&lt;br /&gt;
| [[#GPUREG_SH_INTUNIFORM_Ii|GPUREG_GSH_INTUNIFORM_I1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_INT1&lt;br /&gt;
|-&lt;br /&gt;
| 0283&lt;br /&gt;
| [[#GPUREG_SH_INTUNIFORM_Ii|GPUREG_GSH_INTUNIFORM_I2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_INT2&lt;br /&gt;
|-&lt;br /&gt;
| 0284&lt;br /&gt;
| [[#GPUREG_SH_INTUNIFORM_Ii|GPUREG_GSH_INTUNIFORM_I3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_INT3&lt;br /&gt;
|-&lt;br /&gt;
| 0285&lt;br /&gt;
| [[#GPUREG_0285|GPUREG_0285]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0286&lt;br /&gt;
| [[#GPUREG_0286|GPUREG_0286]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0287&lt;br /&gt;
| [[#GPUREG_0287|GPUREG_0287]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0288&lt;br /&gt;
| [[#GPUREG_0288|GPUREG_0288]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0289&lt;br /&gt;
| [[#GPUREG_SH_INPUTBUFFER_CONFIG|GPUREG_GSH_INPUTBUFFER_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_ATTR_NUM&lt;br /&gt;
|-&lt;br /&gt;
| 028A&lt;br /&gt;
| [[#GPUREG_SH_ENTRYPOINT|GPUREG_GSH_ENTRYPOINT]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_START_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 028B&lt;br /&gt;
| [[#GPUREG_SH_ATTRIBUTES_PERMUTATION_LOW|GPUREG_GSH_ATTRIBUTES_PERMUTATION_LOW]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_ATTR_IN_REG_MAP0&lt;br /&gt;
|-&lt;br /&gt;
| 028C&lt;br /&gt;
| [[#GPUREG_SH_ATTRIBUTES_PERMUTATION_HIGH|GPUREG_GSH_ATTRIBUTES_PERMUTATION_HIGH]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_ATTR_IN_REG_MAP1&lt;br /&gt;
|-&lt;br /&gt;
| 028D&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_MASK|GPUREG_GSH_OUTMAP_MASK]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_OUT_REG_MASK&lt;br /&gt;
|-&lt;br /&gt;
| 028E&lt;br /&gt;
| [[#GPUREG_028E|GPUREG_028E]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 028F&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_END|GPUREG_GSH_CODETRANSFER_END]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_RENEWAL_END&lt;br /&gt;
|-&lt;br /&gt;
| 0290&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_GSH_FLOATUNIFORM_DATA0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_GSH_FLOATUNIFORM_DATA1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_GSH_FLOATUNIFORM_DATA2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_GSH_FLOATUNIFORM_DATA3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_GSH_FLOATUNIFORM_DATA4]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_GSH_FLOATUNIFORM_DATA5]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_GSH_FLOATUNIFORM_DATA6]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_GSH_FLOATUNIFORM_DATA7]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0299&lt;br /&gt;
| [[#GPUREG_0299|GPUREG_0299]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 029A&lt;br /&gt;
| [[#GPUREG_029A|GPUREG_029A]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 029B&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_INDEX|GPUREG_GSH_CODETRANSFER_INDEX]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_GS_PROG_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 029C&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_GSH_CODETRANSFER_DATA0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_GSH_CODETRANSFER_DATA1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_GSH_CODETRANSFER_DATA2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_GSH_CODETRANSFER_DATA3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_GSH_CODETRANSFER_DATA4]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_GSH_CODETRANSFER_DATA5]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_GSH_CODETRANSFER_DATA6]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_GSH_CODETRANSFER_DATA7]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02A4&lt;br /&gt;
| [[#GPUREG_02A4|GPUREG_02A4]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02A5&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_INDEX|GPUREG_GSH_OPDESCS_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 02A6&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_GSH_OPDESCS_DATA0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_GSH_OPDESCS_DATA1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_GSH_OPDESCS_DATA2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_GSH_OPDESCS_DATA3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_GSH_OPDESCS_DATA4]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_GSH_OPDESCS_DATA5]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_GSH_OPDESCS_DATA6]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_GSH_OPDESCS_DATA7]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02AE&lt;br /&gt;
| [[#GPUREG_02AE|GPUREG_02AE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02AF&lt;br /&gt;
| [[#GPUREG_02AF|GPUREG_02AF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
! colspan=4 | Vertex shader&lt;br /&gt;
|-&lt;br /&gt;
| 02B0&lt;br /&gt;
| [[#GPUREG_SH_BOOLUNIFORM|GPUREG_VSH_BOOLUNIFORM]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_BOOL&lt;br /&gt;
|-&lt;br /&gt;
| 02B1&lt;br /&gt;
| [[#GPUREG_SH_INTUNIFORM_Ii|GPUREG_VSH_INTUNIFORM_I0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_INT0&lt;br /&gt;
|-&lt;br /&gt;
| 02B2&lt;br /&gt;
| [[#GPUREG_SH_INTUNIFORM_Ii|GPUREG_VSH_INTUNIFORM_I1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_INT1&lt;br /&gt;
|-&lt;br /&gt;
| 02B3&lt;br /&gt;
| [[#GPUREG_SH_INTUNIFORM_Ii|GPUREG_VSH_INTUNIFORM_I2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_INT2&lt;br /&gt;
|-&lt;br /&gt;
| 02B4&lt;br /&gt;
| [[#GPUREG_SH_INTUNIFORM_Ii|GPUREG_VSH_INTUNIFORM_I3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_INT3&lt;br /&gt;
|-&lt;br /&gt;
| 02B5&lt;br /&gt;
| [[#GPUREG_02B5|GPUREG_02B5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02B6&lt;br /&gt;
| [[#GPUREG_02B6|GPUREG_02B6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02B7&lt;br /&gt;
| [[#GPUREG_02B7|GPUREG_02B7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02B8&lt;br /&gt;
| [[#GPUREG_02B8|GPUREG_02B8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02B9&lt;br /&gt;
| [[#GPUREG_SH_INPUTBUFFER_CONFIG|GPUREG_VSH_INPUTBUFFER_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_ATTR_NUM0&lt;br /&gt;
|-&lt;br /&gt;
| 02BA&lt;br /&gt;
| [[#GPUREG_SH_ENTRYPOINT|GPUREG_VSH_ENTRYPOINT]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_START_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 02BB&lt;br /&gt;
| [[#GPUREG_SH_ATTRIBUTES_PERMUTATION_LOW|GPUREG_VSH_ATTRIBUTES_PERMUTATION_LOW]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_ATTR_IN_REG_MAP0&lt;br /&gt;
|-&lt;br /&gt;
| 02BC&lt;br /&gt;
| [[#GPUREG_SH_ATTRIBUTES_PERMUTATION_HIGH|GPUREG_VSH_ATTRIBUTES_PERMUTATION_HIGH]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_ATTR_IN_REG_MAP1&lt;br /&gt;
|-&lt;br /&gt;
| 02BD&lt;br /&gt;
| [[#GPUREG_SH_OUTMAP_MASK|GPUREG_VSH_OUTMAP_MASK]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_OUT_REG_MASK&lt;br /&gt;
|-&lt;br /&gt;
| 02BE&lt;br /&gt;
| [[#GPUREG_02BE|GPUREG_02BE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02BF&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_END|GPUREG_VSH_CODETRANSFER_END]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_RENEWAL_END&lt;br /&gt;
|-&lt;br /&gt;
| 02C0&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_INDEX|GPUREG_VSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 02C1&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA4]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA5]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA6]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_VSH_FLOATUNIFORM_DATA7]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C9&lt;br /&gt;
| [[#GPUREG_02C9|GPUREG_02C9]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02CA&lt;br /&gt;
| [[#GPUREG_02CA|GPUREG_02CA]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02CB&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_INDEX|GPUREG_VSH_CODETRANSFER_INDEX]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_VS_PROG_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 02CC&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_VSH_CODETRANSFER_DATA0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_VSH_CODETRANSFER_DATA1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_VSH_CODETRANSFER_DATA2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_VSH_CODETRANSFER_DATA3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_VSH_CODETRANSFER_DATA4]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_VSH_CODETRANSFER_DATA5]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_VSH_CODETRANSFER_DATA6]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_VSH_CODETRANSFER_DATA7]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02D4&lt;br /&gt;
| [[#GPUREG_02D4|GPUREG_02D4]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02D5&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_INDEX|GPUREG_VSH_OPDESCS_INDEX]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 02D6&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_VSH_OPDESCS_DATA0]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_VSH_OPDESCS_DATA1]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_VSH_OPDESCS_DATA2]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_VSH_OPDESCS_DATA3]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_VSH_OPDESCS_DATA4]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_VSH_OPDESCS_DATA5]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_VSH_OPDESCS_DATA6]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_VSH_OPDESCS_DATA7]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02DE&lt;br /&gt;
| [[#GPUREG_02DE|GPUREG_02DE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02DF&lt;br /&gt;
| [[#GPUREG_02DF|GPUREG_02DF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Unknown registers (0x2E0-0x2FF) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register ID&lt;br /&gt;
! Register name&lt;br /&gt;
! Notes&lt;br /&gt;
! Official Name&lt;br /&gt;
|-&lt;br /&gt;
| 02E0&lt;br /&gt;
| [[#GPUREG_02E0|GPUREG_02E0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E1&lt;br /&gt;
| [[#GPUREG_02E1|GPUREG_02E1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E2&lt;br /&gt;
| [[#GPUREG_02E2|GPUREG_02E2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E3&lt;br /&gt;
| [[#GPUREG_02E3|GPUREG_02E3]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E4&lt;br /&gt;
| [[#GPUREG_02E4|GPUREG_02E4]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E5&lt;br /&gt;
| [[#GPUREG_02E5|GPUREG_02E5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E6&lt;br /&gt;
| [[#GPUREG_02E6|GPUREG_02E6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E7&lt;br /&gt;
| [[#GPUREG_02E7|GPUREG_02E7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E8&lt;br /&gt;
| [[#GPUREG_02E8|GPUREG_02E8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02E9&lt;br /&gt;
| [[#GPUREG_02E9|GPUREG_02E9]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02EA&lt;br /&gt;
| [[#GPUREG_02EA|GPUREG_02EA]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02EB&lt;br /&gt;
| [[#GPUREG_02EB|GPUREG_02EB]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02EC&lt;br /&gt;
| [[#GPUREG_02EC|GPUREG_02EC]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02ED&lt;br /&gt;
| [[#GPUREG_02ED|GPUREG_02ED]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02EE&lt;br /&gt;
| [[#GPUREG_02EE|GPUREG_02EE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02EF&lt;br /&gt;
| [[#GPUREG_02EF|GPUREG_02EF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F0&lt;br /&gt;
| [[#GPUREG_02F0|GPUREG_02F0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F1&lt;br /&gt;
| [[#GPUREG_02F1|GPUREG_02F1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F2&lt;br /&gt;
| [[#GPUREG_02F2|GPUREG_02F2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F3&lt;br /&gt;
| [[#GPUREG_02F3|GPUREG_02F3]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F4&lt;br /&gt;
| [[#GPUREG_02F4|GPUREG_02F4]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F5&lt;br /&gt;
| [[#GPUREG_02F5|GPUREG_02F5]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F6&lt;br /&gt;
| [[#GPUREG_02F6|GPUREG_02F6]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F7&lt;br /&gt;
| [[#GPUREG_02F7|GPUREG_02F7]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F8&lt;br /&gt;
| [[#GPUREG_02F8|GPUREG_02F8]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02F9&lt;br /&gt;
| [[#GPUREG_02F9|GPUREG_02F9]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02FA&lt;br /&gt;
| [[#GPUREG_02FA|GPUREG_02FA]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02FB&lt;br /&gt;
| [[#GPUREG_02FB|GPUREG_02FB]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02FC&lt;br /&gt;
| [[#GPUREG_02FC|GPUREG_02FC]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02FD&lt;br /&gt;
| [[#GPUREG_02FD|GPUREG_02FD]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02FE&lt;br /&gt;
| [[#GPUREG_02FE|GPUREG_02FE]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 02FF&lt;br /&gt;
| [[#GPUREG_02FF|GPUREG_02FF]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Miscellaneous registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FINALIZE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Trigger P3D Interrupt (0 = idle, non-zero = trigger)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Writing to this register seems to signal the GPU to stop processing GPU commands from the current buffer; any command following a write to this register will be ignored. The value written to this register does not appear to matter, although 0x12345678 is the value typically written by commercial software.&lt;br /&gt;
Failure to write to this register in any command buffer will result in the GPU hanging.&lt;br /&gt;
&lt;br /&gt;
== Rasterizer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FACECULLING_CONFIG ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Culling mode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the face culling mode.&lt;br /&gt;
&lt;br /&gt;
Culling mode values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Front Face (Counter Clockwise)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Back Face (Counter Clockwise)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VIEWPORT_WIDTH ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| float1.7.16, width / 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the viewport width, along with GPUREG_VIEWPORT_INVW.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_VIEWPORT_INVW ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 1-31&lt;br /&gt;
| float1.7.23, 2 / width&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the viewport width, along with GPUREG_VIEWPORT_WIDTH.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VIEWPORT_HEIGHT ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| float1.7.16, height / 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the viewport height, along with GPUREG_VIEWPORT_INVH.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VIEWPORT_INVH ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 1-31&lt;br /&gt;
| float1.7.23, 2 / height&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the viewport height, along with GPUREG_VIEWPORT_HEIGHT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAGOP_CLIP ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to enable clipping planes.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAGOP_CLIP_DATA&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| float1.7.16, Clipping plane coefficient &#039;&#039;i&#039;&#039;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure clipping plane coefficients.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_DEPTHMAP_SCALE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| float1.7.16, Near - Far&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the depth range scale.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_DEPTHMAP_OFFSET ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| float1.7.16, Near + Polygon Offset&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the depth range bias.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTMAP_TOTAL ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, Number of following attributes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the total shader output map attributes.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-4&lt;br /&gt;
| unsigned, Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-12&lt;br /&gt;
| unsigned, Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-20&lt;br /&gt;
| unsigned, Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-28&lt;br /&gt;
| unsigned, Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers map components of the corresponding vertex shader output register to specific fixed-function semantics.&lt;br /&gt;
&lt;br /&gt;
Semantic values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Semantic&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x00&lt;br /&gt;
| position.x&lt;br /&gt;
| rowspan=&amp;quot;4&amp;quot; | Vertex Position&lt;br /&gt;
|-&lt;br /&gt;
| 0x01&lt;br /&gt;
| position.y&lt;br /&gt;
|-&lt;br /&gt;
| 0x02&lt;br /&gt;
| position.z&lt;br /&gt;
|-&lt;br /&gt;
| 0x03&lt;br /&gt;
| position.w&lt;br /&gt;
|-&lt;br /&gt;
| 0x04&lt;br /&gt;
| normquat.x&lt;br /&gt;
| rowspan=&amp;quot;4&amp;quot; | Quaternion specifying the normal/tangent frame (for fragment lighting)&lt;br /&gt;
|-&lt;br /&gt;
| 0x05&lt;br /&gt;
| normquat.y&lt;br /&gt;
|-&lt;br /&gt;
| 0x06&lt;br /&gt;
| normquat.z&lt;br /&gt;
|-&lt;br /&gt;
| 0x07&lt;br /&gt;
| normquat.w&lt;br /&gt;
|-&lt;br /&gt;
| 0x08&lt;br /&gt;
| color.r&lt;br /&gt;
| rowspan=&amp;quot;4&amp;quot; | Vertex color&lt;br /&gt;
|-&lt;br /&gt;
| 0x09&lt;br /&gt;
| color.g&lt;br /&gt;
|-&lt;br /&gt;
| 0x0A&lt;br /&gt;
| color.b&lt;br /&gt;
|-&lt;br /&gt;
| 0x0B&lt;br /&gt;
| color.a&lt;br /&gt;
|-&lt;br /&gt;
| 0x0C&lt;br /&gt;
| texcoord0.u&lt;br /&gt;
| rowspan=&amp;quot;2&amp;quot; | Texture coordinates for texture 0&lt;br /&gt;
|-&lt;br /&gt;
| 0x0D&lt;br /&gt;
| texcoord0.v&lt;br /&gt;
|-&lt;br /&gt;
| 0x0E&lt;br /&gt;
| texcoord1.u&lt;br /&gt;
| rowspan=&amp;quot;2&amp;quot; | Texture coordinates for texture 1&lt;br /&gt;
|-&lt;br /&gt;
| 0x0F&lt;br /&gt;
| texcoord1.v&lt;br /&gt;
|-&lt;br /&gt;
| 0x10&lt;br /&gt;
| texcoord0.w&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
| 0x12&lt;br /&gt;
| view.x&lt;br /&gt;
| rowspan=&amp;quot;3&amp;quot; | View vector (for fragment lighting)&lt;br /&gt;
|-&lt;br /&gt;
| 0x13&lt;br /&gt;
| view.y&lt;br /&gt;
|-&lt;br /&gt;
| 0x14&lt;br /&gt;
| view.z&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
| 0x16&lt;br /&gt;
| texcoord2.u&lt;br /&gt;
| rowspan=&amp;quot;2&amp;quot; | Texture coordinates for texture 2&lt;br /&gt;
|-&lt;br /&gt;
| 0x17&lt;br /&gt;
| texcoord2.v&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
| 0x1F&lt;br /&gt;
| Unused component&lt;br /&gt;
| Should be set for unused components of the output register&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_EARLYDEPTH_FUNC ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Early depth function&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the early depth test function.&lt;br /&gt;
&lt;br /&gt;
Early depth function values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| &amp;gt;=&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| &amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| &amp;lt;=&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| &amp;lt;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_EARLYDEPTH_TEST1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets whether the early depth test is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_EARLYDEPTH_CLEAR ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Trigger (0 = idle, 1 = clear)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register triggers clearing the early depth data.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTATTR_MODE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Use texture coordinates (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the shader output attribute mode.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SCISSORTEST_MODE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Enabled (0 = disabled, 3 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to enable scissor testing.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SCISSORTEST_POS ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-9&lt;br /&gt;
| unsigned, X1&lt;br /&gt;
|-&lt;br /&gt;
| 16-25&lt;br /&gt;
| unsigned, Y1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the scissor test start position.&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_SCISSORTEST_DIM ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-9&lt;br /&gt;
| unsigned, X2&lt;br /&gt;
|-&lt;br /&gt;
| 16-25&lt;br /&gt;
| unsigned, Y2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the scissor test end position.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VIEWPORT_XY ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-9&lt;br /&gt;
| signed, X&lt;br /&gt;
|-&lt;br /&gt;
| 16-25&lt;br /&gt;
| signed, Y&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the viewport position.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_EARLYDEPTH_DATA ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| unsigned, Clear value&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the early depth clear value.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_DEPTHMAP_ENABLE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to enable depth range.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_RENDERBUF_DIM ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-10&lt;br /&gt;
| unsigned, Width&lt;br /&gt;
|-&lt;br /&gt;
| 12-21&lt;br /&gt;
| unsigned, Height - 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the output framebuffer dimensions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTATTR_CLOCK ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, &#039;position.z&#039; present (0 = absent, 1 = present)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, &#039;color&#039; component present (0 = absent, 1 = present)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, &#039;texcoord0&#039; component present (0 = absent, 1 = present)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, &#039;texcoord1&#039; component present (0 = absent, 1 = present)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, &#039;texcoord2&#039; component present (0 = absent, 1 = present)&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| unsigned, &#039;texcoord0.w&#039; present (0 = absent, 1 = present)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| unsigned, &#039;normquat&#039; or &#039;view&#039; component present (0 = absent, 1 = present)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register controls the clock supply to parts relating to certain attributes.&lt;br /&gt;
&lt;br /&gt;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXUNIT_CONFIG ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Texture 0 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Texture 1 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| unsigned, Texture 2 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| unsigned, Texture 3 coordinates&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, Texture 3 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| unsigned, Texture 2 coordinates&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| unsigned, Clear texture cache (0 = don&#039;t clear, 1 = clear)&lt;br /&gt;
|-&lt;br /&gt;
| 17-31&lt;br /&gt;
| 0x0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to enable texture units.&lt;br /&gt;
&lt;br /&gt;
Texture 3 coordinates values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Texture 0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Texture 1&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Texture 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Texture 2 coordinates values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Texture 2&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Texture 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXUNIT&#039;&#039;i&#039;&#039;_BORDER_COLOR ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, Alpha&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set a texture unit&#039;s border color.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXUNIT&#039;&#039;i&#039;&#039;_DIM ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-10&lt;br /&gt;
| unsigned, Height&lt;br /&gt;
|-&lt;br /&gt;
| 16-26&lt;br /&gt;
| unsigned, Width&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set a texture unit&#039;s dimensions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXUNIT&#039;&#039;i&#039;&#039;_PARAM ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Magnification filter&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| unsigned, Minification filter&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| unsigned, ETC1 (0 = not ETC1, 2 = ETC1) note: still 0 for ETC1A4&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| unsigned, Wrap T&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| unsigned, Wrap S&lt;br /&gt;
|-&lt;br /&gt;
| 16-17&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| unsigned, Shadow (Texture 0 only, 0 = not shadow, 1 = shadow)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| unsigned, Mipmap filter&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| unsigned, Type (Texture 0 only)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set a texture unit&#039;s extra parameters.&lt;br /&gt;
&lt;br /&gt;
Filter values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Nearest&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Linear&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Wrap values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Clamp to edge&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Clamp to border&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Repeat&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Mirrored repeat&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Type values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 2D&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Cube map&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Shadow 2D&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Projection&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Shadow cube&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disabled&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXUNIT&#039;&#039;i&#039;&#039;_LOD ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-12&lt;br /&gt;
| fixed1.4.8, Bias&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| unsigned, Max Level&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| unsigned, Min Level&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure a texture unit&#039;s level of detail.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXUNIT&#039;&#039;i&#039;&#039;_ADDR&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
First ADDR register:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-27&lt;br /&gt;
| unsigned, Texture physical address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Subsequent ADDR registers:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-21&lt;br /&gt;
| unsigned, Texture physical address &amp;gt;&amp;gt; 3 (upper 6 bits reused from first ADDR register)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set a texture unit&#039;s physical address(es) in memory. Individual texels in a texture are laid out in memory as a [http://en.wikipedia.org/wiki/Z-order_curve Z-order curve]. Mipmap data is stored directly following the main texture data.&lt;br /&gt;
&lt;br /&gt;
If the texture is a cube:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Register&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| ADDR1&lt;br /&gt;
| Positive X&lt;br /&gt;
|-&lt;br /&gt;
| ADDR2&lt;br /&gt;
| Negative X&lt;br /&gt;
|-&lt;br /&gt;
| ADDR3&lt;br /&gt;
| Positive Y&lt;br /&gt;
|-&lt;br /&gt;
| ADDR4&lt;br /&gt;
| Negative Y&lt;br /&gt;
|-&lt;br /&gt;
| ADDR5&lt;br /&gt;
| Positive Z&lt;br /&gt;
|-&lt;br /&gt;
| ADDR6&lt;br /&gt;
| Negative Z&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Otherwise, ADDR(1) points to a 2D texture, and the rest are empty.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXUNIT&#039;&#039;i&#039;&#039;_SHADOW ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Perspective (0 = not perspective, 1 = perspective)&lt;br /&gt;
|-&lt;br /&gt;
| 1-23&lt;br /&gt;
| fixed0.0.24, Z bias (upper 23 bits)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set a texture unit&#039;s shadow texture properties.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXUNIT&#039;&#039;i&#039;&#039;_TYPE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Format&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set a texture unit&#039;s data format.&lt;br /&gt;
&lt;br /&gt;
Format values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
!  GL Format&lt;br /&gt;
!  GL Data Type&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| RGBA8888&lt;br /&gt;
| GL_RGBA&lt;br /&gt;
| GL_UNSIGNED_BYTE&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| RGB888&lt;br /&gt;
| GL_RGB&lt;br /&gt;
| GL_UNSIGNED_BYTE&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| RGBA5551&lt;br /&gt;
| GL_RGBA&lt;br /&gt;
| GL_UNSIGNED_SHORT_5_5_5_1&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| RGB565&lt;br /&gt;
| GL_RGB&lt;br /&gt;
| GL_UNSIGNED_SHORT_5_6_5&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| RGBA4444&lt;br /&gt;
| GL_RGBA&lt;br /&gt;
| GL_UNSIGNED_SHORT_4_4_4_4&lt;br /&gt;
|-&lt;br /&gt;
| 0x5&lt;br /&gt;
| IA8&lt;br /&gt;
| GL_LUMINANCE_ALPHA&lt;br /&gt;
| GL_UNSIGNED_BYTE&lt;br /&gt;
|-&lt;br /&gt;
| 0x6&lt;br /&gt;
| HILO8&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| 0x7&lt;br /&gt;
| I8&lt;br /&gt;
| GL_LUMINANCE&lt;br /&gt;
| GL_UNSIGNED_BYTE&lt;br /&gt;
|-&lt;br /&gt;
| 0x8&lt;br /&gt;
| A8&lt;br /&gt;
| GL_ALPHA&lt;br /&gt;
| GL_UNSIGNED_BYTE&lt;br /&gt;
|-&lt;br /&gt;
| 0x9&lt;br /&gt;
| IA44&lt;br /&gt;
| GL_LUMINANCE_ALPHA&lt;br /&gt;
| GL_UNSIGNED_BYTE_4_4_EXT&lt;br /&gt;
|-&lt;br /&gt;
| 0xA&lt;br /&gt;
| I4&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0xB&lt;br /&gt;
| A4&lt;br /&gt;
| GL_ALPHA&lt;br /&gt;
| GL_UNSIGNED_NIBBLE_EXT&lt;br /&gt;
|-&lt;br /&gt;
| 0xC&lt;br /&gt;
| ETC1&lt;br /&gt;
| GL_ETC1_RGB8_OES&lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| 0xD&lt;br /&gt;
| ETC1A4&lt;br /&gt;
|&lt;br /&gt;
| &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to enable lighting.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXUNIT3_PROCTEX0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, U-direction clamp&lt;br /&gt;
|-&lt;br /&gt;
| 3-5&lt;br /&gt;
| unsigned, V-direction clamp&lt;br /&gt;
|-&lt;br /&gt;
| 6-9&lt;br /&gt;
| unsigned, RGB mapping function&lt;br /&gt;
|-&lt;br /&gt;
| 10-13&lt;br /&gt;
| unsigned, Alpha mapping function&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| unsigned, Handle alpha separately (0 = don&#039;t separate, 1 = separate)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| unsigned, Noise enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 16-17&lt;br /&gt;
| unsigned, U-direction shift&lt;br /&gt;
|-&lt;br /&gt;
| 18-19&lt;br /&gt;
| unsigned, V-direction shift&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| float1.5.10, Texture bias (lower 8 bits)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the procedural texture unit.&lt;br /&gt;
&lt;br /&gt;
Clamp values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Clamp to zero&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Clamp to edge&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Symmetrical repeat&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Mirrored repeat&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Pulse&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Mapping function values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| U&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| U2&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| V&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| V2&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| U + V&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| U2 + V2&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| sqrt(U2*U2 + V2*V2)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Minimum&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Maximum&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Rmax&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Shift values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Odd&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Even&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXUNIT3_PROCTEX1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| fixed1.3.12, U-direction noise amplitude&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| float1.5.10, U-direction noise phase&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the procedural texture unit&#039;s U-direction noise amplitude/phase.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXUNIT3_PROCTEX2 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| fixed1.3.12, V-direction noise amplitude&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| float1.5.10, V-direction noise phase&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the procedural texture unit&#039;s V-direction noise amplitude/phase.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXUNIT3_PROCTEX3 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| float1.5.10, U-direction noise frequency&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| float1.5.10, V-direction noise frequency&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the procedural texture unit&#039;s U-direction and V-direction noise frequency.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXUNIT3_PROCTEX4 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, Minification filter&lt;br /&gt;
|-&lt;br /&gt;
| 3-10&lt;br /&gt;
| 0x60&lt;br /&gt;
|-&lt;br /&gt;
| 11-18&lt;br /&gt;
| unsigned, Texture width&lt;br /&gt;
|-&lt;br /&gt;
| 19-26&lt;br /&gt;
| float1.5.10, Texture bias (upper 8 bits)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the procedural texture unit.&lt;br /&gt;
&lt;br /&gt;
Minification filter values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Nearest&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Linear&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Nearest, Mipmap Nearest&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Linear, Mipmap Nearest&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Nearest, Mipmap Linear&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Linear, Mipmap Linear&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXUNIT3_PROCTEX5 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Texture offset&lt;br /&gt;
|-&lt;br /&gt;
| 8-31&lt;br /&gt;
| 0xE0C080&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the procedural texture unit&#039;s offset.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_PROCTEX_LUT ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Index&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| unsigned, Reference table&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set which look-up table to write to, with GPUREG_PROCTEX_LUT_DATA&#039;&#039;i&#039;&#039;, at what index.&lt;br /&gt;
&lt;br /&gt;
Reference table values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Noise table&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| RGB mapping function table&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Alpha mapping function table&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Color table&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Color difference table&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_PROCTEX_LUT_DATA&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| LUT data&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers behave as a FIFO queue. Each write to these registers writes the provided value to the table selected with GPUREG_PROCTEX_LUT, starting at the selected index.&lt;br /&gt;
&lt;br /&gt;
==== Noise Table ====&lt;br /&gt;
&lt;br /&gt;
128 elements:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-11&lt;br /&gt;
| fixed0.0.12, Value&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| fixed1.0.11, Difference from next element&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== RGB Mapping Function Table ====&lt;br /&gt;
&lt;br /&gt;
128 elements:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-11&lt;br /&gt;
| fixed0.0.12, Value&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| fixed1.0.11, Difference from next element&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Alpha Mapping Function Table ====&lt;br /&gt;
&lt;br /&gt;
128 elements:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-11&lt;br /&gt;
| fixed0.0.12, Value&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| fixed1.0.11, Difference from next element&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Color Table ====&lt;br /&gt;
&lt;br /&gt;
256 elements:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, Alpha&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Color Difference Table ====&lt;br /&gt;
&lt;br /&gt;
256 elements:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| fixed1.0.7, Red difference between current and next color table elements&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| fixed1.0.7, Green difference between current and next color table elements&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| fixed1.0.7, Blue difference between current and next color table elements&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| fixed1.0.7, Alpha difference between current and next color table elements&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXENV&#039;&#039;i&#039;&#039;_SOURCE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, RGB source 0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| unsigned, RGB source 1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| unsigned, RGB source 2&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| unsigned, Alpha source 0&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| unsigned, Alpha source 1&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| unsigned, Alpha source 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures a texture combiner&#039;s sources.&lt;br /&gt;
&lt;br /&gt;
Source values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Primary color&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Fragment primary color&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Fragment secondary color&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Texture 0&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Texture 1&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Texture 2&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Texture 3&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Previous buffer&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Constant (from GPUREG_TEXENV&#039;&#039;i&#039;&#039;_COLOR)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Previous&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXENV&#039;&#039;i&#039;&#039;_OPERAND ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, RGB operand 0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| unsigned, RGB operand 1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| unsigned, RGB operand 2&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| unsigned, Alpha operand 0&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| unsigned, Alpha operand 1&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| unsigned, Alpha operand 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures a texture combiner&#039;s operands.&lt;br /&gt;
&lt;br /&gt;
RGB operand values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Source color&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| One minus source color&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Source alpha&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| One minus source alpha&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Source red&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| One minus source red&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Source green&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| One minus source green&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Source blue&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| One minus source blue&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Alpha operand values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Source alpha&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| One minus source alpha&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Source red&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| One minus source red&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Source green&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| One minus source green&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Source blue&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| One minus source blue&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXENV&#039;&#039;i&#039;&#039;_COMBINER ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, RGB combine&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| unsigned, Alpha combine&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures a texture combiner&#039;s combine mode.&lt;br /&gt;
&lt;br /&gt;
Combine values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Replace&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Modulate&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Add&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Add signed&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Interpolate&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Subtract&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Dot3 RGB&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Dot3 RGBA&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Multiply then add&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Add then multiply&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXENV&#039;&#039;i&#039;&#039;_COLOR ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, Alpha&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures a texture combiner&#039;s constant color.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXENV&#039;&#039;i&#039;&#039;_SCALE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, RGB scale&lt;br /&gt;
|-&lt;br /&gt;
| 16-17&lt;br /&gt;
| unsigned, Alpha scale&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures a texture combiner&#039;s scale value.&lt;br /&gt;
&lt;br /&gt;
Scale values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 1x&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 2x&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 4x&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_TEXENV_UPDATE_BUFFER ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, Fog mode&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| unsigned, Shading density source&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, TexEnv 1 RGB buffer input&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, TexEnv 2 RGB buffer input&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, TexEnv 3 RGB buffer input&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| unsigned, TexEnv 4 RGB buffer input&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| unsigned, TexEnv 1 alpha buffer input&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| unsigned, TexEnv 2 alpha buffer input&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| unsigned, TexEnv 3 alpha buffer input&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| unsigned, TexEnv 4 alpha buffer input&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| unsigned, Z flip (0 = don&#039;t flip, 1 = flip)&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| 0x0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is shared between the gas/fog mode configuration and texture combiner buffer inputs. Texture combiner buffer inputs are typically written with a mask of 0x2, and the gas/fog mode configuration is typically written with a mask of 0x5.&lt;br /&gt;
&lt;br /&gt;
Fog mode values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Disabled&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Fog&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Gas&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Shading density source values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Plain density&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Depth density&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Buffer input values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Previous buffer&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Previous&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_FOG_COLOR ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the color of fog.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_GAS_ATTENUATION ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| float1.5.10, Gas density attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the gas density attenuation.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_GAS_ACCMAX ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| float1.5.10, Gas maximum density accumulation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the gas maximum density accumulation.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FOG_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| unsigned, Index&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set what index to write to with GPUREG_FOG_LUT_DATA&#039;&#039;i&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_FOG_LUT_DATA&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| LUT data&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers behave as a FIFO queue. Each write to these registers writes the provided value to the fog look-up table, starting at the index selected with GPUREG_FOG_LUT_INDEX.&lt;br /&gt;
&lt;br /&gt;
==== Fog Look-Up Table ====&lt;br /&gt;
&lt;br /&gt;
128 elements:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-12&lt;br /&gt;
| fixed1.1.11, Difference from next element &lt;br /&gt;
|-&lt;br /&gt;
| 13-23&lt;br /&gt;
| fixed0.0.11, Value&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_TEXENV_BUFFER_COLOR ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, Alpha&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the texture combiner buffer color.&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLOR_OPERATION ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Fragment operation mode&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Blend mode&lt;br /&gt;
|-&lt;br /&gt;
| 16-25&lt;br /&gt;
| 0x0E4&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the fragment operation mode and whether to use logic ops or blending.&lt;br /&gt;
&lt;br /&gt;
Fragment operation mode values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Default&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Gas&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Shadow&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Blend mode values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Logic op&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Blend&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_BLEND_FUNC ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, RGB equation&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| unsigned, Alpha equation&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| unsigned, RGB source function&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| unsigned, RGB destination function&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| unsigned, Alpha source function&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| unsigned, Alpha destination function&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the blending function.&lt;br /&gt;
&lt;br /&gt;
Equation values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Add&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Subtract&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Reverse subtract&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Minimum&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Maximum&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Function values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Zero&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| One&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Source color&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| One minus source color&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Destination color&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| One minus destination color&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Source alpha&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| One minus source alpha&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Destination alpha&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| One minus destination alpha&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Constant color&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| One minus constant color&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Constant alpha&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| One minus constant alpha&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Source alpha saturate&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LOGIC_OP ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Logic op&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the logic op.&lt;br /&gt;
&lt;br /&gt;
Logic op values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Clear&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| AND&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Reverse AND&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Copy&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Set&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Inverted copy&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Noop&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Invert&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| NAND&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| OR&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| NOR&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| XOR&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Equivalent&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Inverted AND&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Reverse OR&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Inverted OR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_BLEND_COLOR ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, Alpha&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the blending color.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_FRAGOP_ALPHA_TEST ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| unsigned, Function&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Reference value&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure alpha testing.&lt;br /&gt;
&lt;br /&gt;
Function values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Never&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Always&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Equal&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Not equal&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Less than&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Less than or equal&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Greater than&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Greater than or equal&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_STENCIL_TEST ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| unsigned, Function&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Buffer mask&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| signed, Reference value&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, Mask&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure stencil testing.&lt;br /&gt;
&lt;br /&gt;
Function values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Never&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Always&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Equal&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Not equal&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Less than&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Less than or equal&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Greater than&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Greater than or equal&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_STENCIL_OP ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, Fail operation&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| unsigned, Z-fail operation&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| unsigned, Z-pass operation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure stencil result operations.&lt;br /&gt;
&lt;br /&gt;
Operation values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Keep&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Zero&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Replace&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Increment&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Decrement&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Invert&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Increment and wrap&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Decrement and wrap&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_DEPTH_COLOR_MASK ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Depth test enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| unsigned, Depth function&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Red write enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, Green write enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, Blue write enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| unsigned, Alpha write enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| unsigned, Depth write enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to depth testing and framebuffer write masking.&lt;br /&gt;
&lt;br /&gt;
Note that setting the &amp;quot;Depth test enabled&amp;quot; bit to 0 will &#039;&#039;not&#039;&#039; also disable depth writes. It will instead behave as if the depth function were set to &amp;quot;Always&amp;quot;. To completely disable depth-related operations both the depth test and depth write bits must be disabled.&lt;br /&gt;
&lt;br /&gt;
Depth function values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Never&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Always&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Equal&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Not equal&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Less than&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Less than or equal&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Greater than&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Greater than or equal&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Trigger (0 = idle, 1 = invalidate)&lt;br /&gt;
|-&lt;br /&gt;
| 1-31&lt;br /&gt;
| 0x0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Writing 1 to this register invalidates the framebuffer cache. This should be done when changing the framebuffer or when it is cleared before rendering. Note that it does &#039;&#039;&#039;not&#039;&#039;&#039; flush the cache, so it should always be preceded by a write to GPUREG_FRAMEBUFFER_FLUSH.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_FLUSH ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Trigger (0 = idle, 1 = flush)&lt;br /&gt;
|-&lt;br /&gt;
| 1-31&lt;br /&gt;
| 0x0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Writing 1 to this register flushes the framebuffer cache to memory. This should be done after rendering before changing the framebuffer or using rendering results.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_READ ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Allow read (0 = disable, 0xF = enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures read access from the color buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_WRITE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Allow write (0 = disable, 0xF = enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures write access to the color buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_DEPTHBUFFER_READ ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Allow stencil read (0 = disable, 1 = enable)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Allow depth read (0 = disable, 1 = enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures read access from the depth and stencil buffers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_DEPTHBUFFER_WRITE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Allow stencil write (0 = disable, 1 = enable)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Allow depth write (0 = disable, 1 = enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures write access to the depth and stencil buffers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Format&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the depth buffer data format.&lt;br /&gt;
&lt;br /&gt;
Format values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 16-bit depth&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 24-bit depth&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 24-bit depth + 8-bit stencil&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Pixel size&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| unsigned, Format&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the color buffer data format. Color components are laid out in reverse byte order in memory, with the most significant bits used first.&lt;br /&gt;
&lt;br /&gt;
Pixel size values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 16-bit color&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 32-bit color&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| RGBA8/Gas&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| RGB5A1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| RGB565&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| RGBA4&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_EARLYDEPTH_TEST2 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register enables the early depth test.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Render block mode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the framebuffer block mode. To untile the color buffer when using the 32x32 block format, use bit 16 of the [[GPU/External_Registers#Transfer_Engine|display transfer flags]]. It is unknown if there are any advantages to using the 32x32 format.&lt;br /&gt;
&lt;br /&gt;
Render block mode values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 8x8 blocks&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 32x32 blocks&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_DEPTHBUFFER_LOC ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-27&lt;br /&gt;
| unsigned, Depth buffer physical address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the depth buffer physical address.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_LOC ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-27&lt;br /&gt;
| unsigned, Color buffer physical address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the color buffer physical address.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_DIM ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-10&lt;br /&gt;
| unsigned, Width&lt;br /&gt;
|-&lt;br /&gt;
| 12-21&lt;br /&gt;
| unsigned, Height - 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the framebuffer dimensions.&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_GAS_LIGHT_XY ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Planar shading minimum intensity&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Planar shading maximum intensity&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Planar shading density attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures gas light planar shading.&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_GAS_LIGHT_Z ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, View shading minimum intensity&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, View shading maximum intensity&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, View shading density attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures gas light view shading.&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_GAS_LIGHT_Z_COLOR ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, View shading effect in line-of-sight direction&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures gas light shading in the line-of-sight direction.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_GAS_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| unsigned, Index&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set what index to write to with GPUREG_GAS_LUT_DATA&#039;&#039;i&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_GAS_LUT_DATA ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| LUT data&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers behave as a FIFO queue. Each write to these registers writes the provided value to the gas look-up table, starting at the index selected with GPUREG_GAS_LUT_INDEX.&lt;br /&gt;
&lt;br /&gt;
==== Gas Look-Up Table ====&lt;br /&gt;
&lt;br /&gt;
16 elements:&lt;br /&gt;
&lt;br /&gt;
First 8 elements:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| signed, Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| signed, Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| signed, Blue&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Last 8 elements:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_GAS_DELTAZ_DEPTH ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| fixed0.16.8, Depth direction attenuation proportion&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the gas depth direction attenuation proportion.&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_FRAGOP_SHADOW ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| float1.5.10, Sum of penumbra scale and penumbra bias&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| float1.5.10, Penumbra scale with reversed sign&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure shadow properties.&lt;br /&gt;
&lt;br /&gt;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_XY ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| float1.5.10, X coordinate&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| float1.5.10, Y coordinate&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with GPUREG_LIGHT&#039;&#039;i&#039;&#039;_Z) represent the light position (for a positional light) or the light direction vector (for a directional light) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_Z ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| float1.5.10, Z coordinate&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with GPUREG_LIGHT&#039;&#039;i&#039;&#039;_XY) represent the light position (for a positional light) or the light direction vector (for a directional light) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_SPOTDIR_XY ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-12&lt;br /&gt;
| fixed1.1.11, X coordinate (negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| fixed1.1.11, Y coordinate (negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with GPUREG_LIGHT&#039;&#039;i&#039;&#039;_SPOTDIR_Z) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_SPOTDIR_Z ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-12&lt;br /&gt;
| fixed1.1.11, Z coordinate (negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with GPUREG_LIGHT&#039;&#039;i&#039;&#039;_SPOTDIR_XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_CONFIG ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Two side diffuse (0 = one side, 1 = both sides)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| unsigned, Use geometric factor 0 (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| unsigned, Use geometric factor 1 (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures a light&#039;s properties.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-19&lt;br /&gt;
| float1.7.12, Distance attenuation bias&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value of the corresponding light. The attenuation factor is DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHT&#039;&#039;i&#039;&#039;_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-19&lt;br /&gt;
| float1.7.12, Distance attenuation scale&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value of the corresponding light. The attenuation factor is DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Blue&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| unsigned, Green&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| unsigned, Red&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register contains the initial value of the fragment primary color before the partial colors that correspond to each enabled light are added. Usually set to material_emission + material_ambient*scene_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, Number of active lights - 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the number of active lights.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_CONFIG0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Shadow factor enabled (0 = disabled, 1 = enabled) (usually accompanied by bit 16, 17, or 18)&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| unsigned, Fresnel selector&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| unsigned, Light environment configuration&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| 0x4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| unsigned, Apply shadow attenuation to primary color (0 = don&#039;t apply, 1 = apply)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| unsigned, Apply shadow attenuation to secondary color (0 = don&#039;t apply, 1 = apply)&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| unsigned, Invert shadow attenuation (0 = don&#039;t invert, 1 = invert)&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| unsigned, Apply shadow attenuation to alpha component (0 = don&#039;t apply, 1 = apply)&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| unsigned, Bump map texture unit&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| unsigned, Shadow map texture unit&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| unsigned, Clamp highlights (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| unsigned, Bump mode&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| unsigned, Recalculate bump vectors (0 = enabled, 1 = disabled) (usually set to 1 when bump mode is not 0)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the light environment.&lt;br /&gt;
&lt;br /&gt;
Fresnel selector values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Primary alpha&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Secondary alpha&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Primary and secondary alpha&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The light environment configuration controls which LUTs are available for use. If a LUT is not available in the selected configuration, its value will always read a constant 1.0 regardless of the enable state in GPUREG_LIGHTING_CONFIG1. If RR is enabled but not RG or RB, the output of RR is used for the three components; Red, Green and Blue.&lt;br /&gt;
&lt;br /&gt;
Light environment configuration values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
! Available LUTs&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Configuration 0&lt;br /&gt;
| D0, RR, SP, DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Configuration 1&lt;br /&gt;
| FR, RR, SP, DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Configuration 2&lt;br /&gt;
| D0, D1, RR, DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Configuration 3&lt;br /&gt;
| D0, D1, FR, DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Configuration 4&lt;br /&gt;
| All except for FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Configuration 5&lt;br /&gt;
| All except for D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Configuration 6&lt;br /&gt;
| All except for RB and RG&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Configuration 7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Not used&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Use as bump map&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Use as tangent map&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_CONFIG1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Fragment light source 0 shadows disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Fragment light source 1 shadows disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| unsigned, Fragment light source 2 shadows disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| unsigned, Fragment light source 3 shadows disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| unsigned, Fragment light source 4 shadows disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| unsigned, Fragment light source 5 shadows disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| unsigned, Fragment light source 6 shadows disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| unsigned, Fragment light source 7 shadows disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Fragment light source 0 spot light disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, Fragment light source 1 spot light disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, Fragment light source 2 spot light disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| unsigned, Fragment light source 3 spot light disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| unsigned, Fragment light source 4 spot light disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| unsigned, Fragment light source 5 spot light disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| unsigned, Fragment light source 6 spot light disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| unsigned, Fragment light source 7 spot light disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| unsigned, Term 0 distribution component D0 LUT disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| unsigned, Term 1 distribution component D1 LUT disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| unsigned, Fresnel FR LUT disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| unsigned, Term 1 reflection component RB LUT disabled (0 = enabled, 7 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| unsigned, Term 1 reflection component RG LUT disabled (0 = enabled, 7 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| unsigned, Term 1 reflection component RR LUT disabled (0 = enabled, 7 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| unsigned, Fragment light source 0 distance attenuation disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| unsigned, Fragment light source 1 distance attenuation disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| unsigned, Fragment light source 2 distance attenuation disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| unsigned, Fragment light source 3 distance attenuation disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| unsigned, Fragment light source 4 distance attenuation disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| unsigned, Fragment light source 5 distance attenuation disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| unsigned, Fragment light source 6 distance attenuation disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| unsigned, Fragment light source 7 distance attenuation disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to disable various aspects of the light environment.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Starting index&lt;br /&gt;
|-&lt;br /&gt;
| 8-12&lt;br /&gt;
| unsigned, Look-up table&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the GPUREG_LIGHTING_LUT_DATA&#039;&#039;i&#039;&#039; register writes to.&lt;br /&gt;
&lt;br /&gt;
Lookup table values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| RR&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| SP0-7&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| DA0-7&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Disabled (0 = enabled, 1 = disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is set to 1 when fragment lighting is disabled, and to 0 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| LUT data&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Lighting LUT data is written here.&lt;br /&gt;
&lt;br /&gt;
A LUT contains data for the input domain [-1.0, 1.0], which is indexed using a signed 8-bit number [-128, 127]. Therefore a LUT contains 256 entries. The index of a value is (int)(x/127.0f) &amp;amp; 0xFF.&lt;br /&gt;
&lt;br /&gt;
DA: The input domain is [0.0, 1.0], and the index is an unsigned 8-bit number [0, 255] instead.&lt;br /&gt;
&lt;br /&gt;
Format of an entry:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-11&lt;br /&gt;
| fixed0.0.12, Entry value&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| fixed1.0.11, Absolute value of the difference between the next entry and this entry, used to implement linear interpolation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUTINPUT_ABS ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, abs() flag for the input of D0 (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| unsigned, abs() flag for the input of D1 (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, abs() flag for the input of SP (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| unsigned, abs() flag for the input of FR (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| unsigned, abs() flag for the input of RB (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| unsigned, abs() flag for the input of RG (0 = enabled, 1 = disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| unsigned, abs() flag for the input of RR (0 = enabled, 1 = disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register controls whether the absolute value of the input is taken before using a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUTINPUT_SELECT ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, Input selector for D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| unsigned, Input selector for D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| unsigned, Input selector for SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| unsigned, Input selector for FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| unsigned, Input selector for RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| unsigned, Input selector for RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| unsigned, Input selector for RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register selects the input from LUTs.&lt;br /&gt;
&lt;br /&gt;
Input selector values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| N·H&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| V·H&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| N·V&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| L·N&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| -L·P (aka Spotlight aka SP)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| cos φ (aka CP)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUTINPUT_SCALE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, Scaler selector for D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| unsigned, Scaler selector for D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| unsigned, Scaler selector for SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| unsigned, Scaler selector for FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| unsigned, Scaler selector for RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| unsigned, Scaler selector for RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| unsigned, Scaler selector for RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
Scaler selector values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 1x&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 2x&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 4x&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 8x&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| 0.25x&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| 0.5x&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LIGHT_PERMUTATION ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-2&lt;br /&gt;
| unsigned, ID of the 1st enabled light&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| unsigned, ID of the 2nd enabled light&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| unsigned, ID of the 3rd enabled light&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| unsigned, ID of the 4th enabled light&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| unsigned, ID of the 5th enabled light&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| unsigned, ID of the 6th enabled light&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| unsigned, ID of the 7th enabled light&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| unsigned, ID of the 8th enabled light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the IDs of enabled light sources.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_ATTRIBBUFFERS_LOC ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 1-28&lt;br /&gt;
| unsigned, Vertex arrays base address&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the base address of all vertex arrays.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_ATTRIBBUFFERS_FORMAT_LOW ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Vertex attribute 0 type&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| unsigned, Vertex attribute 0 size&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| unsigned, Vertex attribute 1 type&lt;br /&gt;
|-&lt;br /&gt;
| 6-7&lt;br /&gt;
| unsigned, Vertex attribute 1 size&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| unsigned, Vertex attribute 2 type&lt;br /&gt;
|-&lt;br /&gt;
| 10-11&lt;br /&gt;
| unsigned, Vertex attribute 2 size&lt;br /&gt;
|-&lt;br /&gt;
| 12-13&lt;br /&gt;
| unsigned, Vertex attribute 3 type&lt;br /&gt;
|-&lt;br /&gt;
| 14-15&lt;br /&gt;
| unsigned, Vertex attribute 3 size&lt;br /&gt;
|-&lt;br /&gt;
| 16-17&lt;br /&gt;
| unsigned, Vertex attribute 4 type&lt;br /&gt;
|-&lt;br /&gt;
| 18-19&lt;br /&gt;
| unsigned, Vertex attribute 4 size&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| unsigned, Vertex attribute 5 type&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| unsigned, Vertex attribute 5 size&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| unsigned, Vertex attribute 6 type&lt;br /&gt;
|-&lt;br /&gt;
| 26-27&lt;br /&gt;
| unsigned, Vertex attribute 6 size&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| unsigned, Vertex attribute 7 type&lt;br /&gt;
|-&lt;br /&gt;
| 30-31&lt;br /&gt;
| unsigned, Vertex attribute 7 size&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the types and sizes of the first 8 vertex attributes.&lt;br /&gt;
&lt;br /&gt;
Vertex attribute type values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Byte&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unsigned byte&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Short&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Float&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Vertex attribute size values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 8 bits&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 16 bits&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 24 bits&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 32 bits&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_ATTRIBBUFFERS_FORMAT_HIGH ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Vertex attribute 8 type&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| unsigned, Vertex attribute 8 size&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| unsigned, Vertex attribute 9 type&lt;br /&gt;
|-&lt;br /&gt;
| 6-7&lt;br /&gt;
| unsigned, Vertex attribute 9 size&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| unsigned, Vertex attribute 10 type&lt;br /&gt;
|-&lt;br /&gt;
| 10-11&lt;br /&gt;
| unsigned, Vertex attribute 10 size&lt;br /&gt;
|-&lt;br /&gt;
| 12-13&lt;br /&gt;
| unsigned, Vertex attribute 11 type&lt;br /&gt;
|-&lt;br /&gt;
| 14-15&lt;br /&gt;
| unsigned, Vertex attribute 11 size&lt;br /&gt;
|-&lt;br /&gt;
| 16-27&lt;br /&gt;
| unsigned, Fixed vertex attribute mask&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| unsigned, Total vertex attribute count - 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the types and sizes of the last 4 vertex attributes, along with the attribute mask and the total attribute count.&lt;br /&gt;
&lt;br /&gt;
See GPUREG_ATTRIBBUFFERS_FORMAT_LOW for vertex attribute type and size values.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_ATTRIBBUFFER&#039;&#039;i&#039;&#039;_OFFSET ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-27&lt;br /&gt;
| unsigned, Offset from base vertex arrays address&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the offset of a vertex array from the base vertex arrays address.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_ATTRIBBUFFER&#039;&#039;i&#039;&#039;_CONFIG1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Component 1&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| unsigned, Component 2&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| unsigned, Component 3&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| unsigned, Component 4&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| unsigned, Component 5&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| unsigned, Component 6&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| unsigned, Component 7&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| unsigned, Component 8&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the first 8 component types of a vertex array.&lt;br /&gt;
&lt;br /&gt;
Component values:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Vertex attribute 0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Vertex attribute 1&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Vertex attribute 2&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Vertex attribute 3&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Vertex attribute 4&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Vertex attribute 5&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Vertex attribute 6&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Vertex attribute 7&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Vertex attribute 8&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Vertex attribute 9&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Vertex attribute 10&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Vertex attribute 11&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| 4-byte padding&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| 8-byte padding&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| 12-byte padding&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| 16-byte padding&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_ATTRIBBUFFER&#039;&#039;i&#039;&#039;_CONFIG2 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Component 9&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| unsigned, Component 10&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| unsigned, Component 11&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| unsigned, Component 12&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Bytes per vertex&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| unsigned, Total number of components&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the last 4 component types of a vertex array, along with the bytes per vertex and the total number of components.&lt;br /&gt;
&lt;br /&gt;
See GPUREG_ATTRIBBUFFER&#039;&#039;i&#039;&#039;_CONFIG1 for component values.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_INDEXBUFFER_CONFIG ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-27&lt;br /&gt;
| unsigned, Offset from base vertex arrays address&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Index type (0 = unsigned byte, 1 = unsigned short or drawing arrays)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the index array used when drawing elements.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_NUMVERTICES ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Number of vertices to render&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the number of vertices to render.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GEOSTAGE_CONFIG ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-1&lt;br /&gt;
| unsigned, Geometry shader in use (0 = not in use, 2 = in use)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Drawing triangle elements (0 = not, 1 = drawing triangle elements)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| unsigned, Use reserved geometry shader subdivision (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the geometry stage of the GPU pipeline.&lt;br /&gt;
&lt;br /&gt;
When using vertex buffers and drawing elements in triangles mode, bit 8 is set to 1, else it is set to 0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VERTEX_OFFSET ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Starting vertex offset&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the offset of the first vertex in an array to render.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_POST_VERTEX_CACHE_NUM ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Number of entries in the post-vertex cache (usually 0x4 or 0x84)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the post-vertex cache.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_DRAWARRAYS ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Trigger (0 = idle, non-zero = draw arrays)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register triggers drawing vertex arrays.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_DRAWELEMENTS ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Trigger (0 = idle, non-zero = draw elements)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register triggers drawing vertex array elements.&lt;br /&gt;
&lt;br /&gt;
=== 	GPUREG_VTX_FUNC ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Trigger (0 = idle, non-zero = clear post-vertex cache)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register triggers clearing the post-vertex cache.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Fixed attribute index (0-11, 0xF = immediate-mode submission)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register selects the index of the fixed attribute to be input with GPUREG_FIXEDATTRIB_DATA&#039;&#039;i&#039;&#039;. See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| colspan=&amp;quot;2&amp;quot; | &#039;&#039;&#039;DATA0:&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| float1.7.16, Vertex attribute element 3 (Z) (bits 16-23)&lt;br /&gt;
|-&lt;br /&gt;
| 8-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 4 (W)&lt;br /&gt;
|-&lt;br /&gt;
| colspan=&amp;quot;2&amp;quot; | &#039;&#039;&#039;DATA1:&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| float1.7.16, Vertex attribute element 2 (Y) (bits 8-23)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 3 (Z) (bits 0-15)&lt;br /&gt;
|-&lt;br /&gt;
| colspan=&amp;quot;2&amp;quot; | &#039;&#039;&#039;DATA2:&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 0-23&lt;br /&gt;
| float1.7.16, Vertex attribute element 1 (X)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 2 (Y) (bits 0-7)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Accepts four 24-bit floating-point values that make up a vertex attribute. Stored in the fixed attribute currently specified with GPUREG_FIXEDATTRIB_INDEX. If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_CMDBUF_SIZE0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-20&lt;br /&gt;
| unsigned, Size of command buffer 0 &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the size of the first command buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_CMDBUF_SIZE1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-20&lt;br /&gt;
| unsigned, Size of command buffer 1 &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the size of the second command buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_CMDBUF_ADDR0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-28&lt;br /&gt;
| unsigned, Physical address of command buffer 0 &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the physical address of the first command buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_CMDBUF_ADDR1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-28&lt;br /&gt;
| unsigned, Physical address of command buffer 1 &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the physical address of the second command buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_CMDBUF_JUMP0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Trigger (0 = idle, non-zero = execute command buffer 0)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register triggers a jump to the first command buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_CMDBUF_JUMP1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Trigger (0 = idle, non-zero = execute command buffer 1)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register triggers a jump to the second command buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_NUM_ATTR ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Number of vertex shader input attributes - 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the number of vertex shader input attributes.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_COM_MODE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Geometry shader configuration enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets whether to use the geometry shader configuration or reuse the vertex shader configuration for the geometry shader shading unit.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_START_DRAW_FUNC0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Mode (0 = drawing, 1 = configuration)&lt;br /&gt;
|-&lt;br /&gt;
| 1-7&lt;br /&gt;
| 0x0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is related to drawing. When the mode value is set to 1, rendering is not performed properly. When set to 0, changes to the vertex shader configuration registers are not applied correctly. Because of this, it is usually initialized to 1, set to 0 immediately before triggering a draw, and set back to 1 immediately after triggering a draw.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OUTMAP_TOTAL1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Number of vertex shader output map registers - 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the number of vertex shader output map registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OUTMAP_TOTAL2 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Number of vertex shader output map registers - 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the number of vertex shader output map registers.&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_GSH_MISC0 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Misc data (0x00000001 = Reserved geometry shader subdivision in use, 0x01004302 = Particle system in use, 0 otherwise)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures miscellaneous geometry shader properties.&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_GEOSTAGE_CONFIG2 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Function indicator (with vertex buffers: 0 = draw elements, 1 = draw arrays, without: 0 = not inputting, 1 = inputting vertex attribute data)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Drawing triangle elements (0 = not, 1 = drawing triangle elements)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the geometry stage of the GPU pipeline.&lt;br /&gt;
&lt;br /&gt;
When using vertex buffers, bit 0 is set to 1 before drawing arrays, and cleared to 0 immediately after. When using immediate mode to directly input vertex attribute data, bit 0 is set to 1 before inputting vertex attribute data, and cleared to 0 immediately after. While bit 0 is set to 1, some register writes outside of the 0x200-0x254 and 0x280-0x2DF ranges may be processed incorrectly.&lt;br /&gt;
&lt;br /&gt;
When using vertex buffers and drawing elements in triangles mode, bit 8 is set to 1, else it is set to 0.&lt;br /&gt;
&lt;br /&gt;
===	GPUREG_GSH_MISC1 ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-4&lt;br /&gt;
| unsigned, Reserved geometry shader subdivision type (2 = Loop, 3 = Catmull-Clark)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures the type of reserved geometry shader subdivision in use. The value is ignored when a subdivision is not in use.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_PRIMITIVE_CONFIG ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned,  Number of vertex shader output map registers - 1&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| unsigned, Primitive mode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures primitive drawing.&lt;br /&gt;
&lt;br /&gt;
Primitive mode value:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Value&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Triangles&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Triangle strip&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Triangle fan&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometry primitive&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_RESTART_PRIMITIVE ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Trigger (0 = idle, 1 = reset primitive)&lt;br /&gt;
|-&lt;br /&gt;
| 1-31&lt;br /&gt;
| 0x0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register triggers resetting primitive drawing.&lt;br /&gt;
&lt;br /&gt;
== Shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_BOOLUNIFORM ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Boolean register b0 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Boolean register b1 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| unsigned, Boolean register b2 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| unsigned, Boolean register b3 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| unsigned, Boolean register b4 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| unsigned, Boolean register b5 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| unsigned, Boolean register b6 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| unsigned, Boolean register b7 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Boolean register b8 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, Boolean register b9 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, Boolean register b10 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| unsigned, Boolean register b11 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| unsigned, Boolean register b12 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| unsigned, Boolean register b13 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| unsigned, Boolean register b14 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| unsigned, Boolean register b15 value (0 = false, 1 = true)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| 0x7FFF&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set a shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_INTUNIFORM_I&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Integer register i&#039;&#039;i&#039;&#039; X value&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Integer register i&#039;&#039;i&#039;&#039; Y value&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, Integer register i&#039;&#039;i&#039;&#039; Z value&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, Integer register i&#039;&#039;i&#039;&#039; W value&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers are used to set a shader unit&#039;s integer registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_INPUTBUFFER_CONFIG ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Input vertex attributes - 1&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, Use reserved geometry shader subdivision (0 = don&#039;t use, 1 = use) (always 0 for vertex shaders)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, Use geometry shader (0x8 = use, 0xA0 = don&#039;t use) (always 0xA0 for vertex shaders)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure a shader unit&#039;s input buffer.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_ENTRYPOINT ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-15&lt;br /&gt;
| unsigned, Code entry point offset, in 32-bit words&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| 0x7FFF&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets a shader unit&#039;s code entry point.&lt;br /&gt;
&lt;br /&gt;
For geometry shaders, this sets the entry point for the single shader unit which can be dedicated to running geometry shaders, regardless of the current geometry stage mode. This is means that while this register is normally used to set the geometry shader entry point, it can also be used to set this single shader unit to run from a different entry point than the other three, even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
For vertex shaders, this sets the entry point for the shader units set to vertex shader mode. Depending on the current geometry stage mode this can include either all 4 shader units or just 3 of them. &lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_ATTRIBUTES_PERMUTATION_LOW ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Vertex attribute 0 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| unsigned, Vertex attribute 1 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| unsigned, Vertex attribute 2 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| unsigned, Vertex attribute 3 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| unsigned, Vertex attribute 4 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| unsigned, Vertex attribute 5 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| unsigned, Vertex attribute 6 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| unsigned, Vertex attribute 7 input register index&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the shader unit input register index which will correspond to each attribute contained by the input buffer (which in the case of geometry shaders is the vertex shader output buffer) for the first 8 attributes. For example, having bits 0-3 set to 5 means that, in the shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_ATTRIBUTES_PERMUTATION_HIGH ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-3&lt;br /&gt;
| unsigned, Vertex attribute 8 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| unsigned, Vertex attribute 9 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| unsigned, Vertex attribute 10 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| unsigned, Vertex attribute 11 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| unsigned, Vertex attribute 12 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| unsigned, Vertex attribute 13 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| unsigned, Vertex attribute 14 input register index&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| unsigned, Vertex attribute 15 input register index&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the shader unit input register index which will correspond to each attribute contained by the input buffer (which in the case of geometry shaders is the vertex shader output buffer) for attributes 8 through 15. For example, having bits 0-3 set to 5 means that, in the shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_OUTMAP_MASK ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| unsigned, Output register o0 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Output register o1 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| unsigned, Output register o2 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| unsigned, Output register o3 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| unsigned, Output register o4 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| unsigned, Output register o5 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| unsigned, Output register o6 enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| unsigned, Output register o7 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Output register o8 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, Output register o9 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, Output register o10 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| unsigned, Output register o11 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| unsigned, Output register o12 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| unsigned, Output register o13 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| unsigned, Output register o14 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| unsigned, Output register o15 enabled (0 = disabled, 1 = enabled) (vertex shader only)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| 0x0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles a shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_CODETRANSFER_END ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Signal transfer end (0 = idle, non-zero = signal)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register&#039;s value should be set to 1 in order to finalize the transfer of shader code.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_FLOATUNIFORM_INDEX ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-7&lt;br /&gt;
| unsigned, Target floating-point register index (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| unsigned, Transfer mode (0 = float1.7.16, 1 = float1.8.23)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the shader unit&#039;s target floating-point register and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_SH_FLOATUNIFORM_DATAi|GPUREG_&#039;&#039;SH&#039;&#039;_FLOATUNIFORM_DATA&#039;&#039;i&#039;&#039;]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_FLOATUNIFORM_DATA&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| Floating-point register component data&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the components of a shader unit&#039;s floating-point registers, each having 4 components. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_SH_FLOATUNIFORM_INDEX|GPUREG_&#039;&#039;SH&#039;&#039;_FLOATUNIFORM_INDEX]]. This register functions as a FIFO queue: after each time a 4-component uniform register is successfully set, the target register index is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_SH_FLOATUNIFORM_INDEX|GPUREG_&#039;&#039;SH&#039;&#039;_FLOATUNIFORM_INDEX]].&lt;br /&gt;
&lt;br /&gt;
* In the case of float24 transfer mode, data should be sent by writing three words which are the concatenation of the float24 value of the uniform register&#039;s 4 components, in the reverse order. Assuming each letter corresponds to 4 bits, the format becomes:&lt;br /&gt;
** first word : ZZWWWWWW&lt;br /&gt;
** second word : YYYYZZZZ&lt;br /&gt;
** third word : XXXXXXYY&lt;br /&gt;
* In the case of float32 transfer mode, data should be sent by writing four words which are each the float32 value of the uniform register&#039;s 4 components, in the reverse order.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_CODETRANSFER_INDEX ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-11&lt;br /&gt;
| unsigned, Target shader code offset&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming shader code data transferred through [[#GPUREG_SH_CODETRANSFER_DATAi|GPUREG_&#039;&#039;SH&#039;&#039;_CODETRANSFER_DATA&#039;&#039;i&#039;&#039;]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_CODETRANSFER_DATA&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Shader instruction data&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer shader code data. This register behaves as a FIFO queue: each write to this register writes the provided value to the GPU shader code memory bank at the offset initially set by [[#GPUREG_SH_CODETRANSFER_INDEX|GPUREG_&#039;&#039;SH&#039;&#039;_CODETRANSFER_INDEX]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_OPDESCS_INDEX ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-11&lt;br /&gt;
| unsigned, Target shader operand descriptor offset&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming shader operand descriptor data transferred through [[#GPUREG_SH_OPDESCS_DATAi|GPUREG_&#039;&#039;SH&#039;&#039;_OPDESCS_DATA&#039;&#039;i&#039;&#039;]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_&#039;&#039;SH&#039;&#039;_OPDESCS_DATA&#039;&#039;i&#039;&#039; ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Bits&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| 0-31&lt;br /&gt;
| unsigned, Shader operand descriptor data&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer shader operand descriptor data. This register behaves as a FIFO queue: each write to this register writes the provided value to the GPU shader operand descriptor memory bank at the offset initially set by [[#GPUREG_SH_OPDESCS_INDEX|GPUREG_&#039;&#039;SH&#039;&#039;_OPDESCS_INDEX]]. The offset in question is incremented after each write to this register.&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=15770</id>
		<title>Homebrew Applications</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=15770"/>
		<updated>2016-02-10T07:33:47Z</updated>

		<summary type="html">&lt;p&gt;Cruel: Undo revision 15769 by Plutooo (talk)&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Installing==&lt;br /&gt;
Applications are installed by copying the necessary files to the 3ds/ folder in the root of the SD-card. Most applications come with two files:&lt;br /&gt;
* (app name).3dsx: The executable.&lt;br /&gt;
* (app name).smdh: The icon/metadata.&lt;br /&gt;
&lt;br /&gt;
The [[Homebrew Launcher]] will scan the sdcard for all .3dsx files, but will only display an icon for those who have one according to the format described above.&lt;br /&gt;
&lt;br /&gt;
==List==&lt;br /&gt;
&lt;br /&gt;
===Official Launcher===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/3ds_hb_menu Homebrew Launcher]&lt;br /&gt;
| Run homebrew on your 3DS!&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| [https://smealum.github.io/ninjhax2/boot.3dsx Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/3ds_hb_menu Homebrew Starter Pack]&lt;br /&gt;
| Everything to get you started.&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| [https://smealum.github.io/ninjhax2/starter.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Applications===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/yellows8/3ds_homemenu_extdatatool 3DS HomeMenu extdata Tool]&lt;br /&gt;
| Tool for accessing the SD extdata which Home Menu uses. This essentially allows writing custom themes to extdata which get loaded at Home Menu startup.&lt;br /&gt;
| [[User:yellows8|yellows8]]&lt;br /&gt;
| [https://github.com/yellows8/3ds_homemenu_extdatatool/releases]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/markwinap/3DS_Nyan_Cat 3DS Nyan Cat]&lt;br /&gt;
| 3DS Nyan Cat using LIBSF2D.&lt;br /&gt;
| [[User:markwinap|markwinap]]&lt;br /&gt;
| [https://www.dropbox.com/s/e400my3xm0zw74r/nyan_cat.zip?dl=0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/videahs-various-stuff.397562/ 3dsfetch]&lt;br /&gt;
| Small 3DS version of a popular Linux ricing script called screenfetch&lt;br /&gt;
| [[User:VideahGams|VideahGams]]&lt;br /&gt;
| [https://github.com/VideahGams/3dsfetch Here]&lt;br /&gt;
| [https://github.com/VideahGams/3dsfetch Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/S3r1alpari4h/Brainfudge3DS Brainfudge]&lt;br /&gt;
| Alpha brainfuck interpreter&lt;br /&gt;
| [[User:s3r1alpari4h|V0idst4r]]&lt;br /&gt;
| [https://github.com/s3r1alpari4h/Brainfudge3DS/releases/ Here]&lt;br /&gt;
| [https://github.com/S3r1alpari4h/Brainfudge3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/plutooo/ctrrpc ctrrpc]&lt;br /&gt;
| A small and easily extensible RPC server/client written in C/Python. Allows you to quickly poke service-commands and syscalls over wifi from a Python shell on your PC. Useful during reverse-engineering.&lt;br /&gt;
| [[User:plutooo|plutoo]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/yellows8/ctr-streaming-server ctr-streaming-server]&lt;br /&gt;
| This is a server which runs on a 3DS, which receives audio/video for playback. This can also send [[HID_Shared_Memory|HID]] state to the client (see the README) when enabled. The included parse_hidstream tool can be used to parse that HID data to simulate keyboard/mouse input events, via Linux uinput.&lt;br /&gt;
| [[User:yellows8|yellows8]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Rinnegatamante/CHMM2 Custom Home Menu Manager 2]&lt;br /&gt;
| Theme manager for Nintendo 3DS&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [http://rinnegatamante.it/CHMM2.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/DownloadMii/DownloadMii DownloadMii]&lt;br /&gt;
| This is a WIP homebrew online store.&lt;br /&gt;
| [[User:filfat|filfat]]&lt;br /&gt;
| [https://www.downloadmii.com/download/#release Latest]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/linoma/fb43ds fb43ds]&lt;br /&gt;
| This is a simple Facebook&#039;s chat client&lt;br /&gt;
| [[User:linoma|linoma]]&lt;br /&gt;
| [https://github.com/linoma/fb43ds Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/FBI FBI]&lt;br /&gt;
| Open source CIA (un)installer.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/iamevn/for-anyone-who-walks-a-lot for-anyone-who-walks-a-lot]&lt;br /&gt;
| Tool to get past the 10 coin per day limit on earning Play Coins by walking.&lt;br /&gt;
| [[User:iamevn|iamevn]]&lt;br /&gt;
| [https://github.com/iamevn/for-anyone-who-walks-a-lot/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mtheall/ftbrony ftBRONY]&lt;br /&gt;
| An FTP server.&lt;br /&gt;
| [https://github.com/mtheall mtheall]&lt;br /&gt;
| [https://github.com/mtheall/ftbrony/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/iamevn/FTP-3DS FTP-3DS]&lt;br /&gt;
| Fork of ftBRONY with a Nintendo theme.&lt;br /&gt;
| [[User:iamevn|iamevn]]&lt;br /&gt;
| [https://github.com/iamevn/FTP-3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/ftPONY ftPONY]&lt;br /&gt;
| A basic FTP server, useful for testing new homebrew versions without swapping the SD card.&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| [https://mega.co.nz/#!nchBkL7B!T3vXnX4q8Uwp6APYYTDSZi2bkm25la-Qyz6j4CjsllI Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/zeta0134/3ds-homebrew-browser Homebrew Browser]&lt;br /&gt;
| Download homebrew from the internet!&lt;br /&gt;
| [[User:cromo|cromo]] [[User:zeta0134|zeta0134]]&lt;br /&gt;
| [https://github.com/zeta0134/3ds-homebrew-browser/releases/tag/v0.1 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-nasa-universal-cia-manager-for-fw-4-1-10-3.409806/ NASA]&lt;br /&gt;
| Universal CIA Manager for FWs 4.1 - 10.3&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [http://rinnegatamante.it/NASA_11.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|[https://github.com/meladroit/svdt svdt]&lt;br /&gt;
|Save Data Explorer/Manager&lt;br /&gt;
|[[User:meladroit|meladroit]]&lt;br /&gt;
|[https://github.com/meladroit/svdt/releases Here]&lt;br /&gt;
|Yes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Game Engines===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-l%C3%B6vepotion-l%C3%96ve-api-for-3ds-homebrew-beta.397559/ LövePotion]&lt;br /&gt;
| An unofficial work in progress implementation of the LÖVE API for 3DS Homebrew&lt;br /&gt;
| [[User:VideahGams|VideahGams]]&lt;br /&gt;
| [https://github.com/VideahGams/LovePotion/releases Here]&lt;br /&gt;
| [https://github.com/VideahGams/LovePotion Yes]&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Games===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-100-boxes-2ds.384714/ 100 Boxes 2DS]&lt;br /&gt;
| Simple puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/100Boxes2DS/100_Boxes_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D 2048-3D]&lt;br /&gt;
| &amp;quot;2048 was a big hit not so long ago, and I still see many people at my school playing it. So I thought it would be pretty cool to be able to play 2048 on the go on the 3DS.&amp;quot;&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D/blob/master/2048-3D.3dsx?raw=true Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/3dscraft 3DSCraft]&lt;br /&gt;
| Minecraft clone.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| [http://smealum.github.io/3dscraft/downloads/3dscraft_141120.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/preview-ld-34-port-antibounce.406361 Antibounce]&lt;br /&gt;
| Move your player to bounce around and collect coins. Go between screens through the holes in the sides of the floor. 3D can also be enabled.&lt;br /&gt;
| TurtleP&lt;br /&gt;
| [https://github.com/TurtleP/Antibounce/releases Here]&lt;br /&gt;
| [https://github.com/TurtleP/Antibounce Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/UnsureSherlock/checkers3ds/tree/master checkers3ds]&lt;br /&gt;
| A buggy ASCII checkers game&lt;br /&gt;
| [[User:UnsureSherlock|UnsureSherlock]]&lt;br /&gt;
| [http://www.filedropper.com/checkers3ds Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-drawattack-networked-drawing-game.402291/ DrawAttack]&lt;br /&gt;
| Online multiplayer drawing game like pictionary.&lt;br /&gt;
| [[User:Cruel|Cruel]]&lt;br /&gt;
| [https://github.com/Cruel/DrawAttack/releases/latest Here]&lt;br /&gt;
| [https://github.com/Cruel/DrawAttack Yes]&lt;br /&gt;
| 16/Nov/15&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-hamsters-2ds.383457/ Hamsters 2DS]&lt;br /&gt;
| A hamster breeding game in text mode.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Hamsters2DS/Hamsters_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS Helii]&lt;br /&gt;
| Fly a helicopter through a 2D tunnel! Ported from the Wii.&lt;br /&gt;
| [[User:BHSPitMonkey|BHSPitMonkey]]&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS/releases/ Here]&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS Yes]&lt;br /&gt;
| 18/Sep/15&lt;br /&gt;
|-&lt;br /&gt;
| [http://gowengamedev.com/insectoid-defense/ Insectoid Defense]&lt;br /&gt;
| A Sci-Fi Tower Defense game. This is merely a port of the Android/iOS/Windows Phone version.&lt;br /&gt;
| [http://www.3dbrew.org/wiki/User:Sgowen sgowen]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/insectoid-defense/releases/download/v1.0-all/insectoid-defense-3DS.zip Here]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/insectoid-defense Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/videahs-various-stuff.397562/ NumberFucker3DS]&lt;br /&gt;
| Simple math game, originally used as a debug game for LövePotion&lt;br /&gt;
| [[User:VideahGams|VideahGams]]&lt;br /&gt;
| [https://github.com/VideahGams/NumberFucker3DS Here]&lt;br /&gt;
| [https://github.com/VideahGams/NumberFucker3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-mastermind-3ds.394710/#post-5611660 Mastermind 3DS]&lt;br /&gt;
| Mastermind on 3DS&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/Mastermind-3DS/blob/master/Mastermind.zip?raw=true Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-minesweeper-2ds.384185/ Minesweeper 2DS]&lt;br /&gt;
| Minesweeper clone.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Minesweeper2DS/Minesweeper_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-paddle-puffle-3ds.392215/ Paddle Puffle 3DS]&lt;br /&gt;
| A port of [http://puffles.gatuno.mx Paddle Puffle] for the 3DS.&lt;br /&gt;
| Peanut42&lt;br /&gt;
| [http://puffles.gatuno.mx/releases/paddlepuffle3ds.zip Here]&lt;br /&gt;
| [https://github.com/gatuno/PaddlePuffle3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-shuffle-2ds.398540/ Pixel Shuffle 2DS]&lt;br /&gt;
| Puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelShuffle2DS/Pixel_Shuffle_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-swap-2ds.395749/ Pixel Swap 2DS]&lt;br /&gt;
| Relaxing Puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelSwap2DS/Pixel_Swap_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/portal3DS Portal3DS]&lt;br /&gt;
| An adaptation of [https://en.wikipedia.org/wiki/Portal_(video_game) Portal] for the 3DS.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| N/A&lt;br /&gt;
| [https://github.com/smealum/portal3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-reversi-othello-for-3ds.395442/ Reversi]&lt;br /&gt;
| [https://en.wikipedia.org/wiki/Reversi Reversi] for the 3DS.&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/Othello-3DS/releases Here]&lt;br /&gt;
| [https://github.com/MrJPGames/Othello-3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-space-fruit.399088/ Space Fruit]&lt;br /&gt;
| Hackathon game by 4 friends ported to 3DS. Asteroids but with fruit (kinda)&lt;br /&gt;
| TurtleP&lt;br /&gt;
| [https://github.com/TurtleP/Space_Fruit/releases Here]&lt;br /&gt;
| [https://github.com/TurtleP/Space_Fruit/tree/3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gowengamedev.com/tappy-plane/ Tappy Plane]&lt;br /&gt;
| A Flappy Bird clone, but with a colorful plane. This is merely a port of the Android/iOS/Windows Phone version.&lt;br /&gt;
| [http://www.3dbrew.org/wiki/User:Sgowen sgowen]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/tappy-plane/releases/download/v1.0-all/tappy-plane-3DS.zip Here]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/tappy-plane Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tilemap-2ds.386733/ TileMap 2DS]&lt;br /&gt;
| Puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/TileMap2DS/TileMap_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tiles-2ds.385796/ Tiles 2DS]&lt;br /&gt;
| Puzzle game, Lights Out Like.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Tiles2DS/Tiles_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/trucmuche-2ds-09.404859// Trucmuche 2DS 09]&lt;br /&gt;
| Hidden Objects.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Trucmuche2DS09/Trucmuche_2DS_09.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand World of 3DSand]&lt;br /&gt;
| World of Sand clone.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/yeti3DS Yeti3DS]&lt;br /&gt;
| A quick and dirty port of Derek Evans&#039; Yeti3D software rendering engine.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/masterfeizz/ctrQuake ctrQuake]&lt;br /&gt;
| Unofficial port of Quake for the 3DS, fully playable.&lt;br /&gt;
| [https://twitter.com/masterfeizz MasterFeizz]&lt;br /&gt;
| [https://github.com/masterfeizz/ctrQuake/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/masterfeizz/EDuke3D EDuke3D]&lt;br /&gt;
| Unofficial port of EDuke32 for the Nintendo 3DS&lt;br /&gt;
| [https://twitter.com/masterfeizz MasterFeizz]&lt;br /&gt;
| [https://github.com/masterfeizz/EDuke3D/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Emulators===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/st4rk/3DNES 3DNES]&lt;br /&gt;
| An NES emulator. (No longer being worked on)&lt;br /&gt;
| St4rk&lt;br /&gt;
| [http://filetrip.net/3ds-downloads/homebrew/dl-3dnes-1-2-f32931.html Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| March 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/StapleButter/blargSnes blargSnes]&lt;br /&gt;
| A Super Nintendo emulator. A compatibility list can be found [http://wiki.gbatemp.net/wiki/BlargSnes_Compatibility_List here].&lt;br /&gt;
| StapleButter&lt;br /&gt;
| [http://kuribo64.net/get.php?id=fYRTHLeS0pR3DXFw Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| May 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/xerpi/CHIP-3DS CHIP-3DS]&lt;br /&gt;
| A simple and slow CHIP-8 emulator.&lt;br /&gt;
| xerpi&lt;br /&gt;
| [https://www.mediafire.com/?y94yjhzf70fsfsi Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| March 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/shinyquagsire23/gpsp CitrAGB]&lt;br /&gt;
| Yet another GBA emulator.&lt;br /&gt;
| shinyquagsire23&lt;br /&gt;
| [https://www.dropbox.com/s/sxb7x34u58g4zo2/3ds.3dsx?dl=0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| September 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/GameYob/ GameYob]&lt;br /&gt;
| A Game Boy (Color) emulator. A compatibility list can be found [http://wiki.gbatemp.net/wiki/GameYob_3DS_Compatibility_List here].&lt;br /&gt;
| Drenn/Steveice10&lt;br /&gt;
| [https://github.com/Steveice10/GameYob/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| November 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mrdanielps/r3Ddragon r3Ddragon]&lt;br /&gt;
| A virtual boy emulator.&lt;br /&gt;
| mrdanielps&lt;br /&gt;
| [https://github.com/mrdanielps/r3Ddragon/releases/download/v0.85-preview.1/r3Ddragon.cia Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| October 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/libretro/RetroArch RetroArch]&lt;br /&gt;
| A multisystem emulator. (GB, GBA, SNES, Genesis, CPS1, CPS2, etc.)&lt;br /&gt;
| libretro&lt;br /&gt;
| [http://buildbot.libretro.com/nightly/nintendo/3ds/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| December 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mgba-emu/mgba mGBA]&lt;br /&gt;
| A GBA emulator that runs good without kernel hax.&lt;br /&gt;
| endrift&lt;br /&gt;
| [https://mgba.io/nightlies.html Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| December 2015&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Icon Packs===&lt;br /&gt;
Icon Packs are SMDH Packs for homebrew apps&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
|Simplok&lt;br /&gt;
|The first 3DS Icon pack.&lt;br /&gt;
|link6155&lt;br /&gt;
|[http://1drv.ms/1EJCq2e Download]&lt;br /&gt;
| 7 September 2015&lt;br /&gt;
|-&lt;br /&gt;
|1LP&lt;br /&gt;
|Cool Icon Pack!.&lt;br /&gt;
|[[User:100pcrack|100pcrack]]&lt;br /&gt;
|[http://github.com/100pcrack/1LP/releases Releases]&lt;br /&gt;
| 27 November 2015&lt;br /&gt;
|-&lt;br /&gt;
|Modern UI&lt;br /&gt;
|A simple icon pack with a flat and minimalist design.&lt;br /&gt;
|[https://gbatemp.net/members/louch-%E9%9B%AA-daishiteru.371920/ LouchDaishiteru]&lt;br /&gt;
|[https://gbatemp.net/threads/icon-pack-modern-ui.404366/ Download]&lt;br /&gt;
| 20 January 2016&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Demos===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| cubedemo&lt;br /&gt;
| A short demo of Homebrew on 3ds with working sound.&lt;br /&gt;
| [[User:plutoo|plutoo]]&lt;br /&gt;
| [https://mega.co.nz/#!KUQFiQYA!pv8HDEyrmuX6Eyw2hW0opL7gf9Ztmjd9J5pPsvs_rD4 Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| Spine 2D&lt;br /&gt;
| Demo of [http://esotericsoftware.com/ Spine] 2D skeletal animations&lt;br /&gt;
| [[User:Cruel|Cruel]]&lt;br /&gt;
| [https://mega.nz/#!Xg411B5R!kcVHP69Ilggmjh4q5OYmr2cFvf5UGdHWA98-_VttDTo 3DSX] [https://mega.nz/#!z8gxHSQb!H0as1A4wqYrdKBhXJwdYik7nPd_msXJhz5N1CeZm1Iw CIA]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| demo ou mourir&lt;br /&gt;
| Small demo for the 3DS with music and 2D effects&lt;br /&gt;
| Desire&lt;br /&gt;
| [http://www.pouet.net/prod.php?which=66607 Pouet]&lt;br /&gt;
| No&lt;br /&gt;
| November 2015&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Alternate Launchers===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
|-&lt;br /&gt;
| Mashers HBL&lt;br /&gt;
| Homebrew Launcher with a grid and folders support.&lt;br /&gt;
| [[User:Mashers|Mashers]]&lt;br /&gt;
| [http://gbatemp.net/threads/release-homebrew-launcher-with-grid-layout.397527/ Here]&lt;br /&gt;
| No&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=IRC_Quotes&amp;diff=15568</id>
		<title>IRC Quotes</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=IRC_Quotes&amp;diff=15568"/>
		<updated>2016-01-22T00:00:29Z</updated>

		<summary type="html">&lt;p&gt;Cruel: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&#039;&#039;This page contains quotes from the IRC channel, #3dsdev.&#039;&#039;&lt;br /&gt;
*&amp;quot;BARK BARK BARK BARK BARK BARK BARK BARK BARK BARK BARK BARK&amp;quot; -meowkins, January 21st 2016&lt;br /&gt;
*&amp;quot;emulife&amp;quot; -[[User:Tomsterley|tomsterle]], January 21st 2016&lt;br /&gt;
*&amp;quot;can we not vandalize the wiki&amp;quot; -Dazzozo, January 21st 2016&lt;br /&gt;
*&amp;quot;can you run citra on 3dsx&amp;quot; -plutoooo, January 21st 2016&lt;br /&gt;
*&amp;quot;(&amp;gt;ლ)&amp;quot; -profi200, January 21st 2016&lt;br /&gt;
*&amp;quot;[[User:Tomsterley|tomsterle]], the awkward fanboy&amp;quot; -meowkins, January 21st 2016&lt;br /&gt;
* &amp;quot;Wiki | Page changed: IRC Quotes | User: Cruel | http://3dbrew.org/w/index.php?curid=2513&amp;amp;diff=15568&amp;amp;oldid=15567&amp;quot; -plutobot, January 21st 2016&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=IRC_Quotes&amp;diff=15560</id>
		<title>IRC Quotes</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=IRC_Quotes&amp;diff=15560"/>
		<updated>2016-01-21T23:41:44Z</updated>

		<summary type="html">&lt;p&gt;Cruel: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&#039;&#039;This page contains quotes from the IRC channel, #3dsdev.&#039;&#039;&lt;br /&gt;
*&amp;quot;BARK BARK BARK BARK BARK BARK BARK BARK BARK BARK BARK BARK&amp;quot; -meowkins, January 21st 2016&lt;br /&gt;
*&amp;quot;emulife&amp;quot; -tomsterle, January 21st 2016&lt;br /&gt;
*&amp;quot;can we not vandalize the wiki&amp;quot; -Dazzozo, January 21st 2016&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=15097</id>
		<title>Homebrew Applications</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=15097"/>
		<updated>2015-12-30T19:43:41Z</updated>

		<summary type="html">&lt;p&gt;Cruel: Add Drawattack&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Installing==&lt;br /&gt;
Applications are installed by copying the necessary files to the 3ds/ folder in the root of the SD-card. Most applications come with two files:&lt;br /&gt;
* (app name).3dsx: The executable.&lt;br /&gt;
* (app name).smdh: The icon/metadata.&lt;br /&gt;
&lt;br /&gt;
The [[Homebrew Launcher]] will scan the sdcard for all .3dsx files, but will only display an icon for those who have one according to the format described above.&lt;br /&gt;
&lt;br /&gt;
==List==&lt;br /&gt;
&lt;br /&gt;
===Official Launcher===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/3ds_hb_menu Homebrew Launcher]&lt;br /&gt;
| Run homebrew on your 3DS!&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| [https://smealum.github.io/ninjhax2/boot.3dsx Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/3ds_hb_menu Homebrew Starter Pack]&lt;br /&gt;
| Everything to get you started.&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| [https://smealum.github.io/ninjhax2/starter.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Applications===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/yellows8/3ds_homemenu_extdatatool 3DS HomeMenu extdata Tool]&lt;br /&gt;
| Tool for accessing the SD extdata which Home Menu uses. This essentially allows writing custom themes to extdata which get loaded at Home Menu startup.&lt;br /&gt;
| [[User:yellows8|yellows8]]&lt;br /&gt;
| [https://github.com/yellows8/3ds_homemenu_extdatatool/releases]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/markwinap/3DS_Nyan_Cat 3DS Nyan Cat]&lt;br /&gt;
| 3DS Nyan Cat using LIBSF2D.&lt;br /&gt;
| [[User:markwinap|markwinap]]&lt;br /&gt;
| [https://www.dropbox.com/s/e400my3xm0zw74r/nyan_cat.zip?dl=0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/videahs-various-stuff.397562/ 3dsfetch]&lt;br /&gt;
| Small 3DS version of a popular Linux ricing script called screenfetch&lt;br /&gt;
| [[User:VideahGams|VideahGams]]&lt;br /&gt;
| [https://github.com/VideahGams/3dsfetch Here]&lt;br /&gt;
| [https://github.com/VideahGams/3dsfetch Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/S3r1alpari4h/Brainfudge3DS Brainfudge]&lt;br /&gt;
| Alpha brainfuck interpreter&lt;br /&gt;
| [[User:s3r1alpari4h|V0idst4r]]&lt;br /&gt;
| [https://github.com/s3r1alpari4h/Brainfudge3DS/releases/ Here]&lt;br /&gt;
| [https://github.com/S3r1alpari4h/Brainfudge3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/plutooo/ctrrpc ctrrpc]&lt;br /&gt;
| A small and easily extensible RPC server/client written in C/Python. Allows you to quickly poke service-commands and syscalls over wifi from a Python shell on your PC. Useful during reverse-engineering.&lt;br /&gt;
| [[User:plutooo|plutoo]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/yellows8/ctr-streaming-server ctr-streaming-server]&lt;br /&gt;
| This is a server which runs on a 3DS, which receives audio/video for playback. This can also send [[HID_Shared_Memory|HID]] state to the client (see the README) when enabled. The included parse_hidstream tool can be used to parse that HID data to simulate keyboard/mouse input events, via Linux uinput.&lt;br /&gt;
| [[User:yellows8|yellows8]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Rinnegatamante/CHMM2 Custom Home Menu Manager 2]&lt;br /&gt;
| Theme manager for Nintendo 3DS&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [http://rinnegatamante.it/CHMM2.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/DownloadMii/DownloadMii DownloadMii]&lt;br /&gt;
| This is a WIP homebrew online store.&lt;br /&gt;
| [[User:filfat|filfat]]&lt;br /&gt;
| [https://www.downloadmii.com/download/#release Latest]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/linoma/fb43ds fb43ds]&lt;br /&gt;
| This is a simple Facebook&#039;s chat client&lt;br /&gt;
| [[User:linoma|linoma]]&lt;br /&gt;
| [https://github.com/linoma/fb43ds Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/FBI FBI]&lt;br /&gt;
| Open source CIA (un)installer.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/iamevn/for-anyone-who-walks-a-lot for-anyone-who-walks-a-lot]&lt;br /&gt;
| Tool to get past the 10 coin per day limit on earning Play Coins by walking.&lt;br /&gt;
| [[User:iamevn|iamevn]]&lt;br /&gt;
| [https://github.com/iamevn/for-anyone-who-walks-a-lot/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mtheall/ftbrony ftBRONY]&lt;br /&gt;
| An FTP server.&lt;br /&gt;
| [[User:mtheall|mtheall]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/iamevn/FTP-3DS FTP-3DS]&lt;br /&gt;
| Fork of ftBRONY with a Nintendo theme.&lt;br /&gt;
| [[User:iamevn|iamevn]]&lt;br /&gt;
| [https://github.com/iamevn/FTP-3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/ftPONY ftPONY]&lt;br /&gt;
| A basic FTP server, useful for testing new homebrew versions without swapping the SD card.&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| [https://mega.co.nz/#!nchBkL7B!T3vXnX4q8Uwp6APYYTDSZi2bkm25la-Qyz6j4CjsllI Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/zeta0134/3ds-homebrew-browser Homebrew Browser]&lt;br /&gt;
| Download homebrew from the internet!&lt;br /&gt;
| [[User:cromo|cromo]] [[User:zeta0134|zeta0134]]&lt;br /&gt;
| [https://github.com/zeta0134/3ds-homebrew-browser/releases/tag/v0.1 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|[https://github.com/meladroit/svdt svdt]&lt;br /&gt;
|Save Data Explorer/Manager&lt;br /&gt;
|[[User:meladroit|meladroit]]&lt;br /&gt;
|[https://github.com/meladroit/svdt/releases Here]&lt;br /&gt;
|Yes&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Game Engines===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-l%C3%B6vepotion-l%C3%96ve-api-for-3ds-homebrew-beta.397559/ LövePotion]&lt;br /&gt;
| An unofficial work in progress implementation of the LÖVE API for 3DS Homebrew&lt;br /&gt;
| [[User:VideahGams|VideahGams]]&lt;br /&gt;
| [https://github.com/VideahGams/LovePotion/releases Here]&lt;br /&gt;
| [https://github.com/VideahGams/LovePotion Yes]&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Games===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-100-boxes-2ds.384714/ 100 Boxes 2DS]&lt;br /&gt;
| Simple puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/100Boxes2DS/100_Boxes_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D 2048-3D]&lt;br /&gt;
| &amp;quot;2048 was a big hit not so long ago, and I still see many people at my school playing it. So I thought it would be pretty cool to be able to play 2048 on the go on the 3DS.&amp;quot;&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D/blob/master/2048-3D.3dsx?raw=true Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/3dscraft 3DSCraft]&lt;br /&gt;
| Minecraft clone.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| [http://smealum.github.io/3dscraft/downloads/3dscraft_141120.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/preview-ld-34-port-antibounce.406361 Antibounce]&lt;br /&gt;
| Move your player to bounce around and collect coins. Go between screens through the holes in the sides of the floor. 3D can also be enabled.&lt;br /&gt;
| TurtleP&lt;br /&gt;
| [https://github.com/TurtleP/Antibounce/releases Here]&lt;br /&gt;
| [https://github.com/TurtleP/Antibounce Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/UnsureSherlock/checkers3ds/tree/master checkers3ds]&lt;br /&gt;
| A buggy ASCII checkers game&lt;br /&gt;
| [[User:UnsureSherlock|UnsureSherlock]]&lt;br /&gt;
| [http://www.filedropper.com/checkers3ds Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-drawattack-networked-drawing-game.402291/ DrawAttack]&lt;br /&gt;
| Online multiplayer drawing game like pictionary.&lt;br /&gt;
| [[User:Cruel|Cruel]]&lt;br /&gt;
| [https://github.com/Cruel/DrawAttack/releases/latest Here]&lt;br /&gt;
| [https://github.com/Cruel/DrawAttack Yes]&lt;br /&gt;
| 11/16/15&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-hamsters-2ds.383457/ Hamsters 2DS]&lt;br /&gt;
| A hamster breeding game in text mode.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Hamsters2DS/Hamsters_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS Helii]&lt;br /&gt;
| Fly a helicopter through a 2D tunnel! Ported from the Wii.&lt;br /&gt;
| [[User:BHSPitMonkey|BHSPitMonkey]]&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS/releases/ Here]&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS Yes]&lt;br /&gt;
| 9/18/15&lt;br /&gt;
|-&lt;br /&gt;
| [http://gowengamedev.com/insectoid-defense/ Insectoid Defense]&lt;br /&gt;
| A Sci-Fi Tower Defense game. This is merely a port of the Android/iOS/Windows Phone version.&lt;br /&gt;
| [http://www.3dbrew.org/wiki/User:Sgowen sgowen]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/insectoid-defense/releases/download/v1.0-all/insectoid-defense-3DS.zip Here]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/insectoid-defense Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/videahs-various-stuff.397562/ NumberFucker3DS]&lt;br /&gt;
| Simple math game, originally used as a debug game for LövePotion&lt;br /&gt;
| [[User:VideahGams|VideahGams]]&lt;br /&gt;
| [https://github.com/VideahGams/NumberFucker3DS Here]&lt;br /&gt;
| [https://github.com/VideahGams/NumberFucker3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-mastermind-3ds.394710/#post-5611660 Mastermind 3DS]&lt;br /&gt;
| Mastermind on 3DS&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/Mastermind-3DS/blob/master/Mastermind.zip?raw=true Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-minesweeper-2ds.384185/ Minesweeper 2DS]&lt;br /&gt;
| Minesweeper clone.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Minesweeper2DS/Minesweeper_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-paddle-puffle-3ds.392215/ Paddle Puffle 3DS]&lt;br /&gt;
| A port of [http://puffles.gatuno.mx Paddle Puffle] for the 3DS.&lt;br /&gt;
| Peanut42&lt;br /&gt;
| [http://puffles.gatuno.mx/releases/paddlepuffle3ds.zip Here]&lt;br /&gt;
| [https://github.com/gatuno/PaddlePuffle3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-shuffle-2ds.398540/ Pixel Shuffle 2DS]&lt;br /&gt;
| Puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelShuffle2DS/Pixel_Shuffle_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-swap-2ds.395749/ Pixel Swap 2DS]&lt;br /&gt;
| Relaxing Puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelSwap2DS/Pixel_Swap_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/portal3DS Portal3DS]&lt;br /&gt;
| An adaptation of [https://en.wikipedia.org/wiki/Portal_(video_game) Portal] for the 3DS.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| N/A&lt;br /&gt;
| [https://github.com/smealum/portal3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-reversi-othello-for-3ds.395442/ Reversi]&lt;br /&gt;
| [https://en.wikipedia.org/wiki/Reversi Reversi] for the 3DS.&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/Othello-3DS/releases Here]&lt;br /&gt;
| [https://github.com/MrJPGames/Othello-3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-space-fruit.399088/ Space Fruit]&lt;br /&gt;
| Hackathon game by 4 friends ported to 3DS. Asteroids but with fruit (kinda)&lt;br /&gt;
| TurtleP&lt;br /&gt;
| [https://github.com/TurtleP/Space_Fruit/releases Here]&lt;br /&gt;
| [https://github.com/TurtleP/Space_Fruit/tree/3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gowengamedev.com/tappy-plane/ Tappy Plane]&lt;br /&gt;
| A Flappy Bird clone, but with a colorful plane. This is merely a port of the Android/iOS/Windows Phone version.&lt;br /&gt;
| [http://www.3dbrew.org/wiki/User:Sgowen sgowen]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/tappy-plane/releases/download/v1.0-all/tappy-plane-3DS.zip Here]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/tappy-plane Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tilemap-2ds.386733/ TileMap 2DS]&lt;br /&gt;
| Puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/TileMap2DS/TileMap_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tiles-2ds.385796/ Tiles 2DS]&lt;br /&gt;
| Puzzle game, Lights Out Like.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Tiles2DS/Tiles_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/trucmuche-2ds-09.404859// Trucmuche 2DS 09]&lt;br /&gt;
| Hidden Objects.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Trucmuche2DS09/Trucmuche_2DS_09.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand World of 3DSand]&lt;br /&gt;
| World of Sand clone.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/yeti3DS Yeti3DS]&lt;br /&gt;
| A quick and dirty port of Derek Evans&#039; Yeti3D software rendering engine.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/masterfeizz/ctrQuake ctrQuake]&lt;br /&gt;
| Unofficial port of Quake for the 3DS, fully playable.&lt;br /&gt;
| [https://twitter.com/masterfeizz MasterFeizz]&lt;br /&gt;
| [https://github.com/masterfeizz/ctrQuake/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/masterfeizz/EDuke3D EDuke3D]&lt;br /&gt;
| Unofficial port of EDuke32 for the Nintendo 3DS&lt;br /&gt;
| [https://twitter.com/masterfeizz MasterFeizz]&lt;br /&gt;
| [https://github.com/masterfeizz/EDuke3D/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Emulators===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/st4rk/3DNES 3DNES]&lt;br /&gt;
| An NES emulator. (No longer being worked on)&lt;br /&gt;
| St4rk&lt;br /&gt;
| [http://filetrip.net/3ds-downloads/homebrew/dl-3dnes-1-2-f32931.html Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| March 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/StapleButter/blargSnes blargSnes]&lt;br /&gt;
| A Super Nintendo emulator. A compatibility list can be found [http://wiki.gbatemp.net/wiki/BlargSnes_Compatibility_List here].&lt;br /&gt;
| StapleButter&lt;br /&gt;
| [http://kuribo64.net/get.php?id=fYRTHLeS0pR3DXFw Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| May 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/xerpi/CHIP-3DS CHIP-3DS]&lt;br /&gt;
| A simple and slow CHIP-8 emulator.&lt;br /&gt;
| xerpi&lt;br /&gt;
| [https://www.mediafire.com/?y94yjhzf70fsfsi Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| March 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/shinyquagsire23/gpsp CitrAGB]&lt;br /&gt;
| Yet another GBA emulator.&lt;br /&gt;
| shinyquagsire23&lt;br /&gt;
| [https://www.dropbox.com/s/sxb7x34u58g4zo2/3ds.3dsx?dl=0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| September 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/GameYob/ GameYob]&lt;br /&gt;
| A Game Boy (Color) emulator. A compatibility list can be found [http://wiki.gbatemp.net/wiki/GameYob_3DS_Compatibility_List here].&lt;br /&gt;
| Drenn/Steveice10&lt;br /&gt;
| [https://github.com/Steveice10/GameYob/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| November 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mrdanielps/r3Ddragon r3Ddragon]&lt;br /&gt;
| A virtual boy emulator.&lt;br /&gt;
| mrdanielps&lt;br /&gt;
| [https://github.com/mrdanielps/r3Ddragon/releases/download/v0.85-preview.1/r3Ddragon.cia Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| October 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/libretro/RetroArch RetroArch]&lt;br /&gt;
| A multisystem emulator. (GB, GBA, SNES, Genesis, CPS1, CPS2, etc.)&lt;br /&gt;
| libretro&lt;br /&gt;
| [http://buildbot.libretro.com/nightly/nintendo/3ds/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| December 2015&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mgba-emu/mgba mGBA]&lt;br /&gt;
| A GBA emulator that runs good without kernel hax.&lt;br /&gt;
| endrift&lt;br /&gt;
| [https://mgba.io/nightlies.html Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| December 2015&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Icon Packs===&lt;br /&gt;
Icon Packs are SMDH Packs for homebrew apps&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
|Simplok&lt;br /&gt;
|The first 3DS Icon pack.&lt;br /&gt;
|link6155&lt;br /&gt;
|[http://1drv.ms/1EJCq2e Download]&lt;br /&gt;
| 7 September 2015&lt;br /&gt;
|-&lt;br /&gt;
|1LP&lt;br /&gt;
|Cool Icon Pack!.&lt;br /&gt;
|[[User:100pcrack|100pcrack]]&lt;br /&gt;
|[http://github.com/100pcrack/1LP/releases Releases]&lt;br /&gt;
| 27 November 2015&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Demos===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| cubedemo&lt;br /&gt;
| A short demo of Homebrew on 3ds with working sound.&lt;br /&gt;
| [[User:plutoo|plutoo]]&lt;br /&gt;
| [https://mega.co.nz/#!KUQFiQYA!pv8HDEyrmuX6Eyw2hW0opL7gf9Ztmjd9J5pPsvs_rD4 Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| Spine 2D&lt;br /&gt;
| Demo of [http://esotericsoftware.com/ Spine] 2D skeletal animations&lt;br /&gt;
| [[User:Cruel|Cruel]]&lt;br /&gt;
| [https://mega.nz/#!Xg411B5R!kcVHP69Ilggmjh4q5OYmr2cFvf5UGdHWA98-_VttDTo 3DSX] [https://mega.nz/#!z8gxHSQb!H0as1A4wqYrdKBhXJwdYik7nPd_msXJhz5N1CeZm1Iw CIA]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
===Alternate Launchers===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
|-&lt;br /&gt;
| Mashers HBL&lt;br /&gt;
| Homebrew Launcher with a grid and folders support.&lt;br /&gt;
| [[User:Mashers|Mashers]]&lt;br /&gt;
| [http://gbatemp.net/threads/release-homebrew-launcher-with-grid-layout.397527/ Here]&lt;br /&gt;
| No&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=13311</id>
		<title>Homebrew Applications</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=13311"/>
		<updated>2015-09-18T06:34:41Z</updated>

		<summary type="html">&lt;p&gt;Cruel: Add demo&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Installing==&lt;br /&gt;
Applications are installed by copying the necessary files to the 3ds/ folder in the root of the SD-card. Most applications come with two files:&lt;br /&gt;
* boot.3dsx: The executable.&lt;br /&gt;
* icon.bin: The icon/metadata.&lt;br /&gt;
&lt;br /&gt;
The [[Homebrew Launcher]] will scan the sdcard for all .3dsx files, but will only display an icon for those who have one according to the format described above.&lt;br /&gt;
&lt;br /&gt;
==List==&lt;br /&gt;
&lt;br /&gt;
===Launcher===&lt;br /&gt;
See [[Homebrew_Exploits|here]].&lt;br /&gt;
&lt;br /&gt;
===Applications===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/yellows8/3ds_homemenu_extdatatool 3DS HomeMenu extdata Tool]&lt;br /&gt;
| Tool for accessing the SD extdata which Home Menu uses. This essentially allows writing custom themes to extdata which get loaded at Home Menu startup.&lt;br /&gt;
| [[User:yellows8|yellows8]]&lt;br /&gt;
| [https://github.com/yellows8/3ds_homemenu_extdatatool/releases]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/markwinap/3DS_Nyan_Cat 3DS Nyan Cat]&lt;br /&gt;
| 3DS Nyan Cat using LIBSF2D.&lt;br /&gt;
| [[User:markwinap|markwinap]]&lt;br /&gt;
| [https://www.dropbox.com/s/e400my3xm0zw74r/nyan_cat.zip?dl=0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/plutooo/ctrrpc ctrrpc]&lt;br /&gt;
| A small and easily extensible RPC server/client written in C/Python. Allows you to quickly poke service-commands and syscalls over wifi from a Python shell on your PC. Useful during reverse-engineering.&lt;br /&gt;
| [[User:plutooo|plutoo]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/yellows8/ctr-streaming-server ctr-streaming-server]&lt;br /&gt;
| This is a server which runs on a 3DS, which receives audio/video for playback. This can also send [[HID_Shared_Memory|HID]] state to the client (see the README) when enabled. The included parse_hidstream tool can be used to parse that HID data to simulate keyboard/mouse input events, via Linux uinput.&lt;br /&gt;
| [[User:yellows8|yellows8]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/DownloadMii/DownloadMii DownloadMii]&lt;br /&gt;
| This is a WIP homebrew online store.&lt;br /&gt;
| [[User:filfat|filfat]]&lt;br /&gt;
| [https://www.downloadmii.com/download/#release Latest]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/linoma/fb43ds fb43ds]&lt;br /&gt;
| This is a simple Facebook&#039;s chat client&lt;br /&gt;
| [[User:linoma|linoma]]&lt;br /&gt;
| [https://github.com/linoma/fb43ds Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/FBI FBI]&lt;br /&gt;
| Open source CIA (un)installer.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/iamevn/for-anyone-who-walks-a-lot for-anyone-who-walks-a-lot]&lt;br /&gt;
| Tool to get past the 10 coin per day limit on earning Play Coins by walking.&lt;br /&gt;
| [[User:iamevn|iamevn]]&lt;br /&gt;
| [https://github.com/iamevn/for-anyone-who-walks-a-lot/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mtheall/ftbrony ftBRONY]&lt;br /&gt;
| An FTP server.&lt;br /&gt;
| [[User:mtheall|mtheall]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/iamevn/FTP-3DS FTP-3DS]&lt;br /&gt;
| Fork of ftBRONY with a Nintendo theme.&lt;br /&gt;
| [[User:iamevn|iamevn]]&lt;br /&gt;
| [https://github.com/iamevn/FTP-3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/ftPONY ftPONY]&lt;br /&gt;
| A basic FTP server, useful for testing new homebrew versions without swapping the SD card.&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| [https://mega.co.nz/#!nchBkL7B!T3vXnX4q8Uwp6APYYTDSZi2bkm25la-Qyz6j4CjsllI Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/zeta0134/3ds-homebrew-browser Homebrew Browser]&lt;br /&gt;
| Download homebrew from the internet!&lt;br /&gt;
| [[User:cromo|cromo]] [[User:zeta0134|zeta0134]]&lt;br /&gt;
| [https://github.com/zeta0134/3ds-homebrew-browser/releases/tag/v0.1 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Games===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-100-boxes-2ds.384714/ 100 Boxes 2DS]&lt;br /&gt;
| Simple puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/100Boxes2DS/100_Boxes_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D 2048-3D]&lt;br /&gt;
| &amp;quot;2048 was a big hit not so long ago, and I still see many people at my school playing it. So I thought it would be pretty cool to be able to play 2048 on the go on the 3DS.&amp;quot;&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D/blob/master/2048-3D.3dsx?raw=true Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/3dscraft 3DSCraft]&lt;br /&gt;
| Minecraft clone.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| [http://smealum.github.io/3dscraft/downloads/3dscraft_141120.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/UnsureSherlock/checkers3ds/tree/master checkers3ds]&lt;br /&gt;
| A buggy ASCII checkers game&lt;br /&gt;
| [[User:UnsureSherlock|UnsureSherlock]]&lt;br /&gt;
| [http://www.filedropper.com/checkers3ds Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-hamsters-2ds.383457/ Hamsters 2DS]&lt;br /&gt;
| A hamster breeding game in text mode.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Hamsters2DS/Hamsters_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS Helii]&lt;br /&gt;
| Fly a helicopter through a 2D tunnel! Ported from the Wii.&lt;br /&gt;
| [[User:BHSPitMonkey|BHSPitMonkey]]&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS/releases/ Here]&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS Yes]&lt;br /&gt;
| 9/18/15&lt;br /&gt;
|-&lt;br /&gt;
| [http://gowengamedev.com/insectoid-defense/ Insectoid Defense]&lt;br /&gt;
| A Sci-Fi Tower Defense game. This is merely a port of the Android/iOS/Windows Phone version.&lt;br /&gt;
| [http://www.3dbrew.org/wiki/User:Sgowen sgowen]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/insectoid-defense/releases/download/v1.0-all/insectoid-defense-3DS.zip Here]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/insectoid-defense Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-mastermind-3ds.394710/#post-5611660 Mastermind 3DS]&lt;br /&gt;
| Mastermind on 3DS&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/Mastermind-3DS/blob/master/Mastermind.zip?raw=true Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-minesweeper-2ds.384185/ Minesweeper 2DS]&lt;br /&gt;
| Minesweeper clone.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Minesweeper2DS/Minesweeper_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-paddle-puffle-3ds.392215/ Paddle Puffle 3DS]&lt;br /&gt;
| A port of [http://puffles.gatuno.mx Paddle Puffle] for the 3DS.&lt;br /&gt;
| Peanut42&lt;br /&gt;
| [http://puffles.gatuno.mx/releases/paddlepuffle3ds.zip Here]&lt;br /&gt;
| [https://github.com/gatuno/PaddlePuffle3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-swap-2ds.395749/ Pixel Swap 2DS]&lt;br /&gt;
| Relaxing Puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelSwap2DS/Pixel_Swap_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/portal3DS Portal3DS]&lt;br /&gt;
| An adaptation of [https://en.wikipedia.org/wiki/Portal_(video_game) Portal] for the 3DS.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| N/A&lt;br /&gt;
| [https://github.com/smealum/portal3DS Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gowengamedev.com/tappy-plane/ Tappy Plane]&lt;br /&gt;
| A Flappy Bird clone, but with a colorful plane. This is merely a port of the Android/iOS/Windows Phone version.&lt;br /&gt;
| [http://www.3dbrew.org/wiki/User:Sgowen sgowen]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/tappy-plane/releases/download/v1.0-all/tappy-plane-3DS.zip Here]&lt;br /&gt;
| [https://github.com/GowenGameDevOpenSource/tappy-plane Yes]&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tilemap-2ds.386733/ TileMap 2DS]&lt;br /&gt;
| Puzzle game.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/TileMap2DS/TileMap_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tiles-2ds.385796/ Tiles 2DS]&lt;br /&gt;
| Puzzle game, Lights Out Like.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Tiles2DS/Tiles_2DS.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand World of 3DSand]&lt;br /&gt;
| World of Sand clone.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/yeti3DS Yeti3DS]&lt;br /&gt;
| A quick and dirty port of Derek Evans&#039; Yeti3D software rendering engine.&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Emulators===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/st4rk/3DNES 3DNES]&lt;br /&gt;
| An NES emulator. (No longer being worked on)&lt;br /&gt;
| St4rk&lt;br /&gt;
| [http://filetrip.net/3ds-downloads/homebrew/dl-3dnes-1-2-f32931.html Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/StapleButter/blargSnes blargSnes]&lt;br /&gt;
| A Super Nintendo emulator. A compatibility list can be found [http://wiki.gbatemp.net/wiki/BlargSnes_Compatibility_List here].&lt;br /&gt;
| StapleButter&lt;br /&gt;
| [http://kuribo64.net/get.php?id=fYRTHLeS0pR3DXFw Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/xerpi/CHIP-3DS CHIP-3DS]&lt;br /&gt;
| A simple and slow CHIP-8 emulator.&lt;br /&gt;
| xerpi&lt;br /&gt;
| [https://www.mediafire.com/?y94yjhzf70fsfsi Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/shinyquagsire23/gpsp CitrAGB]&lt;br /&gt;
| Yet another GBA emulator.&lt;br /&gt;
| shinyquagsire23&lt;br /&gt;
| [https://www.dropbox.com/s/sxb7x34u58g4zo2/3ds.3dsx?dl=0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/GameYob/ GameYob]&lt;br /&gt;
| A Game Boy (Color) emulator. A compatibility list can be found [http://wiki.gbatemp.net/wiki/GameYob_3DS_Compatibility_List here].&lt;br /&gt;
| Drenn/Steveice10&lt;br /&gt;
| [https://github.com/Steveice10/GameYob/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
===Icon Packs===&lt;br /&gt;
Icon Packs are SMDH Packs for homebrew apps&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
|Simplok&lt;br /&gt;
|The first 3DS Icon pack.&lt;br /&gt;
|link6155&lt;br /&gt;
|[http://1drv.ms/1EJCq2e Download]&lt;br /&gt;
| 7 September 2015&lt;br /&gt;
|}&lt;br /&gt;
===Demos===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| cubedemo&lt;br /&gt;
| A short demo of Homebrew on 3ds with working sound.&lt;br /&gt;
| [[User:plutoo|plutoo]]&lt;br /&gt;
| [https://mega.co.nz/#!KUQFiQYA!pv8HDEyrmuX6Eyw2hW0opL7gf9Ztmjd9J5pPsvs_rD4 Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| Spine 2D&lt;br /&gt;
| Demo of [http://esotericsoftware.com/ Spine] 2D skeletal animations&lt;br /&gt;
| [[User:Cruel|Cruel]]&lt;br /&gt;
| [https://mega.nz/#!Xg411B5R!kcVHP69Ilggmjh4q5OYmr2cFvf5UGdHWA98-_VttDTo 3DSX] [https://mega.nz/#!z8gxHSQb!H0as1A4wqYrdKBhXJwdYik7nPd_msXJhz5N1CeZm1Iw CIA]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Libraries_and_Tools&amp;diff=13283</id>
		<title>Homebrew Libraries and Tools</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Libraries_and_Tools&amp;diff=13283"/>
		<updated>2015-09-14T18:32:48Z</updated>

		<summary type="html">&lt;p&gt;Cruel: Add cpp3ds in prep for release&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;This is a list of libraries and tools that can be used to develop 3DS Homebrew.&lt;br /&gt;
&lt;br /&gt;
==List==&lt;br /&gt;
&lt;br /&gt;
===Libraries===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot; width=&amp;quot;100%&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/ctrulib ctrulib]&lt;br /&gt;
| C library for writing user mode ARM11 code for the 3DS (CTR) &lt;br /&gt;
| [https://twitter.com/smealum smea] et al.&lt;br /&gt;
| [[Setting_up_Development_Environment|See here]]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/xerpi/sf2dlib sf2dlib]&lt;br /&gt;
| Simple and Fast 2D library for the Nintendo 3DS (using ctrulib)&lt;br /&gt;
| [https://github.com/xerpi xerpi]&lt;br /&gt;
| [https://github.com/xerpi/sf2dlib/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/cpp3ds/gl3ds gl3ds]&lt;br /&gt;
| OpenGL implementation for Nintendo 3DS using ctrulib&lt;br /&gt;
| [https://github.com/Cruel Cruel] et al.&lt;br /&gt;
| [https://github.com/cpp3ds/gl3ds/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/machinamentum/Caelina Caelina]&lt;br /&gt;
| An OpenGL implementation for (N)3DS&lt;br /&gt;
| [https://github.com/machinamentum machinamentum]&lt;br /&gt;
| [https://github.com/machinamentum/Caelina/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Myriachan/libkhax libkhax]&lt;br /&gt;
| Library for modifying kernel memory on a certain handheld game console.&lt;br /&gt;
| [https://github.com/Myriachan Myria] et al.&lt;br /&gt;
| [https://github.com/Myriachan/libkhax/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/cpp3ds/cpp3ds cpp3ds]&lt;br /&gt;
| Object-oriented C++ game library and port of [http://www.sfml-dev.org/ SFML]&lt;br /&gt;
| [https://github.com/Cruel Cruel] et al.&lt;br /&gt;
| [https://github.com/cpp3ds/cpp3ds/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Tools===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot; width=&amp;quot;100%&amp;quot;&lt;br /&gt;
!  width=&amp;quot;20%&amp;quot; | Name&lt;br /&gt;
!  width=&amp;quot;50%&amp;quot; | Description&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Author&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Download&lt;br /&gt;
!  width=&amp;quot;10%&amp;quot; | Open-Source&lt;br /&gt;
|-&lt;br /&gt;
| [http://devkitpro.org/ devkitARM]&lt;br /&gt;
| GCC-based toolchain tuned for homebrew development for ARM-based consoles.&lt;br /&gt;
| [https://github.com/WinterMute WinterMute] et al.&lt;br /&gt;
| [[Setting_up_Development_Environment|See here]]&lt;br /&gt;
| [https://github.com/devkitPro Yes]&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/smealum/aemstro aemstro]&lt;br /&gt;
| Set of tools used to disassemble and assemble shader code for DMP&#039;s MAESTRO shader extension used in the 3DS&#039;s PICA200 GPU&lt;br /&gt;
| [https://twitter.com/smealum smea]&lt;br /&gt;
| [https://github.com/smealum/aemstro/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/fincs/picasso picasso]&lt;br /&gt;
| Homebrew PICA200 shader assembler&lt;br /&gt;
| [https://github.com/fincs fincs]&lt;br /&gt;
| [https://github.com/fincs/picasso/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [http://4dsdev.org/thread.php?id=14 nihstro]&lt;br /&gt;
| 3DS shader assembler and disassembler &lt;br /&gt;
| [https://github.com/neobrain neobrain]&lt;br /&gt;
| [http://4dsdev.org/thread.php?id=14 Here]&lt;br /&gt;
| [https://github.com/neobrain/nihstro Yes]&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Lectem/3ds-cmake 3ds-cmake]&lt;br /&gt;
| CMake files for devkitARM and 3DS homebrew development&lt;br /&gt;
| [https://github.com/Lectem Lectem]&lt;br /&gt;
| [https://github.com/Lectem/3ds-cmake/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/profi200/Project_CTR/archive/master.zip makerom]&lt;br /&gt;
|  Tool which can be used to create NCCH, CCI, and CIA files. &lt;br /&gt;
| [http://3dbrew.org/wiki/User:3dsguy 3dsguy] maintained by [https://github.com/profi200 profi200]&lt;br /&gt;
| [https://github.com/profi200/Project_CTR/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/bannertool bannertool]&lt;br /&gt;
| Tool to create NCCH banners&lt;br /&gt;
| [https://github.com/Steveice10 Steveice10]&lt;br /&gt;
| [https://github.com/Steveice10/bannertool/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/socram8888/amiitool amiitool]&lt;br /&gt;
| Tool to decrypt, encrypt and sign amiibo dumps&lt;br /&gt;
| [https://github.com/socram8888 socram8888]&lt;br /&gt;
| [https://github.com/socram8888/amiitool/archive/master.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Commands&amp;diff=13275</id>
		<title>GPU/Commands</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=GPU/Commands&amp;diff=13275"/>
		<updated>2015-09-14T03:27:48Z</updated>

		<summary type="html">&lt;p&gt;Cruel: Add combiner function definitions&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;This page describes the structure of the buffer submitted via the registers at [[GPU|0x1EF018E0]] (or equivalently via [[GSP_Shared_Memory|GX command]] 1). This buffer is used for GPU commands including functionality equivalent to OpenGL commands.&lt;br /&gt;
&lt;br /&gt;
[[GPU Internal Registers]] provides a more structured overview for the available commands but is still work in progress, and hence should be used as a complementary source of information.&lt;br /&gt;
&lt;br /&gt;
=== Overview ===&lt;br /&gt;
Each command is at least 8 bytes wide. The first word is the command parameter and the second word constitutes the command header. Optionally, more parameter words may follow (potentially including a padding word to align commands to multiples of 8 bytes).&lt;br /&gt;
&lt;br /&gt;
In the simplest case, a command is exactly 8 bytes wide. You can think of such a command as writing the parameter word to an internal register (the index of which is given in the command header). The more general case where more than one parameter word is given is equivalent to multiple simple commands (one for each parameter word). If consecutive writing mode is enabled in the command header, the current command index will be incremented after each parameter write. Otherwise, the parameters will be consecutively written to the same register.&lt;br /&gt;
&lt;br /&gt;
For example, the sequence &amp;quot;0xAAAAAAAA 0x802F011C 0xBBBBBBBB 0xCCCCCCCC&amp;quot; is equivalent to a call to commands 0xF011C with parameter 0xAAAAAAAA, 0xF011D with parameter 0xBBBBBBBB and 0xF011E with parameter 0xCCCCCCCC. If consecutive writing mode were disabled, the command would be equivalent to three consecutive calls to 0xF011C (once with parameter 0xAAAAAAAA, once with 0xBBBBBBBB, and finally with 0xCCCCCCCC).&lt;br /&gt;
&lt;br /&gt;
Invalid GPU command parameters including NaN floats can cause the GPU to hang, which then causes the GSP module to hang as well.&lt;br /&gt;
&lt;br /&gt;
The size of GPU command buffers must be 0x10-byte aligned; the lower 3 bits of the size are cleared. A common pitfall is having the finalization command (write to register 0x0010) not executed because it was the last 8 bytes of a non-0x10 byte aligned command buffer, and having the GPU hang as a result.&lt;br /&gt;
&lt;br /&gt;
=== Command Header ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 15-0&lt;br /&gt;
| Command ID&lt;br /&gt;
|-&lt;br /&gt;
| 19-16&lt;br /&gt;
| Parameter mask&lt;br /&gt;
|-&lt;br /&gt;
| 30-20&lt;br /&gt;
| Number of extra parameters (may be zero)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Consecutive writing mode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter masking ===&lt;br /&gt;
&lt;br /&gt;
Using a value other than 0xF, parts of a word in internal GPU memory can be updated without touching the other bits of it. For example, setting bit 16 to zero indicates that the least significant byte of the parameter will not be overwritten, setting bit 17 to zero indicates that the parameter&#039;s second LSB will not be overwritten, etc. This means that for instance commands 0x00010107 and 0x00020107 refer to the same thing but write different parts of the parameter.&lt;br /&gt;
&lt;br /&gt;
=== Command IDs ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0010&lt;br /&gt;
| Value is 0x12345678&lt;br /&gt;
| This command is always the last command in the buffer.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0110&lt;br /&gt;
| Value 0x1&lt;br /&gt;
| This command is immediately before command 0x0010, this is also used elsewhere for beginning rendering of mesh(es) as well.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0111&lt;br /&gt;
| Value 0x1&lt;br /&gt;
| This command is immediately before command 0x0110, however command 0x0110 doesn&#039;t always follow this command.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0040&lt;br /&gt;
| u32, valid values are 0x1 and 0x2, values 0x0 and 0x3 have the same effect as value 0x2. Only bits 1-0 are used.&lt;br /&gt;
| Value 2 = GL_FRONT/GL_CW or GL_BACK/GL_CCW. Value 1 = GL_FRONT/GL_CCW or GL_BACK/GL_CW.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0041&lt;br /&gt;
| float24&lt;br /&gt;
| VIEWPORT_WIDTH. See command set 0x0041.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0042&lt;br /&gt;
| float32&lt;br /&gt;
| VIEWPORT_WIDTH_INV. See command set 0x0041.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0043&lt;br /&gt;
| float24&lt;br /&gt;
| VIEWPORT_HEIGHT. See command set 0x0041.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0044&lt;br /&gt;
| float32&lt;br /&gt;
| VIEWPORT_HEIGHT_INV. See command set 0x0041.&lt;br /&gt;
|-&lt;br /&gt;
| 0x004D&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x004D.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0065&lt;br /&gt;
| &lt;br /&gt;
| Scissor test. See command set 0x0065.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0068&lt;br /&gt;
| u32&lt;br /&gt;
| VIEWPORT Y/X. See command set 0x0041.&lt;br /&gt;
|-&lt;br /&gt;
| 0x006D&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x004D.&lt;br /&gt;
|-&lt;br /&gt;
| 0x006E&lt;br /&gt;
| u32&lt;br /&gt;
| See command set 0x0111.&lt;br /&gt;
|-&lt;br /&gt;
| 0x006F&lt;br /&gt;
| u32&lt;br /&gt;
| See command set 0x006F.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0080&lt;br /&gt;
| u32&lt;br /&gt;
| See command set 0x0080.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0081&lt;br /&gt;
| &lt;br /&gt;
| This is used to set the current texture info used for rendering, see command set [[GPU_Textures|0x0081]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x008E&lt;br /&gt;
| u32 color type&lt;br /&gt;
| This command sets the texture color type, see command set [[GPU_Textures|0x0081]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x0091&lt;br /&gt;
| &lt;br /&gt;
| This sets current texture info, see command [[GPU_Textures|0x0091]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x0099&lt;br /&gt;
| &lt;br /&gt;
| This sets current texture info, see command [[GPU_Textures|0x0099]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x00C3&lt;br /&gt;
| val&amp;lt;&amp;lt;24&lt;br /&gt;
| Val is usually 0xFF or 0x00, however 0x00-0xFF is valid as well. This is alpha-blending related?&lt;br /&gt;
|-&lt;br /&gt;
| 0x00CB&lt;br /&gt;
| val&amp;lt;&amp;lt;24&lt;br /&gt;
| Val is usually 0xFF or 0x00, however 0x00-0xFF is valid as well. This is alpha-blending related?&lt;br /&gt;
|-&lt;br /&gt;
| 0x00C0&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00C4&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00C8&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00CC&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00D0&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00D4&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00D8&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00DC&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00F0&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00F4&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00F8&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00FC&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00C0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00E0&lt;br /&gt;
| Normally value zero.&lt;br /&gt;
| Unknown, fragment related?&lt;br /&gt;
|-&lt;br /&gt;
| 0x00E0&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00E0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00E1&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00E0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00E6&lt;br /&gt;
| Value zero&lt;br /&gt;
| See command set 0x00E6.&lt;br /&gt;
|-&lt;br /&gt;
| 0x00E8&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x00E6.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0100&lt;br /&gt;
| u32, value is 0x00E40100&lt;br /&gt;
| See command set 0x0100.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0100&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;0x00E40000 | val&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| See command set 0x0100.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0101&lt;br /&gt;
| u32&lt;br /&gt;
| See command set 0x0100.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0102&lt;br /&gt;
| u32&lt;br /&gt;
| See command set 0x0100.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0103&lt;br /&gt;
| &lt;br /&gt;
| See command set 0x0100.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0104&lt;br /&gt;
| u32&lt;br /&gt;
| glAlphaFunc()&lt;br /&gt;
|-&lt;br /&gt;
| 0x0105&lt;br /&gt;
| u32&lt;br /&gt;
| Stencil test settings&lt;br /&gt;
|-&lt;br /&gt;
| 0x0106&lt;br /&gt;
| u32&lt;br /&gt;
| Stencil replacement operators&lt;br /&gt;
|-&lt;br /&gt;
| 0x0107&lt;br /&gt;
| &lt;br /&gt;
| See command set command 0x0107.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0116&lt;br /&gt;
| u32&lt;br /&gt;
| DEPTHBUFFER FORMAT. See command set 0x0111.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0117&lt;br /&gt;
| u32&lt;br /&gt;
| COLORBUFFER FORMAT/PIXEL. See command set 0x0111.&lt;br /&gt;
|-&lt;br /&gt;
| 0x011C&lt;br /&gt;
| Physical address&amp;gt;&amp;gt;3&lt;br /&gt;
| DEPTHBUFFER ADDRESS. See command set 0x0111.&lt;br /&gt;
|-&lt;br /&gt;
| 0x011D&lt;br /&gt;
| Physical address&amp;gt;&amp;gt;3&lt;br /&gt;
| COLORBUFFER ADDRESS. See command set 0x0111.&lt;br /&gt;
|-&lt;br /&gt;
| 0x011E&lt;br /&gt;
| u32&lt;br /&gt;
| COLORBUFFER HEIGHT/WIDTH. See command set 0x0111.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0112&lt;br /&gt;
| &lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
| 0x01C5&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;(dmp_FragmentLightSource ID)&amp;lt;&amp;lt;8 | (sampler ID)&amp;lt;&amp;lt;11&amp;lt;/nowiki&amp;gt; ?&lt;br /&gt;
| This command is in conjunction with 0x01C8 used to send fragment 1D samplers. (LUTs) sampler ID 1 for sampler samplerSP and 2 for samplerDA&lt;br /&gt;
|-&lt;br /&gt;
| 0x01C8&lt;br /&gt;
| LUT as parameter&lt;br /&gt;
| Used to send fragment LUT data.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0200&lt;br /&gt;
| &lt;br /&gt;
| See command set [[GPU_GL_Arrays|0x0200]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x0126&lt;br /&gt;
| &lt;br /&gt;
| See command set command 0x0107.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0227&lt;br /&gt;
| u32&lt;br /&gt;
| This specifies the address of an array containing vertex array indices, and the data-type of the indices, used for rendering primitives. See command set [[GPU_GL_Arrays|glDrawElements()]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x0228&lt;br /&gt;
| u32 total elements in the array to use for rendering.&lt;br /&gt;
| See command set [[GPU_GL_Arrays|glDrawElements()]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x0232&lt;br /&gt;
| &lt;br /&gt;
| See command set [[GPU_GL_Arrays|0x0200]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x0244&lt;br /&gt;
| bool ?&lt;br /&gt;
| Set geo shader enabled/disabled ?&lt;br /&gt;
|-&lt;br /&gt;
| 0x025E&lt;br /&gt;
| u32, val&amp;lt;&amp;lt;8.&lt;br /&gt;
| This sets the GL rendering mode, see command set [[GPU_GL_Arrays|0x0200]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x0280&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;0x7FFF0000 | val&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set geo shader boolean uniforms. ((val&amp;gt;&amp;gt;i)&amp;amp;1 = !b_i) value (b0 = False =&amp;gt; val&amp;amp;1 == 1)&lt;br /&gt;
|-&lt;br /&gt;
| 0x0281&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;(x&amp;amp;0xff)|((y&amp;amp;0xff)&amp;lt;&amp;lt;8)|((z&amp;amp;0xff)&amp;lt;&amp;lt;16)|((w&amp;amp;0xff)&amp;lt;&amp;lt;24)&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set i0 (geo shader)&lt;br /&gt;
|-&lt;br /&gt;
| 0x0282&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;(x&amp;amp;0xff)|((y&amp;amp;0xff)&amp;lt;&amp;lt;8)|((z&amp;amp;0xff)&amp;lt;&amp;lt;16)|((w&amp;amp;0xff)&amp;lt;&amp;lt;24)&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set i1 (geo shader)&lt;br /&gt;
|-&lt;br /&gt;
| 0x0283&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;(x&amp;amp;0xff)|((y&amp;amp;0xff)&amp;lt;&amp;lt;8)|((z&amp;amp;0xff)&amp;lt;&amp;lt;16)|((w&amp;amp;0xff)&amp;lt;&amp;lt;24)&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set i2 (geo shader)&lt;br /&gt;
|-&lt;br /&gt;
| 0x0284&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;(x&amp;amp;0xff)|((y&amp;amp;0xff)&amp;lt;&amp;lt;8)|((z&amp;amp;0xff)&amp;lt;&amp;lt;16)|((w&amp;amp;0xff)&amp;lt;&amp;lt;24)&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set i3 (geo shader)&lt;br /&gt;
|-&lt;br /&gt;
| 0x028A&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;0x7FFF0000 | entrypoint offset&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| Sets the entrypoint offset for the geometry shader program&lt;br /&gt;
|-&lt;br /&gt;
| 0x0290&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;0x80000000 | Type&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| Geometry shader equivalent of 0x02C0&lt;br /&gt;
|-&lt;br /&gt;
| 0x02B0&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;0x7FFF0000 | val&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set the 16 vertex shader boolean uniforms. (b_i = (val&amp;gt;&amp;gt;i)&amp;amp;1)&lt;br /&gt;
|-&lt;br /&gt;
| 0x02B1&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;(x&amp;amp;0xff)|((y&amp;amp;0xff)&amp;lt;&amp;lt;8)|((z&amp;amp;0xff)&amp;lt;&amp;lt;16)|((w&amp;amp;0xff)&amp;lt;&amp;lt;24)&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set i0 (vertex shader)&lt;br /&gt;
|-&lt;br /&gt;
| 0x02B2&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;(x&amp;amp;0xff)|((y&amp;amp;0xff)&amp;lt;&amp;lt;8)|((z&amp;amp;0xff)&amp;lt;&amp;lt;16)|((w&amp;amp;0xff)&amp;lt;&amp;lt;24)&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set i1 (vertex shader)&lt;br /&gt;
|-&lt;br /&gt;
| 0x02B3&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;(x&amp;amp;0xff)|((y&amp;amp;0xff)&amp;lt;&amp;lt;8)|((z&amp;amp;0xff)&amp;lt;&amp;lt;16)|((w&amp;amp;0xff)&amp;lt;&amp;lt;24)&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set i2 (vertex shader)&lt;br /&gt;
|-&lt;br /&gt;
| 0x02B4&lt;br /&gt;
| u32, value is &amp;lt;nowiki&amp;gt;(x&amp;amp;0xff)|((y&amp;amp;0xff)&amp;lt;&amp;lt;8)|((z&amp;amp;0xff)&amp;lt;&amp;lt;16)|((w&amp;amp;0xff)&amp;lt;&amp;lt;24)&amp;lt;/nowiki&amp;gt;.&lt;br /&gt;
| Used to set i3 (vertex shader)&lt;br /&gt;
|-&lt;br /&gt;
| 0x02BB&lt;br /&gt;
| &lt;br /&gt;
| See command set [[GPU_GL_Arrays|0x0200]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x02BA&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;0x7FFF0000 | entrypoint offset&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| Sets the entrypoint offset for the vertex shader program&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C0&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;0x80000000 | Type&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| This is used immediately before command 0x02C1. This type field controls the command parameter buffer type. This command can also be used to send over (float24 only ?) data directly, without using 0x02C1. In that case, the first parameter is still Type but with bit 31 not set; the actual data follows.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C1&lt;br /&gt;
| First word in the first entry&lt;br /&gt;
| A list of entries follow this command.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C2&lt;br /&gt;
| First word in the first entry&lt;br /&gt;
| Alias for 0x02C1&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C3&lt;br /&gt;
| First word in the first entry&lt;br /&gt;
| Alias for 0x02C1&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C4&lt;br /&gt;
| First word in the first entry&lt;br /&gt;
| Alias for 0x02C1&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C5&lt;br /&gt;
| First word in the first entry&lt;br /&gt;
| Alias for 0x02C1&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C6&lt;br /&gt;
| First word in the first entry&lt;br /&gt;
| Alias for 0x02C1&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C7&lt;br /&gt;
| First word in the first entry&lt;br /&gt;
| Alias for 0x02C1&lt;br /&gt;
|-&lt;br /&gt;
| 0x02C8&lt;br /&gt;
| First word in the first entry&lt;br /&gt;
| Alias for 0x02C1&lt;br /&gt;
|-&lt;br /&gt;
| 0x029B&lt;br /&gt;
| Value 0x0 ?&lt;br /&gt;
| This is used immediately before command 0x029C. It is used to indicate that geometry shader program data will follow.&lt;br /&gt;
|-&lt;br /&gt;
| 0x029C&lt;br /&gt;
| First word of geometry shader program data chunk.&lt;br /&gt;
| This command is used to transfer geometry shader program data (as the parameter data). It can be called multiple times in a row if the shader program is too big to fit into a single call.&lt;br /&gt;
|-&lt;br /&gt;
| 0x028F&lt;br /&gt;
| Value 0x1 ?&lt;br /&gt;
| This is used immediately after a set of command 0x029C. It is used to indicate that geometry shader program data transfer is complete.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02A5&lt;br /&gt;
| Value 0x0 ?&lt;br /&gt;
| This is used immediately before command 0x02A6.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02A6&lt;br /&gt;
| First entry.&lt;br /&gt;
| This is used to send over the geometry shader program operand descriptor table.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02CB&lt;br /&gt;
| Value 0x0 ?&lt;br /&gt;
| This is used immediately before command 0x02CC. It is used to indicate that shader program data will follow.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02CC&lt;br /&gt;
| First word of vertex shader program data chunk.&lt;br /&gt;
| This command is used to transfer vertex shader program data (as the parameter data). It can be called multiple times in a row if the vertex shader program is too big to fit into a single call.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02BF&lt;br /&gt;
| Value 0x1 ?&lt;br /&gt;
| This is used immediately after a set of command 0x02CC. It is used to indicate that vertex shader program data transfer is complete.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02D5&lt;br /&gt;
| Value 0x0 ?&lt;br /&gt;
| This is used immediately before command 0x02A6.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02D6&lt;br /&gt;
| First entry.&lt;br /&gt;
| This is used to send over the vertex shader program operand descriptor table.&lt;br /&gt;
|-&lt;br /&gt;
| 0x004F&lt;br /&gt;
| Number of vertex shader output attributes&lt;br /&gt;
| Sets number of vertex shader output attributes&lt;br /&gt;
|-&lt;br /&gt;
| 0x0050&lt;br /&gt;
| First entry&lt;br /&gt;
| This command is used to setup vertex shader output registers. The n-th word-long entry is a map of the (n*2)-th output register&#039;s components. Each byte of each entry corresponds to where a component is mapped. Value 0x1F indicates that the corresponding component is unused.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Command Sets ====&lt;br /&gt;
&lt;br /&gt;
===== glDrawElements() =====&lt;br /&gt;
See [[GPU_GL_Arrays|GPU GL Arrays]].&lt;br /&gt;
&lt;br /&gt;
===== glClear() / glClearColor() =====&lt;br /&gt;
The GPU does not have dedicated commands for clearing the color buffer, therefore applications implement color buffer clearing by rendering a quad. Applications normally store this vertex and color [[GPU_GL_Arrays|array]] in the GSP application heap.&lt;br /&gt;
&lt;br /&gt;
===== Command 0x0081 =====&lt;br /&gt;
This sets current texture info, see [[GPU Textures|GPU textures]].&lt;br /&gt;
&lt;br /&gt;
===== Command 0x0065 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x0065&lt;br /&gt;
| Scissor test enable&lt;br /&gt;
| 0 = disabled, 1 = inverted (pixels within the scissor box are excluded), 2 = disabled, 3 = normal (pixels outside of the scissor box are excluded)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0x0066&lt;br /&gt;
| Scissor box X/Y&lt;br /&gt;
| Bit 0-15: X, bit 16-31: Y&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 0x0067&lt;br /&gt;
| Scissor box width/height&lt;br /&gt;
| Bit 0-15: width-1, bit 16-31: height-1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===== Command 0x006F =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x006F&lt;br /&gt;
| Typically only bit8-10 are used.&lt;br /&gt;
| Bit8 enables texture coordinate output for texture unit 0, bit9 enables texcoords for texture unit 1, and bit2 enables texcoords for texture unit 2.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===== Command 0x0080 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x0080&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;0x11000 | val&amp;lt;/nowiki&amp;gt;, where only bits 2-0 are used in val.&lt;br /&gt;
| bit0-2 enables/disables texture units 0-2 respectively&lt;br /&gt;
|}&lt;br /&gt;
Note that bit0-2 in this command only enable texture processing. For texturing to work fully, the corresponding texture coordinate outputs must be enabled as well via command 0x006F.&lt;br /&gt;
&lt;br /&gt;
===== Command 0x00C0 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;SlotCmdID&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;SlotCmdID + 4&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is used for glTexEnv(), for the slot indicated by the command id. There&#039;s a total of 6 slots, where each slot corresponds to the following u16 command ids: 0xC0, 0xC8, 0xD0, 0xD8, 0xF0, 0xF8.&lt;br /&gt;
&lt;br /&gt;
===== Command 0x00E0 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x00E0&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;5 | val&amp;lt;&amp;lt;16&amp;lt;/nowiki&amp;gt;, where val is 0 or 1.&lt;br /&gt;
| Val0 = enable, val1 = disable.&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0x00E1&lt;br /&gt;
| &lt;br /&gt;
| This specifies a color.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is usually used immediately after command set glDrawElements(). This is used to specify a color used for blending?&lt;br /&gt;
&lt;br /&gt;
===== Command 0x00E6 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x00E6&lt;br /&gt;
| Value 0&lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0x00E8&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is usually the last command set used for rendering a mesh, when command set 0x00E0 was used. This command set is used immediately after command set 0x00E0.&lt;br /&gt;
&lt;br /&gt;
===== Command 0x0100 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x0100&lt;br /&gt;
| Value 0x00E40100&lt;br /&gt;
| Controls color compositing&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0x0101&lt;br /&gt;
| 0x01010000 when disabled&lt;br /&gt;
| Alphablending equations and factors&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 0x0103&lt;br /&gt;
| This is set to zero when the command 0x0101 parameter is value 0x01010000.&lt;br /&gt;
| Constant color for alphablending&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is fragment related?&lt;br /&gt;
&lt;br /&gt;
===== Command 0x004D =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x004D&lt;br /&gt;
| &lt;br /&gt;
| glDepthRange()&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0x006D&lt;br /&gt;
| 0 = unknown, 1 = unknown.&lt;br /&gt;
| Value zero causes the mesh to not be rendered.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===== Command 0x0041 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x0041&lt;br /&gt;
| float&lt;br /&gt;
| This corresponds to the framebuffer width.&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0x0043&lt;br /&gt;
| float&lt;br /&gt;
| This parameter value is calculated the same way as the command 0x0041 parameter, except the framebuffer height is used instead.&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 0x0042&lt;br /&gt;
| float&lt;br /&gt;
| This corresponds to the framebuffer width.&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x0044&lt;br /&gt;
| float&lt;br /&gt;
| This parameter value value is calculated the same way as the command 0x0042 parameter, except the framebuffer height is used instead.&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| 0x0068&lt;br /&gt;
| u32&lt;br /&gt;
| This sets the X/Y coordinates used for glViewport().&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This command set initializes the projection matrix. This command set is used twice when beginning rendering for each screen. The framebuffer width used here for the main screen is 240, however this is 480 with stereoscopy enabled for the second time this command set is used.&lt;br /&gt;
&lt;br /&gt;
===== Command 0x0111 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x0111&lt;br /&gt;
| Value 1&lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0x0110&lt;br /&gt;
| Value 1&lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| 0x0117&lt;br /&gt;
| Framebuffer color format descriptor&lt;br /&gt;
| See [[GPU_Internal_Registers#GPUREG_COLORBUFFER_FORMAT]]&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x011D&lt;br /&gt;
| Physical address&amp;gt;&amp;gt;3&lt;br /&gt;
| This initializes the framebuffer address used for rendering, this framebuffer is used for the input framebuffer with [[GSP_Shared_Memory|GX command]] 3 and 4. This command is used immediately after command 0x0117.&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| 0x0116&lt;br /&gt;
| &lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| 0x011C&lt;br /&gt;
| Physical address&amp;gt;&amp;gt;3&lt;br /&gt;
| Unknown, normally this address is located in VRAM.&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| 0x011E&lt;br /&gt;
| u32, 0x01000000|(((h-1)&amp;amp;0xFFF)&amp;lt;&amp;lt;12)|(w&amp;amp;0xFFF)&lt;br /&gt;
| This sets the width and height for the framebuffer used for rendering. Therefore this is glViewport(), x/y are specified by command 0x0068.&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| 0x006E&lt;br /&gt;
| Same input parameter value as command 0x011E.&lt;br /&gt;
| &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This command set is normally used after the two 0x0041 command sets.&lt;br /&gt;
&lt;br /&gt;
===== Command 0x0107 =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Command Index&lt;br /&gt;
!  CommandID&lt;br /&gt;
!  Parameter&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0x0107&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0x0126&lt;br /&gt;
| type&amp;lt;&amp;lt;24&lt;br /&gt;
| &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This command set is used for disabling the alpha-blending info set by command set 0x0107? The GL AlphaFunction used here is normally GL_ALWAYS.&lt;br /&gt;
&lt;br /&gt;
=== Parameter format for command 0x0107 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0 = disable GL_DEPTH_TEST, 1 = enable GL_DEPTH_TEST&lt;br /&gt;
|-&lt;br /&gt;
| 3-1&lt;br /&gt;
| Unused?&lt;br /&gt;
|-&lt;br /&gt;
| 7-4&lt;br /&gt;
| Depth test function&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable color writing for red component&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable color writing for green component&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable color writing for blue component&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable color writing for alpha component&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable depth writing (doesn&#039;t affect stencil writing)&lt;br /&gt;
|-&lt;br /&gt;
| 31-13&lt;br /&gt;
| Unused&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Alpha function values ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  GL AlphaFunction&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| GL_NEVER&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| GL_ALWAYS&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| GL_EQUAL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| GL_NOTEQUAL&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| GL_LESS&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| GL_LEQUAL&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| GL_GREATER&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| GL_GEQUAL&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Alpha types for command 0x0126 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  GL AlphaFunction&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| GL_NEVER&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| GL_ALWAYS&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| GL_GREATER/GL_GEQUAL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| The remaining GL alpha functions.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x0104 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0 = disable GL_ALPHA_TEST, 1 = enable GL_ALPHA_TEST&lt;br /&gt;
|-&lt;br /&gt;
| 3-1&lt;br /&gt;
| Unused?&lt;br /&gt;
|-&lt;br /&gt;
| 7-4&lt;br /&gt;
| Alpha function&lt;br /&gt;
|-&lt;br /&gt;
| 15-8&lt;br /&gt;
| u8 ref, range is 0-255&lt;br /&gt;
|-&lt;br /&gt;
| 31-16&lt;br /&gt;
| Unused?&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is glAlphaFunc().&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x011E ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 11-0&lt;br /&gt;
| Framebuffer/viewport width&lt;br /&gt;
|-&lt;br /&gt;
| 23-12&lt;br /&gt;
| Framebuffer/viewport height - 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Must be set&lt;br /&gt;
|-&lt;br /&gt;
| 31-25&lt;br /&gt;
| Unused?&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This specifies the width/height for glViewport(). Normally the framebuffer width and height is set to the same [[GPU|dimensions]] used with GX [[GSP_Shared_Memory|command]] 3 and 4.&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x0068 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 15-0&lt;br /&gt;
| X&lt;br /&gt;
|-&lt;br /&gt;
| 31-16&lt;br /&gt;
| Y&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This specifies the X/Y coordinates for glViewport().&lt;br /&gt;
&lt;br /&gt;
=== Parameter structure for command 0x00C0 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Index Word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Value 0xFFF0FFF / 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value 0xFFFFFFFF&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value 0x0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This individual command is used instead of the 0x80XF00C0 command set when none of the associated rendering parameters for this slot are set.&lt;br /&gt;
&lt;br /&gt;
=== Parameter structure for command 0x00C0 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Index Word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Param0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Param1&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Param2&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Constant. 0xAABBBGGRR format (or same as the color buffer ?)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Param4&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
See command set 0x80XF00C0.&lt;br /&gt;
&lt;br /&gt;
==== Param0 format for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 3-0&lt;br /&gt;
| See below values.(Field0 index0)&lt;br /&gt;
|-&lt;br /&gt;
| 7-4&lt;br /&gt;
| See below values.(Field0 index1)&lt;br /&gt;
|-&lt;br /&gt;
| 11-8&lt;br /&gt;
| See below values.(Field0 index2)&lt;br /&gt;
|-&lt;br /&gt;
| 15-12&lt;br /&gt;
| Unused&lt;br /&gt;
|-&lt;br /&gt;
| 19-16&lt;br /&gt;
| See below values.(Field1 index0)&lt;br /&gt;
|-&lt;br /&gt;
| 23-20&lt;br /&gt;
| See below values.(Field1 index1)&lt;br /&gt;
|-&lt;br /&gt;
| 27-24&lt;br /&gt;
| See below values.(Field1 index2)&lt;br /&gt;
|-&lt;br /&gt;
| 31-28&lt;br /&gt;
| Unused&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Param0 values for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  GL type&lt;br /&gt;
! Comment&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| GL_PRIMARY_COLOR&lt;br /&gt;
|The color that comes from the upper shader&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| GL_FRAGMENT_PRIMARY_COLOR&lt;br /&gt;
| Sum of ambient, emissive, and diffuse components of lightning stage&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| GL_FRAGMENT_SECONDARY_COLOR&lt;br /&gt;
| Specular component of the lightning stage + ?&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| GL_TEXTURE0&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| GL_TEXTURE1&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x5&lt;br /&gt;
| GL_TEXTURE2&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x6&lt;br /&gt;
| GL_TEXTURE3&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0xC-0x7&lt;br /&gt;
|(GL_PRIMARY_COLOR)No?&lt;br /&gt;
| Please detail. Gives 0 on TexEnv0&lt;br /&gt;
|-&lt;br /&gt;
| 0xD&lt;br /&gt;
| ?&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0xE&lt;br /&gt;
| GL_CONSTANT&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0xF&lt;br /&gt;
| GL_PREVIOUS&lt;br /&gt;
| Color that comes from the previous texture stage&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Param1 format for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 3-0&lt;br /&gt;
| See below values for field0.(Index0)&lt;br /&gt;
|-&lt;br /&gt;
| 7-4&lt;br /&gt;
| See below values for field0.(Index1)&lt;br /&gt;
|-&lt;br /&gt;
| 11-8&lt;br /&gt;
| See below values for field0.(Index2)&lt;br /&gt;
|-&lt;br /&gt;
| 15-12&lt;br /&gt;
| See below values for field1.(Index0)&lt;br /&gt;
|-&lt;br /&gt;
| 19-16&lt;br /&gt;
| See below values for field1.(Index1)&lt;br /&gt;
|-&lt;br /&gt;
| 23-20&lt;br /&gt;
| See below values for field1.(Index2)&lt;br /&gt;
|-&lt;br /&gt;
| 31-24&lt;br /&gt;
| Unused&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This specifies the pname for glTexEnv().&lt;br /&gt;
&lt;br /&gt;
==== Param1 field0 values for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  GL type&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| GL_SRC_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| GL_ONE_MINUS_SRC_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| GL_SRC_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| GL_ONE_MINUS_SRC_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| GL_SRC_R&lt;br /&gt;
|-&lt;br /&gt;
| 0x5&lt;br /&gt;
| GL_ONE_MINUS_SRC_R&lt;br /&gt;
|-&lt;br /&gt;
| 0x6&lt;br /&gt;
| GL_SRC_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0x7&lt;br /&gt;
| GL_SRC_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0x8&lt;br /&gt;
| GL_SRC_G&lt;br /&gt;
|-&lt;br /&gt;
| 0x9&lt;br /&gt;
| GL_ONE_MINUS_SRC_G&lt;br /&gt;
|-&lt;br /&gt;
| 0xA&lt;br /&gt;
| GL_SRC_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0xB&lt;br /&gt;
| GL_SRC_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0xC&lt;br /&gt;
| GL_SRC_B&lt;br /&gt;
|-&lt;br /&gt;
| 0xD&lt;br /&gt;
| GL_ONE_MINUS_SRC_B&lt;br /&gt;
|}&lt;br /&gt;
Note : GL_SRC_X and GL_ONE_MINUS_SRC_X where X=R|G|B are the same as GL_SRC_COLOR and GL_ONE_MINUS_SRC_COLOR but will use only the corresponding color component.&lt;br /&gt;
&lt;br /&gt;
==== Param1 field1 values for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  GL type&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| GL_SRC_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| GL_ONE_MINUS_SRC_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| GL_SRC_R&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| GL_ONE_MINUS_SRC_R&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| GL_SRC_G&lt;br /&gt;
|-&lt;br /&gt;
| 0x5&lt;br /&gt;
| GL_ONE_MINUS_SRC_G&lt;br /&gt;
|-&lt;br /&gt;
| 0x6&lt;br /&gt;
| GL_SRC_B&lt;br /&gt;
|-&lt;br /&gt;
| 0x7&lt;br /&gt;
| GL_ONE_MINUS_SRC_B&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Param2 format for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 15-0&lt;br /&gt;
| See below field0 values.&lt;br /&gt;
|-&lt;br /&gt;
| 31-16&lt;br /&gt;
| See below field1 values.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is used to specify the param for glTexEnv(..., ..., param).&lt;br /&gt;
&lt;br /&gt;
==== Param2 field0 values for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  GL type&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| GL_REPLACE&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| GL_MODULATE&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| GL_ADD&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| GL_ADD_SIGNED&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| GL_INTERPOLATE&lt;br /&gt;
|-&lt;br /&gt;
| 0x5&lt;br /&gt;
| GL_SUBTRACT&lt;br /&gt;
|-&lt;br /&gt;
| 0x6&lt;br /&gt;
| GL_DOT3_RGB&lt;br /&gt;
|-&lt;br /&gt;
| 0x7&lt;br /&gt;
| GL_DOT3_RGBA&lt;br /&gt;
|-&lt;br /&gt;
| 0x8&lt;br /&gt;
| None: SRC0 &amp;amp;times; SRC1 + SRC2&lt;br /&gt;
|-&lt;br /&gt;
| 0x9&lt;br /&gt;
| None: (SRC0 + SRC1 clamped [0,1] range) &amp;amp;times; SRC2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Param2 field1 values for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  GL type&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| GL_REPLACE&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| GL_MODULATE&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| GL_ADD&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| GL_ADD_SIGNED&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| GL_INTERPOLATE&lt;br /&gt;
|-&lt;br /&gt;
| 0x5&lt;br /&gt;
| GL_SUBTRACT&lt;br /&gt;
|-&lt;br /&gt;
| 0x6&lt;br /&gt;
| GL_REPLACE&lt;br /&gt;
|-&lt;br /&gt;
| 0x7&lt;br /&gt;
| GL_DOT3_RGBA&lt;br /&gt;
|-&lt;br /&gt;
| 0x8&lt;br /&gt;
| None: SRC0 &amp;amp;times; SRC1 + SRC2&lt;br /&gt;
|-&lt;br /&gt;
| 0x9&lt;br /&gt;
| None: (SRC0 + SRC1 clamped [0,1] range) &amp;amp;times; SRC2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Note: Inputs and outputs of combiner stages are clamped to [0,1].&lt;br /&gt;
&lt;br /&gt;
==== Param4 format for command 0x00C0 ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 31-18&lt;br /&gt;
| Unused&lt;br /&gt;
|-&lt;br /&gt;
| 17-16&lt;br /&gt;
| Alpha output scale factor&lt;br /&gt;
|-&lt;br /&gt;
| 15-2&lt;br /&gt;
| Unused&lt;br /&gt;
|-&lt;br /&gt;
| 1-0&lt;br /&gt;
| Color output scale factor&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Scale value&lt;br /&gt;
!  Corresponding factor&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| 1.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| 2.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| 4.0&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x00C4 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 15-0&lt;br /&gt;
| Valid values: 0=unknown, 1=unknown, 2=unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 31-16&lt;br /&gt;
| Same format as bits15-0.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
See command set 0x80XF00C0.&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x00E1 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 7-0&lt;br /&gt;
| Red component&lt;br /&gt;
|-&lt;br /&gt;
| 15-8&lt;br /&gt;
| Green component&lt;br /&gt;
|-&lt;br /&gt;
| 23-16&lt;br /&gt;
| Blue component&lt;br /&gt;
|-&lt;br /&gt;
| 31-24&lt;br /&gt;
| Unused&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x0100 ===&lt;br /&gt;
This command controls color compositing. It is typically used right after commands 0x0101 or 0x0102 to select the appropriate blending mode.&lt;br /&gt;
&lt;br /&gt;
Alphablending and color logic op can&#039;t be used together. Attempting to issue commands 0x0101 and 0x0102 at the same time can freeze the GPU.&lt;br /&gt;
&lt;br /&gt;
For blending to work correctly, color buffer reading needs to be enabled (see command set 0x0112). Otherwise zero values will be used as destination color/alpha.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Weird mode (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| When set, nothing is drawn to the color, depth and stencil buffers. This bit can cause a noisy picture when used with bit 0 (this seems to also cause the depth buffer&#039;s endianness to be reversed, and forces stencil values to 0xFF).&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Selects blending mode. 0 = color logic op, 1 = alphablending&lt;br /&gt;
|-&lt;br /&gt;
| 23-16&lt;br /&gt;
| Unknown, typically set to 0xE4. No observed effect when changing this.&lt;br /&gt;
|-&lt;br /&gt;
| 25-24&lt;br /&gt;
| 0 = normal, 1-3 = apply dithering (3 = 0% source)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
When &amp;quot;weird mode&amp;quot; is enabled, the source color/alpha values are ignored. Instead, each 16-bit value in the destination color buffer is converted according to its bits 14-8, as follows:&lt;br /&gt;
 * if bits 14-8 are between 0x00 and 0x03, the value is replaced with 0x0000&lt;br /&gt;
 * if bits 14-8 are between 0x7D and 0x7F, the value is replaced with 0x7FFF&lt;br /&gt;
 * in all other cases, the value is left unchanged&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x0101 ===&lt;br /&gt;
This command controls alphablending. To disable alphablending, the value is set to 0x01010000.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 7-0&lt;br /&gt;
| Color blend equation&lt;br /&gt;
|-&lt;br /&gt;
| 15-8&lt;br /&gt;
| Alpha blend equation&lt;br /&gt;
|-&lt;br /&gt;
| 19-16&lt;br /&gt;
| Color source factor&lt;br /&gt;
|-&lt;br /&gt;
| 23-20&lt;br /&gt;
| Color destination factor&lt;br /&gt;
|-&lt;br /&gt;
| 27-24&lt;br /&gt;
| Alpha source factor&lt;br /&gt;
|-&lt;br /&gt;
| 31-28&lt;br /&gt;
| Alpha destination factor&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Blend equation values:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| GL_FUNC_ADD&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| GL_FUNC_SUBTRACT&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| GL_FUNC_REVERSE_SUBTRACT&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| GL_MIN&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| GL_MAX&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Source/destination factor values:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| GL_ZERO&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| GL_ONE&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| GL_SRC_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| GL_ONE_MINUS_SRC_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| GL_DST_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| GL_ONE_MINUS_DST_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| GL_SRC_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| GL_ONE_MINUS_SRC_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| GL_DST_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| GL_ONE_MINUS_DST_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| GL_CONSTANT_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| GL_ONE_MINUS_CONSTANT_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| GL_CONSTANT_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| GL_ONE_MINUS_CONSTANT_ALPHA&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| GL_SRC_ALPHA_SATURATE&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x0102 ===&lt;br /&gt;
This command controls color logic op.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 3-0&lt;br /&gt;
| Logic operation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Logic operation values:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| GL_CLEAR&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| GL_AND&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| GL_AND_REVERSE&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| GL_COPY&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| GL_SET&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| GL_COPY_INVERTED&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| GL_NOOP&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| GL_INVERT&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| GL_NAND&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| GL_OR&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| GL_NOR&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| GL_XOR&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| GL_EQUIV&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| GL_AND_INVERTED&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| GL_OR_REVERSE&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| GL_OR_INVERTED&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x0105 ===&lt;br /&gt;
This command controls stencil testing.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Enable stencil test&lt;br /&gt;
|-&lt;br /&gt;
| 7-4&lt;br /&gt;
| Stencil test function (values same as for alpha and depth tests)&lt;br /&gt;
|-&lt;br /&gt;
| 15-8&lt;br /&gt;
| Stencil buffer write mask&lt;br /&gt;
|-&lt;br /&gt;
| 23-16&lt;br /&gt;
| Reference value for the stencil test. Note that the test does &amp;quot;reference FUNC value&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| 31-24&lt;br /&gt;
| Mask for the stencil test.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter value format for command 0x0106 ===&lt;br /&gt;
This command controls stencil buffer replacement.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 2-0&lt;br /&gt;
| Action when the stencil test fails&lt;br /&gt;
|-&lt;br /&gt;
| 6-4&lt;br /&gt;
| Action when the stencil test passes but the depth test fails&lt;br /&gt;
|-&lt;br /&gt;
| 10-8&lt;br /&gt;
| Action when both stencil test and depth test pass&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Action values:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  Final stencil value&lt;br /&gt;
!  OpenGL equivalent&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| old_stencil&lt;br /&gt;
| GL_KEEP&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| 0&lt;br /&gt;
| GL_ZERO&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| reference&lt;br /&gt;
| GL_REPLACE&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| min(old_stencil + 1, 255)&lt;br /&gt;
| GL_INCR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| max(old_stencil - 1, 0)&lt;br /&gt;
| GL_DECR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| ~old_stencil&lt;br /&gt;
| GL_INVERT&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| old_stencil + 1&lt;br /&gt;
| GL_INCR_WRAP&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| old_stencil - 1&lt;br /&gt;
| GL_DECR_WRAP&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
&#039;old_stencil&#039; is the value present in the stencil buffer, &#039;reference&#039; is the reference value specified in command 0x0105.&lt;br /&gt;
&lt;br /&gt;
=== Parameter structure for command 0x004D ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Index Word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| float far&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| float near&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is glDepthRange().&lt;br /&gt;
&lt;br /&gt;
=== Parameter structure for command 0x00E8 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Index Word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x7D-0x00&lt;br /&gt;
| Usually value 0x00FFE000.&lt;br /&gt;
|-&lt;br /&gt;
| 0x7E&lt;br /&gt;
| Usually value 0x00FFFEE6?&lt;br /&gt;
|-&lt;br /&gt;
| 0x7F&lt;br /&gt;
| Usually value 0x00DCD919?&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Parameter structure for command 0x0112 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Index Word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Setting bits 3-0 to a nonzero value allows the GPU to read from the color buffer.&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Setting bits 3-0 to a nonzero value allows the GPU to write to the color buffer.&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Setting bits 1-0 to a nonzero value allows the GPU to read from the depth/stencil buffer.&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Setting bits 1-0 to a nonzero value allows the GPU to write to the depth/stencil buffer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Entries for command 0x02C1 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Index Word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| float, the GPU handles this as the 4th word.&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| float, the GPU handles this as the 3rd word.&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| float, the GPU handles this as the 2nd word.&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| float, the GPU handles this as the 1st word.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The below entry structure info is in the raw order used for the command, not the order used by the GPU.&lt;br /&gt;
&lt;br /&gt;
==== Color Entry ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Index Word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| float Red component&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| float Blue component&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| float Green component&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| float Alpha&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Lighting Color Entry ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Index Word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| float Alpha&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| float Blue component&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| float Green component&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| float Red component&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Types for command 0x02C0 ===&lt;br /&gt;
&lt;br /&gt;
The 0x02C0/0x02C1 is actually used as a generic way to set uniforms, regardless of what they represent. 0x02C0&#039;s parameter represents the ID of the destination GPU register (0x0 is c0, 0x1 is c1 etc). As such, the meaning of the data being sent over is entirely dependant on the shader currently in use.&lt;br /&gt;
The values below may be &amp;quot;default&amp;quot; values used by Nintendo&#039;s openGL implementation.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Value&lt;br /&gt;
!  Entries per chunk&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x00&lt;br /&gt;
| 4&lt;br /&gt;
| This specifies 16-floats for a 4x4 matrix, used for glLoadMatrix() for the projection matrix.&lt;br /&gt;
|-&lt;br /&gt;
| 0x04&lt;br /&gt;
| 4&lt;br /&gt;
| This specifies a 4x4 matrix, used for glLoadMatrix() for the model-view matrix. This is usually an identity matrix.&lt;br /&gt;
|-&lt;br /&gt;
| 0x08&lt;br /&gt;
| 2&lt;br /&gt;
| Sets the color.&lt;br /&gt;
|-&lt;br /&gt;
| 0x0A&lt;br /&gt;
| 4&lt;br /&gt;
| Specifies a 4x4 matrix, used for glLoadMatrix() for the texture matrix.(Index0)&lt;br /&gt;
|-&lt;br /&gt;
| 0x0E&lt;br /&gt;
| 3&lt;br /&gt;
| Specifies a 4x3 texture matrix.(Index1)&lt;br /&gt;
|-&lt;br /&gt;
| 0x11&lt;br /&gt;
| 3&lt;br /&gt;
| Specifies a 4x3 texture matrix.(Index2)&lt;br /&gt;
|-&lt;br /&gt;
| 0x14&lt;br /&gt;
| &amp;lt;=30&lt;br /&gt;
| Used to specify a 4xN matrix, where N is the total command 0x02C1 entries. This is glMultMatrix() for the model-view matrix, except the input matrix is 4xN instead of 4x4.&lt;br /&gt;
|-&lt;br /&gt;
| 0x4C&lt;br /&gt;
| 4&lt;br /&gt;
| This specifies a 4x4 float matrix.&lt;br /&gt;
|-&lt;br /&gt;
| 0x50, 0x53, and 0x56&lt;br /&gt;
| 1&lt;br /&gt;
| This specifies the GL_LIGHT0-2 color for GL_AMBIENT?&lt;br /&gt;
|-&lt;br /&gt;
| 0x51, 0x54, and 0x57&lt;br /&gt;
| 1&lt;br /&gt;
| This specifies the GL_LIGHT0-2 color for GL_DIFFUSE?&lt;br /&gt;
|-&lt;br /&gt;
| 0x52, 0x55, and 0x58&lt;br /&gt;
| 1&lt;br /&gt;
| This specifies the GL_LIGHT0-2 color for GL_SPECULAR?&lt;br /&gt;
|-&lt;br /&gt;
| 0x59&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, the entry data is floats converted from s32s. Usually each entry word is zeros.&lt;br /&gt;
|-&lt;br /&gt;
| 0x5A&lt;br /&gt;
| 2&lt;br /&gt;
| Color related?&lt;br /&gt;
|-&lt;br /&gt;
| 0x5C&lt;br /&gt;
| 1&lt;br /&gt;
| ?&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The matrices for types 0x00 and 0x04 use row-major order, instead of column-major order.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Cruel</name></author>
	</entry>
</feed>