<?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=Fincs</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=Fincs"/>
	<link rel="alternate" type="text/html" href="https://www.3dbrew.org/wiki/Special:Contributions/Fincs"/>
	<updated>2026-05-04T00:52:01Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.43.1</generator>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Multi-threading&amp;diff=22313</id>
		<title>Multi-threading</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Multi-threading&amp;diff=22313"/>
		<updated>2023-08-18T21:36:36Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Threads */ Remove misconceptions about Horizon threading&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;This page documents all kernel functionality for managing multiple processes and threads as well as handling synchronization between them.&lt;br /&gt;
&lt;br /&gt;
= Processes =&lt;br /&gt;
&lt;br /&gt;
Each process is given an array of [[NCCH/Extended_Header#ARM11_Kernel_Capabilities|kernel capability descriptors]] upon creation (see CreateProcess). Official software forwards the descriptors specified in the [[NCCH#Extended_Header|NCCH exheader]].&lt;br /&gt;
&lt;br /&gt;
Any process can only use SVCs which are enabled in its kernel capability descriptors. This is enforced by the ARM11 kernel SVC handler by checking the syscall access control mask stored on the SVC-mode stack. If the SVC isn&#039;t enabled, a kernelpanic() is triggered. Each process has a separate SVC-mode stack; this stack and the syscall access mask stored here are initialized when the process is started. Applications normally only have access to SVCs &amp;lt;=0x3D, however not all SVCs &amp;lt;=0x3D are accessible to the application. The majority of the SVCs accessible to applications are unused by the application.&lt;br /&gt;
&lt;br /&gt;
Each process has a separate handle-table, the size of which is stored in the kernel capability descriptor. The handles in a handle-table can&#039;t be used in the context of other processes, since those handles don&#039;t exist in other handle-tables.&lt;br /&gt;
&lt;br /&gt;
0xFFFF8001 is a handle alias for the current process.&lt;br /&gt;
&lt;br /&gt;
Calling svcBreak on retail will only terminate the process which called this SVC.&lt;br /&gt;
&lt;br /&gt;
== Usage ==&lt;br /&gt;
&lt;br /&gt;
=== CreateCodeSet ===&lt;br /&gt;
(behavior unconfirmed)&lt;br /&gt;
&lt;br /&gt;
Allocates memory for a process according to the given CodeSetInfo contents and copies the segment data from the given memory locations to the allocated memory.&lt;br /&gt;
&lt;br /&gt;
=== CreateProcess ===&lt;br /&gt;
(behavior unconfirmed)&lt;br /&gt;
&lt;br /&gt;
Sets up a process using the segments managed by the given CodeSet handle.&lt;br /&gt;
&lt;br /&gt;
This system call furthermore processes the [[NCCH/Extended_Header#ARM11_Kernel_Capabilities|kernel capabilities]] from the [[NCCH/Extended_Header|ExHeader]], hence setting up virtual address mappings, CPU clock frequency/L2 cache configuration, and other things.&lt;br /&gt;
&lt;br /&gt;
=== Run ===&lt;br /&gt;
(behavior unconfirmed)&lt;br /&gt;
&lt;br /&gt;
Sets up the main process thread and appends it to the scheduler queue.&lt;br /&gt;
&lt;br /&gt;
The argc, argv, and envp fields from the given StartupInfo structure are ignored.&lt;br /&gt;
&lt;br /&gt;
== struct CodeSetInfo ==&lt;br /&gt;
All addresses are given virtual for the process to be created.&lt;br /&gt;
All sizes are given in 0x1000-pages.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u8[8]&lt;br /&gt;
| Codeset Name&lt;br /&gt;
|-&lt;br /&gt;
| u16&lt;br /&gt;
| Unknown, this is written to field 0x5A of KCodeSet&lt;br /&gt;
|-&lt;br /&gt;
| u16&lt;br /&gt;
| Unknown/padding&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Unknown/padding&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| .text addr&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| .text size&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| .rodata start&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| .rodata size&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| RW addr (.data + .bss)&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| RW size (.data + .bss)&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Total .text pages&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Total .rodata pages&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Total RW pages (.data + .bss)&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Unknown/padding&lt;br /&gt;
|-&lt;br /&gt;
| u8[8]&lt;br /&gt;
| Program ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= Threads =&lt;br /&gt;
&lt;br /&gt;
For Kernel implementation details, see [[KThread]].&lt;br /&gt;
&lt;br /&gt;
Though it is possible to run multi-threaded programs, running those on different cores is not possible &amp;quot;as-is&amp;quot;. One core is always dedicated to the OS, hence you will never get 100% of both cores.&lt;br /&gt;
&lt;br /&gt;
Using CloseHandle() with a KThread handle will terminate the specified thread only if the reference count reaches 0.&lt;br /&gt;
&lt;br /&gt;
Lower priority values give the thread higher priority. For userland apps, priorities between 0x18 and 0x3F are allowed. The priority of the app&#039;s main thread seems to be 0x30.&lt;br /&gt;
&lt;br /&gt;
The [[Glossary#appcore|appcore]] thread scheduler, in typical real-time operating system fashion, implements a simple preemptive algorithm based around multiple thread priority levels. This algorithm guarantees that the currently executing thread is always the highest priority runnable thread (also known as SCHED_FIFO). In other words, a thread will be interrupted (preempted) if and only if a higher priority thread is woken up, by means of an event (i.e. svcSendSyncRequest) or similar. Contrary to typical desktop operating systems, no timeslice-based scheduling is performed, which means that if a thread uses up all available CPU time (for example if it enters an endless loop), all other threads with equal or lower priority that run on the same CPU core won&#039;t get a chance to run. Address arbiters can be used to implement process-local synchronization primitives.&lt;br /&gt;
&lt;br /&gt;
0xFFFF8000 is a handle alias for the currently active thread.&lt;br /&gt;
&lt;br /&gt;
== Usage ==&lt;br /&gt;
&lt;br /&gt;
=== CreateThread ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x08&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result CreateThread(Handle* thread, func entrypoint, u32 arg, u32 stacktop, s32 threadpriority, s32 processorid);&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Configuration&#039;&#039;&#039;&lt;br /&gt;
 R0=s32 threadpriority&lt;br /&gt;
 R1=func entrypoint&lt;br /&gt;
 R2=u32 arg&lt;br /&gt;
 R3=u32 stacktop&lt;br /&gt;
 R4=s32 processorid&lt;br /&gt;
&lt;br /&gt;
 Result result=R0&lt;br /&gt;
 Handle* thread=R1&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Details&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
Creates a new thread in the current process which will begin execution at the given entrypoint. The SP CPU register will be initialized to stacktop, while r0 will be initialized to the given arg.&lt;br /&gt;
&lt;br /&gt;
The input address used for Entrypoint_Param and StackTop are normally the same, but they may be chosen arbitrarily. For the main thread (created in svcRun), the Entrypoint_Param is value 0.&lt;br /&gt;
&lt;br /&gt;
The stacktop must be aligned to 0x8-bytes, otherwise when not aligned to 0x8-bytes the ARM11 kernel clears the low 3-bits of the stacktop address.&lt;br /&gt;
&lt;br /&gt;
The processorid parameter specifies which processor the thread can run on. Non-negative values correspond to a specific CPU. (e.g. 0 for the Appcore and 1 for the Syscore on Old3DS. On New3DS, IDs 2 and 3 are also valid, referring to the 2 additional CPU cores) Special value -1 means all CPUs, and -2 means the default CPU for the process (Read from the [[NCCH/Extended Header|Exheader]], usually 0 for applications, 1 for system services). Games usually create threads using -2.&lt;br /&gt;
&lt;br /&gt;
The thread priority value must be in the range 0x0..0x3F. Otherwise, error 0xE0E01BFD is returned.&lt;br /&gt;
&lt;br /&gt;
With the Old3DS kernel, the s32 processorid must be &amp;lt;=2 (for the processorid validation check in the kernel). With the New3DS kernel, the processorid validation check requires processorid to be less than or equal to &amp;lt;total cores(MPCore &amp;quot;SCU Configuration Register&amp;quot; CPU number value + 1)&amp;gt;, and a number of additional constraints apply: When processorid==0x2 and the process is not a BASE mem-region process, exheader kernel-flags bitmask 0x2000 must be set (otherwise error 0xD9001BEA is returned). When processorid==0x3 and the process is not a BASE mem-region process, error 0xD9001BEA is returned. These are the only restriction checks done by the kernel for processorid.&lt;br /&gt;
&lt;br /&gt;
=== ExitThread  ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x09&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 void ExitThread(void);&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Details&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
Makes the currently running thread exit. When a thread exits, all mutex objects it owns are released and made available to other threads.&lt;br /&gt;
&lt;br /&gt;
=== SleepThread  ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x0A&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 void SleepThread(s64 nanoseconds);&lt;br /&gt;
&lt;br /&gt;
=== GetThreadPriority ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x0B&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result GetThreadPriority(s32* priority, Handle thread);&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;asm&#039;&#039;&#039;&lt;br /&gt;
 .global svcGetThreadPriority&lt;br /&gt;
 .type svcGetThreadPriority, %function&lt;br /&gt;
 svcGetThreadPriority:&lt;br /&gt;
 	str r0, [sp, #-0x4]!&lt;br /&gt;
 	svc 0x0B&lt;br /&gt;
 	ldr r3, [sp], #4&lt;br /&gt;
 	str r1, [r3]&lt;br /&gt;
 	bx  lr&lt;br /&gt;
&lt;br /&gt;
=== SetThreadPriority ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x0C&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result SetThreadPriority(Handle thread, s32 priority);&lt;br /&gt;
&lt;br /&gt;
=== OpenThread ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x34&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result OpenThread(Handle* thread, Handle process, u32 threadId);&lt;br /&gt;
&lt;br /&gt;
=== GetProcessIdOfThread ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x36&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result GetProcessIdOfThread(u32* processId, Handle thread);&lt;br /&gt;
&lt;br /&gt;
=== GetThreadId ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x37&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result GetThreadId(u32* threadId, Handle thread);&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Details&#039;&#039;&#039;&lt;br /&gt;
It seems that only the thread itself or one of its parent can get the ID. Calling this on the handle of a sibling or parent seems to always yield the ID 0.&lt;br /&gt;
&lt;br /&gt;
=== GetThreadInfo ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x2C&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result GetThreadInfo(s64* out, Handle thread, ThreadInfoType type);&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039; Details &#039;&#039;&#039;&lt;br /&gt;
This requests always return an error when called, it only checks if the handle is a thread or not. &lt;br /&gt;
Hence, it will return 0xD8E007ED (BAD_ENUM) if the Handle is a Thread Handle, 0xD8E007F7 (BAD_HANDLE) if it isn&#039;t.&lt;br /&gt;
&lt;br /&gt;
=== GetThreadContext ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x3B&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result GetThreadContext(ThreadContext* context, Handle thread);&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Details&#039;&#039;&#039;&lt;br /&gt;
Stubbed?&lt;br /&gt;
&lt;br /&gt;
== Core affinity == &lt;br /&gt;
&lt;br /&gt;
The cores are numbered from 0 to 1 for Old 3DS and 0 to 3 for the new 3DS.&lt;br /&gt;
&lt;br /&gt;
=== GetThreadAffinityMask ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x0D&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result GetThreadAffinityMask(u8* affinitymask, Handle thread, s32 processorcount);&lt;br /&gt;
&lt;br /&gt;
=== SetThreadAffinityMask ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x0E&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result SetThreadAffinityMask(Handle thread, u8* affinitymask, s32 processorcount);&lt;br /&gt;
&lt;br /&gt;
=== GetThreadIdealProcessor ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x0F&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Signature&#039;&#039;&#039;&lt;br /&gt;
 Result GetThreadIdealProcessor(s32* processorid, Handle thread);&lt;br /&gt;
&lt;br /&gt;
=== SetThreadIdealProcessor ===&lt;br /&gt;
&#039;&#039;&#039;svc&#039;&#039;&#039; : 0x10&lt;br /&gt;
&lt;br /&gt;
=== APT:SetApplicationCpuTimeLimit ===&lt;br /&gt;
&lt;br /&gt;
See [[APT:SetApplicationCpuTimeLimit]].&lt;br /&gt;
&lt;br /&gt;
You are not able to use the system core (core1) by default. You have to first assign the amount of time dedicated to the system.&lt;br /&gt;
The value is in percent, the higher it is, the more the system will be available for your application. &lt;br /&gt;
&lt;br /&gt;
For example if you set this value to 25%, it means that your application will be able to use 25% of the system core at most, even if you never issue system calls.&lt;br /&gt;
&lt;br /&gt;
If you set the value to a non-zero value, you will not be able to set it back to 0%.&lt;br /&gt;
Keep in mind that if your application is heavily dependant on the system, setting a high value for your application might yield poorer performance than if you had set a low value.&lt;br /&gt;
&lt;br /&gt;
=== APT:GetApplicationCpuTimeLimit ===&lt;br /&gt;
&lt;br /&gt;
See [[APT:GetApplicationCpuTimeLimit]].&lt;br /&gt;
&lt;br /&gt;
== Debug == &lt;br /&gt;
&lt;br /&gt;
=== GetThreadList ===&lt;br /&gt;
&lt;br /&gt;
=== GetDebugThreadContext ===&lt;br /&gt;
&lt;br /&gt;
=== SetDebugThreadContext ===&lt;br /&gt;
&lt;br /&gt;
=== GetDebugThreadParam ===&lt;br /&gt;
&lt;br /&gt;
= Synchronization =&lt;br /&gt;
&lt;br /&gt;
Synchronization can be performed via WaitSynchronization on any handles deriving from [[KSynchronizationObject]]. The semantic meaning of the call depends on the particular object type referred to by the given handle:&lt;br /&gt;
&lt;br /&gt;
* KClientPort: Wakes if max sessions not reached (free session available)&lt;br /&gt;
* KClientSession: Always false?&lt;br /&gt;
* KDebug: Waits until a debug event is signaled (the user should then use svcGetProcessDebugEvent to get the debug event info)&lt;br /&gt;
* KDmaObject: ???&lt;br /&gt;
* KEvent: Waits until the event is signaled&lt;br /&gt;
* KMutex: Acquires a lock on the mutex (blocks until this succeeds)&lt;br /&gt;
* KProcess: Waits until the process exits/is terminated&lt;br /&gt;
* KSemaphore: This consumes a value from the semaphore count, if possible, otherwise continues to wait&lt;br /&gt;
* KServerPort: Waits for a new client connection, upon which svcAcceptSession is ready to be called&lt;br /&gt;
* KServerSession: Waits for an IPC command to be submitted to the server process&lt;br /&gt;
* KThread: Waits until the thread terminates&lt;br /&gt;
* KTimer: Wakes when timer activates (this also clears the timer if it is oneshot)&lt;br /&gt;
&lt;br /&gt;
Most synchronization systems seem to have both a &amp;quot;normal&amp;quot; and &amp;quot;light-weight&amp;quot; version&lt;br /&gt;
&lt;br /&gt;
== Mutex ==&lt;br /&gt;
&lt;br /&gt;
For Kernel implementation details, see [[KMutex]]&lt;br /&gt;
&lt;br /&gt;
===  CreateMutex ===&lt;br /&gt;
&lt;br /&gt;
/!\ It seems that the mutex will not be available once the thread that created it is destroyed &lt;br /&gt;
&lt;br /&gt;
=== ReleaseMutex ===&lt;br /&gt;
&lt;br /&gt;
== Semaphore ==&lt;br /&gt;
&lt;br /&gt;
== Event ==&lt;br /&gt;
&lt;br /&gt;
== Address Arbiters ==&lt;br /&gt;
&lt;br /&gt;
Address arbiters are a low-level primitive to implement synchronization based on a counter stored at some user-specified virtual memory address. Address arbiters are used to put the current thread to sleep until the counter is signaled. Both of these tasks are implemented in ArbitrateAddress.&lt;br /&gt;
&lt;br /&gt;
Address arbiters are implemented by [[KAddressArbiter]].&lt;br /&gt;
&lt;br /&gt;
===CreateAddressArbiter===&lt;br /&gt;
 Result CreateAddressArbiter(Handle* arbiter)&lt;br /&gt;
&lt;br /&gt;
Creates an address arbiter handle for use with ArbitrateAddress.&lt;br /&gt;
&lt;br /&gt;
=== ArbitrateAddress ===&lt;br /&gt;
 Result ArbitrateAddress(Handle arbiter, u32 addr, ArbitrationType type, s32 value, s64 nanoseconds)&lt;br /&gt;
&lt;br /&gt;
if &amp;lt;code&amp;gt;type&amp;lt;/code&amp;gt; is SIGNAL, the ArbitrateAddress call will resume up to &amp;lt;code&amp;gt;value&amp;lt;/code&amp;gt; of the threads waiting on &amp;lt;code&amp;gt;addr&amp;lt;/code&amp;gt; using an arbiter, starting with the highest-priority threads. If &amp;lt;code&amp;gt;value&amp;lt;/code&amp;gt; is negative, all of these threads are released. &amp;lt;code&amp;gt;nanoseconds&amp;lt;/code&amp;gt; remains unused in this mode.&lt;br /&gt;
&lt;br /&gt;
The other modes are used to (conditionally) put the current thread to sleep based on the memory word at virtual address &amp;lt;code&amp;gt;addr&amp;lt;/code&amp;gt; until another thread signals that address using ArbitrateAddress with the &amp;lt;code&amp;gt;type&amp;lt;/code&amp;gt; SIGNAL. WAIT_IF_LESS_THAN will put the current thread to sleep if that word is smaller than &amp;lt;code&amp;gt;value&amp;lt;/code&amp;gt;. DECREMENT_AND_WAIT_IF_LESS_THAN will furthermore decrement the memory value before the comparison. WAIT_IF_LESS_THAN_TIMEOUT and DECREMENT_AND_WAIT_IF_LESS_THAN_TIMEOUT will do the same as their counterparts, but will have thread execution resume if &amp;lt;code&amp;gt;nanoseconds&amp;lt;/code&amp;gt; nanoseconds pass without &amp;lt;code&amp;gt;addr&amp;lt;/code&amp;gt; being signaled.&lt;br /&gt;
&lt;br /&gt;
=== enum ArbitrationType ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Address arbitration type&lt;br /&gt;
!  Value&lt;br /&gt;
|-&lt;br /&gt;
| SIGNAL&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| WAIT_IF_LESS_THAN&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| DECREMENT_AND_WAIT_IF_LESS_THAN&lt;br /&gt;
| 2&lt;br /&gt;
|-&lt;br /&gt;
| WAIT_IF_LESS_THAN_TIMEOUT&lt;br /&gt;
| 3&lt;br /&gt;
|-&lt;br /&gt;
| DECREMENT_AND_WAIT_IF_LESS_THAN_TIMEOUT&lt;br /&gt;
| 4&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Talk:3DS_System_Flaws&amp;diff=21583</id>
		<title>Talk:3DS System Flaws</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Talk:3DS_System_Flaws&amp;diff=21583"/>
		<updated>2021-09-08T13:45:54Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Fincs moved page Talk:3DS system flaws to Talk:3DS System Flaws over a redirect without leaving a redirect: Revert rename&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;I have a way to freeze the 3DS which might be exploitable - see [[Talk:Internet Browser]]. [[User:R4wrz0rz0r|R4wrz0rz0r]] 14:59, 20 June 2011 (CEST)&lt;br /&gt;
: That crash isn&#039;t exploitable unless you&#039;re extremely lucky. Don&#039;t waste your time. --[[User:Luigi2us|Luigi2us]] 20:44, 15 August 2011 (CEST)&lt;br /&gt;
&lt;br /&gt;
It is not so bad to looking for buffer overflow.&lt;br /&gt;
 But try to know about file system  is more important.&lt;br /&gt;
&lt;br /&gt;
And we do not know enough about CCI,... formats to write an exploit with a loader which loads an executable file!&lt;br /&gt;
Maybe we should try to make a savegame exploit...&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Yeah, yeah, great hacking plans, kids. What are you going to do once you find a buffer overflow? Blindly write stuff to memory hoping to hit the PICA200 registers someday? Quit wasting your time with buffer overflows. Come back when more is known. --[[User:Luigi2us|Luigi2us]] 20:42, 15 August 2011 (CEST)&lt;br /&gt;
&lt;br /&gt;
         How would you write a 3DS Exploit, Luigi2us?&lt;br /&gt;
&lt;br /&gt;
We should ask Neimod to use his RAM dumping setup to see where link&#039;s name is in OOT:3D. If it is not properly limited, and is near the regions the console executes next, we might be able to get a buffer overflow exploit. We should try to get a way to do a system exploit ASAP with this method &lt;br /&gt;
--[[User:Alex theman|Alex theman]] 16:00, 15 July 2013 (CEST)&lt;br /&gt;
:Dear iirc, neimod use RAM modfication not exploit, and yellow use exploit. --snip-- --[[User:Syphurith|Syphurith]] 06:29, 16 July 2013 (CEST) &lt;br /&gt;
I know that and we should see what would happen, &#039;&#039;&#039;if&#039;&#039;&#039; we could get this exploit running. And by the way you are really mentally handicapped and should not be posting on this wiki period. Third, [http://tvtropes.org/pmwiki/pmwiki.php/Main/CowboyBebopAtHisComputer your a cowboy bebop at his computer]. And I have been on the sega fourms and i know this BS like the back of my hand. Go on the Sega fourm now!. Before you get banned! For stupidity!&lt;br /&gt;
:Orz. All okey. If you are hurted, take my apologize. I&#039;m not wanting to hurt anyone, so not knowing why you&#039;re getting angry. Also i would take no more interests in that gateway (at least before anyone confirmed that). &lt;br /&gt;
:*Buffer overflow is somewhat difficult for ARM executables since there is no-execution flags. So yellow&#039;s is ROP.&lt;br /&gt;
:*If you think you&#039;re very powerful to get new progress just contact him on IRC not here (he merely be here). Also that is your idea that a RAM dump may help so please ask him yourself.&lt;br /&gt;
:*Always be calm. This wiki is not a site for querrals - So if you think i&#039;m wrong OK i&#039;m wrong.&lt;br /&gt;
:&amp;gt;&amp;gt;Head back to continue MSIL hacking.. Have a good time here.--[[User:Syphurith|Syphurith]] 08:16, 18 July 2013 (CEST)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
SAFE FIRM was only updated once, at 3.0: maybe because of the OTP locking fail? --[[User:motezazer|motezazer]] 20:56, 02 January 2017 (CET)&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=3DS_System_Flaws&amp;diff=21582</id>
		<title>3DS System Flaws</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=3DS_System_Flaws&amp;diff=21582"/>
		<updated>2021-09-08T13:45:53Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Fincs moved page 3DS system flaws to 3DS System Flaws over a redirect without leaving a redirect: Revert rename&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Exploits are used to execute unofficial code (homebrew) on the Nintendo 3DS. This page is a list of publicly known system flaws, for userland applications/applets flaws see [[3DS_Userland_Flaws|here]].&lt;br /&gt;
&lt;br /&gt;
=Stale / Rejected Efforts=&lt;br /&gt;
* In the early days of 3DS hacking, Neimod was working on a RAM dumping setup for a while. He has de-soldered the 3DS&#039;s RAM chip and hooked it and the RAM pinouts on the 3DS&#039;s PCB up to a custom RAM dumping setup. He &#039;&#039;has&#039;&#039; published photos showing his setup to be working quite well, with the 3DS successfully booting up, but however, his flickr stream is now private along with most of his work and this method has been unreleased. RAM dumping can be done through homebrew now, making this method obsolete regardless.&lt;br /&gt;
&lt;br /&gt;
==Tips and info==&lt;br /&gt;
The 3DS uses the XN feature of the ARM11 processor. There&#039;s no official way from applications to enable executable permission for memory containing arbitrary unsigned code(there&#039;s a [[SVC]] for this, but only [[RO_Services|RO-module]] has access to it). A usable userland exploit would still be useful: you could only do return-oriented-programming with it initially. From ROP one could then exploit system flaw(s), see below.&lt;br /&gt;
&lt;br /&gt;
SD card [[extdata]] and SD savegames can be attacked, for consoles where the console-unique [[Nand/private/movable.sed|movable.sed]] was dumped(accessing SD data is far easier by running code on the target 3DS however).&lt;br /&gt;
&lt;br /&gt;
=System flaws=&lt;br /&gt;
== Hardware ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Fixed with hardware model/revision&lt;br /&gt;
!  Newest hardware model/revision this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| ARM9/ARM11 bootrom vectors point at uninitialized RAM&lt;br /&gt;
| ARM9&#039;s and ARM11&#039;s exception vectors are hardcoded to point at the CPU&#039;s internal memory (0x08000000 region for ARM9, AXIWRAM for ARM11). While the bootrom does set them up to point to an endless loop at some point during boot, it does not do so immediately. As such, a carefully-timed fault injection (via hardware) to trigger an exception (such as an invalid instruction) will cause execution to fall into ARM9 RAM. &lt;br /&gt;
Since RAM isn&#039;t cleared on boot (see below), one can immediately start execution of their own code here to dump bootrom, OTP, etc.&lt;br /&gt;
The ARM9 bootrom does the following at reset:  reset vector branches to another instruction, then branches to bootrom+0x8000. Hence, there&#039;s no way to know for certain when exactly the ARM9 exception-vector data stored in memory gets initialized.&lt;br /&gt;
&lt;br /&gt;
This requires *very* *precise* timing for triggering the hardware fault.&lt;br /&gt;
&lt;br /&gt;
It has been exploited by derrek to dump the ARM9 bootrom as of Summer 2015.&lt;br /&gt;
| None: all available 3DS models at the time of writing have the exact same ARM9/ARM11 bootrom for the unprotected areas.&lt;br /&gt;
| New3DS&lt;br /&gt;
| End of February 2014&lt;br /&gt;
| [[User:Derrek|derrek]], WulfyStylez (May 2015) independently&lt;br /&gt;
|-&lt;br /&gt;
| Missing AES key clearing&lt;br /&gt;
| The hardware AES engine does not clear keys when doing a hard reset/reboot.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| August 2014&lt;br /&gt;
| Mathieulh/Others&lt;br /&gt;
|-&lt;br /&gt;
| No RAM clearing on reboots&lt;br /&gt;
| On an MCU-triggered reboot all RAM including FCRAM/ARM9 memory/AXIWRAM/VRAM keeps its contents.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| March 2014&lt;br /&gt;
| [[User:Derrek|derrek]]&lt;br /&gt;
|-&lt;br /&gt;
| 32bits of actual console-unique TWLNAND keydata&lt;br /&gt;
| On retail the 8-bytes at ARM9 address [[Memory_layout|0x01FFB808]] are XORed with hard-coded data, to generate the TWL console-unique keys, including TWLNAND. On Old3DS the high u32 is always 0x0, while on New3DS that u32 is always 0x2. On top of this, the lower u32&#039;s highest bit is always ORed. only 31 bits of the TWL console-unique keydata / TWL consoleID are actually console-unique.&lt;br /&gt;
This allows one to easily bruteforce the TWL console-unique keydata with *just* data from TWLNAND. On DSi the actual console-unique data for key generation is 8-bytes(all bytes actually set).&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| 2012?&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| DSi / 3DS-TWL key-generator&lt;br /&gt;
| After using the key generator to generate the normal-key, you could overwrite parts of the normal-key with your own data and then recover the key-generator output by comparing the new crypto output with the original crypto output. From the normal-key outputs, you could deduce the TWL key-generator function.&lt;br /&gt;
This applies to the keyX/keyY too.&lt;br /&gt;
&lt;br /&gt;
This attack does not work for the 3DS key-generator because keyslots 0-3 are only for TWL keys.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| 2011&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| 3DS key-generator&lt;br /&gt;
| The algorithm for generating the normal-keys for keyslots is cryptographically weak.  As a result, it is easily susceptible to differential cryptanalysis if the normal-key corresponding to any scrambler-generated keyslot is discovered.&lt;br /&gt;
&lt;br /&gt;
Several such pairs of matching normal-keys and KeyY values were found, leading to deducing the key-generator function.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| February 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]], [[User:Plutooo|plutoo]]&lt;br /&gt;
|-&lt;br /&gt;
| RSA keyslots don&#039;t clear exponent when setting modulus&lt;br /&gt;
| The [[RSA_Registers|RSA keyslots]] are set by boot ROM to have four private RSA keys.  The exponent value in the RSA registers is write-only and not readable.&lt;br /&gt;
&lt;br /&gt;
However, when setting a keyslot&#039;s modulus, the RSA hardware leaves the exponent alone.  This allows retrieving the exponent by doing a discrete logarithm of the output.&lt;br /&gt;
&lt;br /&gt;
By setting the modulus to a prime number whose modular multiplicative order is &amp;quot;smooth&amp;quot; (that is, p-1 is divisible by only small prime numbers), discrete logarithms can be calculated quickly using the [[wikipedia:Pohlig-Hellman algorithm|Pohlig-Hellman algorithm]].  If the prime chosen is greater than the modulus, but the same bit size, the discrete logarithm is the private exponent.&lt;br /&gt;
&lt;br /&gt;
This exploit&#039;s usefulness is limited: RSA keyslot 0 is only used in current firmware for deriving the 6.x save and 7.x NCCH keys, which were already known, and the other three keyslots are entirely unused.  Additionally, with a boot ROM dump, this exploit is moot; these private keys are located in the protected ARM9 boot ROM.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| March 2016&lt;br /&gt;
| [[User:Myria|Myria]]&lt;br /&gt;
|-&lt;br /&gt;
| [[CONFIG11_Registers#CFG11_GPUPROT|CFG11_GPUPROT]] allowing acccess to AXIWRAM/FCRAM-BASE-memregion&lt;br /&gt;
| [[CONFIG11_Registers#CFG11_GPUPROT|CFG11_GPUPROT]] can be configured by anything with access to it to allow the GPU to access the entire AXIWRAM+FCRAM. For example, this is an issue for any sysmodule that gets exploited and has access to this register memory-page(include one that&#039;s listed below).&lt;br /&gt;
&lt;br /&gt;
See also &amp;quot;kernelhax via gspwn&amp;quot; below.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| February 7, 2017&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Boot ROM ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Fixed with hardware model/revision&lt;br /&gt;
!  Newest hardware model/revision this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| FIRM partitions known-plaintext&lt;br /&gt;
| The [[Flash_Filesystem|FIRM partitions]] are encrypted with AES-CTR without a MAC. Since this works by XOR&#039;ing data with a static (per-console in this case) keystream, one can deduce the keystream of a portion of each FIRM partition if they have the actual FIRM binary stored in it.&lt;br /&gt;
&lt;br /&gt;
This can be paired with many exploits. For example, it allows minor FIRM downgrades (i.e. 10.4 to 9.6 or 9.5 to 9.4, but not 9.6 to 9.5).&lt;br /&gt;
However it is most commonly used to install arbitrary FIRMs (usually boot9strap), thanks to sighax.&lt;br /&gt;
&lt;br /&gt;
This can be somewhat addressed by having a FIRM header skip over previously used section offsets, but this would just air-gap newer FIRMs without fixing the core bug. This can also only be done a limited number of times due to the size of FIRM versus the size of the partitions.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| &lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| Boot9 AES keyinit function issues&lt;br /&gt;
| [[Bootloader|Boot9]] seems to have two bugs in the AES key-init function, see [[AES_Registers#AES_key-init|here]].&lt;br /&gt;
| None&lt;br /&gt;
| BootROM issue.&lt;br /&gt;
| 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| New3DS has same boot ROM as Old3DS&lt;br /&gt;
| The New3DS has the exact same boot ROM as the Old3DS.  This means, among other things, that all the same boot ROM flaws are present.  Also, this meant that it is possible to boot Old3DS firmware on New3DS (see &amp;quot;CFG9_SYSPROT9 bit1 not set by Kernel9&amp;quot;).&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| October 2014&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| sighax: Boot9 improper validation of FIRM partition RSA signatures&lt;br /&gt;
| The [[Flash_Filesystem|FIRM partitions]] are signed with RSA-2048 using SHA-256 and PKCS #1 v1.5 padding.  Boot9, however, improperly validates the padding in three ways:&lt;br /&gt;
# Boot9 permits block type 02, meant for encrypted messages, to be used for signatures.  Only 01, for signatures, should have been permitted.  As a result, when using block type 02, a signature block is not required to have a long string of FF bytes as padding, but rather any nonzero random values suffice.&lt;br /&gt;
# Boot9 does not require that the length of the padding fill out the signature block completely.  As a result, there is considerable freedom in the layout of a signature.&lt;br /&gt;
# Boot9 fails to do bounds checking in its parsing of the DER-encoded hash algorithm type and hash value; the length values given in DER are permitted to point outside the signature block.&lt;br /&gt;
Flaw 3 allows the DER encoding to be such that boot9 believes that the signature&#039;s hash value is outside the range of the block itself, somewhere on the stack.  This can be pointed at the correct hash value it computes.  Boot9 then memcmp&#039;s the calculated hash against itself, and thinks that the hash is valid.&lt;br /&gt;
&lt;br /&gt;
As a result of the above, we estimate that one in 2&amp;lt;sup&amp;gt;43&amp;lt;/sup&amp;gt; (~8.8 trillion) random fake signatures will be considered by Boot9 to be valid.  This is well within the range of brute force, particularly with an optimized GPU implementation.  An Nvidia GTX 1080 Ti would take about one week to find a match.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| July 2015&lt;br /&gt;
| [[User:Derrek|derrek]]&lt;br /&gt;
|-&lt;br /&gt;
| Boot9 FIRM loading doesn&#039;t blacklist memory-mapped I/O&lt;br /&gt;
| [[Bootloader|Boot9]]&#039;s FIRM loading blacklists Boot9 data regions, but forgets to do other important regions, including Memory-mapped I/O. Combined with sighax, a malicious FIRM can be used to overwrite:&lt;br /&gt;
a) boot9 data-abort handler, coupled with a 4th section that tries to NDMA copy to NULL, causing a data abort&lt;br /&gt;
&lt;br /&gt;
b) boot9 IRQ handler (this has the disadvantage that you must restore the original handler, then call it manually when your payload runs)&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| 2015(?)&lt;br /&gt;
| [[User:Derrek|derrek]] (2015?), [[User:Normmatt|Normmatt]] and [[User:SciresM|SciresM]] independently (January 2017).&lt;br /&gt;
|-&lt;br /&gt;
| &amp;quot;superhax&amp;quot;: Boot9 FIRM loading blacklist check is flawed&lt;br /&gt;
| Boot9 only makes sure the &#039;&#039;&#039;start&#039;&#039;&#039; and &#039;&#039;&#039;end&#039;&#039;&#039; address of each section is not covered by a blacklisted region. Thus, it is possible to overwrite blacklisted regions (e.g. ARM9 Exception Vectors) by choosing a FIRM section range that encloses an entire blacklisted region. The vulnerable code looks like this: if(blRegions[i].start &amp;lt;= sectionStart &amp;amp;&amp;amp; blRegions[i].end &amp;gt; sectionStart &amp;lt;nowiki&amp;gt;||&amp;lt;/nowiki&amp;gt; blRegions[i].start &amp;lt;= sectionEnd &amp;amp;&amp;amp; blRegions[i].end &amp;gt; sectionEnd) return false; // failure&lt;br /&gt;
The boot9 vector table (0x08000000) contains 6 entries, each 8-bytes wide (0x30 bytes); Only 0x08000000 through 0x08000040 are blacklisted, and boot9 doesn&#039;t use the region after the vector table (this is convenient because we can put any payload we want after it and not worry about overwriting chunks of boot9 code)&lt;br /&gt;
&lt;br /&gt;
To exploit this, craft a FIRM section payload that&#039;s loaded a few bytes before 0x08000000, add padding to get to 0x08000000 and overwrite the vector table; You could overwrite the data-abort vector and craft a 4th FIRM section that causes a data-abort OR you can just overwrite the IRQ function pointer at 0x08000004 (make sure your payload replaces the original boot9 function pointer); you can point the rest of the vectors to infinite loops since they shouldn&#039;t be triggered.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| August 2015&lt;br /&gt;
| [[User:Plutoo|plutoo]], [[User:Yellows8|yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ARM9 software ==&lt;br /&gt;
&lt;br /&gt;
=== arm9loader ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Public disclosure timeframe&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| Generating the keysector console-unique keys with ITCM+Boot9&lt;br /&gt;
| [[Bootloader|Boot9]] decrypts the 0x100-byte [[OTP_Registers|OTP]] using AES-CBC with keydata stored in Boot9. If hash verification is successful, the plaintext of the first 0x90-bytes are copied into [[Memory_layout|ITCM]]. This is the &#039;&#039;exact&#039;&#039; &#039;&#039;same&#039;&#039; region hashed by arm9loader when generating the console-unique keys for decrypting the keysector, except arm9loader uses the raw encrypted OTP.&lt;br /&gt;
&lt;br /&gt;
Therefore, with the OTP keydata+IV from Boot9 you can: encrypt the 0x90-bytes from ITCM, then hash the output to get the console-unique keys for the system&#039;s keysector. This can even be done for Old3DS which doesn&#039;t have the arm9loader keysector officially.&lt;br /&gt;
&lt;br /&gt;
It&#039;s unknown why arm9loader only used the first 0x90-bytes of OTP. Using more data from OTP would&#039;ve prevented this. Fixing this would require doing exactly that, but that would also mean updating the NAND keysector(which is dangerous).&lt;br /&gt;
| See description.&lt;br /&gt;
| None&lt;br /&gt;
| &lt;br /&gt;
| 2015&lt;br /&gt;
| January 6, 2017&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| Rearrangable keys in the NAND keystore&lt;br /&gt;
| Due to the keystore being encrypted with AES-ECB, one can rearrange blocks and still have the NAND keystore decrypt in a deterministic way. &lt;br /&gt;
&lt;br /&gt;
Using 10.0 FIRM it is possible to rearrange keys such that ARM9 memory is executed. As such using existing ARM9 execution 10.0 FIRM can be written to NAND and a payload written to memory, with the payload to be executed post-K9L using an MCU reboot.&lt;br /&gt;
| arm9loaderhax given existing ARM9 code execution&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| Early 2016&lt;br /&gt;
| 27 September 2016&lt;br /&gt;
| Myria, [[User:Dark samus|dark_samus]]; mathieulh (independently); [[User:Plutooo|plutoo]] (independently) + others&lt;br /&gt;
|-&lt;br /&gt;
| Uncleared OTP hash keydata in console-unique 0x11 key-generation&lt;br /&gt;
| Kernel9Loader does not clear the [[SHA_Registers#SHA_HASH|SHA_HASH register]] after use. As a result, the data stored here as K9L hands over to Kernel9 is the hash of [[OTP_Registers|OTP data]] used to seed the [[FIRM#New_3DS_FIRM|console-unique NAND keystore decryption key]] set on keyslot 0x11.&lt;br /&gt;
&lt;br /&gt;
Retrieving this keydata and the [[Flash_Filesystem#0x12C00|NAND keystore]] of the same device allows calculating the decrypted New3DS NAND keystore (non-unique, common to all New3DS units), which contains AES normal keys, also set on keyslot 0x11, which are then used to derive all current [[AES_Registers#Keyslots|New3DS-only AES keyXs]] including the newer batch introduced in [[9.6.0-24#arm9loader|9.6.0-X]]. From there, it is trivial to perform the same key derivation in order to initialize those keys on any system version, and even on Old3DS.&lt;br /&gt;
&lt;br /&gt;
This can be performed by exploiting the &amp;quot;arm9loaderhax&amp;quot; vulnerability to obtain post-K9L code execution after an MCU reboot (the bootrom section-loading fail is not relevant here, this attack was performed without OTP data by brute-forcing keys), and using this to dump the SHA_HASH register. This attack works on any FIRM version shipping a vulnerable version of K9L, whereas OTP dumping required a boot of &amp;lt;[[3.0.0-6|3.0.0-X]].&lt;br /&gt;
&lt;br /&gt;
This attack results in obtaining the entire (0x200-bytes) NAND keystore - it was confirmed at a later date that this keystore is encrypted with the same key (by comparing the decrypted data from multiple units), and therefore using another key in this store will not remedy the issue as all keys are known (i.e. later, unused keys decrypt to the same 0x200-bytes constant with the same OTP hash). Later keys could have been encrypted differently but this is not the case. As a result of this, it is not possible for Nintendo to use K9L again in its current format for its intended purpose, though this was not news from the moment people dumped a New3DS OTP.&lt;br /&gt;
| Derivation of all New3DS keys generated via the NAND keystore (0x1B &amp;quot;Secure4&amp;quot; etc.)&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| ~April 2015, implemented in May 2015&lt;br /&gt;
| 13 January 2016&lt;br /&gt;
| [[User:WulfyStylez|WulfyStylez]], [[User:Dazzozo|Dazzozo]], [[User:Shinyquagsire23|shinyquagsire23]] (complimentary + implemented), [[User:Plutooo|plutoo]], Normmatt (discovered independently)&lt;br /&gt;
|-&lt;br /&gt;
| enhanced-arm9loaderhax&lt;br /&gt;
| See the 32c3 3ds talk.&lt;br /&gt;
Since this is a combination of a trick with the arm9-bootrom + arm9loaderhax, and since you have to manually write FIRM to the firm0/firm1 NAND partitions, this can&#039;t be completely fixed. Any system with existing ARM9 code execution and an OTP/OTP hash dump can exploit this. Additionally, by using the FIRM partition known-plaintext bug and bruteforcing the second entry in the keystore, this can currently be exploited on all New3DS systems without any other prerequisite hacks.&lt;br /&gt;
| arm9loaderhax which automatically occurs at hard-boot.&lt;br /&gt;
| See arm9loaderhax / description.&lt;br /&gt;
| See arm9loaderhax / description.&lt;br /&gt;
| Theorized around mid July, 2015. Later implemented+tested by [[User:Plutooo|plutoo]] and [[User:Derrek|derrek]].&lt;br /&gt;
| 32c3 3ds talk (December 27, 2015)&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| arm9loaderhax: Missing verification block for the 9.6 keys&lt;br /&gt;
| Starting with [[9.6.0-24|9.6.0-X]] a new set of NAND-based keys were introduced. However, no verification block was added to verify that the new key read from NAND is correct. This was technically an issue from [[9.5.0-22|9.5.0-X]] with the original sector+0 keydata, however the below is only possible with [[9.6.0-24|9.6.0-X]] since keyslots 0x15 and 0x16 are generated from different 0x11 keyXs.&lt;br /&gt;
&lt;br /&gt;
Writing an incorrect key to NAND will cause arm9loader to decrypt the ARM9 kernel as garbage and then jump to it.&lt;br /&gt;
&lt;br /&gt;
This allows an hardware-based attack where you can boot into an older exploited firmware, fill all memory with NOP sleds/jump-instructions, and then reboot into executing garbage. By automating this process with various input keydata, eventually you&#039;ll find some garbage that jumps to your code.&lt;br /&gt;
&lt;br /&gt;
This gives very early ARM9 code execution (pre-ARM9 kernel). As such, it is possible to dump RSA keyslots with this and calculate the 6.x [[Savegames#6.0.0-11_Savegame_keyY|save]], and 7.x [[NCCH]] keys. This cannot be used to recover keys initialized by arm9loader itself. This is due to it wiping the area used for its stack during NAND sector decryption and keyslot init. &lt;br /&gt;
&lt;br /&gt;
Due to FIRMs on both Old and New 3DS using the same RSA data, this can be exploited on Old3DS as well, but only if one already has the actual plaintext normalkey from New3DS NAND sector 0x96 offset-0 and has dumped the OTP area of the Old3DS.&lt;br /&gt;
| Recovery of 6.x [[Savegames#6.0.0-11_Savegame_keyY|save key]]/7.x [[NCCH]] key, access to uncleared OTP hash keydata&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| March 2015&lt;br /&gt;
| &lt;br /&gt;
| [[User:Plutooo|plutoo]]&lt;br /&gt;
|-&lt;br /&gt;
| arm9loader runs on Old3DS&lt;br /&gt;
| Despite being written only for New3DS, all of arm9loader runs fine on Old3DS.  It&#039;s not until booting Kernel9 that a New3DS FIRM partition would crash on an Old3DS.  As a result, if a bug exists in arm9loader to get control, it can be exploited on Old3DS by writing New3DS FIRM to the FIRM partitions.  Thus, arm9loaderhax works on both Old3DS and New3DS.&lt;br /&gt;
| arm9loader bugs also compromise Old3DS&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| Sometime in 2015&lt;br /&gt;
| &lt;br /&gt;
| [[User:Plutooo|plutoo]] presumably&lt;br /&gt;
|-&lt;br /&gt;
| Uncleared New3DS keyslot 0x11&lt;br /&gt;
| Originally the New3DS [[FIRM]] arm9bin loader only cleared keyslot 0x11 when it gets executed at firmlaunch. This was fixed with [[9.5.0-22|9.5.0-X]] by completely clearing keyslot 0x11 immediately after the loader finishes using keyslot 0x11.&lt;br /&gt;
This means that any ARM9 code that can execute before the loader clears the keyslot at firmlaunch(including firmlaunch-hax) can get access to the uncleared keyslot 0x11, which then allows one to generate all &amp;lt;=v9.5 New3DS keyXs which are generated by keyslot 0x11.&lt;br /&gt;
&lt;br /&gt;
Therefore, to completely fix this the loader would have to generate more keys using different keyslot 0x11 keydata. This was done with [[9.6.0-24|9.6.0-X]].&lt;br /&gt;
| New3DS keyXs generation&lt;br /&gt;
| Mostly fixed with [[9.5.0-22|9.5.0-X]], completely fixed with new keys with [[9.6.0-24|9.6.0-X]].&lt;br /&gt;
| &lt;br /&gt;
| February 3, 2015 (one day after [[9.5.0-22|9.5.0-X]] release)&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Process9 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Public disclosure timeframe&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| Leak of normal-key matching a key-scrambler key&lt;br /&gt;
| New 3DS firmware versions [[8.1.0-0 New3DS|8.1.0]] through [[9.2.0-20|9.2.0]] set the encryption key for [[Amiibo]] data using a hardcoded normal-key in Process9.  In firmware [[9.3.0-21|9.3.0]], Nintendo &amp;quot;fixed&amp;quot; this by using the key scrambler instead, by calculating the keyY value for keyslot 0x39 that results in the same normal-key, then hardcoding that keyY into Process9.&lt;br /&gt;
&lt;br /&gt;
Nintendo&#039;s fix is actually the problem: Nintendo revealed the normal-key matching an unknown keyX and a known keyY.  Combined with the key scrambler using an insecure scrambling algorithm (see &amp;quot;Hardware&amp;quot; above), the key scrambler function could be deduced.&lt;br /&gt;
| Deducing the keyX for keyslot 0x39 and the key scrambler algorithm&lt;br /&gt;
| New 3DS [[9.3.0-21|9.3.0-X]], sort of&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| Sometime in 2015 after the hardware key-generator was broken.&lt;br /&gt;
| 32c3 3ds talk (December 27, 2015)&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| Leak of normal-key matching a key-generator key&lt;br /&gt;
| During the 3DS&#039; development (June/July 2010) Nintendo added support installing encrypted content ([[CIA]]). Common-key index1 was intended to be a [[AES|hardware generated key]]. However while they added code to generate the key in hardware, they forgot to remove the normal-key for index1 (used elsewhere, likely old debug code). Nintendo later removed the normal key sometime before the first non-prototype firmware release.&lt;br /&gt;
&lt;br /&gt;
Knowing the keyY and the normal-key for common-key index1, the devkit key-generator algorithm can be deduced (see &amp;quot;Hardware&amp;quot; above). Additionally the remaining devkit common-keys can be generated once the common-key keyX is recovered.&lt;br /&gt;
&lt;br /&gt;
Note that the devkit key-generator was discovered to be the same as the retail key-generator.&lt;br /&gt;
| Deducing the keyX for keyslot 0x3D and hardware key-generator algorithm. Generate remaining devkit common-keys.&lt;br /&gt;
| pre-[[1.0.0-0|1.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| Shortly after the key-generator was revealed to be flawed at the 32c3 3ds talk&lt;br /&gt;
| January 20, 2016&lt;br /&gt;
| [[User:Jakcron|jakcron]]&lt;br /&gt;
|-&lt;br /&gt;
| Factory firmware is vulnerable to sighax&lt;br /&gt;
| During the 3DS&#039;s development, presumably boot9 was written (including the sighax vulnerability). This vulnerability is also present in factory firmware (and earlier, including 0.11). This was fixed in version 1.0.0-0.&lt;br /&gt;
| Deducing the mechanics of the sighax vulnerability in boot9 without having a dump of protected boot9. ARM9 code execution on factory/earlier firmware.&lt;br /&gt;
| [[1.0.0-0|1.0.0-X]]&lt;br /&gt;
| [[1.0.0-0|1.0.0-X]]&lt;br /&gt;
| May 9, 2017&lt;br /&gt;
| May 19, 2017&lt;br /&gt;
| [[User:SciresM|SciresM]], [[User:Myria|Myria]]&lt;br /&gt;
|-&lt;br /&gt;
| safecerthax &lt;br /&gt;
| O3DS &amp;amp; O2DS SAFE_FIRM is still vulnerable to the PXIAM:ImportCertificates flaw fixed in [[5.0.0-11]] and to SSLoth fixed in [[11.14.0-46]]. It makes it possible to spoof the official NUS update server and remotely trigger the vulnerability in SAFE_FIRM.&lt;br /&gt;
| Remote Arm9 code execution in O3DS/O2DS SAFE_FIRM&lt;br /&gt;
| None&lt;br /&gt;
| [[11.14.0-46|11.14.0-X]]&lt;br /&gt;
| 2020&lt;br /&gt;
| December 18, 2020&lt;br /&gt;
| [[User:Nba_Yoh|MrNbaYoh]]&lt;br /&gt;
|-&lt;br /&gt;
| twlhax: Corrupted SRL header leads to memory overwrite&lt;br /&gt;
| During TWL_FIRM boot, the ARM11 process TwlBg puts launcher.srl, the DSi bootloader, into FCRAM.  TWL_FIRM Process9 then parses the [http://dsibrew.org/wiki/NDS_Format SRL header] to place launcher.srl&#039;s code where DSi mode can execute it.&lt;br /&gt;
&lt;br /&gt;
DSi-mode memory is in FCRAM, but interleaved.  Each byte of DSi-mode memory also exists at some address in 3DS FCRAM space.&lt;br /&gt;
&lt;br /&gt;
Process9 does not validate the RSA signature on launcher.srl, unlike SRLs loaded from cartridge or NAND (DSiWare).  A compromised ARM11 can, in a manner similar to firmlaunchhax, send a launcher.srl with a modified SRL header.  By setting the SRL header&#039;s ARM7/ARM9 load addresses and sizes carefully, accounting for the different memory map and for DSi mode&#039;s interleaved memory, it is possible to overwrite part of Process9&#039;s stack and take control with a ROP chain.&lt;br /&gt;
&lt;br /&gt;
Fixed in 11.8.0-X by... (fill me in)&lt;br /&gt;
| ARM9 code execution (whilst still in 3DS mode)&lt;br /&gt;
| [[11.8.0-41|11.8.0-X]]&lt;br /&gt;
| [[11.8.0-41|11.8.0-X]]&lt;br /&gt;
|&lt;br /&gt;
| August 11, 2018&lt;br /&gt;
| smea&lt;br /&gt;
|-&lt;br /&gt;
| agbhax&lt;br /&gt;
| This is the same issue as twlhax above. Legacy FIRMs share the same OS code (Arm9-side OS, Arm11 kernel), and therefore, the outdated AGB_FIRM can be tricked into executing the still vulnerable PrepareArm9ForTwl function.&lt;br /&gt;
| ARM9 code execution (whilst still in 3DS mode)&lt;br /&gt;
| None&lt;br /&gt;
| [[11.14.0-46|11.14.0-X]]&lt;br /&gt;
|&lt;br /&gt;
| December 17, 2020&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| safefirmhax&lt;br /&gt;
| SAFE_MODE_FIRM is almost never updated(even when NATIVE_FIRM is updated for vuln fixes), this can be noticed by &#039;&#039;just&#039;&#039; checking 3dbrew/ninupdates title-listings.&lt;br /&gt;
&lt;br /&gt;
The fix for firmlaunch-hax was only applied to NATIVE_FIRM in [[9.5.0-22|9.5.0-X]], leaving SAFE_FIRM exploitable. With ARM11-kernel execution, one can trigger FIRM-launch in to SAFE_FIRM, do Kernel9 &amp;lt;=&amp;gt; Kernel11 sync, PXI sync and then repeat the original attack on SAFE_FIRM instead.&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| 2012-2013?&lt;br /&gt;
| Wiki: January 2, 2017&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| safefirmhax 1.1&lt;br /&gt;
| Nintendo&#039;s original safefirmhax fix was flawed -- they added a global boolean that got set to true whenever a non-sysmodule title got launched (except for a hardcoded repair title id), and panic()&#039;d if that boolean was true to prevent launching safefirm after hax was active. However, because the boolean was initially false after firmlaunch -- With ARM11-kernel execution, one could FIRM-launch into NATIVE_FIRM, and then immediately FIRM-launch again into SAFE_FIRM early in NATIVE_FIRM boot before the boolean got set to true to repeat the safehax attack.&lt;br /&gt;
&lt;br /&gt;
This was fixed by adding additional CFG9_BOOTENV checks to firmlaunch code in 11.4.&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[11.4.0-37|11.4.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| safefirmhax fix&lt;br /&gt;
| Wiki: April 10, 2017&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| ntrcardhax&lt;br /&gt;
| When reading the banner of a NTR title, Process9 relies on a hardware register to know when the banner was fully read.&lt;br /&gt;
However that register is shared between the ARM9 and the ARM11.&lt;br /&gt;
An attacker with k11 control can so make Process9 believe the banner continues forever and so trigger a buffer overflow.&lt;br /&gt;
With a custom banner for a NTR flashcart, this leads to code execution in Process9.&lt;br /&gt;
&lt;br /&gt;
This was fixed by adding bound checks on the read data.&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[10.4.0-29|10.4.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| March 2015&lt;br /&gt;
| 32c3 3ds talk (December 27, 2015)&lt;br /&gt;
| [[User:Plutooo|plutoo]]&lt;br /&gt;
|-&lt;br /&gt;
| Title downgrading via [[Application_Manager_Services|AM]]([[Application_Manager_Services_PXI|PXI]])&lt;br /&gt;
| When a title is *already* installed, Process9 will compare the installed title-version with the title-version being installed. When the one being installed is older, Process9 would return an error.&lt;br /&gt;
&lt;br /&gt;
However, this can be bypassed by just deleting the title first via the service command(s) for that: with the title removed from the [[Title_Database]], Process9 can&#039;t compare the input title-version with anything. Hence, titles can be downgraded this way.&lt;br /&gt;
&lt;br /&gt;
[[11.0.0-33|11.0.0-X]] fixed this for key system titles (MSET, Home Menu, spider, ErrDisp, SKATER, NATIVE_FIRM, and every retail system module), by checking the version of the title to install against a hard-coded list of (titleID, minimumVersionRequired) pairs.&lt;br /&gt;
| Bypassing title version check at installation, which then allows downgrading any title.&lt;br /&gt;
| [[11.0.0-33|11.0.0-X]], for key system titles.&lt;br /&gt;
| NATIVE_FIRM / AM-sysmodule [[11.0.0-33|11.0.0-X]]&lt;br /&gt;
| ?&lt;br /&gt;
| &lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
| Anti-downgrade list did not include all system titles initially&lt;br /&gt;
| The anti-downgrade list did not include legacy FIRMs until [[11.8.0-41|11.8.0-X]]. Therefore, legacy FIRMs could still be downgraded.&lt;br /&gt;
| Downgrading legacy FIRMs; allowing to exploit bugs in older legacy FIRMs (of which at least one exists, see below).&lt;br /&gt;
| [[11.8.0-33|11.8.0]]&lt;br /&gt;
| [[11.8.0-33|11.8.0]]&lt;br /&gt;
| ?&lt;br /&gt;
| Wiki: August 5, 2018&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| TWL_FIRM cmd-9 unchecked offset&lt;br /&gt;
| In [[1.0.0-0|1.0.0-X]]&#039;s TWL_FIRM, cmds 8 and 9 were not stubbed (whereas in the corresponding NATIVE_FIRM, they were).&lt;br /&gt;
Command 8 does the Process9 initialisation for NTR carts if an NTR cart is inserted (NTR, not TWL, judged by chipid).&lt;br /&gt;
&lt;br /&gt;
Command 9 takes (u32 offset_read, u32 offset_write, u32 offset_read_end), and basically just copies (offset_read_end - offset_read) bytes starting at (offset_read) of [NTR cart header in arm9mem, NTR secure area in fcram, TWL secure area in fcram], to 0x18001000 + offset_write + offset_read.&lt;br /&gt;
&lt;br /&gt;
offset_write is not checked at all, thus this leads to ARM9 code execution as long as any NTR cart, including flashcarts that would normally be blocked by TWL_FIRM, is inserted.&lt;br /&gt;
&lt;br /&gt;
In [[2.0.0-2|2.0.0-X]] TWL_FIRM, those commands were stubbed out.&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[2.0.0-2|2.0.0-X]]&lt;br /&gt;
| [[2.0.0-2|2.0.0-X]]&lt;br /&gt;
| January 2018&lt;br /&gt;
| Wiki: August 5, 2018&lt;br /&gt;
| [[User:Riley|Riley]]&lt;br /&gt;
|-&lt;br /&gt;
| FIRM launch doesn&#039;t check target FIRM version&lt;br /&gt;
| When executing a FIRM launch, Process9 doesn&#039;t validate that the target FIRM isn&#039;t an old version.  This allows booting an exploitable FIRM from a newer FIRM, if you can get the exploitable FIRM installed.  ([[11.0.0-33|11.0.0-X]] now prevents installing old versions of system titles, but this doesn&#039;t affect titles already installed.)&lt;br /&gt;
&lt;br /&gt;
This had a use after [[9.6.0-24|9.6.0-X]]: on a compromised 3DS running 9.2.0, you could install the 9.6.0 NATIVE_FIRM to FIRM0/FIRM1, but avoid putting it into the NATIVE_FIRM title.  This would boot the 9.2.0 system software but with the 9.6.0 Process9 and Kernel11.  With a user-mode exploit in a sufficiently-privileged application (e.g. mset), you could trigger a FIRM launch back to NATIVE_FIRM, which would load the 9.2.0 Process9 and Kernel11.&lt;br /&gt;
&lt;br /&gt;
9.6.0&#039;s keyslots 0x15 and 0x16 are unknown to 9.2.0, so 9.2.0 would not clear them.  You then could do firmlaunchhax against 9.2.0 to get ARM9 access with keyslots 0x15 and 0x16 set to their proper 9.6.0 values, allowing decrypting 9.6.0&#039;s encrypted titles.  Once the New3DS keystore was dumped, this became moot.&lt;br /&gt;
| Decrypting 9.6.0 NCCH files without dumping New3DS keystore&lt;br /&gt;
| None (but now moot)&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| March 2015&lt;br /&gt;
| August 12, 2018&lt;br /&gt;
| [[User:Yellows8|Yellows8]], [[User:Myria|Myria]]&lt;br /&gt;
|-&lt;br /&gt;
| FAT FS code null-deref&lt;br /&gt;
| When FSFile:Read is used with a file which is corrupted on a FAT filesystem(in particular SD), Process9 can crash. This particular crash is caused by a function returning NULL instead of an actual ptr due to an error. The caller of that function doesn&#039;t check for NULL which then triggers a read based at NULL.&lt;br /&gt;
&lt;br /&gt;
Sample &amp;quot;fsck.vfat -n -v -V &amp;lt;fat image backup&amp;gt;&amp;quot; output for the above crash:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;...&lt;br /&gt;
Starting check/repair pass.&lt;br /&gt;
&amp;lt;FilePath0&amp;gt; and&lt;br /&gt;
&amp;lt;FilePath1&amp;gt;&lt;br /&gt;
 share clusters.&lt;br /&gt;
 Truncating second to 3375104 bytes.&lt;br /&gt;
&amp;lt;FilePath1&amp;gt;&lt;br /&gt;
 File size is 2787392 bytes, cluster chain length is 16384 bytes.&lt;br /&gt;
 Truncating file to 16384 bytes.&lt;br /&gt;
Checking for unused clusters.&lt;br /&gt;
Reclaimed 1 unused cluster (16384 bytes).&lt;br /&gt;
Checking free cluster summary.&lt;br /&gt;
Free cluster summary wrong (1404490 vs. really 1404491)&lt;br /&gt;
 Auto-correcting.&lt;br /&gt;
Starting verification pass.&lt;br /&gt;
Checking for unused clusters.&lt;br /&gt;
Leaving filesystem unchanged.&amp;lt;/pre&amp;gt;&lt;br /&gt;
| Useless null-based-read&lt;br /&gt;
| None&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| July 8-9, 2015&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| RSA signature padding checks&lt;br /&gt;
| The TWL_FIRM RSA sig padding check code used for all TWL RSA sig-checks has issues, see [[FIRM|here]].&lt;br /&gt;
The main 3DS RSA padding check code(non-certificate, including NATIVE_FIRM) uses the function used with the above to extract more padding + the actual hash from the additional padding. This isn&#039;t really a problem here because there&#039;s proper padding check code which is executed prior to this.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.5.0-22|9.5.0-X]]&lt;br /&gt;
| March 2015&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[AMPXI:ValidateDSiWareSectionMAC]] [[AES_Registers|AES]] keyslot reuse&lt;br /&gt;
| When the input DSiWare section index is higher than &amp;lt;max number of DSiWare sections supported by this FIRM&amp;gt;, Process9 uses keyid 0x40 for calculating the AESMAC, which translates to keyslot 0x40. The result is that the keyslot is left at whatever was already selected before, since the AES selectkeyslot code will immediately  return when keyslot is &amp;gt;=0x40. However, actually exploiting this is difficult: the calculated AESMAC is never returned, this command just compares the calculated AESMAC with the input AESMAC(result-code depends on whether the AESMACs match). It&#039;s unknown whether a timing attack would work with this.&lt;br /&gt;
This is basically a different form of the pxips9 keyslot vuln, except with AESMAC etc.&lt;br /&gt;
| See description.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| March 15, 2015&lt;br /&gt;
| December 29, 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| pxips9 [[AES_Registers|AES]] keyslot reuse&lt;br /&gt;
| This requires access to the [[Process_Services|ps:ps]]/pxi:ps9 services. One way to get access to this would be snshax on system-version &amp;lt;=10.1.0-X(see 32c3 3ds talk).&lt;br /&gt;
When an invalid key-type value is passed to any of the PS commands, Process9 will try to select keyslot 0x40. That aesengine_setkeyslot() code will then immediately return due to the invalid keyslot value. Since that function doesn&#039;t return any errors, Process9 will just continue to do crypto with whatever AES keyslot was selected before the PS command was sent.&lt;br /&gt;
| Reusing the previously used keyslot, for crypto with PS.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| Roughly the same time(same day?) as firmlaunch-hax.&lt;br /&gt;
| December 29, 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| firmlaunch-hax: FIRM header ToCToU&lt;br /&gt;
| This can&#039;t be exploited from ARM11 userland.&lt;br /&gt;
During [[FIRM]] launch, the only FIRM header the ARM9 uses at all is stored in FCRAM, this is 0x200-bytes(the actual used FIRM RSA signature is read to the Process9 stack however). The ARM9 doesn&#039;t expect &amp;quot;anything&amp;quot; besides the ARM9 to access this data.&lt;br /&gt;
With [[9.5.0-22]] the address of this FIRM header was changed from a FCRAM address, to ARM9-only address 0x01fffc00.&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[9.5.0-22]]&lt;br /&gt;
| &lt;br /&gt;
| 2012, 3 days after [[User:Yellows8|Yellows8]] started Process9 code RE.&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| Uninitialized data output for (PXI) command replies&lt;br /&gt;
| PXI commands for various services(including some [[Filesystem_services_PXI|here]] and many others) can write uninitialized data (like from ARM registers) to the command reply. This happens with stubbed commands, but this can also occur with certain commands when returning an error.&lt;br /&gt;
Certain ARM11 service commands have this same issue as well.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.3.0-21|9.3.0-X]]&lt;br /&gt;
| ?&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[Filesystem_services_PXI|FSPXI]] OpenArchive SD permissions&lt;br /&gt;
| Process9 does not use the exheader ARM9 access-mount permission flag for SD at all.&lt;br /&gt;
This would mean ARM11-kernelmode code / fs-module itself could directly use FSPXI to access SD card without ARM9 checking for SD access, but this is rather useless since a process is usually running with SD access(Home Menu for example) anyway.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.3.0-21|9.3.0-X]]&lt;br /&gt;
| 2012&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[AMPXI:ExportDSiWare]] export path&lt;br /&gt;
| Process9 allocates memory on Process9 heap for the export path then verifies that the actual allocated size matches the input size. Then Process9 copies the input path from FCRAM to this buffer, and uses it with the Process9 FS openfile code, which use paths in the form of &amp;quot;&amp;lt;mountpoint&amp;gt;:/&amp;lt;path&amp;gt;&amp;quot;.&lt;br /&gt;
Process9 does not check the contents of this path at all before passing it to the FS code, besides writing a NUL-terminator to the end of the buffer.&lt;br /&gt;
| Exporting of DSiWare to arbitrary Process9 file-paths, such as &amp;quot;nand:/&amp;lt;path&amp;gt;&amp;quot; etc. This isn&#039;t really useful since the data which gets written can&#039;t be controlled.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.5.0-22]]&lt;br /&gt;
| April 2013&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[DSiWare_Exports]] [[CTCert]] verification&lt;br /&gt;
| Just like DSi originally did, 3DS verifies the APCert for DSiWare on SD with the CTCert also in the DSiWare .bin. On DSi this was fixed with with system-version 1.4.2 by verifying with the actual console-unique cert instead(stored in NAND), while on 3DS it&#039;s still not fixed.&lt;br /&gt;
On 3DS this is used in conjunction with seedminer to be able to decrypt &amp;amp; modify DSiWare TAD containers and inject them with exploitable DSiWare titles such as sudoku (sudokuhax) and Flipnote JPN (ugopwn)&lt;br /&gt;
| When the movable.sed keyY for the target 3DS is known and the target 3DS CTCert private-key is unknown, importing of modified DSiWare SD .bin files.&lt;br /&gt;
| None.&lt;br /&gt;
| 11.10.0-X&lt;br /&gt;
| April 2013&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| seedminer: movable.sed keyY vulnerable to brute-force&lt;br /&gt;
| Half of the movable.sed keyY&#039;s 128 bits are leaked through the [[Nandrw/sys/LocalFriendCodeSeed_B|LFCS]], which is available in userland and below. The LFCS itself also leaks almost half of the remaining bits by following the ratio: u32 keyY[3]=1/5(LFCS). The remaining keyY[3] uncertainty of about ±2000 can be greatly reduced by plotting expected error margins with several keyYs. This results in a final uncertainty of about 2^40, easily within practical brute force range of an average modern PC.&lt;br /&gt;
| Knowing the keyY of a given 3ds allows for modification of DSiWare export contents, and chained with several other public vulns, ultimately arm9 execution.&lt;br /&gt;
| None.&lt;br /&gt;
| 11.8.0-X&lt;br /&gt;
| December 2017&lt;br /&gt;
| January 2018&lt;br /&gt;
| zoogie&lt;br /&gt;
|-&lt;br /&gt;
| Improper validation of DSiWare title SRLs&lt;br /&gt;
| The 3DS does not verify if the actual SRL embedded in the title&#039;s directory matches the titleID in the TMD before launching it or importing it from an sd DSiWare export. &lt;br /&gt;
| This allows embedding older, exploitable DSiWare titles in completely different, unexploitable DSiWare titles. Since DSiWare has raw NAND RW, this can result in arm9 control through FIRM known-plaintext and sighax attacks.&lt;br /&gt;
| None.&lt;br /&gt;
| 11.10.0-X&lt;br /&gt;
| 2015?&lt;br /&gt;
| December 2016&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| DSiWare import/export functions allow TWL system titles as arguments&lt;br /&gt;
| AM ImportTwlBackup/ExportTwlBackup unnecessarily allow TWL system titles such as DS Download Play to import/export from userland and System Settings -&amp;gt; Data Management (only am:sys is needed for userland). This is difficult to abuse for dsihax injection because no TWL system title has a save file, and any import with a save included will result in FS err C8804464. However, there is at least one dsihax primary that can load a payload from a non-NAND source, and not error if it can&#039;t access its public.sav (JPN Flipnote Studio v0).&lt;br /&gt;
| When combined with other public vulns, arm9 code execution.&lt;br /&gt;
| None.&lt;br /&gt;
| 11.10.0-X&lt;br /&gt;
| May 2018&lt;br /&gt;
| Sept 2018&lt;br /&gt;
| zoogie&lt;br /&gt;
|-&lt;br /&gt;
| [[Gamecard_Services_PXI]] unchecked REG_CTRCARDCNT transfer-size&lt;br /&gt;
| The u8 REG_CTRCARDCNT transfer-size parameter for the [[Gamecard_Services_PXI]] read/write CTRCARD commands is used as an index for an array of u16 values. Before [[5.0.0-11|5.0.0-X]] this u8 value wasn&#039;t checked, thus out-of-bounds reads could be triggered(which is rather useless in this case).&lt;br /&gt;
| Out-of-bounds read for a value which gets written to a register.&lt;br /&gt;
| [[5.0.0-11|5.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| 2013?&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[PXI_Registers|PXI]] cmdbuf buffer overrun&lt;br /&gt;
| The Process9 code responsible [[PXI_Registers|PXI]] communications didn&#039;t verify the size of the incoming command before writing it to a C++ member variable. &lt;br /&gt;
| Probably ARM9 code execution&lt;br /&gt;
| [[5.0.0-11|5.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| March 2015, original timeframe if any unknown&lt;br /&gt;
| &lt;br /&gt;
| [[User:Plutooo|plutoo]]/[[User:Yellows8|Yellows8]]/maybe others(?)&lt;br /&gt;
|-&lt;br /&gt;
| [[Application_Manager_Services_PXI|PXIAM]]:ImportCertificates (See also [[Application_Manager_Services|this]])&lt;br /&gt;
| When handling this command, Process9 allocates a 0x2800-byte heap buffer, then copies the 4 FCRAM input buffers to this heap buffer without checking the sizes at all(only the buffers with non-zero sizes are copied). Starting with [[5.0.0-11|5.0.0-X]], the total combined size of the input data must be &amp;lt;=0x2800.&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[5.0.0-11|5.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| May 2013&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[Process_Services_PXI|PS RSA]] commands buffer overflows&lt;br /&gt;
| pxips9 cmd1(not accessible via ps:ps) and VerifyRsaSha256: unchecked copy to a buffer in Process9&#039;s .bss, from the input FCRAM buffer. The buffer is located before the pxi cmdhandler threads&#039; stacks. SignRsaSha256 also has a buf overflow, but this isn&#039;t exploitable.&lt;br /&gt;
The buffer for this is the buffer for the signature data. With v5.0, the signature buffer was moved to stack, with a check for the signature data size. When the signature data size is too large, Process9 uses [[SVC|svcBreak]].&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[5.0.0-11|5.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[PXI_Registers|PXI]] pxi_id bad check&lt;br /&gt;
| The Process9 code responsible for [[PXI_Registers|PXI]] communications read pxi_id as a signed char. There were two flaws:&lt;br /&gt;
* They used it as index to a lookup-table without checking the value at all.&lt;br /&gt;
* Another function verified that pxi_id &amp;lt; 7, allowing negative values to pass the check. This would also cause an out-of-range table-lookup.&lt;br /&gt;
| Maybe ARM9 code execution&lt;br /&gt;
| [[3.0.0-5|3.0.0-5]]&lt;br /&gt;
|&lt;br /&gt;
| March 2015, originally 2012 for the first issue at least&lt;br /&gt;
| &lt;br /&gt;
| [[User:Plutooo|plutoo]], [[User:Yellows8|Yellows8]], maybe others(?)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Kernel9 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[CONFIG Registers#CFG9_SYSPROT9|CFG9_SYSPROT9]] bit1 not set by Kernel9&lt;br /&gt;
| Old versions of Kernel9 never set bit1 of [[CONFIG Registers#CFG9_SYSPROT9|CFG9_SYSPROT9]]. This leaves the [[OTP Registers|0x10012000]]-region unprotected (this region should be locked early during boot!). Since it&#039;s never locked, you can dump it once you get ARM9 code execution.&lt;br /&gt;
&lt;br /&gt;
From [[3.0.0-5|3.0.0-X]] this was fixed by setting the bit in Kernel9 after poking some registers in that region. On New3DS arm9loader sets this bit instead of Kernel9, which is exploitable through a hardware + software vulnerability (see arm9loaderhax / description).&lt;br /&gt;
&lt;br /&gt;
This flaw resurged when it gained a new practical use: retrieving the OTP data for a New3DS console in order to decrypt the key data used in arm9loader (see enhanced-arm9loaderhax / description). This was performed by downgrading to a vulnerable system version. By accounting for differences in CTR-NAND crypto (0x05 -&amp;gt; 0x04, see partition encryption types [[Flash_Filesystem#NAND_structure|here]]) and using an Old3DS [[NCSD#NCSD_header|NCSD Header]], it is possible to boot a New3DS using Old3DS firmware 1.0-2.x to retrieve the required OTP data using this flaw.&lt;br /&gt;
| Dumping the [[OTP Registers|OTP]] area.&lt;br /&gt;
Decrypting New3DS sector 0x96 keyblock.&lt;br /&gt;
| [[3.0.0-5|3.0.0-X]]&lt;br /&gt;
|&lt;br /&gt;
| February 2015&lt;br /&gt;
| [[User:Plutooo|plutoo]], Normmatt independently&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ARM11 software ==&lt;br /&gt;
=== Kernel11 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcUnbindInterrupt]] double free when irqId = 15&lt;br /&gt;
| svcBindInterrupt and svcUnbindInterrupt give special treatment to irqId 15 (FIQ helper): the access control list is bypassed and the provided KInterruptEvent (event or semaphore, via handle) is stored inside a singleton static object after having its refcount increased by 1.&lt;br /&gt;
&lt;br /&gt;
svcUnbindInterrupt assumes that the user-provided handle is what is stored in the singleton and will decref the user-provided KInterruptEvent twice, causing a use-after-free if the attacker didn&#039;t actually provide an handle to the same event or semaphore.&lt;br /&gt;
&lt;br /&gt;
This was &amp;quot;fixed&amp;quot; on [[11.14.0-46|11.14.0-X]] by preventing irqId 15 to be bound on retail units altogether (in both functions).&lt;br /&gt;
| Arm11 kernel code execution&lt;br /&gt;
| [[11.14.0-46|11.14.0-X]] (only on retail units)&lt;br /&gt;
| [[11.14.0-46|11.14.0-X]]&lt;br /&gt;
| 2019&lt;br /&gt;
| [[User:TuxSH|TuxSH]], maybe others&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcKernelSetState]] op=3 could map the NULL page&lt;br /&gt;
| svcKernelSetState op=3 param1=1 maps the firmlaunch parameters page to the user-specified VA.&lt;br /&gt;
&lt;br /&gt;
It had previously no check, allowing the attacker to map data at VA 0.&lt;br /&gt;
&lt;br /&gt;
Starting from [[11.14.0-46|11.14.0-X]], the VA must be in the standard 0x10000000-0x14000000 address range.&lt;br /&gt;
| Mapping the NULL page (as RW) to leverage other kernel vulnerabilities&lt;br /&gt;
| [[11.14.0-46|11.14.0-X]]&lt;br /&gt;
| [[11.14.0-46|11.14.0-X]]&lt;br /&gt;
| 2019&lt;br /&gt;
| [[User:TuxSH|TuxSH]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcMapProcessMemory]] can map the NULL page&lt;br /&gt;
| svcMapProcessMemory&#039;s destination VA is unchecked.&lt;br /&gt;
&lt;br /&gt;
By passing a big enough &amp;quot;size&amp;quot; parameter, an attacker can map chunks of data at VA 0 in the destination (caller) process.&lt;br /&gt;
| Mapping the NULL page (as RW) to leverage other kernel vulnerabilities&lt;br /&gt;
| None&lt;br /&gt;
| [[11.14.0-46|11.14.0-X]]&lt;br /&gt;
| 2020&lt;br /&gt;
| [[User:TuxSH|TuxSH]]&lt;br /&gt;
|-&lt;br /&gt;
| Resource limit use-after-free&lt;br /&gt;
| When assigning a KResourceLimit to a KProcess, the reslimit&#039;s refcounter doesn&#039;t get incremented. This essentially means all KResourceLimit get freed if pm gets somehow terminated.&lt;br /&gt;
&lt;br /&gt;
It turns out it is possible to ask pm (via ns:s or pm:app) to terminate itself along all other KIPs simply by passing TID 0004000100001000.&lt;br /&gt;
&lt;br /&gt;
Calling [[SVC|svcGetResourceLimit]] afterwards triggers a use-after-free. This is rather difficult to exploit, however: there is one slot left in the reslimit slabheap. An attacker either has to map the NULL page as R(W)X (svcControlProcessMemory vuln fixed on [[11.8.0-41|11.8.0-X]]), or use one of the map-null exploits above while having access to svcCreateResourceLimit (with the only one that is easy enough to use in that context having been fixed on [[11.14.0-46|11.14.0-X]], anyway).&lt;br /&gt;
| Arm11 kernel code execution&lt;br /&gt;
| None (although near impossible to exploit on [[11.14.0-46|11.14.0-X]])&lt;br /&gt;
| [[11.14.0-46|11.14.0-X]]&lt;br /&gt;
| 2020&lt;br /&gt;
| [[User:TuxSH|TuxSH]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcSetProcessIdealProcessor]] reference count overflow and therefore use-after-free.&lt;br /&gt;
| The SVC receive two arguments: handle and idealprocessor. The handle is used to get the KProcess object and the KProcess-&amp;gt;refCnt gets incremented,later the function check if the KProcess-&amp;gt;mem_type != BASE and if yes, it checks for idealprocessor == 2 or idealprocessor != 3. The problem here is that if you pass the idealprocessor = 3 it won&#039;t meet any condition and return the error 0xD9001BEA without decrement the reference count. &lt;br /&gt;
It can be abused to overflow the KProcess reference count that will lead to an Use-after-free. &lt;br /&gt;
| Before [[11.2.0-35|11.2.0-X]]: reference count overflow and therefore use-after-free.&lt;br /&gt;
| &lt;br /&gt;
| [[11.6.0-39|11.6.0-X]]&lt;br /&gt;
| November 2, 2017&lt;br /&gt;
| [[User:st4rk|st4rk]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcGetThreadList]] process reference leak&lt;br /&gt;
| When given a valid process handle (including &amp;lt;code&amp;gt;0xFFFF8001&amp;lt;/code&amp;gt;), svcGetThreadList forgets to decrement the reference count of the underlying [[KProcess]] instance, after having finished using it.&lt;br /&gt;
| Before [[11.2.0-35|11.2.0-X]]: reference count overflow and therefore use-after-free, but this UAF was most likely not exploitable&lt;br /&gt;
| &lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| April 3, 2017&lt;br /&gt;
| [[User:TuxSH|TuxSH]]&lt;br /&gt;
|-&lt;br /&gt;
| kernelhax via gspwn&lt;br /&gt;
| Originally the kernel didn&#039;t initialize [[CONFIG11_Registers#CFG11_GPUPROT|CFG11_GPUPROT]]. Since it&#039;s 0 at hard-boot, this allowed the GPU to access the entire FCRAM + AXIWRAM.&lt;br /&gt;
| Entire FCRAM+AXIWRAM R/W.&lt;br /&gt;
| [[3.0.0-5|3.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| February 7, 2017&lt;br /&gt;
| [[User:Plutooo|plutoo]], [[User:Yellows8|Yellows8]] partly&lt;br /&gt;
|-&lt;br /&gt;
| fasthax&lt;br /&gt;
| When a KTimer is created in pulse mode, the kernel calls a virtual function to reset the timer each time it pulses. The scheduler is locked for that core to avoid race conditions, but another core can call CloseHandle on the timer and free it, leading to a UAF vtable call.&lt;br /&gt;
| See description.&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| May 2016&lt;br /&gt;
| nedwill&lt;br /&gt;
|-&lt;br /&gt;
| ipctakeover&lt;br /&gt;
| When sending cmdreplies, it does not validate that the src_addr and src_size match the equivalent dst_addr and dst_size. With a modified addr/size specified in a cmdreply for an output buffer, the data-copy for the first/last pages could be used to overwrite data outside of the buffer specified by the original process.&lt;br /&gt;
&lt;br /&gt;
Used by ctr-httpwn as of v1.2, for &amp;quot;ipctakeover/bosshaxx&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This can be used to takeover processes where the process is using your service session. Like HTTPC -&amp;gt; BOSS, for bosshaxx above. NIM takeover can be done too(actual stack buffer overflow can trigger), etc.&lt;br /&gt;
| See description.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| November 26, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| Using IPC input buffers as output buffers&lt;br /&gt;
| When sending cmdreplies, it does not validate that the cmdreply descriptor type matches the equivalent cmdreq descriptor type. This could be used by an exploited sysmodule to use what was intended as an input-buffer as an output-buffer, and also combine other IPC vuln(s) with this.&lt;br /&gt;
&lt;br /&gt;
Used by ctr-httpwn as of v1.2, for &amp;quot;ipctakeover/bosshaxx&amp;quot;.&lt;br /&gt;
| See description.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| November 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
|  [[SVC]] table too small&lt;br /&gt;
|  The table of function pointers for SVC&#039;s only contains entries up to 0x7D, but the biggest allowed SVC for the table is 0x7F. Thus, executing SVC7E or SVC7F would make the SVC-handler read after the buffer, and interpret some ARM instructions as function pointers.&lt;br /&gt;
&lt;br /&gt;
However, this would require patching the kernel .text or modifying SVC-access-control. Even if you could get these to execute, they would still jump to memory that isn&#039;t mapped as executable.&lt;br /&gt;
| &lt;br /&gt;
|  None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| 2012&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
|  [[SVC|svcBackdoor (0x7B)]]&lt;br /&gt;
|  This backdoor allows executing SVC-mode code at the user-specified code-address. This is used by Process9, using this on the ARM11 (with NATIVE_FIRM) required patching the kernel .text or modifying SVC-access-control.&lt;br /&gt;
| See description&lt;br /&gt;
| [[11.0.0-33|11.0.0-X]] (deleted)&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| veryslowpidhax&lt;br /&gt;
| &#039;&#039;&#039;This is completely different from the kernelmode-code-execution vuln described in the below separate entry.&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
When updating the kernel global PID counter under [[SVC|svcCreateProcess]] the kernel does not check for wraparound to 0x0(the PID for the very first process). This only matters because [[Services|SM-module]] allows processes with PID value less than &amp;lt;total ARM11 FIRM modules&amp;gt; to access &#039;&#039;all&#039;&#039; services, without checking exheader service-access-control; and because Kernel11 checks for the PID to be 1 (loader) to use the input mem-region value on ControlMemory. This alone does not affect access the [[SVC|SVCs]] access table at all.&lt;br /&gt;
&lt;br /&gt;
Inlined ldrex+strex code is used for updating the above counter. [[11.2.0-35|11.2.0-X]] had changes for similar code, but it was only for dedicated ldrex+strex functions(mainly for kernel objects) and hence this PID code was not affected.&lt;br /&gt;
&lt;br /&gt;
With launching+terminating a sysmodule repeatedly with this via ns:s, it would take weeks to finish(if not at least about a month?).&lt;br /&gt;
| Access to all [[Services_API|services]], ControlMemory on any given mem-region.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| 2012 maybe?&lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
|  slowhax/waithax&lt;br /&gt;
|  svcWaitSynchronizationN does not decrement the references to valid handles in an array before returning an error when it encounters an invalid handle. This allows one to (slowly) overflow the reference count for a handle object to zero.&lt;br /&gt;
| ARM11 kernel-mode code execution&lt;br /&gt;
| [[11.2.0-35|11.2.0-X]]&lt;br /&gt;
| [[11.2.0-35|11.2.0-X]]&lt;br /&gt;
| 2016&lt;br /&gt;
| nedwill, [[User:Derrek|derrek]]&lt;br /&gt;
|-&lt;br /&gt;
| [[Memory_layout#ARM11_Detailed_virtual_memory_map|0xEFF00000]] / 0xDFF00000 ARM11 kernel virtual-memory&lt;br /&gt;
| The ARM11 kernel-mode 0xEFF00000/0xDFF00000 virtual-memory(size 0x100000) is mapped to phys-mem 0x1FF00000(entire DSP-mem + entire AXIWRAM), with permissions RW-. This is used during ARM11 kernel startup for loading the FIRM-modules from the FIRM section located in DSP-mem, this never seems to be used after that, however. This is never unmapped either.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[11.3.0-36|11.3.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| memchunkhax2.1&lt;br /&gt;
| Nintendo&#039;s fix for memchunkhax2 in [[10.4.0-29|10.4.0-X]] did not fix the GPU case: one may cause the requisite ToCToU race using gspwn, bypassing the new validation.&lt;br /&gt;
derrek&#039;s original 32c3 presentation for memchunkhax2 commented that a GPU-based attack was possible, but would be difficult.  However, memchunkhax2.1 showed that it was possible to do fairly reliably.&lt;br /&gt;
| ARM11 kernel code execution&lt;br /&gt;
| [[11.0.0-33|11.0.0-X]], via the new [[Memory_Management#MemoryBlockHeader|memchunkhdr]] MAC which prevents modifying memchunkhdr data with DMA.&lt;br /&gt;
| [[11.0.0-33|11.0.0-X]]&lt;br /&gt;
|&lt;br /&gt;
| [[User:Derrek|derrek]], aliaspider&lt;br /&gt;
|-&lt;br /&gt;
| memchunkhax2&lt;br /&gt;
| When allocating a block of memory, the &amp;quot;next&amp;quot; pointer of the [[Memory_Management#MemoryBlockHeader|memchunkhdr]] is accessed without being checked after being mapped to userland.&lt;br /&gt;
This allows a race condition, where the process can change the next pointer just before it&#039;s accessed. By pointing the next pointer to a crafted memchunckhdr in the kernel SlabHeap, some of the SlabHeap is allocated to the calling process, allowing to change vtables of kernel objects. &lt;br /&gt;
| ARM11 kernel code execution&lt;br /&gt;
| [[10.4.0-29|10.4.0-X]] (partially, see memchunkhax2.1)&lt;br /&gt;
| [[10.4.0-29|10.4.0-X]]&lt;br /&gt;
|&lt;br /&gt;
| [[User:Derrek|derrek]]&lt;br /&gt;
|-&lt;br /&gt;
| heaphax&lt;br /&gt;
| Can change the size of free memchunk structures stored in FCRAM using DMA, which leads to the ability to allocate memory chunks over already-allocated memory. This can be used in the SYSTEM region to allocate RW memory over any part of the NS system module, which is enough to take it over.&lt;br /&gt;
| Code execution with access to all of NS&#039;s privileges. (including downgrading) Code execution within any applet.&lt;br /&gt;
| [[11.0.0-33|11.0.0-X]], via the new [[Memory_Management#MemoryBlockHeader|memchunkhdr]] MAC which prevents modifying memchunkhdr data with DMA.&lt;br /&gt;
| [[11.0.0-33|11.0.0-X]]&lt;br /&gt;
| April 2015 ?&lt;br /&gt;
| smea&lt;br /&gt;
|-&lt;br /&gt;
| snshax&lt;br /&gt;
| Can force creation of Safe NS process into gspwn-able memory, allowing for takeover.&lt;br /&gt;
| Code execution with access to all of NS&#039;s privileges. (including downgrading)&lt;br /&gt;
| [[10.1.0-27|10.1.0-X]]&lt;br /&gt;
| [[10.1.0-27|10.1.0-X]]&lt;br /&gt;
| April 2015 ?&lt;br /&gt;
| smea&lt;br /&gt;
|-&lt;br /&gt;
|  AffinityMask/processorid validation&lt;br /&gt;
|  With [[10.0.0-27|10.0.0-X]] the following functions were updated: svcGetThreadAffinityMask, svcGetProcessAffinityMask, svcSetProcessAffinityMask, and svcCreateThread. The code changes for all but svcCreateThread are identical.&lt;br /&gt;
The original code with the first 3 did the following: &lt;br /&gt;
* if(u32_processorcount &amp;gt; ~0x80000001)return 0xe0e01bfd;&lt;br /&gt;
* if(s32_processorcount &amp;gt; &amp;lt;total_cores&amp;gt;)return 0xd8e007fd;&lt;br /&gt;
The following code replaced the above:&lt;br /&gt;
* if(u32_processorcount &amp;gt;= &amp;lt;total_cores+1&amp;gt;)return 0xd8e007fd;&lt;br /&gt;
In theory the latter should catch everything that the former did, so it&#039;s unknown if this was really a security issue.&lt;br /&gt;
&lt;br /&gt;
The svcCreateThread changes with [[10.0.0-27|10.0.0-X]] definitely did fix a security issue.&lt;br /&gt;
* Original code: &amp;quot;if(s32_processorid &amp;gt; &amp;lt;total_cores&amp;gt;)return 0xd8e007fd;&amp;quot;&lt;br /&gt;
* New code: &amp;quot;if(s32_processorid &amp;gt;= &amp;lt;total_cores&amp;gt; || s32_processorid &amp;lt;= -4)return 0xd8e007fd;&amp;quot;&lt;br /&gt;
This fixed an off-by-one issue: if one would use processorid=total_cores, which isn&#039;t actually a valid value, svcCreateThread would accept that value on &amp;lt;[[10.0.0-27|10.0.0-X]]. This results in data being written out-of-bounds(baseaddr = arrayaddr + entrysize*processorid), which has the following result:&lt;br /&gt;
* Old3DS: Useless kernel-mode crash due to accessing unmapped memory.&lt;br /&gt;
* New3DS: uncontrolled data write into a kernel-mode L1 MMU-table. This isn&#039;t really useful: the data can&#039;t be controlled, and the data which gets overwritten is all-zero anyway(this isn&#039;t anywhere near MMU L1 entries for actually mapped memory).&lt;br /&gt;
The previous version also allowed large negative s32_processorid values(negative processorid values are special values not actual procids), but it appears using values like that won&#039;t actually do anything(meaning no crash) besides the thread not running / thread not running for a while(besides triggering a kernelpanic with certain s32_processorid value(s)).&lt;br /&gt;
| Nothing useful&lt;br /&gt;
|  [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| svcCreateThread issue: May 31, 2015. The rest: September 8, 2015, via v9.6-&amp;gt;v10.0 ARM11-kernel code-diff.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| memchunkhax&lt;br /&gt;
| The kernel originally did not validate the data stored in the FCRAM kernel heap [[Memchunkhdr|memchunk-headers]] for free-memory at all. Exploiting this requires raw R/W access to these memchunk-headers, like physical-memory access with gspwn.&lt;br /&gt;
&lt;br /&gt;
There are &#039;&#039;multiple&#039;&#039; ways to exploit this, but the end-result for most of these is the same: overwrite code in AXIWRAM via the 0xEFF00000/0xDFF00000 kernel virtual-memory mapping.&lt;br /&gt;
&lt;br /&gt;
This was fixed in [[9.3.0-21|9.3.0-X]] by checking that the memchunk(including size, next, and prev ptrs) is located within the currently used heap memory. The kernel may also check that the next/prev ptrs are valid compared to other memchunk-headers basically. When any of these checks fail, kernelpanic() is called.&lt;br /&gt;
| When combined with other flaws: ARM11-kernelmode code execution&lt;br /&gt;
| [[9.3.0-21|9.3.0-21]]&lt;br /&gt;
| &lt;br /&gt;
| February 2014&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| Multiple [[KLinkedListNode|KLinkedListNode]] SlabHeap use after free bugs&lt;br /&gt;
| The ARM11-kernel did access the &#039;key&#039; field of [[KLinkedListNode|KLinkedListNode]] objects, which are located on the SlabHeap, after freeing them. Thus, triggering an allocation of a new [[KLinkedListNode|KLinkedListNode]] object at the right time could result in a type-confusion. Pseudo-code:&lt;br /&gt;
SlabHeap_free(KLinkedListNode);&lt;br /&gt;
KObject *obj = KLinkedListNode-&amp;gt;key;  // the object there might have changed!&lt;br /&gt;
This bug appeared all over the place.&lt;br /&gt;
| ARM11-kernelmode code exec maybe&lt;br /&gt;
| [[8.0.0-18|8.0.0-18]]&lt;br /&gt;
| &lt;br /&gt;
| April 2015&lt;br /&gt;
| [[User:Derrek|derrek]]&lt;br /&gt;
|-&lt;br /&gt;
| PXI [[RPC_Command_Structure|Command]] input/output buffer permissions&lt;br /&gt;
| Originally the ARM11-kernel didn&#039;t check permissions for PXI input/output buffers for commands. Starting with [[6.0.0-11|6.0.0]] PXI input/output buffers must have RW permissions, otherwise kernelpanic is triggered.&lt;br /&gt;
| &lt;br /&gt;
| [[6.0.0-11|6.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcStartInterProcessDma]]&lt;br /&gt;
| For svcStartInterProcessDma, the kernel code had the following flaws:&lt;br /&gt;
&lt;br /&gt;
* Originally the ARM11-kernel read the input DmaConfig structure directly in kernel-mode(ldr(b/h) instructions), without checking whether the DmaConfig address is readable under userland. This was fixed by copying that structure to the SVC-mode stack, using the ldrbt instruction.&lt;br /&gt;
&lt;br /&gt;
* Integer overflows for srcaddr+size and dstaddr+size are now checked(with [[6.0.0-11]]), which were not checked before.&lt;br /&gt;
&lt;br /&gt;
* The kernel now also checks whether the srcaddr/dstaddr (+size) is within userland memory (0x20000000), the kernel now (with [[6.0.0-11]]) returns an error when the address is beyond userland memory. Using an address &amp;gt;=0x20000000 would result in the kernel reading from the process L1 MMU table, beyond the memory allocated for that MMU table(for vaddr-&amp;gt;physaddr conversion). &lt;br /&gt;
| &lt;br /&gt;
| [[6.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| DmaConfig issue: unknown. The rest: 2014&lt;br /&gt;
| [[User:Plutooo|plutoo]], [[User:Yellows8|Yellows8]] independently&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcControlMemory]] Parameter checks&lt;br /&gt;
| For svcControlMemory the parameter check had these two flaws:&lt;br /&gt;
&lt;br /&gt;
* The allowed range for addr0, addr1, size parameters depends on which MemoryOperation is being specified. The limitation for GSP heap was only checked if op=(u32)0x10003. By setting a random bit in op that has no meaning (like bit17?), op would instead be (u32)0x30003, and the range-check would be less strict and not accurate. However, the kernel doesn&#039;t actually use the input address for LINEAR memory-mapping at all besides the range-checks, so this isn&#039;t actually useful. This was fixed in the kernel by just checking for the LINEAR bit, instead of comparing the entire MemoryOperation value with 0x10003.&lt;br /&gt;
&lt;br /&gt;
* Integer overflows on (addr0+size) are now checked that previously weren&#039;t (this also applies to most other address checks elsewhere in the kernel).&lt;br /&gt;
&lt;br /&gt;
| &lt;br /&gt;
| [[5.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| [[User:Plutooo|plutoo]]&lt;br /&gt;
|-&lt;br /&gt;
| [[RPC_Command_Structure|Command]] request/response buffer overflow&lt;br /&gt;
| Originally the kernel did not check the word-values from the command-header. Starting with [[5.0.0-11]], the kernel will trigger a kernelpanic() when the total word-size of the entire command(including the cmd-header) is larger than 0x40-words (0x100-bytes). This allows overwriting threadlocalstorage+0x180 in the destination thread. However, since the data written there would be translate parameters (such as header-words + buffer addresses), exploiting this would likely be very difficult, if possible at all.&lt;br /&gt;
&lt;br /&gt;
If the two words at threadlocalstorage+0x180 could be overwritten with controlled data this way, one could then use a command with a buffer-header of &amp;lt;nowiki&amp;gt;((size&amp;lt;&amp;lt;14) | 2)&amp;lt;/nowiki&amp;gt; to write arbitrary memory to any RW userland memory in the destination process.&lt;br /&gt;
| &lt;br /&gt;
| [[5.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| v4.1 FIRM -&amp;gt; v5.0 code diff&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|SVC stack allocation overflows]]&lt;br /&gt;
| &lt;br /&gt;
* Syscalls that allocate a variable-length array on stack, only checked bit31 before multiplying by 4/16 (when calculating how much memory to allocate). If a large integer was passed as input to one of these syscalls, an integer overflow would occur, and too little memory would have been allocated on stack resulting in a buffer overrun. &lt;br /&gt;
* The alignment (size+7)&amp;amp;~7 calculation before allocation was not checked for integer overflow.&lt;br /&gt;
&lt;br /&gt;
This might allow for ARM11 kernel code-execution.&lt;br /&gt;
&lt;br /&gt;
(Applies to svcSetResourceLimitValues, svcGetThreadList, svcGetProcessList, svcReplyAndReceive, svcWaitSynchronizationN.)&lt;br /&gt;
| &lt;br /&gt;
| [[5.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| v4.1 FIRM -&amp;gt; v5.0 code diff&lt;br /&gt;
| [[User:Plutooo|plutoo]], [[User:Yellows8|Yellows8]] complementary&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcControlMemory]] MemoryOperation MAP memory-permissions&lt;br /&gt;
| svcControlMemory with MemoryOperation=MAP allows mapping the already-mapped process virtual-mem at addr1, to addr0. The lowest address permitted for addr1 is 0x00100000. Originally the ARM11 kernel didn&#039;t check memory permissions for addr1. Therefore .text as addr1 could be mapped elsewhere as RW- memory, which allowed ARM11 userland code-execution.&lt;br /&gt;
| &lt;br /&gt;
| [[4.1.0-8]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[RPC_Command_Structure|Command]] input/output buffer permissions&lt;br /&gt;
| Originally the ARM11 kernel didn&#039;t check memory permissions for the input/output buffers for commands. Starting with [[4.0.0-7]] the ARM11 kernel will trigger a kernelpanic() if the input/output buffers don&#039;t have the required memory permissions. For example, this allowed a FSUSER file-read to .text, which therefore allowed ARM11-userland code execution.&lt;br /&gt;
| &lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcReadProcessMemory/svcWriteProcessMemory memory]] permissions&lt;br /&gt;
| Originally the kernel only checked the first page(0x1000-bytes) of the src/dst buffers, for svcReadProcessMemory and svcWriteProcessMemory. There is no known retail processes which have access to these SVCs.&lt;br /&gt;
| &lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| &lt;br /&gt;
| 2012?&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== [[FIRM]] Sysmodules ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[Services|&amp;quot;srv:pm&amp;quot;]] process registration&lt;br /&gt;
| Originally any process had access to the port &amp;quot;srv:pm&amp;quot;. The PID&#039;s used for the (un)registration commands are not checked either. This allowed any process to re-register itself with &amp;quot;srv:pm&amp;quot;, and therefore allowed the process to give itself access to any service, bypassing the exheader service-access-control list.&lt;br /&gt;
&lt;br /&gt;
This was fixed in [[7.0.0-13]]: starting with [[7.0.0-13]] &amp;quot;srv:pm&amp;quot; is now a service instead of a globally accessible port. Only processes with PID&#039;s less than 6 (in other words: fs, ldr, sm, pm, pxi modules) have access to it. With [[7.0.0-13]] there can only be one session for &amp;quot;srv:pm&amp;quot; open at a time(this is used by pm module), svcBreak will be executed if more sessions are opened by the processes which can access this.&lt;br /&gt;
&lt;br /&gt;
This flaw was needed for exploiting the &amp;lt;=v4.x Process9 PXI vulnerabilities from ARM11 userland ROP, since most applications don&#039;t have access to those service(s).&lt;br /&gt;
| Access to arbitrary services&lt;br /&gt;
| [[7.0.0-13]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| FSDIR null-deref&lt;br /&gt;
| [[Filesystem_services|FS]]-module may crash in some cases when handling directory reading. The trigger seems to be due to using [[FSDir:Close]] without closing the dir-handle afterwards?(Perhaps this is caused by out-of-memory?) This seems to be useless since it&#039;s just a null-deref.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| May 19(?)-20, 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| Useless [[SM]] off-by-one write&lt;br /&gt;
| After accepting a new session, [[SM]] writes a (handler ID (0 for srv: sessions (max. 64), 1 for the srv:pm one), pointer to session context structure in BSS) pair in a global array. However that array is only 64-entry-big instead of 65 (as it ought to be), and no bound check is done in that regard.&lt;br /&gt;
&lt;br /&gt;
Unfortunately, as of [[11.4.0-37]], the overwritten fields are totally unused after their initialization by &amp;lt;code&amp;gt;__libc_init_array&amp;lt;/code&amp;gt;.&lt;br /&gt;
| Not currently exploitable&lt;br /&gt;
| None&lt;br /&gt;
| [[11.4.0-37]]&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| smpwn&lt;br /&gt;
| When registering a new service (or &amp;quot;port&amp;quot;), no bound checks are done on the service table. One can simply call RegisterPort repeatedly to overflow that table: it will overflow into the command replay structure.&lt;br /&gt;
&lt;br /&gt;
Combined with a other minor bugs in the sysmodule, it is possible to take over [[SM]] with this nevertheless difficult-to-exploit vulnerability.&lt;br /&gt;
| Code execution under [[SM]], etc.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.14.0-46]]&lt;br /&gt;
| July 2017&lt;br /&gt;
| [[User:TuxSH|TuxSH]] (independently), presumably ichfly before &lt;br /&gt;
|-&lt;br /&gt;
| PXI cmdbuf buffer overrun &lt;br /&gt;
| Like its Arm9 counterpart, before version [[5.0.0-11|5.0.0-X]], the PXI system module did not check the command sizes. This makes it possible to get ROP under the PXI sysmodule from a pwned Process9.&lt;br /&gt;
safecerthax uses it to takeover the Arm11 processor after directly getting remote code execution on the Arm9 side. Though, is useless in classic Arm11 -&amp;gt; Arm9 chains.&lt;br /&gt;
| ROP under [[PXI_Services|PXI]]&lt;br /&gt;
| probably [[5.0.0-11|5.0.0-X]]&lt;br /&gt;
| [[11.14.0-46]]&lt;br /&gt;
| &lt;br /&gt;
| Everyone&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Standalone Sysmodules ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in system-module system-version&lt;br /&gt;
!  Last system-module system-version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Timeframe this was added to wiki&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[CSND_Services|CSND]] sysmodule crash due to out of bounds parameters.&lt;br /&gt;
| The CSND command [[CSND:PlaySoundDirectly|PlaySoundDirectly (0x00040080)]] takes a channel ID as the first parameter. Any value outside the range [0-3] makes the system module become unstable or crash due to an out of bounds memory read. &lt;br /&gt;
| Out of bounds memory read, probably not exploitable. More research needed.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.14.0-46]]&lt;br /&gt;
| January 2021&lt;br /&gt;
| January 22, 2021&lt;br /&gt;
| [[User:PabloMK7|PabloMK7]]&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
| SSLoth: [[SSL_Services|SSL]] sysmodule improper certificate verification&lt;br /&gt;
| Initially, the SSL sysmodule missed the R_VERIFY_RES_SIGNATURE entry in the &amp;quot;resource list&amp;quot; provided to the RSA BSAFE library. Consequently, it did not check signatures when validating certificate chains. &lt;br /&gt;
| Forge fake certificates, spoof official servers and perform MitM attacks on SSL/TLS connections.&lt;br /&gt;
| [[11.14.0-46]]&lt;br /&gt;
| [[11.14.0-46]]&lt;br /&gt;
| 2020&lt;br /&gt;
| December 18, 2020&lt;br /&gt;
| [[User:Nba_Yoh|MrNbaYoh]], shutterbug2000 (independently)&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
| [[CECD_Services|CECD:ndm]] SetNZoneMacFilter (cmd8) stack smashing&lt;br /&gt;
| The length of the mac filter is not checked before being copied to a fixed-size buffer on stack.&lt;br /&gt;
| ROP under [[CECD_Services|CECD]] sysmodule&lt;br /&gt;
| None&lt;br /&gt;
| [[11.13.0-45]]&lt;br /&gt;
| 2020&lt;br /&gt;
| July 20, 2020&lt;br /&gt;
| [[User:Nba_Yoh|MrNbaYoh]]&lt;br /&gt;
|-&lt;br /&gt;
| [[CECD_Services|CECD]] message box access &lt;br /&gt;
| CECD allows any process to write to any message box, thus allowing to write Streetpass data to the message box of any title.&lt;br /&gt;
| Install exploit for any title having a vulnerability in Streetpass data parsers (see CTRSDK Streetpass parser vulnerability).&lt;br /&gt;
| None&lt;br /&gt;
| None&lt;br /&gt;
| ?&lt;br /&gt;
| June 1, 2020&lt;br /&gt;
| Everyone?&lt;br /&gt;
|-&lt;br /&gt;
| [[CECD_Services|CECD]] packet type 0x32/0x34 stack-smashing&lt;br /&gt;
| When parsing Streetpass packets of type 0x32 and 0x34, CECD copies a list without checking the number of entries. The packet length is limited to 0x400 bytes, which is not enough to reach the end of the stack frame and overwrite the return address. However, the buffer located just next to the packet buffer is actually filled with data sent just before, hence actually allowing to overwrite the whole stack frame with conrolled data.&lt;br /&gt;
| RCE under [[CECD_Services|CECD]]&lt;br /&gt;
| [[11.12.0-44]]&lt;br /&gt;
| [[11.12.0-44]]&lt;br /&gt;
| Summer 2019&lt;br /&gt;
| June 1, 2020&lt;br /&gt;
| [[User:Nba_Yoh|MrNbaYoh]]&lt;br /&gt;
|-&lt;br /&gt;
| [[CECD_Services|CECD]] TMP files parser multiple vulnerabilities&lt;br /&gt;
| When parsing &amp;quot;TMP_XXX&amp;quot; files, CECD does not check the number of messages contained in the file. This allows to overflow the array of message pointers and message sizes on the stack. Pointers aren&#039;t controlled and sizes are limited (one cannot send gigabytes of data...), yet the last message size can be an arbitrary value (the current message pointer goes outside the file buffer and the parsing loop is broken). This allows to overwrite a pointer to a lock object on the stack and decrement an arbitrary value in memory. One can change the TMP file parsing mode to have CECD trying to free all the message buffers after parsing the next TMP file. The parsing mode is usually restored when parsing a new TMP file, but an invalid TMP file allows to make a function returns an error before the mode is restored , the return value is not checked and the parser consider the file valid. The message pointers and sizes arrays are not updated though, this is not a problem since the previous TMP file buffer is reused for the new TMP file in memory. Thus the message pointers actually points to controlled data. This allows to get a bunch of fake heap chunk freed, thus a bunch of unsafe unlink arbitrary writes.&lt;br /&gt;
| RCE under [[CECD_Services|CECD]]&lt;br /&gt;
| [[11.12.0-44]]&lt;br /&gt;
| [[11.12.0-44]]&lt;br /&gt;
| Summer 2019&lt;br /&gt;
| June 1, 2020&lt;br /&gt;
| [[User:Nba_Yoh|MrNbaYoh]]&lt;br /&gt;
|-&lt;br /&gt;
| [[Config_Services|CFG]]:CreateConfigInfoBlk integer underflow&lt;br /&gt;
| When creating a new block it checks the size of the block is &amp;lt;= 0x8000, but it doesn&#039;t check that the block size is less than the remaining space. This induces an integer underflow (remaining_space-block_size), the result is then used for another check (buf_start+current_offset+constant &amp;lt;= remaining_space-block_size) and then in a mempcy call (dest = buf_start+(u16)(remaining_space-block_size), size =block_size). This allow for writing past the buffer, however because of the u16 cast in the memcpy call memory has to be mapped from buf_start to buf_start+0x10000 (cannot write backward).&lt;br /&gt;
| Theoritically ROP under CFG services, but BSS section is to small (size &amp;lt;= 0x10000) so it only results in a crash.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.8.0-41]]&lt;br /&gt;
| November, 2018&lt;br /&gt;
| November 24, 2018&lt;br /&gt;
| [[User:Nba_Yoh|MrNbaYoh]]&lt;br /&gt;
|-&lt;br /&gt;
| [[MP:SendDataFrame]] missing input array index validation&lt;br /&gt;
| [[MP:SendDataFrame]] doesn&#039;t validate the input index at cmdreq[1], unless the function for flag=non-zero is executed. This is used to calculate the following, without validating the index at all: someptr = stateptr + (index*0x924) + somestateoffset.&lt;br /&gt;
&lt;br /&gt;
After validating some flags from someptr, when input_flag=0 the input buffer data is copied to someptr+someotheroffset+0x14 with the u16 size loaded from someptr+someotheroffset.&lt;br /&gt;
&lt;br /&gt;
With a large input index someptr could be setup to be at a &amp;lt;target address&amp;gt;, for overwriting memory.&lt;br /&gt;
&lt;br /&gt;
This is probably difficult to exploit.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[8.0.0-18]](MP-sysmodule v2048)&lt;br /&gt;
| January 22, 2017&lt;br /&gt;
| January 22, 2017&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[MP_Services|MP]] cmd1 out-of-bounds handle read&lt;br /&gt;
| MP-sysmodule handles the input parameter for cmd1 as a s32. It checks for &amp;gt;=16, but not &amp;lt;0. With &amp;lt;16 it basically does the following(array of entries 4-bytes each): *outhandle = ((Handle*)(stateptr+offsetinstate))[inputindex].&lt;br /&gt;
&lt;br /&gt;
Hence, this can be used to load any handle in MP-sysmodule memory. MP doesn&#039;t really have any service handles of interest however(can be obtained from elsewhere too).&lt;br /&gt;
| Reading any handle in MP-sysmodule memory.&lt;br /&gt;
| None&lt;br /&gt;
| [[8.0.0-18]](MP-sysmodule v2048)&lt;br /&gt;
| January 21, 2017&lt;br /&gt;
| January 22, 2017&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| AM stack/.bss infoleak via [[AM:ReadTwlBackupInfo]]([[AM:ReadTwlBackupInfoEx|Ex]])&lt;br /&gt;
| After writing the output-info structure to stack, it then copies that structure to the output buffer ptr using the size from the command. The size is not checked. This could be used to read data from the AM-service-thread stack handling the command + .bss.&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;This was not tested on hardware.&#039;&#039;&#039;&lt;br /&gt;
| Stack/.bss reading&lt;br /&gt;
| None&lt;br /&gt;
| [[10.0.0-27]](AM v9217)&lt;br /&gt;
| Roughly October 17, 2016&lt;br /&gt;
| October 25, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[MVD_Services|MVD]]: Stack buffer overflow with [[MVDSTD:SetupOutputBuffers]].&lt;br /&gt;
| The input total_entries is not validated when initially processing the input entry-list. This fixed-size input entry-list is copied to stack from the command request. The loop for processing this initializes a global table, the converted linearmem-&amp;gt;physaddrs used there are also copied to stack(0x8-bytes of physaddrs per entry).&lt;br /&gt;
&lt;br /&gt;
If total_entries is too large, MVD-sysmodule will crash due to reading unmapped memory following the stack(0x10000000). Afterwards if the out-of-bounds total_entries is smaller than that, it will crash due accessing address 0x0, hence this useless.&lt;br /&gt;
| MVD-sysmodule crash.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.0.0-20]]&lt;br /&gt;
| April 22, 2016 (Tested on the 25th)&lt;br /&gt;
| April 25, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[NWM_Services|NWM]]: Using CTRSDK heap with UDS sharedmem from the user-process.&lt;br /&gt;
| See the HTTP-sysmodule section below.&lt;br /&gt;
&lt;br /&gt;
CTRSDK heap is used with the sharedmem from [[NWMUDS:InitializeWithVersion]]. Buffers are allocated/freed under this heap using [[NWMUDS:Bind]] and [[NWMUDS:Unbind]].&lt;br /&gt;
&lt;br /&gt;
Hence, overwriting sharedmem with gspwn then using [[NWMUDS:Unbind]] results in the usual controlled CTRSDK memchunk-header write, similar to HTTP-sysmodule.&lt;br /&gt;
&lt;br /&gt;
This could be done by creating an UDS network, without any other nodes on the network.&lt;br /&gt;
&lt;br /&gt;
Besides CTRSDK memchunk-headers, there are no addresses stored under this sharedmem.&lt;br /&gt;
| ROP under NWM-module.&lt;br /&gt;
| None (need to check, but CTRSDK heap code is vulnerable)&lt;br /&gt;
| [[9.0.0-20|9.0.0-X]]&lt;br /&gt;
| April 10, 2016&lt;br /&gt;
| April 16, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[DLP_Services|DLP]]: Out-of-bounds memory access during spectator [[Download_Play|data-frame]] checksum calculation&lt;br /&gt;
| DLP doesn&#039;t validate the frame_size when receiving spectator data-frames at all, unlike non-spectator data-frames. The actual spectator data-frame parsing code doesn&#039;t use that field either. However, the data-frame checksum calculation code called during checksum verification does use the frame_size for loading the size of the framebuf.&lt;br /&gt;
&lt;br /&gt;
Hence, using a large frame_size like 0xFFFF will result in the checksum calculation code reading data out-of-bounds. This isn&#039;t really useful, you could trigger a remote local-WLAN DLP-sysmodule crash while a 3DS system is scanning for DLP networks(due to accessing unmapped memory), but that&#039;s about all(trying to infoleak with this likely isn&#039;t useful either).&lt;br /&gt;
| DLP-sysmodule crash, handled by dlplay system-application by a &amp;quot;connection interrupted&amp;quot; error eventually then a fatal-error via ErrDisp.&lt;br /&gt;
| None&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| April 8, 2016 (Tested on the 10th)&lt;br /&gt;
| April 10, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[DLP_Services|DLP]]: Out-of-bounds output data writing during spectator sysupdate titlelist [[Download_Play|data-frame]] handling&lt;br /&gt;
| The total_entries and out_entryindex fields for the titlelist DLP spectator data-frames are not validated. This is parsed during DLP network scanning. Hence, the specified titlelist data can be written out-of-bounds using the specified out_entryindex and total_entries. A crash will occur while reading the input data-frame titlelist if total_entries is larger than 0x27A, due to accessing unmapped memory.&lt;br /&gt;
&lt;br /&gt;
There&#039;s not much non-zero data to overwrite following the output buffer(located in sharedmem), any ptrs are located in sharedmem. Overwriting certain ptr(s) are only known to cause a crash when attempting to use the DLP-client shutdown service-command.&lt;br /&gt;
&lt;br /&gt;
There&#039;s no known way to exploit the above crash, since the linked-list code involves writes zeros(with a controlled start ptr).&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| April 8-9, 2016&lt;br /&gt;
| April 10, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[IR_Services|IR]]: Stack buffer overflow with custom hardware&lt;br /&gt;
| Originally IR sysmodule used the read value from the I2C-IR registers TXLVL and RXLVL without validating them at all. See [[10.6.0-31|here]] for the fix. This is the size used for reading the data-recv FIFO, etc. The output buffer for reading is located on the stack.&lt;br /&gt;
&lt;br /&gt;
This should be exploitable if one could successfully setup the custom hardware for this and if the entire intended sizes actually get read from I2C.&lt;br /&gt;
| ROP under IR sysmodule.&lt;br /&gt;
| [[10.6.0-31|10.6.0-31]]&lt;br /&gt;
| &lt;br /&gt;
| February 23, 2016 (Unknown if it was noticed before then)&lt;br /&gt;
| February 23, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[HTTP_Services|HTTP]]: Using CTRSDK heap with sharedmem from the user-process.&lt;br /&gt;
| The data from httpcAddPostDataAscii and other commands is stored under a CTRSDK heap. That heap is the sharedmem specified by the user-process via the HTTPC Initialize command.&lt;br /&gt;
Normally this sharedmem isn&#039;t accessible to the user-process once the sysmodule maps it, hence using it is supposed to be &amp;quot;safe&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This isn&#039;t the case due to gspwn however. Since CTRSDK heap code is so insecure in general, one can use gspwn to locate the HTTPC sharedmem + read/write it, then trigger a mem-write under the sysmodule. This can then be used to get ROP going under HTTP-sysmodule.&lt;br /&gt;
&lt;br /&gt;
This is exploited by [https://github.com/yellows8/ctr-httpwn/ctr-httpwn ctr-httpwn].&lt;br /&gt;
| ROP under HTTP sysmdule.&lt;br /&gt;
| None&lt;br /&gt;
| [[11.13.0-45|11.13.0-X]]&lt;br /&gt;
| Late 2015&lt;br /&gt;
| March 22, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[NIM_Services|NIM]]: Downloading old title-versions from eShop&lt;br /&gt;
| Multiple NIM service commands(such as [[NIMS:StartDownload]]) use a title-version value specified by the user-process, NIM does not validate that this input version matches the latest version available via SOAP. Therefore, when combined with AM(PXI) [[#Process9|title-downgrading]] via deleting the target eShop title with System Settings Data Management(if the title was already installed), this allows downloading+installing any title-version from eShop &#039;&#039;if&#039;&#039; it&#039;s still available from CDN.&lt;br /&gt;
The easiest way to exploit this is to just patch the eShop system-application code using these NIM commands(ideally the code which loads the title-version).&lt;br /&gt;
&lt;br /&gt;
Originally this was tested with a debugging-system via modded-FIRM, eventually smea implemented it in HANS for the 32c3 release.&lt;br /&gt;
| Downloading old title-versions from eShop&lt;br /&gt;
| None&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| October 24, 2015 (Unknown when exactly the first eShop title downgrade was actually tested, maybe November)&lt;br /&gt;
| January 7, 2016 (Same day Ironfall v1.0 was removed from CDN via the main-CXI files)&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SPI_Services|SPI]] service out-of-bounds write&lt;br /&gt;
| cmd1 has out-of-bounds write allowing overwrite of some static variables in .data.&lt;br /&gt;
| Code execution under spi sysmodule; access to [[CONFIG11_Registers|CFG11_GPUPROT]] and ultimately kernel code execution. &lt;br /&gt;
| None&lt;br /&gt;
| [[11.14.0-46]]&lt;br /&gt;
| March 2015&lt;br /&gt;
| &lt;br /&gt;
| [[User:Plutooo|plutoo]]&lt;br /&gt;
|-&lt;br /&gt;
| [[NFC_Services|NFC]] module service command buf-overflows&lt;br /&gt;
| NFC module copies data with certain commands, from command input buffers to stack without checking the size. These commands include the following, it&#039;s unknown if there&#039;s more commands with similar issues: &amp;quot;nfc:dev&amp;quot; &amp;lt;0x000C....&amp;gt; and &amp;quot;nfc:s&amp;quot; &amp;lt;0x0037....&amp;gt;.&lt;br /&gt;
Since both of these commands are stubbed in the Old3DS NFC module from the very first version(those just return an error), these issues only affect the New3DS NFC module.&lt;br /&gt;
&lt;br /&gt;
There&#039;s no known retail titles which have access to either of these services.&lt;br /&gt;
| ROP under NFC module.&lt;br /&gt;
| New3DS: None&lt;br /&gt;
| New3DS: [[9.5.0-22]]&lt;br /&gt;
| December 2014?&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[News_Services|NEWSS]] service command notificationID validation failure&lt;br /&gt;
| This module does not validate the input notificationID for &amp;lt;nowiki&amp;gt;&amp;quot;news:s&amp;quot;&amp;lt;/nowiki&amp;gt; service commands. This is an out-of-bounds array index bug. For example, [[NEWSS:SetNotificationHeader]] could be used to exploit news module: this copies the input data(size is properly checked) to: out = newsdb_savedata+0x10 + (someu32array[notificationID]*0x70).&lt;br /&gt;
| ROP under news module.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.7.0-25|9.7.0-X]]&lt;br /&gt;
| December 2014&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[NWMUDS:DecryptBeaconData]] heap buffer overflow&lt;br /&gt;
| input_size = 0x1E * &amp;lt;value the u8 from input_[[NWM_Services|networkstruct]]+0x1D&amp;gt;. Then input_tag0 is copied to a heap buffer. When input_size is larger than 0xFA-bytes, it will then copy input_tag1 to &amp;lt;end_address_of_previous_outbuf&amp;gt;, with size=input_size-0xFA.&lt;br /&gt;
&lt;br /&gt;
This can be triggered by either using this command directly, or by boadcasting a wifi beacon which triggers it while a 3DS system running the target process is in range, when the process is scanning for hosts to connect to. Processes will only pass tag data to this command when the wlancommID and other thing(s) match the values for the process.&lt;br /&gt;
&lt;br /&gt;
There&#039;s no known way to actually exploit this for getting ROP under NWM-module, at the time of originally adding this to the wiki. This is because the data which gets copied out-of-bounds *and* actually causes crash(es), can&#039;t be controlled it seems(with just broadcasting a beacon at least). It&#039;s unknown whether this could be exploited from just using NWMUDS service-cmd(s) directly.&lt;br /&gt;
| Without any actual way to exploit this: NWM-module DoS, resulting in process termination(process crash). This breaks *everything* involving wifi comms, a reboot is required to recover from this.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.0.0-20]]&lt;br /&gt;
| ~September 23, 2014(see the [[NWMUDS:DecryptBeaconData]] page history)&lt;br /&gt;
| August 3, 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[HID_Services|HID]] module shared-mem&lt;br /&gt;
| HID module does not validate the index values in [[HID_Shared_Memory|sharedmem]](just changes index to 0 when index == maxval when updating), therefore large values will result in HID module writing HID data to arbitrary addresses.&lt;br /&gt;
| ROP under HID module, but this is *very* unlikely to be exploitable since the data written is HID data.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.3.0-21]]&lt;br /&gt;
| 2014?&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| gspwn&lt;br /&gt;
| GSP module does not validate addresses given to the GPU. This allows a user-mode application/applet to read/write to a large part of physical FCRAM using GPU DMA. From this, you can overwrite the .text segment of the application you&#039;re running under, and gain real code-execution from a ROP-chain. Normally applets&#039; .text([[Home Menu]], [[Internet Browser]], etc) is located beyond the area accessible by the GPU, except for [[RO_Services|CROs]] used by applets([[Internet Browser]] for example).&lt;br /&gt;
&lt;br /&gt;
FCRAM is gpu-accessible up to physaddr 0x26800000 on Old3DS, and 0x2D800000 on New3DS. This is BASE_memregion_start(aka SYSTEM_memregion_end)-0x400000 (0x800000 with New3DS) with the default memory-layout on Old3DS/New3DS. With [[11.3.0-36|11.3.0-X]] the cutoff now varies due to the new [[SVC]] 0x59. The New3DS &amp;quot;normal&amp;quot;(non-APPLICATION) cutoff was changed to 0x2D000000 due to the new [[SVC]] 0x59.&lt;br /&gt;
| User-mode code execution.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Early 2014&lt;br /&gt;
| &lt;br /&gt;
| smea, [[User:Yellows8|Yellows8]]/others before then&lt;br /&gt;
|-&lt;br /&gt;
| rohax&lt;br /&gt;
| Using gspwn, it is possible to overwrite a loaded [[CRO0]]/[[CRR0]] after its RSA-signature has been validated. Badly validated [[CRO0]] header leads to arbitrary read/write of memory in the ro-process. This gives code-execution in the ro module, who has access to [[SVC|syscalls]] 0x70-0x72, 0x7D.&lt;br /&gt;
&lt;br /&gt;
This was fixed after [[ninjhax]] release by adding checks on [[CRO0]]-based pointers before writing to them.&lt;br /&gt;
| Memory-mapping syscalls.&lt;br /&gt;
| [[9.3.0-21]]&lt;br /&gt;
| [[9.4.0-21]]&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| smea, [[User:Plutooo|plutoo]] joint effort&lt;br /&gt;
|-&lt;br /&gt;
| Region free&lt;br /&gt;
| Only [[Home Menu]] itself checks gamecards&#039; region when launching them. Therefore, any application launch that is done directly with [[NS]] without signaling Home Menu to launch the app, will result in region checks being bypassed.&lt;br /&gt;
This essentially means launching the gamecard with the [[NS_and_APT_Services|&amp;quot;ns:s&amp;quot;]] service. The main way to exploit this is to trigger a FIRM launch with an application specified, either with a normal FIRM launch or a hardware [[NSS:RebootSystem|reboot]].&lt;br /&gt;
| Launching gamecards from any region + bypassing Home Menu gamecard-sysupdate installation&lt;br /&gt;
| None&lt;br /&gt;
| Last tested with [[10.1.0-27|10.1.0-X]].&lt;br /&gt;
| June(?) 2014&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[NWM_Services|NWM]] service-cmd state null-ptr deref&lt;br /&gt;
| The NWMUDS service command code loads a ptr from .data, adds an offset to that, then passes that as the state address for the actual command-handler function. The value of the ptr loaded from .data is not checked, therefore this will cause crashes due to that being 0x0 when NWMUDS was not properly initialized.&lt;br /&gt;
It&#039;s unknown whether any NWM services besides NWMUDS have this issue.&lt;br /&gt;
| This is rather useless since it&#039;s only a crash caused by a state ptr based at 0x0.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.0.0-20]]&lt;br /&gt;
| 2013?&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== General/CTRSDK ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in version&lt;br /&gt;
!  Last version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[CECD_Services|CECD]] Streetpass message exheader stack-smashing&lt;br /&gt;
| When parsing streetpass messages, &amp;quot;nn::cec::CTR::Message::InputMessage&amp;quot; calls &amp;quot;nn::cec::CTR::Message::SetExHeaderWithoutCalc&amp;quot; for each exheader entry in the input message. The number of entries should not exceed 16 but remains unchecked, leading to a stack-buffer-overflow.&lt;br /&gt;
| ROP under any application parsing Streetpass messages&lt;br /&gt;
Remote code execution under [[CECD_Services|CECD]]&lt;br /&gt;
| [[11.12.0-44]]&lt;br /&gt;
| &lt;br /&gt;
| 2019&lt;br /&gt;
| [[User:Nba_Yoh|MrNbaYoh]]&lt;br /&gt;
|-&lt;br /&gt;
| [[NWM_Services|UDS]] beacon additional-data buffer overflow&lt;br /&gt;
| Originally CTRSDK did not validate the UDS additional-data size before using that size to copy the additional-data to a [[NWM_Services|networkstruct]]. This was eventually fixed.&lt;br /&gt;
This was discovered while doing code RE with an old dlp-module version. It&#039;s unknown in what specific CTRSDK version this was fixed, or even what system-version updated titles with a fixed version.&lt;br /&gt;
&lt;br /&gt;
It&#039;s unknown if there&#039;s any titles using a vulnerable CTRSDK version which are also exploitable with this(dlp module can&#039;t be exploited with this).&lt;br /&gt;
&lt;br /&gt;
The maximum number of bytes that can be written beyond the end of the outbuf is 0x37-bytes, with additionaldata_size=0xFF.&lt;br /&gt;
| Perhaps ROP, very difficult if possible with anything at all&lt;br /&gt;
| ?&lt;br /&gt;
| &lt;br /&gt;
| September(?) 2014&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| CTPK buffer overflow&lt;br /&gt;
| At offset 0x20 in CTPK is an array for each texture, each entry is 0x20-bytes. This contains a wordindex(entry+0x18) for some srcdata relative to CTPK+0, and an u8 wordsize(entry+0x14) for this data. The CTRSDK function handling this doesn&#039;t validate the size, when copying srcdata using this size to the output buffer. Applications usually have the output buffer on the stack, hence stack buffer overflow.&lt;br /&gt;
&lt;br /&gt;
While CTPK(*.ctpk) are normally only loaded from RomFS, some application(s) load from elsewhere too.&lt;br /&gt;
| ROP under the target application.&lt;br /&gt;
| None?&lt;br /&gt;
| &amp;quot;[SDK+NINTENDO:CTR_SDK-11_4_0_200_none]&amp;quot;&lt;br /&gt;
| November 14, 2016&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=20883</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=20883"/>
		<updated>2019-01-18T02:11:15Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Command Header */ Size field is 8-bit, not 11-bit (tested on hardware)&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-27&lt;br /&gt;
| Number of extra parameters (may be zero)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| Unused&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 = perspective, 1 = not 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;
| U²&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| V&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| V²&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| (U + V) / 2&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| (U² + V²) / 2&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| sqrt(U² + V²)&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-6&lt;br /&gt;
| Min LOD (usually 0)&lt;br /&gt;
|-&lt;br /&gt;
| 7-10&lt;br /&gt;
| Max LOD (usually 6)&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 (Mipmap level 0 / base level)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| unsigned, mipmap level 1 offset (usually 0x80)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| unsigned, mipmap level 2 offset (usually 0xC0)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| unsigned, mipmap level 3 offset (usually 0xE0)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the procedural texture unit&#039;s offset. Mipmap level 4-7 seems to be hardcoded at offset 0xF0, 0xF8, 0xFC and 0xFE .&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;
| fixed0.0.12 with two&#039;s complement ( [0.5,1.0) mapped to [-1.0,0) ), 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;
| fixed0.0.12 with two&#039;s complement, 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;
| fixed0.0.12 with two&#039;s complement, 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;
| signed, Half of red difference between current and next color table elements&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| signed, Half of green difference between current and next color table elements&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| signed, Half of blue difference between current and next color table elements&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| signed, Half of 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;
&#039;&#039;&#039;Equation values:&#039;&#039;&#039;&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;
Blend equations 5, 6, 7 appear to behave the same as blend equation 0 (Add)&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Function values:&#039;&#039;&#039;&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;
| 8&lt;br /&gt;
| Gas color LUT input&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures gas light shading in the line-of-sight direction, and the input to the gas color LUT.&lt;br /&gt;
&lt;br /&gt;
Color LUT 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;
| Gas density&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Light factor&lt;br /&gt;
|}&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;
| 24-25&lt;br /&gt;
| unsigned, Depth function&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the gas depth direction attenuation proportion, as well as the gas depth function.&lt;br /&gt;
&lt;br /&gt;
Gas 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;
| Greater than/Greater than or equal&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Less than/Less than or equal/Equal/Not equal&lt;br /&gt;
|}&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>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=News&amp;diff=20877</id>
		<title>News</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=News&amp;diff=20877"/>
		<updated>2019-01-02T00:05:25Z</updated>

		<summary type="html">&lt;p&gt;Fincs: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
==Adding an item==&lt;br /&gt;
* Log in to the wiki. Editing is disabled if you don&#039;t have an account.&lt;br /&gt;
* Add the news event to the top of the list, using this format for the date: &amp;lt;tt&amp;gt;&amp;lt;nowiki&amp;gt;&#039;&#039;&#039;&amp;lt;/nowiki&amp;gt;{{#time: d F y}}&amp;lt;nowiki&amp;gt;&#039;&#039;&#039; &amp;lt;/nowiki&amp;gt;&amp;lt;/tt&amp;gt;. Please include the application&#039;s creator, version number, and a link to a page on 3DBrew about the application. No external links please.&lt;br /&gt;
* &#039;&#039;&#039;Move the last entry to the [[:News/Archive|news archive]]. There should be no more than 4 entries in the list.&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
==Archives==&lt;br /&gt;
For older news, see the [[:News/Archive|news archive]].&lt;br /&gt;
&lt;br /&gt;
=== News ===&lt;br /&gt;
&amp;lt;!-- Add news below --&amp;gt;&amp;lt;/noinclude&amp;gt;&lt;br /&gt;
*&#039;&#039;&#039;2 January&#039;&#039;&#039; [https://devkitpro.org/viewtopic.php?f=13&amp;amp;t=8826 libctru 1.5.1, citro3d 1.5.0, citro2d 1.1.0 and 3ds-examples 20190102 were released.]&lt;br /&gt;
*&#039;&#039;&#039;3 December 18&#039;&#039;&#039; Nintendo released system update [[11.9.0-42]].&lt;br /&gt;
*&#039;&#039;&#039;11 August 18 &#039;&#039;&#039; [[User:smea|Smealum]] [https://media.defcon.org/DEF%20CON%2026/DEF%20CON%2026%20presentations/smea/ publishes at Defcon 26] a complete userland to ARM9 exploit chain for N3DS, developed in the past two years.&lt;br /&gt;
*&#039;&#039;&#039;30 July 18&#039;&#039;&#039; Nintendo released system update [[11.8.0-41]].&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Setting_up_Development_Environment&amp;diff=20671</id>
		<title>Setting up Development Environment</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Setting_up_Development_Environment&amp;diff=20671"/>
		<updated>2018-04-12T08:01:56Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Undo revision 20670 by LinkSoraZelda (talk) The link is not dead, it definitely works. The edit makes it prone to becoming outdated, only the newest version of the script should be used.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= Setup =&lt;br /&gt;
* Install [https://devkitpro.org/ devkitARM]. If it&#039;s already installed, update it.&lt;br /&gt;
** On Windows, there&#039;s a [https://github.com/devkitPro/installer/releases/latest graphical installer].&lt;br /&gt;
** On Unix-like platforms such as Linux/macOS, there&#039;s a [https://raw.githubusercontent.com/devkitPro/installer/master/perl/devkitARMupdate.pl Perl script]. Make sure you also select libctru and the 3ds examples when installing.&lt;br /&gt;
* Depending on the kind of homebrew you want to develop, you may be interested in installing and using additional libraries and tools which don&#039;t ship alongside devkitARM/libctru. A list of them can be found in [[Homebrew Libraries and Tools]].&lt;br /&gt;
&lt;br /&gt;
==Windows==&lt;br /&gt;
devkitPro provides Win32-native precompiled versions of devkitARM which can be run directly on Windows.&lt;br /&gt;
* [https://github.com/devkitPro/installer/releases/latest download the latest version of the graphical installer] from SourceForge and run it, following the instructions as you go.&lt;br /&gt;
* An Internet connection is required.&lt;br /&gt;
* You will want to make sure devkitARM is selected during the installation process to develop for the 3DS (and also the DS and GBA) - you can also install devkitPPC (for GameCube/Wii development) and devkitPSP (for PlayStation Portable development) if you wish.&lt;br /&gt;
* Once the installer has finished, launch MSYS from:&lt;br /&gt;
** Windows 7 and earlier: Start -&amp;gt; All Programs -&amp;gt; devkitPro -&amp;gt; MSYS&lt;br /&gt;
** Windows 8 and 8.1: Right click on the Start screen and select &#039;All Apps&#039;. You should find MSYS there.&lt;br /&gt;
** Windows 10 (pre-Anniversary Update): Start -&amp;gt; All Apps -&amp;gt; devkitPro -&amp;gt; MSYS&lt;br /&gt;
** Windows 10 (post-Anniversary Update): Start -&amp;gt; devkitPro -&amp;gt; MSYS&lt;br /&gt;
&lt;br /&gt;
Alternatively starting with Windows 10 Anniversary Update (Version 1607), the [https://msdn.microsoft.com/en-us/commandline/wsl/install_guide Windows Subsystem for Linux (WSL)] may also be used to run the Linux version of devkitARM. Unless you have some particular need for WSL it&#039;s recommended that you stick to a more standard environment. &lt;br /&gt;
&lt;br /&gt;
==Unix-like platforms==&lt;br /&gt;
Currently devkitPro provides precompiled versions of devkitARM for the following Unix-like platforms: Linux (x86/x64), macOS (universal binary). Note that Linux x64 binaries are usable under WSL.&lt;br /&gt;
&lt;br /&gt;
* First, you need to install curl so the installer can download the devkitARM packages, and you should also install Git - you&#039;ll need it to update libctru or share your code on GitHub, among many other things. If you are running Linux, you&#039;ll also need wget; it comes preinstalled on most distributions, but not all.&lt;br /&gt;
&lt;br /&gt;
* Find your way into a shell (eg. by opening a Terminal window), and follow the instructions for your OS:&lt;br /&gt;
** Debian/Ubuntu/Linux Mint/Ubuntu on WSL: &amp;lt;code&amp;gt;sudo apt-get install git curl&amp;lt;/code&amp;gt;&lt;br /&gt;
** Fedora/CentOS/RHEL: &amp;lt;code&amp;gt;sudo yum install git curl&amp;lt;/code&amp;gt;&lt;br /&gt;
** openSUSE: &amp;lt;code&amp;gt;sudo zypper install git curl&amp;lt;/code&amp;gt;&lt;br /&gt;
** Arch Linux/ALWSL: &amp;lt;code&amp;gt;sudo pacman -S git curl wget&amp;lt;/code&amp;gt;&lt;br /&gt;
** macOS: Download Git from [http://git-scm.com/download/mac] and install it. Curl is included with the OS.&lt;br /&gt;
&lt;br /&gt;
* Next, we need to download, make executable and run the devkitARM updater (don&#039;t worry, the updater is also the installer.)&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
curl -L https://raw.githubusercontent.com/devkitPro/installer/master/perl/devkitARMupdate.pl -o devkitARMupdate.pl&lt;br /&gt;
chmod +x ./devkitARMupdate.pl&lt;br /&gt;
sudo ./devkitARMupdate.pl /opt/devkitpro&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* Finally, we need to tell your shell where to find the devkitARM binaries.&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
echo &amp;quot;export DEVKITPRO=/opt/devkitpro&amp;quot; &amp;gt;&amp;gt; ~/.bashrc&lt;br /&gt;
echo &amp;quot;export DEVKITARM=/opt/devkitpro/devkitARM&amp;quot; &amp;gt;&amp;gt; ~/.bashrc&lt;br /&gt;
source ~/.bashrc&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
= Building the examples =&lt;br /&gt;
3DS examples are still being created; however, there are a growing number of examples available from the [https://github.com/devkitPro/3ds-examples devkitPro/3ds-examples GitHub repository].&lt;br /&gt;
There are now too many to list here in detail, so go ahead and browse them.&lt;br /&gt;
&lt;br /&gt;
* To download these, if you installed Git (as you will have if you followed the above instructions), simply type &amp;lt;code&amp;gt;git clone https://github.com/devkitPro/3ds-examples.git&amp;lt;/code&amp;gt; into your shell in the directory you wish to store the 3ds-examples folder in.&lt;br /&gt;
&lt;br /&gt;
These can be built from the command line.&lt;br /&gt;
&lt;br /&gt;
To start a new homebrew project from the &amp;lt;code&amp;gt;bash&amp;lt;/code&amp;gt; shell, simply type the following (replacing &amp;lt;code&amp;gt;&#039;&#039;&#039;~/projects/my3dsproject&#039;&#039;&#039;&amp;lt;/code&amp;gt; with the place you would like your project to be stored, with &amp;lt;code&amp;gt;~&amp;lt;/code&amp;gt; meaning your HOME directory):&lt;br /&gt;
 cp -r $DEVKITPRO/examples/3ds/templates/application &#039;&#039;&#039;~/projects/my3dsproject&#039;&#039;&#039;&lt;br /&gt;
 cd &#039;&#039;&#039;~/projects/my3dsproject&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
The standard Makefile will use the folder as the name of the 3dsx that will be built. You can keep that behaviour or simply change the &amp;lt;code&amp;gt;TARGET := $(notdir $(CURDIR))&amp;lt;/code&amp;gt; line in the Makefile to explicitly name your project.&lt;br /&gt;
&lt;br /&gt;
To compile it, type &amp;lt;code&amp;gt;make&amp;lt;/code&amp;gt; in the project directory.&lt;br /&gt;
&lt;br /&gt;
==Running your code==&lt;br /&gt;
To run it on your 3DS, start the Homebrew Launcher, press Y to open the network loader, then on your PC type: &amp;lt;code&amp;gt;$DEVKITARM/bin/3dslink  &#039;&#039;&#039;my3dsproject&#039;&#039;&#039;.3dsx&amp;lt;/code&amp;gt;, replacing &#039;&#039;&#039;my3dsproject&#039;&#039;&#039; with the name of the 3dsx file you want to run.)&lt;br /&gt;
&lt;br /&gt;
If all goes well, you&#039;ll soon see your application running on your 3DS.&lt;br /&gt;
&lt;br /&gt;
==Building the examples on Linux with Netbeans==&lt;br /&gt;
* Go to File-&amp;gt;New Project...&lt;br /&gt;
* Select C/C++ Project with existing code&lt;br /&gt;
* Navigate to the examples directory and select the folder for the project you want to build; eg.    /home/vtsingaras/3ds/examples/app_launch&lt;br /&gt;
* Leave Configuration Mode to &#039;Automatic&#039; and click &#039;Finish&#039;.&lt;br /&gt;
* It will fail to build. Now edit Makefile and insert these two lines, adjusting for your devkitpro path, at the top:&lt;br /&gt;
&amp;lt;pre&amp;gt;export DEVKITPRO=/opt/devkitpro&lt;br /&gt;
export DEVKITARM=/opt/devkitpro/devkitARM&amp;lt;/pre&amp;gt;&lt;br /&gt;
* Right-click the project and go to Properties-&amp;gt;Code Assistance and click C Compiler.&lt;br /&gt;
* In include directories enter &lt;br /&gt;
&amp;lt;pre&amp;gt;/opt/devkitpro/devkitARM/include;/opt/devkitpro/libctru/include&amp;lt;/pre&amp;gt;&lt;br /&gt;
adjusting again for your devkitPro path.&lt;br /&gt;
* Do the same for &#039;C++ Compiler&#039;.&lt;br /&gt;
* Go to &#039;Run&#039; and click &#039;Clean and Build Project&#039;.&lt;br /&gt;
* Now right-click on the project and select Code Assistance-&amp;gt;Reparse Project.&lt;br /&gt;
&lt;br /&gt;
Now you can use Netbeans&#039; code completion feature and build your project from the Run menu.&lt;br /&gt;
&lt;br /&gt;
= Troubleshooting =&lt;br /&gt;
&#039;&#039;&#039;I get the &amp;quot;Please set DEVKITARM in your environment.&amp;quot; error.&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
Use the following command before installing [http://askubuntu.com/questions/573070/problem-setting-up-environment-for-make-command-execution]:&lt;br /&gt;
 sudo chown $USER /opt/devkitpro/ -R&lt;br /&gt;
 echo &amp;quot;export DEVKITPRO=\&amp;quot;/opt/devkitpro/\&amp;quot;&amp;quot; &amp;gt;&amp;gt; ~/.profile&lt;br /&gt;
 echo &amp;quot;export DEVKITARM=\&amp;quot;\${DEVKITPRO}/devkitARM/\&amp;quot;&amp;quot; &amp;gt;&amp;gt; ~/.profile&lt;br /&gt;
 source ~/.profile&lt;br /&gt;
&lt;br /&gt;
For WSL users, you need to close the Bash shell, then reopen it for WSL to reload all of the variables from a clean state.&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Shader_Instruction_Set&amp;diff=20514</id>
		<title>GPU/Shader Instruction Set</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=GPU/Shader_Instruction_Set&amp;diff=20514"/>
		<updated>2017-12-27T16:40:12Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Relative addressing */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GPU]]&lt;br /&gt;
&lt;br /&gt;
== Overview ==&lt;br /&gt;
A compiled shader binary is comprised of two parts : the main instruction sequence and the operand descriptor table. These are both sent to the GPU around the same time but using separate [[GPU/Internal_Registers|GPU Commands]]. Instructions (such as format 1 instruction) may reference operand descriptors. When such is the case, the operand descriptor ID is the offset, in words, of the descriptor within the table.&lt;br /&gt;
Both instructions and descriptors are coded in little endian.&lt;br /&gt;
Basic implementations of the following specification can be found at [https://github.com/smealum/aemstro] and [https://github.com/neobrain/nihstro].&lt;br /&gt;
The instruction set seems to have been heavily inspired by Microsoft&#039;s vs_3_0 [http://msdn.microsoft.com/en-us/library/windows/desktop/bb172938%28v=vs.85%29.aspx] and the Direct3D shader code [https://msdn.microsoft.com/en-us/library/windows/hardware/ff552891%28v=vs.85%29.aspx].&lt;br /&gt;
Please note that this page is being written as the instruction set is reverse engineered; as such it may very well contain mistakes.&lt;br /&gt;
&lt;br /&gt;
Debug information found in the code.bin of &amp;quot;Ironfall: Invasion&amp;quot; suggests that there may not be more than 512 instructions and 128 operand descriptors in a shader.&lt;br /&gt;
&lt;br /&gt;
== Nomenclature ==&lt;br /&gt;
&lt;br /&gt;
* opcode names with I appended to them are the same as their non-I version, except they use the inverted instruction format, giving 7 bits to SRC2 (and access to uniforms) and 5 bits to SRC1&lt;br /&gt;
&lt;br /&gt;
* opcode names with U appended to them are the same as their non-U version, except they are executed conditionally based on the value of a uniform boolean.&lt;br /&gt;
&lt;br /&gt;
* opcode names with C appended to them are the same as their non-C version, except they are executed conditionally based on a logical expression specified in the instruction.&lt;br /&gt;
&lt;br /&gt;
== Instruction formats ==&lt;br /&gt;
&lt;br /&gt;
Format 1 : (used for register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1i : (used for register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xE&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC2 (IDX_2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1u : (used for unary register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|   Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1c : (used for comparison operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Comparison operator for Y (CMPY)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Comparison operator for X (CMPX)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1B&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 2 : (used for flow control instructions)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Number of instructions (NUM)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0xC&lt;br /&gt;
|  Destination offset (in words) (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Condition boolean operator (CONDOP)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Y reference bit (REFY)&lt;br /&gt;
|-&lt;br /&gt;
|  0x19&lt;br /&gt;
|  0x1&lt;br /&gt;
|  X reference bit (REFX)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 3 : (used for uniform-based conditional flow control instructions)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Number of instructions ? (NUM)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0xC&lt;br /&gt;
|  Destination offset (in words) (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Uniform ID (BOOL/INT)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 4 : (used for SETEMIT)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Winding flag (FLAG_WINDING)&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Primitive emit flag (FLAG_PRIMEMIT)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Vertex ID (VTXID)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 5 : (used for MAD)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 3 register (SRC3)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x11&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC2 (IDX_2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 5i : (used for MADI)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 3 register (SRC3)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x11&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC3 (IDX_3)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Instructions ==&lt;br /&gt;
Unless noted otherwise, SRC1 and SRC2 refer to their respectively indexed float[4] registers (after swizzling). Similarly, DST refers to its indexed register modulo destination component masking, i.e. an expression like DST=SRC1 might actually just set DST.y to SRC1.y.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Opcode&lt;br /&gt;
!  Format&lt;br /&gt;
!  Name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x00&lt;br /&gt;
|  1&lt;br /&gt;
|  ADD&lt;br /&gt;
|  Adds two vectors component by component; DST[i] = SRC1[i]+SRC2[i] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x01&lt;br /&gt;
|  1&lt;br /&gt;
|  DP3&lt;br /&gt;
|  Computes dot product on 3-component vectors; DST = SRC1.SRC2&lt;br /&gt;
|-&lt;br /&gt;
|  0x02&lt;br /&gt;
|  1&lt;br /&gt;
|  DP4&lt;br /&gt;
|  Computes dot product on 4-component vectors; DST = SRC1.SRC2&lt;br /&gt;
|-&lt;br /&gt;
|  0x03&lt;br /&gt;
|  1&lt;br /&gt;
|  DPH&lt;br /&gt;
|  Computes dot product on a 3-component vector with 1.0 appended to it and a 4-component vector; DST = SRC1.SRC2 (with SRC1 homogenous)&lt;br /&gt;
|-&lt;br /&gt;
|  0x04&lt;br /&gt;
|  1&lt;br /&gt;
|  DST&lt;br /&gt;
|  Equivalent to Microsoft&#039;s [https://msdn.microsoft.com/en-us/library/windows/desktop/bb219790.aspx dst] instruction: DST = {1, SRC1[1]*SRC2[1], SRC1[2], SRC2[3]}&lt;br /&gt;
|-&lt;br /&gt;
|  0x05&lt;br /&gt;
|  1u&lt;br /&gt;
|  EX2&lt;br /&gt;
|  Computes SRC1&#039;s first component exponent with base 2; DST[i] = EXP2(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x06&lt;br /&gt;
|  1u&lt;br /&gt;
|  LG2&lt;br /&gt;
|  Computes SRC1&#039;s first component logarithm with base 2; DST[i] = LOG2(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x07&lt;br /&gt;
|  1u&lt;br /&gt;
|  LITP&lt;br /&gt;
|  Appears to be related to Microsoft&#039;s [https://msdn.microsoft.com/en-us/library/windows/desktop/bb174703.aspx lit] instruction; DST = clamp(SRC1, min={0, -127.9961, 0, 0}, max={inf, 127.9961, 0, inf})&lt;br /&gt;
|-&lt;br /&gt;
|  0x08&lt;br /&gt;
|  1&lt;br /&gt;
|  MUL&lt;br /&gt;
|  Multiplies two vectors component by component; DST[i] = SRC1[i].SRC2[i] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x09&lt;br /&gt;
|  1&lt;br /&gt;
|  SGE&lt;br /&gt;
|  Sets output if SRC1 is greater than or equal to SRC2; DST[i] = (SRC1[i] &amp;gt;= SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0A&lt;br /&gt;
|  1&lt;br /&gt;
|  SLT&lt;br /&gt;
|  Sets output if SRC1 is strictly less than SRC2; DST[i] = (SRC1[i] &amp;lt; SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0B&lt;br /&gt;
|  1u&lt;br /&gt;
|  FLR&lt;br /&gt;
|  Computes SRC1&#039;s floor component by component; DST[i] = FLOOR(SRC1[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0C&lt;br /&gt;
|  1&lt;br /&gt;
|  MAX&lt;br /&gt;
|  Takes the max of two vectors, component by component; DST[i] = MAX(SRC1[i], SRC2[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0D&lt;br /&gt;
|  1&lt;br /&gt;
|  MIN&lt;br /&gt;
|  Takes the min of two vectors, component by component; DST[i] = MIN(SRC1[i], SRC2[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0E&lt;br /&gt;
|  1u&lt;br /&gt;
|  RCP&lt;br /&gt;
|  Computes the reciprocal of the vector&#039;s first component; DST[i] = 1/SRC1[0] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0F&lt;br /&gt;
|  1u&lt;br /&gt;
|  RSQ&lt;br /&gt;
|  Computes the reciprocal of the square root of the vector&#039;s first component; DST[i] = 1/sqrt(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
| 0x10&lt;br /&gt;
| ?&lt;br /&gt;
| ???&lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
| 0x11&lt;br /&gt;
| ?&lt;br /&gt;
| ???&lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x12&lt;br /&gt;
|  1u&lt;br /&gt;
|  MOVA&lt;br /&gt;
|  Move to address register; Casts the float uniform given by SRC1 to an integer (truncating the fractional part) and assigns the result to (a0.x, a0.y, _, _), respecting the destination component mask.&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  1u&lt;br /&gt;
|  MOV&lt;br /&gt;
|  Moves value from one register to another; DST = SRC1.&lt;br /&gt;
|-&lt;br /&gt;
|  0x14&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  1i&lt;br /&gt;
|  DPHI&lt;br /&gt;
|  Computes dot product on a 3-component vector with 1.0 appended to it and a 4-component vector; DST = SRC1.SRC2 (with SRC1 homogenous)&lt;br /&gt;
|-&lt;br /&gt;
|  0x19&lt;br /&gt;
|  1i&lt;br /&gt;
|  DSTI&lt;br /&gt;
|  DST with sources swapped.&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  1i&lt;br /&gt;
|  SGEI&lt;br /&gt;
|  Sets output if SRC1 is greater than or equal to SRC2; DST[i] = (SRC1[i] &amp;gt;= SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x1B&lt;br /&gt;
|  1i&lt;br /&gt;
|  SLTI&lt;br /&gt;
|  Sets output if SRC1 is strictly less than SRC2; DST[i] = (SRC1[i] &amp;lt; SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x1C&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1E&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1F&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x20&lt;br /&gt;
|  0&lt;br /&gt;
|  BREAK&lt;br /&gt;
|  Breaks out of LOOP block; do not use while in nested IF/CALL block inside LOOP block.&lt;br /&gt;
|-&lt;br /&gt;
|  0x21&lt;br /&gt;
|  0&lt;br /&gt;
|  NOP&lt;br /&gt;
|  Does literally nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x22&lt;br /&gt;
|  0&lt;br /&gt;
|  END&lt;br /&gt;
|  Signals the shader unit that processing for this vertex/primitive is done.&lt;br /&gt;
|-&lt;br /&gt;
|  0x23&lt;br /&gt;
|  2&lt;br /&gt;
|  BREAKC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then breaks out of LOOP block.&lt;br /&gt;
|-&lt;br /&gt;
|  0x24&lt;br /&gt;
|  2&lt;br /&gt;
|  CALL&lt;br /&gt;
|  Jumps to DST and executes instructions until it reaches DST+NUM instructions&lt;br /&gt;
|-&lt;br /&gt;
|  0x25&lt;br /&gt;
|  2&lt;br /&gt;
|  CALLC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then jumps to DST and executes instructions until it reaches DST+NUM instructions, else does nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x26&lt;br /&gt;
|  3&lt;br /&gt;
|  CALLU&lt;br /&gt;
|  Jumps to DST and executes instructions until it reaches DST+NUM instructions if BOOL is true&lt;br /&gt;
|-&lt;br /&gt;
|  0x27&lt;br /&gt;
|  3&lt;br /&gt;
|  IFU&lt;br /&gt;
|  If condition BOOL is true, then executes instructions until DST, then jumps to DST+NUM; else, jumps to DST.&lt;br /&gt;
|-&lt;br /&gt;
|  0x28&lt;br /&gt;
|  2&lt;br /&gt;
|  IFC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then executes instructions until DST, then jumps to DST+NUM; else, jumps to DST&lt;br /&gt;
|-&lt;br /&gt;
|  0x29&lt;br /&gt;
|  3&lt;br /&gt;
|  LOOP&lt;br /&gt;
|  Loops over the code between itself and DST (inclusive), performing INT.x+1 iterations in total. First, aL is initialized to INT.y. After each iteration, aL is incremented by INT.z.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2A&lt;br /&gt;
|  0 (no param)&lt;br /&gt;
|  EMIT&lt;br /&gt;
|  (geometry shader only) Emits a vertex (and primitive if FLAG_PRIMEMIT was set in the corresponding SETEMIT). SETEMIT must be called before this.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2B&lt;br /&gt;
|  4&lt;br /&gt;
|  SETEMIT&lt;br /&gt;
|  (geometry shader only) Sets VTXID, FLAG_WINDING and FLAG_PRIMEMIT for the next EMIT instruction. VTXID is the ID of the vertex about to be emitted within the primitive, while FLAG_PRIMEMIT is zero if we are just emitting a single vertex and non-zero if are emitting a vertex and primitive simultaneously. FLAG_WINDING controls the output primitive&#039;s winding. Note that the output vertex buffer (which holds 4 vertices) is &#039;&#039;&#039;not&#039;&#039;&#039; cleared when the primitive is emitted, meaning that vertices from the previous primitive can be reused for the current one. (this is still a working hypothesis and unconfirmed)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2C&lt;br /&gt;
|  2&lt;br /&gt;
|  JMPC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then jumps to DST, else does nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2D&lt;br /&gt;
|  3&lt;br /&gt;
|  JMPU&lt;br /&gt;
|  If condition BOOL is true, then jumps to DST, else does nothing. Having bit 0 of NUM = 1 will invert the test, jumping if BOOL is false instead.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2E-0x2F&lt;br /&gt;
|  1c&lt;br /&gt;
|  CMP&lt;br /&gt;
|  Sets booleans cmp.x and cmp.y based on the operand&#039;s x and y components and the CMPX and CMPY comparison operators respectively. See [[#Comparison_operator|below]] for details about operators. It&#039;s unknown whether CMP respects the destination component mask or not.&lt;br /&gt;
|-&lt;br /&gt;
|  0x30-0x37&lt;br /&gt;
|  5i&lt;br /&gt;
|  MADI&lt;br /&gt;
|  Multiplies two vectors and adds a third one component by component; DST[i] = SRC3[i] + SRC2[i].SRC1[i] for all i; this is not an FMA, the intermediate result is rounded&lt;br /&gt;
|-&lt;br /&gt;
|  0x38-0x3F&lt;br /&gt;
|  5&lt;br /&gt;
|  MAD&lt;br /&gt;
|  Multiplies two vectors and adds a third one component by component; DST[i] = SRC3[i] + SRC2[i].SRC1[i] for all i; this is not an FMA, the intermediate result is rounded&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Operand descriptors ==&lt;br /&gt;
Sizes below are in bits, not bytes.&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;
|  0x0&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Destination component mask. Bit 3 = x, 2 = y, 1 = z, 0 = w.&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 1 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 1 component selector&lt;br /&gt;
|-&lt;br /&gt;
|  0xD&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 2 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0xE&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 2 component selector&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 3 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 3 component selector&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Component selector :&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;
|  0x0&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 3 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 2 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 1 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x6&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 0 value&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Component&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  x&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  y&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  z&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  w&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The component selector enables swizzling. For example, component selector 0x1B is equivalent to .xyzw, while 0x55 is equivalent to .yyyy.&lt;br /&gt;
&lt;br /&gt;
Depending on the current shader opcode, source components are disabled implicitly by setting the destination component mask. For example, ADD o0.xy, r0.xyzw, r1.xyzw will not make use of r0&#039;s or r1&#039;s z/w components, while DP4 o0.xy, r0.xyzw, r1.xyzw will use all input components regardless of the used destination component mask.&lt;br /&gt;
&lt;br /&gt;
== Relative addressing ==&lt;br /&gt;
&lt;br /&gt;
There are 3 address registers: a0.x, a0.y and aL (loop counter). For format 1 instructions, when IDX != 0, the value of the corresponding address register is added to SRC1&#039;s value. For example, if IDX = 2, a0.y = 3 and SRC1 = c8, then instead SRC1+a0.y = c11 will be used for the instruction. It is only possible to use address registers with vector uniform registers, attempting to use them with input attribute or temporary registers results in the address register being ignored (i.e. read as zero).&lt;br /&gt;
&lt;br /&gt;
a0.x and a0.y are set manually through the MOVA instruction by rounding a float value to integer precision. Hence, they may take negative values.&lt;br /&gt;
&lt;br /&gt;
aL can only be set indirectly by the LOOP instruction. It is still accessible and valid after exiting a LOOP block, though.&lt;br /&gt;
&lt;br /&gt;
== Comparison operator ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  CMPX/CMPY raw value&lt;br /&gt;
!  Operator name&lt;br /&gt;
!  Expression&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  EQ&lt;br /&gt;
|  src1 == src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  NE&lt;br /&gt;
|  src1 != src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  LT&lt;br /&gt;
|  src1 &amp;lt; src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  LE&lt;br /&gt;
|  src1 &amp;lt;= src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  GT&lt;br /&gt;
|  src1 &amp;gt; src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  GE&lt;br /&gt;
|  src1 &amp;gt;= src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x6&lt;br /&gt;
|  ??&lt;br /&gt;
|  true ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  ??&lt;br /&gt;
|  true ?&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
6 and 7 seem to always return true.&lt;br /&gt;
&lt;br /&gt;
== Conditions ==&lt;br /&gt;
&lt;br /&gt;
A number of format 2 instructions are executed conditionally. These conditions are based on two boolean registers which can be set with CMP : cmp.x and cmp.y.&lt;br /&gt;
&lt;br /&gt;
Conditional instructions include 3 parameters : CONDOP, REFX and REFY. REFX and REFY are reference values which are tested for equality against cmp.x and cmp.y, respectively. CONDOP describes how the final truth value is constructed from the results of the two tests. There are four conditional expression formats :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  CONDOP raw value&lt;br /&gt;
!  Expression&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  &amp;lt;nowiki&amp;gt;cmp.x == REFX || cmp.y == REFY&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
|  OR&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  &amp;lt;nowiki&amp;gt;cmp.x == REFX &amp;amp;&amp;amp; cmp.y == REFY&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
|  AND&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  cmp.x == REFX&lt;br /&gt;
|  X&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  cmp.y == REFY&lt;br /&gt;
|  Y&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Registers ==&lt;br /&gt;
Input attribute registers (v0-v7?) store the per-vertex data given by the CPU and hence are read-only.&lt;br /&gt;
&lt;br /&gt;
Output attribute registers (o0-o6) hold the data to be passed to the later GPU stages and are write-only. Each of the output attribute register components is assigned a semantic by setting the corresponding [[GPU_Internal_Registers]].&lt;br /&gt;
&lt;br /&gt;
Uniform registers hold user-specified data which is constant throughout all processed vertices. There are 96 float[4] uniform registers (c0-c95), eight boolean registers (b0-b7), and four int[4] registers (i0-i3).&lt;br /&gt;
&lt;br /&gt;
Temporary registers (r0-r15) can be used for intermediate calculations and can both be read and written.&lt;br /&gt;
&lt;br /&gt;
Many shader instructions which take float arguments have only 5 bits available for the second argument. They may hence only refer to input attributes or temporary registers. In particular, it&#039;s not possible to pass two float[4] uniforms to these instructions.&lt;br /&gt;
&lt;br /&gt;
It appears that writing twice to the same output register can cause problems (e.g. GPU hangs).&lt;br /&gt;
&lt;br /&gt;
DST mapping :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  DST raw value&lt;br /&gt;
!  Register name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0-0x6&lt;br /&gt;
|  o0-o6&lt;br /&gt;
|  Output registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x10-0x1F&lt;br /&gt;
|  r0-r15&lt;br /&gt;
|  Temporary registers.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
SRC mapping :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  SRC1 raw value&lt;br /&gt;
!  Register name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0-0x7&lt;br /&gt;
|  v0-v7&lt;br /&gt;
|  Input attribute registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x10-0x1F&lt;br /&gt;
|  r0-r15&lt;br /&gt;
|  Temporary registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x20-0x7F&lt;br /&gt;
|  c0-c95&lt;br /&gt;
|  Vector uniform registers.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Floating-Point Behavior ==&lt;br /&gt;
&lt;br /&gt;
The PICA200 is not IEEE-compliant. It has positive and negative infinities and NaN, but does not seem to have negative 0. Input and output subnormals are flushed to +0. The internal floating point format seems to be the same as used in shader binaries: 1 sign bit, 7 exponent bits, 16 (explicit) mantissa bits. Several instructions also have behavior that differs from the IEEE functions. Here are the results from some tests done on hardware (s = largest subnormal, n = smallest positive normal):&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Computation&lt;br /&gt;
!  Result&lt;br /&gt;
!  Notes&lt;br /&gt;
|-&lt;br /&gt;
|  inf * 0&lt;br /&gt;
|  0&lt;br /&gt;
|  Including inside MUL, MAD, DP4, etc.&lt;br /&gt;
|-&lt;br /&gt;
|  NaN * 0&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  +inf - +inf&lt;br /&gt;
|  NaN&lt;br /&gt;
|  Indicates +inf is real inf, not FLT_MAX&lt;br /&gt;
|-&lt;br /&gt;
|  rsq(rcp(-inf))&lt;br /&gt;
|  +inf&lt;br /&gt;
|  Indicates that there isn&#039;t -0.0.&lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  rcp(-0)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  no -0 so differs from IEEE where rcp(-0) = -inf &lt;br /&gt;
|-&lt;br /&gt;
|  rcp(0)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rcp(+inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rcp(NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  rsq(-0)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  no -0 so differs from IEEE where rsq(-0) = -inf &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(-2)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(+inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(-inf)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  max(0, +inf)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(0, -inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(0, NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  max violates IEEE but match GLSL spec&lt;br /&gt;
|-&lt;br /&gt;
|  max(NaN, 0)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(-inf, +inf)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  min(0, +inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(0, -inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(0, NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  min violates IEEE but match GLSL spec&lt;br /&gt;
|-&lt;br /&gt;
|  min(NaN, 0)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(-inf, +inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  cmp(s, 0)&lt;br /&gt;
|  false&lt;br /&gt;
|  cmp does not flush input subnormals&lt;br /&gt;
|-&lt;br /&gt;
|  max(s, 0)&lt;br /&gt;
|  s&lt;br /&gt;
|  max does not flush input or output subnormals&lt;br /&gt;
|-&lt;br /&gt;
|  mul(s, 2)&lt;br /&gt;
|  0&lt;br /&gt;
|  input subnormals are flushed in arithmetic instructions&lt;br /&gt;
|-&lt;br /&gt;
|  mul(n, 0.5)&lt;br /&gt;
|  0&lt;br /&gt;
|  output subnormals are flushed in arithmetic instructions&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
1.0 can be multiplied 63 times by 0.5 until the result compares equal zero. This is consistent with a 7-bit exponent and output subnormal flushing.&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Shader_Instruction_Set&amp;diff=20513</id>
		<title>GPU/Shader Instruction Set</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=GPU/Shader_Instruction_Set&amp;diff=20513"/>
		<updated>2017-12-27T16:36:43Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Instructions */ Formatting &amp;amp; add some external links&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GPU]]&lt;br /&gt;
&lt;br /&gt;
== Overview ==&lt;br /&gt;
A compiled shader binary is comprised of two parts : the main instruction sequence and the operand descriptor table. These are both sent to the GPU around the same time but using separate [[GPU/Internal_Registers|GPU Commands]]. Instructions (such as format 1 instruction) may reference operand descriptors. When such is the case, the operand descriptor ID is the offset, in words, of the descriptor within the table.&lt;br /&gt;
Both instructions and descriptors are coded in little endian.&lt;br /&gt;
Basic implementations of the following specification can be found at [https://github.com/smealum/aemstro] and [https://github.com/neobrain/nihstro].&lt;br /&gt;
The instruction set seems to have been heavily inspired by Microsoft&#039;s vs_3_0 [http://msdn.microsoft.com/en-us/library/windows/desktop/bb172938%28v=vs.85%29.aspx] and the Direct3D shader code [https://msdn.microsoft.com/en-us/library/windows/hardware/ff552891%28v=vs.85%29.aspx].&lt;br /&gt;
Please note that this page is being written as the instruction set is reverse engineered; as such it may very well contain mistakes.&lt;br /&gt;
&lt;br /&gt;
Debug information found in the code.bin of &amp;quot;Ironfall: Invasion&amp;quot; suggests that there may not be more than 512 instructions and 128 operand descriptors in a shader.&lt;br /&gt;
&lt;br /&gt;
== Nomenclature ==&lt;br /&gt;
&lt;br /&gt;
* opcode names with I appended to them are the same as their non-I version, except they use the inverted instruction format, giving 7 bits to SRC2 (and access to uniforms) and 5 bits to SRC1&lt;br /&gt;
&lt;br /&gt;
* opcode names with U appended to them are the same as their non-U version, except they are executed conditionally based on the value of a uniform boolean.&lt;br /&gt;
&lt;br /&gt;
* opcode names with C appended to them are the same as their non-C version, except they are executed conditionally based on a logical expression specified in the instruction.&lt;br /&gt;
&lt;br /&gt;
== Instruction formats ==&lt;br /&gt;
&lt;br /&gt;
Format 1 : (used for register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1i : (used for register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xE&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC2 (IDX_2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1u : (used for unary register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|   Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1c : (used for comparison operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Comparison operator for Y (CMPY)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Comparison operator for X (CMPX)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1B&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 2 : (used for flow control instructions)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Number of instructions (NUM)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0xC&lt;br /&gt;
|  Destination offset (in words) (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Condition boolean operator (CONDOP)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Y reference bit (REFY)&lt;br /&gt;
|-&lt;br /&gt;
|  0x19&lt;br /&gt;
|  0x1&lt;br /&gt;
|  X reference bit (REFX)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 3 : (used for uniform-based conditional flow control instructions)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Number of instructions ? (NUM)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0xC&lt;br /&gt;
|  Destination offset (in words) (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Uniform ID (BOOL/INT)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 4 : (used for SETEMIT)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Winding flag (FLAG_WINDING)&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Primitive emit flag (FLAG_PRIMEMIT)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Vertex ID (VTXID)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 5 : (used for MAD)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 3 register (SRC3)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x11&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC2 (IDX_2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 5i : (used for MADI)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 3 register (SRC3)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x11&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC3 (IDX_3)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Instructions ==&lt;br /&gt;
Unless noted otherwise, SRC1 and SRC2 refer to their respectively indexed float[4] registers (after swizzling). Similarly, DST refers to its indexed register modulo destination component masking, i.e. an expression like DST=SRC1 might actually just set DST.y to SRC1.y.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Opcode&lt;br /&gt;
!  Format&lt;br /&gt;
!  Name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x00&lt;br /&gt;
|  1&lt;br /&gt;
|  ADD&lt;br /&gt;
|  Adds two vectors component by component; DST[i] = SRC1[i]+SRC2[i] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x01&lt;br /&gt;
|  1&lt;br /&gt;
|  DP3&lt;br /&gt;
|  Computes dot product on 3-component vectors; DST = SRC1.SRC2&lt;br /&gt;
|-&lt;br /&gt;
|  0x02&lt;br /&gt;
|  1&lt;br /&gt;
|  DP4&lt;br /&gt;
|  Computes dot product on 4-component vectors; DST = SRC1.SRC2&lt;br /&gt;
|-&lt;br /&gt;
|  0x03&lt;br /&gt;
|  1&lt;br /&gt;
|  DPH&lt;br /&gt;
|  Computes dot product on a 3-component vector with 1.0 appended to it and a 4-component vector; DST = SRC1.SRC2 (with SRC1 homogenous)&lt;br /&gt;
|-&lt;br /&gt;
|  0x04&lt;br /&gt;
|  1&lt;br /&gt;
|  DST&lt;br /&gt;
|  Equivalent to Microsoft&#039;s [https://msdn.microsoft.com/en-us/library/windows/desktop/bb219790.aspx dst] instruction: DST = {1, SRC1[1]*SRC2[1], SRC1[2], SRC2[3]}&lt;br /&gt;
|-&lt;br /&gt;
|  0x05&lt;br /&gt;
|  1u&lt;br /&gt;
|  EX2&lt;br /&gt;
|  Computes SRC1&#039;s first component exponent with base 2; DST[i] = EXP2(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x06&lt;br /&gt;
|  1u&lt;br /&gt;
|  LG2&lt;br /&gt;
|  Computes SRC1&#039;s first component logarithm with base 2; DST[i] = LOG2(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x07&lt;br /&gt;
|  1u&lt;br /&gt;
|  LITP&lt;br /&gt;
|  Appears to be related to Microsoft&#039;s [https://msdn.microsoft.com/en-us/library/windows/desktop/bb174703.aspx lit] instruction; DST = clamp(SRC1, min={0, -127.9961, 0, 0}, max={inf, 127.9961, 0, inf})&lt;br /&gt;
|-&lt;br /&gt;
|  0x08&lt;br /&gt;
|  1&lt;br /&gt;
|  MUL&lt;br /&gt;
|  Multiplies two vectors component by component; DST[i] = SRC1[i].SRC2[i] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x09&lt;br /&gt;
|  1&lt;br /&gt;
|  SGE&lt;br /&gt;
|  Sets output if SRC1 is greater than or equal to SRC2; DST[i] = (SRC1[i] &amp;gt;= SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0A&lt;br /&gt;
|  1&lt;br /&gt;
|  SLT&lt;br /&gt;
|  Sets output if SRC1 is strictly less than SRC2; DST[i] = (SRC1[i] &amp;lt; SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0B&lt;br /&gt;
|  1u&lt;br /&gt;
|  FLR&lt;br /&gt;
|  Computes SRC1&#039;s floor component by component; DST[i] = FLOOR(SRC1[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0C&lt;br /&gt;
|  1&lt;br /&gt;
|  MAX&lt;br /&gt;
|  Takes the max of two vectors, component by component; DST[i] = MAX(SRC1[i], SRC2[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0D&lt;br /&gt;
|  1&lt;br /&gt;
|  MIN&lt;br /&gt;
|  Takes the min of two vectors, component by component; DST[i] = MIN(SRC1[i], SRC2[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0E&lt;br /&gt;
|  1u&lt;br /&gt;
|  RCP&lt;br /&gt;
|  Computes the reciprocal of the vector&#039;s first component; DST[i] = 1/SRC1[0] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0F&lt;br /&gt;
|  1u&lt;br /&gt;
|  RSQ&lt;br /&gt;
|  Computes the reciprocal of the square root of the vector&#039;s first component; DST[i] = 1/sqrt(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
| 0x10&lt;br /&gt;
| ?&lt;br /&gt;
| ???&lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
| 0x11&lt;br /&gt;
| ?&lt;br /&gt;
| ???&lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x12&lt;br /&gt;
|  1u&lt;br /&gt;
|  MOVA&lt;br /&gt;
|  Move to address register; Casts the float uniform given by SRC1 to an integer (truncating the fractional part) and assigns the result to (a0.x, a0.y, _, _), respecting the destination component mask.&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  1u&lt;br /&gt;
|  MOV&lt;br /&gt;
|  Moves value from one register to another; DST = SRC1.&lt;br /&gt;
|-&lt;br /&gt;
|  0x14&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  1i&lt;br /&gt;
|  DPHI&lt;br /&gt;
|  Computes dot product on a 3-component vector with 1.0 appended to it and a 4-component vector; DST = SRC1.SRC2 (with SRC1 homogenous)&lt;br /&gt;
|-&lt;br /&gt;
|  0x19&lt;br /&gt;
|  1i&lt;br /&gt;
|  DSTI&lt;br /&gt;
|  DST with sources swapped.&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  1i&lt;br /&gt;
|  SGEI&lt;br /&gt;
|  Sets output if SRC1 is greater than or equal to SRC2; DST[i] = (SRC1[i] &amp;gt;= SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x1B&lt;br /&gt;
|  1i&lt;br /&gt;
|  SLTI&lt;br /&gt;
|  Sets output if SRC1 is strictly less than SRC2; DST[i] = (SRC1[i] &amp;lt; SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x1C&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1E&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1F&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x20&lt;br /&gt;
|  0&lt;br /&gt;
|  BREAK&lt;br /&gt;
|  Breaks out of LOOP block; do not use while in nested IF/CALL block inside LOOP block.&lt;br /&gt;
|-&lt;br /&gt;
|  0x21&lt;br /&gt;
|  0&lt;br /&gt;
|  NOP&lt;br /&gt;
|  Does literally nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x22&lt;br /&gt;
|  0&lt;br /&gt;
|  END&lt;br /&gt;
|  Signals the shader unit that processing for this vertex/primitive is done.&lt;br /&gt;
|-&lt;br /&gt;
|  0x23&lt;br /&gt;
|  2&lt;br /&gt;
|  BREAKC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then breaks out of LOOP block.&lt;br /&gt;
|-&lt;br /&gt;
|  0x24&lt;br /&gt;
|  2&lt;br /&gt;
|  CALL&lt;br /&gt;
|  Jumps to DST and executes instructions until it reaches DST+NUM instructions&lt;br /&gt;
|-&lt;br /&gt;
|  0x25&lt;br /&gt;
|  2&lt;br /&gt;
|  CALLC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then jumps to DST and executes instructions until it reaches DST+NUM instructions, else does nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x26&lt;br /&gt;
|  3&lt;br /&gt;
|  CALLU&lt;br /&gt;
|  Jumps to DST and executes instructions until it reaches DST+NUM instructions if BOOL is true&lt;br /&gt;
|-&lt;br /&gt;
|  0x27&lt;br /&gt;
|  3&lt;br /&gt;
|  IFU&lt;br /&gt;
|  If condition BOOL is true, then executes instructions until DST, then jumps to DST+NUM; else, jumps to DST.&lt;br /&gt;
|-&lt;br /&gt;
|  0x28&lt;br /&gt;
|  2&lt;br /&gt;
|  IFC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then executes instructions until DST, then jumps to DST+NUM; else, jumps to DST&lt;br /&gt;
|-&lt;br /&gt;
|  0x29&lt;br /&gt;
|  3&lt;br /&gt;
|  LOOP&lt;br /&gt;
|  Loops over the code between itself and DST (inclusive), performing INT.x+1 iterations in total. First, aL is initialized to INT.y. After each iteration, aL is incremented by INT.z.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2A&lt;br /&gt;
|  0 (no param)&lt;br /&gt;
|  EMIT&lt;br /&gt;
|  (geometry shader only) Emits a vertex (and primitive if FLAG_PRIMEMIT was set in the corresponding SETEMIT). SETEMIT must be called before this.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2B&lt;br /&gt;
|  4&lt;br /&gt;
|  SETEMIT&lt;br /&gt;
|  (geometry shader only) Sets VTXID, FLAG_WINDING and FLAG_PRIMEMIT for the next EMIT instruction. VTXID is the ID of the vertex about to be emitted within the primitive, while FLAG_PRIMEMIT is zero if we are just emitting a single vertex and non-zero if are emitting a vertex and primitive simultaneously. FLAG_WINDING controls the output primitive&#039;s winding. Note that the output vertex buffer (which holds 4 vertices) is &#039;&#039;&#039;not&#039;&#039;&#039; cleared when the primitive is emitted, meaning that vertices from the previous primitive can be reused for the current one. (this is still a working hypothesis and unconfirmed)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2C&lt;br /&gt;
|  2&lt;br /&gt;
|  JMPC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then jumps to DST, else does nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2D&lt;br /&gt;
|  3&lt;br /&gt;
|  JMPU&lt;br /&gt;
|  If condition BOOL is true, then jumps to DST, else does nothing. Having bit 0 of NUM = 1 will invert the test, jumping if BOOL is false instead.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2E-0x2F&lt;br /&gt;
|  1c&lt;br /&gt;
|  CMP&lt;br /&gt;
|  Sets booleans cmp.x and cmp.y based on the operand&#039;s x and y components and the CMPX and CMPY comparison operators respectively. See [[#Comparison_operator|below]] for details about operators. It&#039;s unknown whether CMP respects the destination component mask or not.&lt;br /&gt;
|-&lt;br /&gt;
|  0x30-0x37&lt;br /&gt;
|  5i&lt;br /&gt;
|  MADI&lt;br /&gt;
|  Multiplies two vectors and adds a third one component by component; DST[i] = SRC3[i] + SRC2[i].SRC1[i] for all i; this is not an FMA, the intermediate result is rounded&lt;br /&gt;
|-&lt;br /&gt;
|  0x38-0x3F&lt;br /&gt;
|  5&lt;br /&gt;
|  MAD&lt;br /&gt;
|  Multiplies two vectors and adds a third one component by component; DST[i] = SRC3[i] + SRC2[i].SRC1[i] for all i; this is not an FMA, the intermediate result is rounded&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Operand descriptors ==&lt;br /&gt;
Sizes below are in bits, not bytes.&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;
|  0x0&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Destination component mask. Bit 3 = x, 2 = y, 1 = z, 0 = w.&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 1 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 1 component selector&lt;br /&gt;
|-&lt;br /&gt;
|  0xD&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 2 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0xE&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 2 component selector&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 3 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 3 component selector&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Component selector :&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;
|  0x0&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 3 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 2 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 1 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x6&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 0 value&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Component&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  x&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  y&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  z&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  w&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The component selector enables swizzling. For example, component selector 0x1B is equivalent to .xyzw, while 0x55 is equivalent to .yyyy.&lt;br /&gt;
&lt;br /&gt;
Depending on the current shader opcode, source components are disabled implicitly by setting the destination component mask. For example, ADD o0.xy, r0.xyzw, r1.xyzw will not make use of r0&#039;s or r1&#039;s z/w components, while DP4 o0.xy, r0.xyzw, r1.xyzw will use all input components regardless of the used destination component mask.&lt;br /&gt;
&lt;br /&gt;
== Relative addressing ==&lt;br /&gt;
&lt;br /&gt;
There are 3 address registers: a0.x, a0.y and aL (loop counter). For format 1 instructions, when IDX != 0, the value of the corresponding address register is added to SRC1&#039;s value. For example, if IDX = 2, a0.y = 3 and SRC1 = c8, then instead SRC1+a0.y = c11 will be used for the instruction.&lt;br /&gt;
&lt;br /&gt;
a0.x and a0.y are set manually through the MOVA instruction by rounding a float value to integer precision. Hence, they may take negative values.&lt;br /&gt;
&lt;br /&gt;
aL can only be set indirectly by the LOOP instruction. It is still accessible and valid after exiting a LOOP block, though.&lt;br /&gt;
&lt;br /&gt;
== Comparison operator ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  CMPX/CMPY raw value&lt;br /&gt;
!  Operator name&lt;br /&gt;
!  Expression&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  EQ&lt;br /&gt;
|  src1 == src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  NE&lt;br /&gt;
|  src1 != src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  LT&lt;br /&gt;
|  src1 &amp;lt; src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  LE&lt;br /&gt;
|  src1 &amp;lt;= src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  GT&lt;br /&gt;
|  src1 &amp;gt; src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  GE&lt;br /&gt;
|  src1 &amp;gt;= src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x6&lt;br /&gt;
|  ??&lt;br /&gt;
|  true ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  ??&lt;br /&gt;
|  true ?&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
6 and 7 seem to always return true.&lt;br /&gt;
&lt;br /&gt;
== Conditions ==&lt;br /&gt;
&lt;br /&gt;
A number of format 2 instructions are executed conditionally. These conditions are based on two boolean registers which can be set with CMP : cmp.x and cmp.y.&lt;br /&gt;
&lt;br /&gt;
Conditional instructions include 3 parameters : CONDOP, REFX and REFY. REFX and REFY are reference values which are tested for equality against cmp.x and cmp.y, respectively. CONDOP describes how the final truth value is constructed from the results of the two tests. There are four conditional expression formats :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  CONDOP raw value&lt;br /&gt;
!  Expression&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  &amp;lt;nowiki&amp;gt;cmp.x == REFX || cmp.y == REFY&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
|  OR&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  &amp;lt;nowiki&amp;gt;cmp.x == REFX &amp;amp;&amp;amp; cmp.y == REFY&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
|  AND&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  cmp.x == REFX&lt;br /&gt;
|  X&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  cmp.y == REFY&lt;br /&gt;
|  Y&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Registers ==&lt;br /&gt;
Input attribute registers (v0-v7?) store the per-vertex data given by the CPU and hence are read-only.&lt;br /&gt;
&lt;br /&gt;
Output attribute registers (o0-o6) hold the data to be passed to the later GPU stages and are write-only. Each of the output attribute register components is assigned a semantic by setting the corresponding [[GPU_Internal_Registers]].&lt;br /&gt;
&lt;br /&gt;
Uniform registers hold user-specified data which is constant throughout all processed vertices. There are 96 float[4] uniform registers (c0-c95), eight boolean registers (b0-b7), and four int[4] registers (i0-i3).&lt;br /&gt;
&lt;br /&gt;
Temporary registers (r0-r15) can be used for intermediate calculations and can both be read and written.&lt;br /&gt;
&lt;br /&gt;
Many shader instructions which take float arguments have only 5 bits available for the second argument. They may hence only refer to input attributes or temporary registers. In particular, it&#039;s not possible to pass two float[4] uniforms to these instructions.&lt;br /&gt;
&lt;br /&gt;
It appears that writing twice to the same output register can cause problems (e.g. GPU hangs).&lt;br /&gt;
&lt;br /&gt;
DST mapping :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  DST raw value&lt;br /&gt;
!  Register name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0-0x6&lt;br /&gt;
|  o0-o6&lt;br /&gt;
|  Output registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x10-0x1F&lt;br /&gt;
|  r0-r15&lt;br /&gt;
|  Temporary registers.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
SRC mapping :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  SRC1 raw value&lt;br /&gt;
!  Register name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0-0x7&lt;br /&gt;
|  v0-v7&lt;br /&gt;
|  Input attribute registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x10-0x1F&lt;br /&gt;
|  r0-r15&lt;br /&gt;
|  Temporary registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x20-0x7F&lt;br /&gt;
|  c0-c95&lt;br /&gt;
|  Vector uniform registers.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Floating-Point Behavior ==&lt;br /&gt;
&lt;br /&gt;
The PICA200 is not IEEE-compliant. It has positive and negative infinities and NaN, but does not seem to have negative 0. Input and output subnormals are flushed to +0. The internal floating point format seems to be the same as used in shader binaries: 1 sign bit, 7 exponent bits, 16 (explicit) mantissa bits. Several instructions also have behavior that differs from the IEEE functions. Here are the results from some tests done on hardware (s = largest subnormal, n = smallest positive normal):&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Computation&lt;br /&gt;
!  Result&lt;br /&gt;
!  Notes&lt;br /&gt;
|-&lt;br /&gt;
|  inf * 0&lt;br /&gt;
|  0&lt;br /&gt;
|  Including inside MUL, MAD, DP4, etc.&lt;br /&gt;
|-&lt;br /&gt;
|  NaN * 0&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  +inf - +inf&lt;br /&gt;
|  NaN&lt;br /&gt;
|  Indicates +inf is real inf, not FLT_MAX&lt;br /&gt;
|-&lt;br /&gt;
|  rsq(rcp(-inf))&lt;br /&gt;
|  +inf&lt;br /&gt;
|  Indicates that there isn&#039;t -0.0.&lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  rcp(-0)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  no -0 so differs from IEEE where rcp(-0) = -inf &lt;br /&gt;
|-&lt;br /&gt;
|  rcp(0)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rcp(+inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rcp(NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  rsq(-0)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  no -0 so differs from IEEE where rsq(-0) = -inf &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(-2)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(+inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(-inf)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  max(0, +inf)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(0, -inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(0, NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  max violates IEEE but match GLSL spec&lt;br /&gt;
|-&lt;br /&gt;
|  max(NaN, 0)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(-inf, +inf)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  min(0, +inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(0, -inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(0, NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  min violates IEEE but match GLSL spec&lt;br /&gt;
|-&lt;br /&gt;
|  min(NaN, 0)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(-inf, +inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  cmp(s, 0)&lt;br /&gt;
|  false&lt;br /&gt;
|  cmp does not flush input subnormals&lt;br /&gt;
|-&lt;br /&gt;
|  max(s, 0)&lt;br /&gt;
|  s&lt;br /&gt;
|  max does not flush input or output subnormals&lt;br /&gt;
|-&lt;br /&gt;
|  mul(s, 2)&lt;br /&gt;
|  0&lt;br /&gt;
|  input subnormals are flushed in arithmetic instructions&lt;br /&gt;
|-&lt;br /&gt;
|  mul(n, 0.5)&lt;br /&gt;
|  0&lt;br /&gt;
|  output subnormals are flushed in arithmetic instructions&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
1.0 can be multiplied 63 times by 0.5 until the result compares equal zero. This is consistent with a 7-bit exponent and output subnormal flushing.&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=20296</id>
		<title>Homebrew Applications</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=20296"/>
		<updated>2017-09-08T20:48:10Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Undo revision 20295 by Sdgsdas (talk) ~ Revert vandalism&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Installing ==&lt;br /&gt;
Applications are installed by copying the necessary files directly to the &amp;lt;code&amp;gt;3ds/&amp;lt;/code&amp;gt; folder in the root of the SD card (preferred for new designs), or in a subdirectory of &amp;lt;code&amp;gt;3ds/&amp;lt;/code&amp;gt;, in which case said subfolder must be named identically to its executable. Most applications come with two files:&lt;br /&gt;
* &amp;lt;code&amp;gt;[appname].3dsx&amp;lt;/code&amp;gt;: The executable.&lt;br /&gt;
* &amp;lt;code&amp;gt;[appname].smdh&amp;lt;/code&amp;gt;: The icon/metadata. (Not required in any case, and may be integrated into the &amp;lt;code&amp;gt;.3dsx&amp;lt;/code&amp;gt;)&lt;br /&gt;
* &amp;lt;code&amp;gt;[appname].xml&amp;lt;/code&amp;gt;: The list of supported targets (i.e. installed titles which the app supports replacing in memory at runtime, thus inheriting its permissions), and of any arguments to be passed to the .3dsx. (Optional)&lt;br /&gt;
&lt;br /&gt;
A standalone .xml file can point to a differently-named .3dsx, launching it with potentially different arguments so that a single application can run in different modes.&lt;br /&gt;
&lt;br /&gt;
The [[Homebrew Launcher]] will scan the SD card for all &amp;lt;code&amp;gt;.3dsx&amp;lt;/code&amp;gt; files, but will only display an icon for those who have one according to the format described above. Recent enough versions can freely navigate the filesystem to select an application.&lt;br /&gt;
&lt;br /&gt;
== List ==&lt;br /&gt;
&lt;br /&gt;
=== Launchers ===&lt;br /&gt;
&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/fincs/new-hbmenu Homebrew Launcher]&lt;br /&gt;
| Run homebrew on your 3DS! Compatible with Rosalina and all prior 3dsx loading solutions&lt;br /&gt;
| [https://devkitpro.org devkitPro]&lt;br /&gt;
| [https://github.com/fincs/new-hbmenu/releases 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;
| [https://github.com/smealum/3ds_hb_menu Homebrew Launcher (v1.x)]&lt;br /&gt;
| The old version of the 3DS Homebrew Launcher, originally created for ninjhax 1.x (Discontinued)&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;
| [http://gbatemp.net/threads/release-homebrew-launcher-with-grid-layout.397527/ Mashers&#039; HBL]&lt;br /&gt;
| Homebrew Launcher with grid and folder support. (Discontinued)&lt;br /&gt;
| [[User:Mashers|Mashers]]&lt;br /&gt;
| [https://github.com/d0k3/3DS-Extended-Homebrew-Starter-Pack/blob/35b8ab7dc40cb550b6ea45da319cdd0a0a3b2b54/boot.3dsx Here]&lt;br /&gt;
| Lost in masher&#039;s retirement&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&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 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-08-17&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/VideahGams/3dsfetch 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/tree/master Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-09-17&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/joel16/3DSident/ 3DSident]&lt;br /&gt;
| Identity tool for the Nintendo 3DS heavily inspired by PSPident.&lt;br /&gt;
| [[User:Joel16|Joel16]]&lt;br /&gt;
| [https://github.com/joel16/3DSident/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-7-21&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 &amp;lt;code&amp;gt;syscall&amp;lt;/code&amp;gt;s over Wi-Fi from a Python shell on your PC. Useful during reverse-engineering. &#039;&#039;No longer under (active) development?&#039;&#039;&lt;br /&gt;
| [[User:plutooo|plutoo]]&lt;br /&gt;
| Build from [https://github.com/plutooo/ctrrpc repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2014-11-10&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/yellows8/ctr-streaming-server ctr-streaming-server]&lt;br /&gt;
| A 3DS homebrew audio/video playback server. It can also send [[HID_Shared_Memory|HID]] state to the client (see the README) when enabled. The included &amp;lt;code&amp;gt;parse_hidstream&amp;lt;/code&amp;gt; tool can be used to parse that HID data to simulate keyboard/mouse input events, via Linux &amp;lt;code&amp;gt;uinput&amp;lt;/code&amp;gt;. &#039;&#039;No longer under (active) development?&#039;&#039;&lt;br /&gt;
| [[User:yellows8|yellows8]]&lt;br /&gt;
| Build from [https://github.com/yellows8/ctr-streaming-server repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2014-11-20&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Rinnegatamante/CHMM2 Custom Home Menu Manager 2]&lt;br /&gt;
| Theme manager for Nintendo 3DS. Discontinued.&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [http://rinnegatamante.it/CHMM2.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-07-04&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/ErmanSayin/Themely/tree/88e93816e3b43a40bcee25b1a7a8c71ef6a37db8 Themely]&lt;br /&gt;
| Theme manager for Nintendo 3DS.&lt;br /&gt;
| ErmanSayin&lt;br /&gt;
| [https://github.com/ErmanSayin/Themely/releases/tag/v1.3.1 Here]&lt;br /&gt;
| Not anymore, 1.3.1 last FOSS version&lt;br /&gt;
| 2017-6-28&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/DownloadMii/DownloadMii-3DS DownloadMii]&lt;br /&gt;
| A WIP repo-based online marketplace for homebrew applications &amp;amp; games.&lt;br /&gt;
| [[User:filfat|filfat]]&lt;br /&gt;
| Build from [https://github.com/DownloadMii/DownloadMii-3DS repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-11-24&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 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-10-07&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/linoma/fb43ds fb43ds]&lt;br /&gt;
| A simple 3DS Facebook chat client&lt;br /&gt;
| [[User:linoma|linoma]]&lt;br /&gt;
| Build from [https://github.com/linoma/fb43ds repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-04-07&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;
| 2016-03-26&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/MrJPGames/NFCReader NFCReader]&lt;br /&gt;
| Allows you to use your 3DS as a NFC/RFID UID Scanner.&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/NFCReader/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-01-21&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/SciresM/ScreenInfo ScreenInfo]&lt;br /&gt;
| Identify whether New 3DS LCD panels are TN or IPS.&lt;br /&gt;
| [[User:SciresM|SciresM]]&lt;br /&gt;
| [https://github.com/SciresM/ScreenInfo/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-09-04&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/VideahGams/LovePotion LövePotion]&lt;br /&gt;
| An unofficial WIP implementation of the [https://github.com/love2d-community/love-api 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;
| Yes&lt;br /&gt;
| 2016-09-12&lt;br /&gt;
|-&lt;br /&gt;
| [https://ctrulua.github.io/ ctrµLua]&lt;br /&gt;
| A Lua interpreter for 3DS, brought to life by the remnants of the µLua community.&lt;br /&gt;
| [[User:Firew0lf|Firew0lf]], Reuh, Negi&lt;br /&gt;
| [https://github.com/ctruLua/ctruLua/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-06-27&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Rinnegatamante/lpp-3ds LuaPlayer+ 3DS]&lt;br /&gt;
| First Lua interpreter 3DS homebrew, under Lua 5.3.1&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [https://github.com/Rinnegatamante/lpp-3ds/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-09-21&lt;br /&gt;
|-&lt;br /&gt;
| [http://asie.pl/homebrew/#megazeux MegaZeux 3DS]&lt;br /&gt;
| A port of the MegaZeux GCS to the 3DS.&lt;br /&gt;
| asie&lt;br /&gt;
| [http://asie.pl/homebrew/#megazeux Here]&lt;br /&gt;
| [https://github.com/asiekierka/megazeux/tree/3ds Yes]&lt;br /&gt;
| 2016-10-30&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&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;
| A remake of homebrew &amp;quot;100 Boxes puzzle&amp;quot; for DS and GBA.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/100Boxes2DS/100_Boxes_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-11&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D 2048-3D]&lt;br /&gt;
| A port of the popular game 2048 for the 3DS.&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-02-12&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://github.com/smealum/3dscraft 3DSCraft]&#039;&#039;&lt;br /&gt;
| A Minecraft port for the 3DS. &#039;&#039;No longer under (active) development?&#039;&#039;&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| Build from [https://github.com/smealum/3dscraft repo] (alt. [https://smealum.github.io/3dscraft/downloads/3dscraft_141120.zip here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2014-11-20&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/markwinap/3DS_Nyan_Cat 3DS Nyan Cat]&lt;br /&gt;
| A port of Nyan Cat for the 3DS, using &amp;lt;code&amp;gt;LIBSF2D&amp;lt;/code&amp;gt;.&lt;br /&gt;
| [[User:markwinap|markwinap]]&lt;br /&gt;
| Build from [https://github.com/markwinap/3DS_Nyan_Cat repo] (alt. [https://www.dropbox.com/s/e400my3xm0zw74r/nyan_cat.zip?dl=0 here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-05-26&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/preview-ld-34-port-antibounce.406361 Antibounce]&lt;br /&gt;
| &amp;quot;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.&amp;quot;&lt;br /&gt;
| [[User:TurtleP|TurtleP]]&lt;br /&gt;
| [https://github.com/TurtleP/Antibounce/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-12-23&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://github.com/UnsureSherlock/checkers3ds checkers3ds]&#039;&#039;&lt;br /&gt;
| A checkers game in glorious ASCII. &#039;&#039;No longer under development.&#039;&#039;&lt;br /&gt;
| [[User:UnsureSherlock|UnsureSherlock]]&lt;br /&gt;
| Build from [https://github.com/UnsureSherlock/checkers3ds repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-02-25&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Kaisogen/CookieCollector-3DS- Cookie Collector]&lt;br /&gt;
| A tiny adaptation of the popular [https://en.wikipedia.org/wiki/Cookie_Clicker Cookie Clicker] game for the 3DS.&lt;br /&gt;
| [[User:Kaisogen|Kaisogen]]&lt;br /&gt;
| [https://github.com/Kaisogen/CookieCollector-3DS-/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-06-04&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/TheMachinumps/Cookie_Clicker_3DS Cookie Clicker 3DS]&lt;br /&gt;
| A simple Cookie Clicker type of game inspired by [[User:Kaisogen|Kaisogen]]&#039;s Cookie Collector&lt;br /&gt;
| [[User:TheMachinumps|TheMachinumps]]&lt;br /&gt;
| [https://github.com/TheMachinumps/Cookie_Clicker_3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-08-27&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 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-04-17&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/masterfeizz/EDuke3D EDuke3D]&lt;br /&gt;
| An unofficial port of EDuke32 for the 3DS.&lt;br /&gt;
| [[User:MasterFeizz|MasterFeizz]]&lt;br /&gt;
| [https://github.com/masterfeizz/EDuke3D/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-05-09&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-hamsters-2ds.383457/ Hamsters 2DS]&lt;br /&gt;
| A text-based hamster breeding game.&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;
| 2015-11-01&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS Helii]&lt;br /&gt;
| A port of [https://github.com/BHSPitMonkey/Helii3D Helii] for the 3DS.&lt;br /&gt;
| [[User:BHSPitMonkey|BHSPitMonkey]]&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-09-18&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/sgowen/insectoid-defense Insectoid Defense]&lt;br /&gt;
| A Sci-Fi Tower Defense game.&lt;br /&gt;
| [[User:Sgowen|sgowen]]&lt;br /&gt;
| [https://github.com/sgowen/insectoid-defense/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-11-09&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/VideahGams/NumberFucker3DS 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;
| Yes&lt;br /&gt;
| 2015-09-19&lt;br /&gt;
|-&lt;br /&gt;
|[https://gbatemp.net/threads/release-zelda-roth-for-3ds.425503/ Zelda ROTH for 3DS]&lt;br /&gt;
|A port of Legend of Zelda: Return of the Hylian, a Zelda fangame, to 3DS.&lt;br /&gt;
|[[User:nop90|nop90]]&lt;br /&gt;
|[https://github.com/nop90/ZeldaROTH/releases Here]&lt;br /&gt;
|Yes&lt;br /&gt;
|2016-09-11&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-mastermind-3ds.394710/ Mastermind 3DS]&lt;br /&gt;
| A port of Mastermind for the 3DS.&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/Mastermind-3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-08-15&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-minesweeper-2ds.384185/ Minesweeper 2DS]&lt;br /&gt;
| A port of Minesweeper for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Minesweeper2DS/Minesweeper_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-01&lt;br /&gt;
|-&lt;br /&gt;
| [https://pyug.at/PyWeek/2012-09 One Whale Trip]&lt;br /&gt;
| Five-lane underwater whale swimming/pearl pickup adventure game in Python.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://bitbucket.org/pyugat/pyweek1209/downloads/OneWhaleTrip-2016-07-18-3DS.zip Here]&lt;br /&gt;
| [https://bitbucket.org/pyugat/pyweek1209/src/bce5156dbee72f38c4fcf5d7b3df9cfb9ddd5b0a/3ds Yes]&lt;br /&gt;
| 2016-10-02&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;
| [[User:Peanut42|Peanut42]]&lt;br /&gt;
| [http://puffles.gatuno.mx/releases/paddlepuffle3ds.zip Here]&lt;br /&gt;
| [https://github.com/gatuno/PaddlePuffle3DS Yes]&lt;br /&gt;
| 2015-07-05&lt;br /&gt;
|-&lt;br /&gt;
| [http://david.dantoine.org/proyecto/26/ Pituka Classics]&lt;br /&gt;
| Play CPC classics using [http://david.dantoine.org/proyecto/4/ Pituka Emulator-Core] on 3DS.&lt;br /&gt;
| [[User:D_Skywalk|D_Skywalk]]&lt;br /&gt;
| [http://david.dantoine.org/descargas/72 Rick Dangerous] [http://david.dantoine.org/descargas/2 Core]&lt;br /&gt;
| [http://david.dantoine.org/descargas/4 Yes (core)]&lt;br /&gt;
| 2016-02-26&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-shuffle-2ds.398540/ Pixel Shuffle 2DS]&lt;br /&gt;
| An adaptation of the puzzle game [http://www.gimme5games.com/play-game/pixelshuffle Pixel Shuffle] for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelShuffle2DS/Pixel_Shuffle_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-01&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-swap-2ds.395749/ Pixel Swap 2DS]&lt;br /&gt;
| An adaptation of puzzle games Pixel Swap 1 &amp;amp; 2 for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelSwap2DS/Pixel_Swap_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-01&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;
| [[User:smea|smea]]&lt;br /&gt;
| Build from [https://github.com/smealum/portal3DS repo] (Decompiled [http://www.mediafire.com/file/yo463wt6y4tybch/portal3DS.rar here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-08-18&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/masterfeizz/ctrQuake ctrQuake]&lt;br /&gt;
| An unofficial port of Quake for the 3DS, fully playable.&lt;br /&gt;
| [[User:MasterFeizz|MasterFeizz]]&lt;br /&gt;
| [https://github.com/masterfeizz/ctrQuake/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-09-16&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;
| Yes&lt;br /&gt;
| 2016-03-05&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/landm2000/sokoban Sokoban]&lt;br /&gt;
| An unofficial port of the puzzle game [https://en.wikipedia.org/wiki/Sokoban Sokoban] for the 3DS.&lt;br /&gt;
| [[User:Landm|Landm]]&lt;br /&gt;
| [https://github.com/landm2000/sokoban/tree/master Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-03-14&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.&lt;br /&gt;
| [[User:TurtleP|TurtleP]]&lt;br /&gt;
| [https://github.com/TurtleP/SpaceFruit/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-04-09&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/sgowen/tappy-plane Tappy Plane]&lt;br /&gt;
| A port of [https://en.wikipedia.org/wiki/Flappy_Bird Flappy Bird] for 3DS, but with a colorful plane.&lt;br /&gt;
| [[User:Sgowen|sgowen]]&lt;br /&gt;
| [https://github.com/sgowen/tappy-plane/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-11-09&lt;br /&gt;
|-&lt;br /&gt;
| [https://thp.itch.io/tetrepetete-3ds Tetrepetete 3DS]&lt;br /&gt;
| A game with blocks.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://thp.itch.io/tetrepetete-3ds Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2016-06-29&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tilemap-2ds.386733/ TileMap 2DS]&lt;br /&gt;
| An adaptation of the puzzle game TileMap for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/TileMap2DS/TileMap_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-03&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tiles-2ds.385796/ Tiles 2DS]&lt;br /&gt;
| An adaptation of the puzzle game Lights Out for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Tiles2DS/Tiles_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-01&lt;br /&gt;
|-&lt;br /&gt;
| [https://thp.itch.io/that-rabbit-game-3ds That Rabbit Game 3DS]&lt;br /&gt;
| Inverse duck hunt with accelerometer input and stereoscopic 3D.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://thp.itch.io/that-rabbit-game-3ds Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2016-07-04&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/trucmuche-2ds-09.404859// Trucmuche 2DS 09]&lt;br /&gt;
| An adaptation of the hidden objects game Trucmuche for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Trucmuche2DS09/Trucmuche_2DS_09.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-12-03&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand World of 3DSand]&lt;br /&gt;
| A port of World of Sand for the 3DS.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-07-12&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;
| [[User:smea|smea]]&lt;br /&gt;
| Build from [https://github.com/smealum/yeti3DS repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-08-07&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://github.com/st4rk/3DNES 3DNES]&#039;&#039;&lt;br /&gt;
| A NES emulator, without sound support. &#039;&#039;No longer under development.&#039;&#039;&lt;br /&gt;
| st4rk, gdkChan&lt;br /&gt;
| [https://github.com/St4rk/3DNES/raw/master/3DNES_old.3dsx Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-03-28&lt;br /&gt;
|-&lt;br /&gt;
| [http://asie.pl/homebrew/#atari800 atari800-3DS]&lt;br /&gt;
| An Atari 8-bit home computer emulator.&lt;br /&gt;
| asie&lt;br /&gt;
| [http://asie.pl/homebrew/#atari800 Here]&lt;br /&gt;
| [https://github.com/asiekierka/atari800-3ds Yes]&lt;br /&gt;
| 2016-10-29&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/StapleButter/blargSnes blargSnes]&lt;br /&gt;
| A Super Nintendo (SNES) emulator. A compatibility list can be found [http://wiki.gbatemp.net/wiki/BlargSnes_Compatibility_List here].&lt;br /&gt;
| StapleButter&lt;br /&gt;
| [http://blargsnes.kuribo64.net/download/blargSnes_1.3b.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-06-12&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;
| Build from [https://github.com/xerpi/CHIP-3DS repo] (alt. [https://www.mediafire.com/?y94yjhzf70fsfsi here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-04-02&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/chip8-3ds.434425/ CHIP8-2DS]&lt;br /&gt;
| CHIP-8 emulator with savestates and touch controls.&lt;br /&gt;
| nopy4869&lt;br /&gt;
| [https://github.com/nopy4869/CHIP8-2DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-07-20&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/shinyquagsire23/gpsp CitrAGB]&lt;br /&gt;
| Yet another GBA emulator for the 3DS.&lt;br /&gt;
| [[User:shinyquagsire23|Shiny Quagsire]]&lt;br /&gt;
| Build from [https://github.com/shinyquagsire23/gpsp/tree/master/3ds repo] (alt. [https://www.dropbox.com/s/sxb7x34u58g4zo2/3ds.3dsx?dl=0 here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-09-21&lt;br /&gt;
|-&lt;br /&gt;
| [https://easy-rpg.org/blog/2016/05/player-for-nintendo-3ds/ EasyRPG Player]&lt;br /&gt;
| RPG Maker 2000/2003 interpreter&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]] &amp;amp; EasyRPG Team&lt;br /&gt;
| [https://easyrpg.org/player/downloads/ Here]&lt;br /&gt;
| [https://github.com/EasyRPG/Player Yes]&lt;br /&gt;
| 2017-06-28&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;
| 2016-07-17&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mgba-emu/mgba mGBA]&lt;br /&gt;
| A GBA emulator that runs well without kernel hax.&lt;br /&gt;
| endrift&lt;br /&gt;
| [https://mgba.io/downloads.html Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-10-13&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mrdanielps/r3Ddragon r3Ddragon]&lt;br /&gt;
| A WIP Virtual Boy emulator for the 3DS based on Reality Boy / Red Dragon.&lt;br /&gt;
| mrdanielps&lt;br /&gt;
| [https://github.com/mrdanielps/r3Ddragon/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-08-16&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;
| Undergoing rapid development.&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/bubble2k16/snes9x_3ds SNES9x for 3DS]&lt;br /&gt;
| A SNES emulator for the old 3DS / 2DS. Optimised from Snes9x 1.43 and runs many games at full speed. Compatibility list [http://wiki.gbatemp.net/wiki/Snes9x_for_3DS here]&lt;br /&gt;
| bubble2k16&lt;br /&gt;
| [https://github.com/bubble2k16/snes9x_3ds/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-02-11&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/bubble2k16/emus3ds_3ds VirtuaNES for 3DS]&lt;br /&gt;
| A NES emulator for the old 3DS / 2DS. Optimised from VirtuaNES 0.9.7 and runs many games at full speed. ]&lt;br /&gt;
| bubble2k16&lt;br /&gt;
| [https://github.com/bubble2k16/emus3ds/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-03-23&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Title managers===&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/FBI FBI]&lt;br /&gt;
| Open source CIA (un)installer and launcher.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases?after=2.0.0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-12-02&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/FBI FBI 2]&lt;br /&gt;
| Multipurpose file/title/ticket/save manager&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-12-31&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.7&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [http://rinnegatamante.it/site/3ds_hbs.php Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2016-04-13&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Save managers===&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/save-data-manager-and-editor-for-firmware-up-to-9-9.396245/ save_manager]&lt;br /&gt;
| Proof of concept save exporter/importer&lt;br /&gt;
| [[User:profi200|profi200]]&lt;br /&gt;
| [http://gbatemp.net/attachments/save_manager_-with_smdh-zip.24349/ Here]&lt;br /&gt;
| [https://gist.github.com/profi200/d0d092c11d0eb0692748 Yes]&lt;br /&gt;
| 2015-09-13&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;
| 2015-10-16&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-jks-savemanager-homebrew-cia-save-manager.413143/ JK&#039;s Save Manager]&lt;br /&gt;
| Save/Extdata Manager&lt;br /&gt;
| JK_&lt;br /&gt;
| [https://gbatemp.net/threads/release-jks-savemanager-homebrew-cia-save-manager.413143/ Here]&lt;br /&gt;
| [https://github.com/J-D-K/JKSM/ Yes]&lt;br /&gt;
| 2016-09-29&lt;br /&gt;
|-&lt;br /&gt;
| JK&#039;s Save Manager for Rosalina&lt;br /&gt;
| Modded version of JKSM for use as .3dsx on Luma 8+&lt;br /&gt;
| Phalk, JK_&lt;br /&gt;
| [https://github.com/Phalk/JKSM/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-7-12&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/BernardoGiordano/PKSM PKSM]&lt;br /&gt;
| Save editor for Pokèmon generations 4 to 7&lt;br /&gt;
| Bernardo Giordano&lt;br /&gt;
| [https://github.com/BernardoGiordano/PKSM/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-8-3&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/phijor/SpecializeMii/ SpecializeMii]&lt;br /&gt;
| Editor for Mii database (specialness)&lt;br /&gt;
| phijor&lt;br /&gt;
| [https://github.com/phijor/SpecializeMii/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-1-22&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/rboninsegna/SpecializeMii/ SpecializeMii]&lt;br /&gt;
| Editor for Mii database (specialness and ownership)&lt;br /&gt;
| phijor, [[User:Ryccardo|Ryccardo]]&lt;br /&gt;
| [https://github.com/rboninsegna/SpecializeMii/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-8-13&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== File servers ===&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mtheall/ftpd ftpd (ftBrony)]&lt;br /&gt;
| A FTP server.&lt;br /&gt;
| [https://github.com/mtheall mtheall]&lt;br /&gt;
| [https://github.com/mtheall/ftpd/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-09-17&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://github.com/iamevn/FTP-3DS FTP-3DS]&#039;&#039;&lt;br /&gt;
| Fork of ftBrony with a Nintendo theme. &#039;&#039;No longer under development and without repo.&#039;&#039;&lt;br /&gt;
| [[User:iamevn|iamevn]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes (&#039;&#039;No source officially available.&#039;&#039;)&lt;br /&gt;
| N/A&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/FloatingStar/FTP-GMX FTP - Graphic ModifierX Edition]&lt;br /&gt;
| Fork of ftpd with aesthetic modifications.&lt;br /&gt;
| [[User:FloatingStar|FloatingStar]]&lt;br /&gt;
| [https://github.com/FloatingStar/FTP-GMX/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-01-27&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. &#039;&#039;No longer under (active) development?&#039;&#039;&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| Build from [https://github.com/smealum/ftpony repo] (alt. [https://mega.co.nz/#!nchBkL7B!T3vXnX4q8Uwp6APYYTDSZi2bkm25la-Qyz6j4CjsllI here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2014-11-24&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Icon Packs ===&lt;br /&gt;
Icon Packs are &amp;lt;code&amp;gt;SMDH&amp;lt;/code&amp;gt; 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;
| [https://gbatemp.net/threads/icon-pack-simplok-for-the-homebrew-launcher.396750/ Simplok]&lt;br /&gt;
| The first 3DS Icon pack.&lt;br /&gt;
| [[User:link6155|link6155]]&lt;br /&gt;
| [http://1drv.ms/1EJCq2e Here]&lt;br /&gt;
| 2015-09-12&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://gbatemp.net/threads/1lp-icon-pack.402018/ 1LP]&#039;&#039;&lt;br /&gt;
| Another 3DS Icon pack. &#039;&#039;Repo is dead, no alternate downloads available.&#039;&#039;&lt;br /&gt;
| [[User:100pcrack|100pcrack]]&lt;br /&gt;
| N/A&lt;br /&gt;
| 2015-12-22&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/icon-pack-modern-ui.404366/ Modern UI]&lt;br /&gt;
| A simple icon pack with a flat and minimalist design.&lt;br /&gt;
| [[User:LouchDaishiteru|LouchDaishiteru]]&lt;br /&gt;
| [https://gbatemp.net/threads/icon-pack-modern-ui.404366/ Here]&lt;br /&gt;
| 2016-02-15&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| cubedemo&lt;br /&gt;
| A short demo of Homebrew on the 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;
| N/A&lt;br /&gt;
|-&lt;br /&gt;
| Spine 2D&lt;br /&gt;
| Demo of [http://esotericsoftware.com/ Spine]&#039;s 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;
| N/A&lt;br /&gt;
|-&lt;br /&gt;
| [http://www.pouet.net/prod.php?which=66607 demo ou mourir]&lt;br /&gt;
| Small demo for the 3DS with music and 2D effects&lt;br /&gt;
| Desire&lt;br /&gt;
| [http://mudlord.info/democrap/dsr_demooumourir.zip Here]&lt;br /&gt;
| No&lt;br /&gt;
| November 2015&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=20235</id>
		<title>Homebrew Applications</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=20235"/>
		<updated>2017-08-13T15:47:23Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Launchers */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Installing ==&lt;br /&gt;
Applications are installed by copying the necessary files directly to the &amp;lt;code&amp;gt;3ds/&amp;lt;/code&amp;gt; folder in the root of the SD card (preferred for new designs), or in a subdirectory of &amp;lt;code&amp;gt;3ds/&amp;lt;/code&amp;gt;, in which case said subfolder must be named identically to its executable. Most applications come with two files:&lt;br /&gt;
* &amp;lt;code&amp;gt;[appname].3dsx&amp;lt;/code&amp;gt;: The executable.&lt;br /&gt;
* &amp;lt;code&amp;gt;[appname].smdh&amp;lt;/code&amp;gt;: The icon/metadata. (Not required in any case, and may be integrated into the &amp;lt;code&amp;gt;.3dsx&amp;lt;/code&amp;gt;)&lt;br /&gt;
* &amp;lt;code&amp;gt;[appname].xml&amp;lt;/code&amp;gt;: The list of supported targets (i.e. installed titles which the app supports replacing in memory at runtime, thus inheriting its permissions), and of any arguments to be passed to the .3dsx. (Optional)&lt;br /&gt;
&lt;br /&gt;
A standalone .xml file can point to a differently-named .3dsx, launching it with potentially different arguments so that a single application can run in different modes.&lt;br /&gt;
&lt;br /&gt;
The [[Homebrew Launcher]] will scan the SD card for all &amp;lt;code&amp;gt;.3dsx&amp;lt;/code&amp;gt; files, but will only display an icon for those who have one according to the format described above. Recent enough versions can freely navigate the filesystem to select an application.&lt;br /&gt;
&lt;br /&gt;
== List ==&lt;br /&gt;
&lt;br /&gt;
=== Launchers ===&lt;br /&gt;
&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/fincs/new-hbmenu Homebrew Launcher]&lt;br /&gt;
| Run homebrew on your 3DS! Compatible with Rosalina and all prior 3dsx loading solutions&lt;br /&gt;
| [https://devkitpro.org devkitPro]&lt;br /&gt;
| [https://github.com/fincs/new-hbmenu/releases 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;
| [https://github.com/smealum/3ds_hb_menu Homebrew Launcher (v1.x)]&lt;br /&gt;
| The old version of the 3DS Homebrew Launcher, originally created for ninjhax 1.x (Discontinued)&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;
| [http://gbatemp.net/threads/release-homebrew-launcher-with-grid-layout.397527/ Mashers&#039; HBL]&lt;br /&gt;
| Homebrew Launcher with grid and folder support. (Discontinued)&lt;br /&gt;
| [[User:Mashers|Mashers]]&lt;br /&gt;
| [https://github.com/d0k3/3DS-Extended-Homebrew-Starter-Pack/blob/35b8ab7dc40cb550b6ea45da319cdd0a0a3b2b54/boot.3dsx Here]&lt;br /&gt;
| Lost in masher&#039;s retirement&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&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 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-08-17&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/VideahGams/3dsfetch 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/tree/master Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-09-17&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/joel16/3DSident/ 3DSident]&lt;br /&gt;
| Identity tool for the Nintendo 3DS heavily inspired by PSPident.&lt;br /&gt;
| [[User:Joel16|Joel16]]&lt;br /&gt;
| [https://github.com/joel16/3DSident/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-7-21&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 &amp;lt;code&amp;gt;syscall&amp;lt;/code&amp;gt;s over Wi-Fi from a Python shell on your PC. Useful during reverse-engineering. &#039;&#039;No longer under (active) development?&#039;&#039;&lt;br /&gt;
| [[User:plutooo|plutoo]]&lt;br /&gt;
| Build from [https://github.com/plutooo/ctrrpc repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2014-11-10&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/yellows8/ctr-streaming-server ctr-streaming-server]&lt;br /&gt;
| A 3DS homebrew audio/video playback server. It can also send [[HID_Shared_Memory|HID]] state to the client (see the README) when enabled. The included &amp;lt;code&amp;gt;parse_hidstream&amp;lt;/code&amp;gt; tool can be used to parse that HID data to simulate keyboard/mouse input events, via Linux &amp;lt;code&amp;gt;uinput&amp;lt;/code&amp;gt;. &#039;&#039;No longer under (active) development?&#039;&#039;&lt;br /&gt;
| [[User:yellows8|yellows8]]&lt;br /&gt;
| Build from [https://github.com/yellows8/ctr-streaming-server repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2014-11-20&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Rinnegatamante/CHMM2 Custom Home Menu Manager 2]&lt;br /&gt;
| Theme manager for Nintendo 3DS. Discontinued.&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [http://rinnegatamante.it/CHMM2.rar Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-07-04&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/ErmanSayin/Themely/tree/88e93816e3b43a40bcee25b1a7a8c71ef6a37db8 Themely]&lt;br /&gt;
| Theme manager for Nintendo 3DS.&lt;br /&gt;
| ErmanSayin&lt;br /&gt;
| [https://github.com/ErmanSayin/Themely/releases/tag/v1.3.1 Here]&lt;br /&gt;
| Not anymore, 1.3.1 last FOSS version&lt;br /&gt;
| 2017-6-28&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/DownloadMii/DownloadMii-3DS DownloadMii]&lt;br /&gt;
| A WIP repo-based online marketplace for homebrew applications &amp;amp; games.&lt;br /&gt;
| [[User:filfat|filfat]]&lt;br /&gt;
| Build from [https://github.com/DownloadMii/DownloadMii-3DS repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-11-24&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 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-10-07&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/linoma/fb43ds fb43ds]&lt;br /&gt;
| A simple 3DS Facebook chat client&lt;br /&gt;
| [[User:linoma|linoma]]&lt;br /&gt;
| Build from [https://github.com/linoma/fb43ds repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-04-07&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;
| 2016-03-26&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/MrJPGames/NFCReader NFCReader]&lt;br /&gt;
| Allows you to use your 3DS as a NFC/RFID UID Scanner.&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/NFCReader/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-01-21&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/SciresM/ScreenInfo ScreenInfo]&lt;br /&gt;
| Identify whether New 3DS LCD panels are TN or IPS.&lt;br /&gt;
| [[User:SciresM|SciresM]]&lt;br /&gt;
| [https://github.com/SciresM/ScreenInfo/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-09-04&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/VideahGams/LovePotion LövePotion]&lt;br /&gt;
| An unofficial WIP implementation of the [https://github.com/love2d-community/love-api 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;
| Yes&lt;br /&gt;
| 2016-09-12&lt;br /&gt;
|-&lt;br /&gt;
| [https://ctrulua.github.io/ ctrµLua]&lt;br /&gt;
| A Lua interpreter for 3DS, brought to life by the remnants of the µLua community.&lt;br /&gt;
| [[User:Firew0lf|Firew0lf]], Reuh, Negi&lt;br /&gt;
| [https://github.com/ctruLua/ctruLua/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-06-27&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Rinnegatamante/lpp-3ds LuaPlayer+ 3DS]&lt;br /&gt;
| First Lua interpreter 3DS homebrew, under Lua 5.3.1&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [https://github.com/Rinnegatamante/lpp-3ds/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-09-21&lt;br /&gt;
|-&lt;br /&gt;
| [http://asie.pl/homebrew/#megazeux MegaZeux 3DS]&lt;br /&gt;
| A port of the MegaZeux GCS to the 3DS.&lt;br /&gt;
| asie&lt;br /&gt;
| [http://asie.pl/homebrew/#megazeux Here]&lt;br /&gt;
| [https://github.com/asiekierka/megazeux/tree/3ds Yes]&lt;br /&gt;
| 2016-10-30&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&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;
| A remake of homebrew &amp;quot;100 Boxes puzzle&amp;quot; for DS and GBA.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/100Boxes2DS/100_Boxes_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-11&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D 2048-3D]&lt;br /&gt;
| A port of the popular game 2048 for the 3DS.&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/2048-3D/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-02-12&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://github.com/smealum/3dscraft 3DSCraft]&#039;&#039;&lt;br /&gt;
| A Minecraft port for the 3DS. &#039;&#039;No longer under (active) development?&#039;&#039;&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| Build from [https://github.com/smealum/3dscraft repo] (alt. [https://smealum.github.io/3dscraft/downloads/3dscraft_141120.zip here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2014-11-20&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/markwinap/3DS_Nyan_Cat 3DS Nyan Cat]&lt;br /&gt;
| A port of Nyan Cat for the 3DS, using &amp;lt;code&amp;gt;LIBSF2D&amp;lt;/code&amp;gt;.&lt;br /&gt;
| [[User:markwinap|markwinap]]&lt;br /&gt;
| Build from [https://github.com/markwinap/3DS_Nyan_Cat repo] (alt. [https://www.dropbox.com/s/e400my3xm0zw74r/nyan_cat.zip?dl=0 here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-05-26&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/preview-ld-34-port-antibounce.406361 Antibounce]&lt;br /&gt;
| &amp;quot;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.&amp;quot;&lt;br /&gt;
| [[User:TurtleP|TurtleP]]&lt;br /&gt;
| [https://github.com/TurtleP/Antibounce/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-12-23&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://github.com/UnsureSherlock/checkers3ds checkers3ds]&#039;&#039;&lt;br /&gt;
| A checkers game in glorious ASCII. &#039;&#039;No longer under development.&#039;&#039;&lt;br /&gt;
| [[User:UnsureSherlock|UnsureSherlock]]&lt;br /&gt;
| Build from [https://github.com/UnsureSherlock/checkers3ds repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-02-25&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Kaisogen/CookieCollector-3DS- Cookie Collector]&lt;br /&gt;
| A tiny adaptation of the popular [https://en.wikipedia.org/wiki/Cookie_Clicker Cookie Clicker] game for the 3DS.&lt;br /&gt;
| [[User:Kaisogen|Kaisogen]]&lt;br /&gt;
| [https://github.com/Kaisogen/CookieCollector-3DS-/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-06-04&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/TheMachinumps/Cookie_Clicker_3DS Cookie Clicker 3DS]&lt;br /&gt;
| A simple Cookie Clicker type of game inspired by [[User:Kaisogen|Kaisogen]]&#039;s Cookie Collector&lt;br /&gt;
| [[User:TheMachinumps|TheMachinumps]]&lt;br /&gt;
| [https://github.com/TheMachinumps/Cookie_Clicker_3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-08-27&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 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-04-17&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/masterfeizz/EDuke3D EDuke3D]&lt;br /&gt;
| An unofficial port of EDuke32 for the 3DS.&lt;br /&gt;
| [[User:MasterFeizz|MasterFeizz]]&lt;br /&gt;
| [https://github.com/masterfeizz/EDuke3D/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-05-09&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-hamsters-2ds.383457/ Hamsters 2DS]&lt;br /&gt;
| A text-based hamster breeding game.&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;
| 2015-11-01&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS Helii]&lt;br /&gt;
| A port of [https://github.com/BHSPitMonkey/Helii3D Helii] for the 3DS.&lt;br /&gt;
| [[User:BHSPitMonkey|BHSPitMonkey]]&lt;br /&gt;
| [https://github.com/BHSPitMonkey/Helii3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-09-18&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/sgowen/insectoid-defense Insectoid Defense]&lt;br /&gt;
| A Sci-Fi Tower Defense game.&lt;br /&gt;
| [[User:Sgowen|sgowen]]&lt;br /&gt;
| [https://github.com/sgowen/insectoid-defense/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-11-09&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/VideahGams/NumberFucker3DS 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;
| Yes&lt;br /&gt;
| 2015-09-19&lt;br /&gt;
|-&lt;br /&gt;
|[https://gbatemp.net/threads/release-zelda-roth-for-3ds.425503/ Zelda ROTH for 3DS]&lt;br /&gt;
|A port of Legend of Zelda: Return of the Hylian, a Zelda fangame, to 3DS.&lt;br /&gt;
|[[User:nop90|nop90]]&lt;br /&gt;
|[https://github.com/nop90/ZeldaROTH/releases Here]&lt;br /&gt;
|Yes&lt;br /&gt;
|2016-09-11&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-mastermind-3ds.394710/ Mastermind 3DS]&lt;br /&gt;
| A port of Mastermind for the 3DS.&lt;br /&gt;
| [[User:MrJPGames|Jasper Peters]]&lt;br /&gt;
| [https://github.com/MrJPGames/Mastermind-3DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-08-15&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-minesweeper-2ds.384185/ Minesweeper 2DS]&lt;br /&gt;
| A port of Minesweeper for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Minesweeper2DS/Minesweeper_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-01&lt;br /&gt;
|-&lt;br /&gt;
| [https://pyug.at/PyWeek/2012-09 One Whale Trip]&lt;br /&gt;
| Five-lane underwater whale swimming/pearl pickup adventure game in Python.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://bitbucket.org/pyugat/pyweek1209/downloads/OneWhaleTrip-2016-07-18-3DS.zip Here]&lt;br /&gt;
| [https://bitbucket.org/pyugat/pyweek1209/src/bce5156dbee72f38c4fcf5d7b3df9cfb9ddd5b0a/3ds Yes]&lt;br /&gt;
| 2016-10-02&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;
| [[User:Peanut42|Peanut42]]&lt;br /&gt;
| [http://puffles.gatuno.mx/releases/paddlepuffle3ds.zip Here]&lt;br /&gt;
| [https://github.com/gatuno/PaddlePuffle3DS Yes]&lt;br /&gt;
| 2015-07-05&lt;br /&gt;
|-&lt;br /&gt;
| [http://david.dantoine.org/proyecto/26/ Pituka Classics]&lt;br /&gt;
| Play CPC classics using [http://david.dantoine.org/proyecto/4/ Pituka Emulator-Core] on 3DS.&lt;br /&gt;
| [[User:D_Skywalk|D_Skywalk]]&lt;br /&gt;
| [http://david.dantoine.org/descargas/72 Rick Dangerous] [http://david.dantoine.org/descargas/2 Core]&lt;br /&gt;
| [http://david.dantoine.org/descargas/4 Yes (core)]&lt;br /&gt;
| 2016-02-26&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-shuffle-2ds.398540/ Pixel Shuffle 2DS]&lt;br /&gt;
| An adaptation of the puzzle game [http://www.gimme5games.com/play-game/pixelshuffle Pixel Shuffle] for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelShuffle2DS/Pixel_Shuffle_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-01&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-pixel-swap-2ds.395749/ Pixel Swap 2DS]&lt;br /&gt;
| An adaptation of puzzle games Pixel Swap 1 &amp;amp; 2 for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/PixelSwap2DS/Pixel_Swap_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-01&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;
| [[User:smea|smea]]&lt;br /&gt;
| Build from [https://github.com/smealum/portal3DS repo] (Decompiled [http://www.mediafire.com/file/yo463wt6y4tybch/portal3DS.rar here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-08-18&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/masterfeizz/ctrQuake ctrQuake]&lt;br /&gt;
| An unofficial port of Quake for the 3DS, fully playable.&lt;br /&gt;
| [[User:MasterFeizz|MasterFeizz]]&lt;br /&gt;
| [https://github.com/masterfeizz/ctrQuake/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-09-16&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;
| Yes&lt;br /&gt;
| 2016-03-05&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/landm2000/sokoban Sokoban]&lt;br /&gt;
| An unofficial port of the puzzle game [https://en.wikipedia.org/wiki/Sokoban Sokoban] for the 3DS.&lt;br /&gt;
| [[User:Landm|Landm]]&lt;br /&gt;
| [https://github.com/landm2000/sokoban/tree/master Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-03-14&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.&lt;br /&gt;
| [[User:TurtleP|TurtleP]]&lt;br /&gt;
| [https://github.com/TurtleP/SpaceFruit/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-04-09&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/sgowen/tappy-plane Tappy Plane]&lt;br /&gt;
| A port of [https://en.wikipedia.org/wiki/Flappy_Bird Flappy Bird] for 3DS, but with a colorful plane.&lt;br /&gt;
| [[User:Sgowen|sgowen]]&lt;br /&gt;
| [https://github.com/sgowen/tappy-plane/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-11-09&lt;br /&gt;
|-&lt;br /&gt;
| [https://thp.itch.io/tetrepetete-3ds Tetrepetete 3DS]&lt;br /&gt;
| A game with blocks.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://thp.itch.io/tetrepetete-3ds Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2016-06-29&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tilemap-2ds.386733/ TileMap 2DS]&lt;br /&gt;
| An adaptation of the puzzle game TileMap for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/TileMap2DS/TileMap_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-03&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/release-tiles-2ds.385796/ Tiles 2DS]&lt;br /&gt;
| An adaptation of the puzzle game Lights Out for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Tiles2DS/Tiles_2DS.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-11-01&lt;br /&gt;
|-&lt;br /&gt;
| [https://thp.itch.io/that-rabbit-game-3ds That Rabbit Game 3DS]&lt;br /&gt;
| Inverse duck hunt with accelerometer input and stereoscopic 3D.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://thp.itch.io/that-rabbit-game-3ds Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2016-07-04&lt;br /&gt;
|-&lt;br /&gt;
| [http://gbatemp.net/threads/trucmuche-2ds-09.404859// Trucmuche 2DS 09]&lt;br /&gt;
| An adaptation of the hidden objects game Trucmuche for the 3DS.&lt;br /&gt;
| [[User:Cid2mizard|Cid2mizard]]&lt;br /&gt;
| [http://3ds.nintendomax.com/Homebrews/Jeux/Trucmuche2DS09/Trucmuche_2DS_09.rar Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2015-12-03&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand World of 3DSand]&lt;br /&gt;
| A port of World of Sand for the 3DS.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/WorldOf3DSand/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-07-12&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;
| [[User:smea|smea]]&lt;br /&gt;
| Build from [https://github.com/smealum/yeti3DS repo]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-08-07&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://github.com/st4rk/3DNES 3DNES]&#039;&#039;&lt;br /&gt;
| A NES emulator, without sound support. &#039;&#039;No longer under development.&#039;&#039;&lt;br /&gt;
| st4rk, gdkChan&lt;br /&gt;
| [https://github.com/St4rk/3DNES/raw/master/3DNES_old.3dsx Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-03-28&lt;br /&gt;
|-&lt;br /&gt;
| [http://asie.pl/homebrew/#atari800 atari800-3DS]&lt;br /&gt;
| An Atari 8-bit home computer emulator.&lt;br /&gt;
| asie&lt;br /&gt;
| [http://asie.pl/homebrew/#atari800 Here]&lt;br /&gt;
| [https://github.com/asiekierka/atari800-3ds Yes]&lt;br /&gt;
| 2016-10-29&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/StapleButter/blargSnes blargSnes]&lt;br /&gt;
| A Super Nintendo (SNES) emulator. A compatibility list can be found [http://wiki.gbatemp.net/wiki/BlargSnes_Compatibility_List here].&lt;br /&gt;
| StapleButter&lt;br /&gt;
| [http://blargsnes.kuribo64.net/download/blargSnes_1.3b.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-06-12&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;
| Build from [https://github.com/xerpi/CHIP-3DS repo] (alt. [https://www.mediafire.com/?y94yjhzf70fsfsi here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-04-02&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/chip8-3ds.434425/ CHIP8-2DS]&lt;br /&gt;
| CHIP-8 emulator with savestates and touch controls.&lt;br /&gt;
| nopy4869&lt;br /&gt;
| [https://github.com/nopy4869/CHIP8-2DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-07-20&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/shinyquagsire23/gpsp CitrAGB]&lt;br /&gt;
| Yet another GBA emulator for the 3DS.&lt;br /&gt;
| [[User:shinyquagsire23|Shiny Quagsire]]&lt;br /&gt;
| Build from [https://github.com/shinyquagsire23/gpsp/tree/master/3ds repo] (alt. [https://www.dropbox.com/s/sxb7x34u58g4zo2/3ds.3dsx?dl=0 here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-09-21&lt;br /&gt;
|-&lt;br /&gt;
| [https://easy-rpg.org/blog/2016/05/player-for-nintendo-3ds/ EasyRPG Player]&lt;br /&gt;
| RPG Maker 2000/2003 interpreter&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]] &amp;amp; EasyRPG Team&lt;br /&gt;
| [https://easyrpg.org/player/downloads/ Here]&lt;br /&gt;
| [https://github.com/EasyRPG/Player Yes]&lt;br /&gt;
| 2017-06-28&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;
| 2016-07-17&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mgba-emu/mgba mGBA]&lt;br /&gt;
| A GBA emulator that runs well without kernel hax.&lt;br /&gt;
| endrift&lt;br /&gt;
| [https://mgba.io/downloads.html Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-10-13&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mrdanielps/r3Ddragon r3Ddragon]&lt;br /&gt;
| A WIP Virtual Boy emulator for the 3DS based on Reality Boy / Red Dragon.&lt;br /&gt;
| mrdanielps&lt;br /&gt;
| [https://github.com/mrdanielps/r3Ddragon/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-08-16&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;
| Undergoing rapid development.&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/bubble2k16/snes9x_3ds SNES9x for 3DS]&lt;br /&gt;
| A SNES emulator for the old 3DS / 2DS. Optimised from Snes9x 1.43 and runs many games at full speed. Compatibility list [http://wiki.gbatemp.net/wiki/Snes9x_for_3DS here]&lt;br /&gt;
| bubble2k16&lt;br /&gt;
| [https://github.com/bubble2k16/snes9x_3ds/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-02-11&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/bubble2k16/emus3ds_3ds VirtuaNES for 3DS]&lt;br /&gt;
| A NES emulator for the old 3DS / 2DS. Optimised from VirtuaNES 0.9.7 and runs many games at full speed. ]&lt;br /&gt;
| bubble2k16&lt;br /&gt;
| [https://github.com/bubble2k16/emus3ds/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-03-23&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Title managers===&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/FBI FBI]&lt;br /&gt;
| Open source CIA (un)installer and launcher.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases?after=2.0.0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-12-02&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/FBI FBI 2]&lt;br /&gt;
| Multipurpose file/title/ticket/save manager&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-12-31&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.7&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [http://rinnegatamante.it/site/3ds_hbs.php Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2016-04-13&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Save managers===&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/save-data-manager-and-editor-for-firmware-up-to-9-9.396245/ save_manager]&lt;br /&gt;
| Proof of concept save exporter/importer&lt;br /&gt;
| [[User:profi200|profi200]]&lt;br /&gt;
| [http://gbatemp.net/attachments/save_manager_-with_smdh-zip.24349/ Here]&lt;br /&gt;
| [https://gist.github.com/profi200/d0d092c11d0eb0692748 Yes]&lt;br /&gt;
| 2015-09-13&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;
| 2015-10-16&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-jks-savemanager-homebrew-cia-save-manager.413143/ JK&#039;s Save Manager]&lt;br /&gt;
| Save/Extdata Manager&lt;br /&gt;
| JK_&lt;br /&gt;
| [https://gbatemp.net/threads/release-jks-savemanager-homebrew-cia-save-manager.413143/ Here]&lt;br /&gt;
| [https://github.com/J-D-K/JKSM/ Yes]&lt;br /&gt;
| 2016-09-29&lt;br /&gt;
|-&lt;br /&gt;
| JK&#039;s Save Manager for Rosalina&lt;br /&gt;
| Modded version of JKSM for use as .3dsx on Luma 8+&lt;br /&gt;
| Phalk, JK_&lt;br /&gt;
| [https://github.com/Phalk/JKSM/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-7-12&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/BernardoGiordano/PKSM PKSM]&lt;br /&gt;
| Save editor for Pokèmon generations 4 to 7&lt;br /&gt;
| Bernardo Giordano&lt;br /&gt;
| [https://github.com/BernardoGiordano/PKSM/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-8-3&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/phijor/SpecializeMii/ SpecializeMii]&lt;br /&gt;
| Editor for Mii database (specialness)&lt;br /&gt;
| phijor&lt;br /&gt;
| [https://github.com/phijor/SpecializeMii/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-1-22&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/rboninsegna/SpecializeMii/ SpecializeMii]&lt;br /&gt;
| Editor for Mii database (specialness and ownership)&lt;br /&gt;
| phijor, [[User:Ryccardo|Ryccardo]]&lt;br /&gt;
| [https://github.com/rboninsegna/SpecializeMii/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2017-8-13&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== File servers ===&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mtheall/ftpd ftpd (ftBrony)]&lt;br /&gt;
| A FTP server.&lt;br /&gt;
| [https://github.com/mtheall mtheall]&lt;br /&gt;
| [https://github.com/mtheall/ftpd/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-09-17&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://github.com/iamevn/FTP-3DS FTP-3DS]&#039;&#039;&lt;br /&gt;
| Fork of ftBrony with a Nintendo theme. &#039;&#039;No longer under development and without repo.&#039;&#039;&lt;br /&gt;
| [[User:iamevn|iamevn]]&lt;br /&gt;
| N/A&lt;br /&gt;
| Yes (&#039;&#039;No source officially available.&#039;&#039;)&lt;br /&gt;
| N/A&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/FloatingStar/FTP-GMX FTP - Graphic ModifierX Edition]&lt;br /&gt;
| Fork of ftpd with aesthetic modifications.&lt;br /&gt;
| [[User:FloatingStar|FloatingStar]]&lt;br /&gt;
| [https://github.com/FloatingStar/FTP-GMX/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-01-27&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. &#039;&#039;No longer under (active) development?&#039;&#039;&lt;br /&gt;
| [[User:smea|smea]]&lt;br /&gt;
| Build from [https://github.com/smealum/ftpony repo] (alt. [https://mega.co.nz/#!nchBkL7B!T3vXnX4q8Uwp6APYYTDSZi2bkm25la-Qyz6j4CjsllI here])&lt;br /&gt;
| Yes&lt;br /&gt;
| 2014-11-24&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Icon Packs ===&lt;br /&gt;
Icon Packs are &amp;lt;code&amp;gt;SMDH&amp;lt;/code&amp;gt; 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;
| [https://gbatemp.net/threads/icon-pack-simplok-for-the-homebrew-launcher.396750/ Simplok]&lt;br /&gt;
| The first 3DS Icon pack.&lt;br /&gt;
| [[User:link6155|link6155]]&lt;br /&gt;
| [http://1drv.ms/1EJCq2e Here]&lt;br /&gt;
| 2015-09-12&lt;br /&gt;
|-&lt;br /&gt;
| &#039;&#039;[https://gbatemp.net/threads/1lp-icon-pack.402018/ 1LP]&#039;&#039;&lt;br /&gt;
| Another 3DS Icon pack. &#039;&#039;Repo is dead, no alternate downloads available.&#039;&#039;&lt;br /&gt;
| [[User:100pcrack|100pcrack]]&lt;br /&gt;
| N/A&lt;br /&gt;
| 2015-12-22&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/icon-pack-modern-ui.404366/ Modern UI]&lt;br /&gt;
| A simple icon pack with a flat and minimalist design.&lt;br /&gt;
| [[User:LouchDaishiteru|LouchDaishiteru]]&lt;br /&gt;
| [https://gbatemp.net/threads/icon-pack-modern-ui.404366/ Here]&lt;br /&gt;
| 2016-02-15&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;5%&amp;quot;  | Open-Source&lt;br /&gt;
!  width=&amp;quot;15%&amp;quot; | Last Updated&lt;br /&gt;
|-&lt;br /&gt;
| cubedemo&lt;br /&gt;
| A short demo of Homebrew on the 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;
| N/A&lt;br /&gt;
|-&lt;br /&gt;
| Spine 2D&lt;br /&gt;
| Demo of [http://esotericsoftware.com/ Spine]&#039;s 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;
| N/A&lt;br /&gt;
|-&lt;br /&gt;
| [http://www.pouet.net/prod.php?which=66607 demo ou mourir]&lt;br /&gt;
| Small demo for the 3DS with music and 2D effects&lt;br /&gt;
| Desire&lt;br /&gt;
| [http://mudlord.info/democrap/dsr_demooumourir.zip Here]&lt;br /&gt;
| No&lt;br /&gt;
| November 2015&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Exploits&amp;diff=20234</id>
		<title>Homebrew Exploits</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Exploits&amp;diff=20234"/>
		<updated>2017-08-13T15:37:26Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Other Homebrew Loaders */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Payload==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Works on latest fw&lt;br /&gt;
!  Name&lt;br /&gt;
!  Description&lt;br /&gt;
!  Supported firmwares&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: DarkOrange&amp;quot; | Only New3DS(XL)&lt;br /&gt;
| [https://smealum.github.io/3ds/ *hax payload]&lt;br /&gt;
| Booted by all of the below non-sysmodule exploits. &#039;&#039;&#039;No longer needed as of [https://github.com/AuroraWright/Luma3DS/releases/tag/v8.0 Luma 8.0]&#039;&#039;&#039;&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-7&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-36&#039;&#039;&#039;, &#039;&#039;&#039;11.4.0-37&#039;&#039;&#039; only New3DS(XL).&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
For the rest of this page, &amp;quot;Supported firmwares&amp;quot; refers to the exploit &#039;&#039;itself&#039;&#039;, not whether *hax payload supports it.&lt;br /&gt;
&lt;br /&gt;
==Standalone Homebrew Launcher Exploits==&lt;br /&gt;
The following homebrew exploits can be executed on a previously un-exploited system. &#039;&#039;Please&#039;&#039; see the above Payload section regarding what &amp;quot;Supported firmwares&amp;quot; indicates &#039;&#039;exactly&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Works on latest fw&lt;br /&gt;
!  Name&lt;br /&gt;
!  Supported firmwares&lt;br /&gt;
!  Requirements&lt;br /&gt;
!  Author&lt;br /&gt;
!  Install&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [[ninjhax|Ninjhax 1.1b]]&lt;br /&gt;
| From &#039;&#039;&#039;4.0.0-7&#039;&#039;&#039; up to and including &#039;&#039;&#039;9.2.0-20&#039;&#039;&#039;.&lt;br /&gt;
| A cartridge or eShop version (JPN-only) of &amp;quot;Cubic Ninja&amp;quot;.&lt;br /&gt;
| smea&lt;br /&gt;
| [http://smealum.net/ninjhax/ Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [[ninjhax|Ninjhax 2.x]]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-7&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-36&#039;&#039;&#039;, &#039;&#039;&#039;11.4.0-37&#039;&#039;&#039; only new3ds(XL).&lt;br /&gt;
|  A cartridge or eShop version (JPN-only, not available anymore for purchase) of &amp;quot;Cubic Ninja&amp;quot;.&lt;br /&gt;
| smea&lt;br /&gt;
| [https://smealum.github.io/ninjhax2/ Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [http://plutooo.github.io/freakyhax/ freakyhax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-7&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-36&#039;&#039;&#039;, &#039;&#039;&#039;11.4.0-37&#039;&#039;&#039; only new3ds(XL).&lt;br /&gt;
|  A cartridge or eShop version (USA/EUR/JAP, not available anymore for purchase) of &amp;quot;Freakyform Deluxe&amp;quot;.&lt;br /&gt;
| plutoo&lt;br /&gt;
| [http://plutooo.github.io/freakyhax/ Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [http://plutooo.github.io/smilehax/ smilehax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-7&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.0.0-33&#039;&#039;&#039;&lt;br /&gt;
| SmileBASIC (JPN all versions up to 3.32 excluded, USA 3.31 only)&lt;br /&gt;
| plutoo&lt;br /&gt;
| [http://plutooo.github.io/smilehax/ Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [http://mrnbayoh.github.io/basicsploit/ BASICSploit]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-7&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.0.0-33&#039;&#039;&#039;&lt;br /&gt;
| SmileBASIC (USA all versions)&lt;br /&gt;
| MrNbaYoh&lt;br /&gt;
| [http://mrnbayoh.github.io/basicsploit/ Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [[smashbroshax|smashbroshax]] (beaconhax)&lt;br /&gt;
| (New 3DS only) From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.4.0-37&#039;&#039;&#039;.&lt;br /&gt;
| Super Smash Bros 3DS (full-game) and a way to broadcast raw wifi beacons. The demo (prior to the updated November 2015 [https://github.com/yellows8/3ds_smashbroshax version]) isn&#039;t usable with the *hax payloads. Game-version v1.1.3 fixed the vuln used with this, see the repo for a workaround for that.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
| [https://github.com/yellows8/3ds_smashbroshax Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [[browserhax]]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-2&#039;&#039;&#039; to &#039;&#039;&#039;11.0.0-33&#039;&#039;&#039;&lt;br /&gt;
Note that the browser-version-check bypass is only usable prior to [[10.7.0-32]].&lt;br /&gt;
| A USA, EUR, JPN, or KOR system.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
| [http://yls8.mtheall.com/3dsbrowserhax.php Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [https://github.com/svanheulen/genhax genhax]&lt;br /&gt;
| (New 3DS only) From &#039;&#039;&#039;9.9.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.2.0-X&#039;&#039;&#039;.&lt;br /&gt;
| A gamecard or eShop-install of Monster Hunter X (JPN only), and the DLC encryption key (see installer instructions). &#039;&#039;&#039;Note: the secondary exploit still works, see bellow&#039;&#039;&#039;&lt;br /&gt;
| svanheulen&lt;br /&gt;
| [https://github.com/svanheulen/genhax_installer Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [https://github.com/nedwill/soundhax soundhax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-13&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-36&#039;&#039;&#039;.&lt;br /&gt;
| A USA, EUR, JPN or KOR system.&lt;br /&gt;
| nedwill&lt;br /&gt;
| [http://soundhax.com Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: darkorange&amp;quot; | Yes, payloads only New3DS(XL)&lt;br /&gt;
| [https://github.com/MrNbaYoh/doodlebomb doodlebomb]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039;(?) up to and including &#039;&#039;&#039;11.4.0-X&#039;&#039;&#039;.&lt;br /&gt;
| An eShop-install of Swapdoodle (version 1.1.1 or lower). As of 2017-4-26, version 1.1.2 was released, blocking outdated app version from sending or receiving messages.&lt;br /&gt;
| MrNbaYoh&lt;br /&gt;
| [https://mrnbayoh.github.io/doodlebomb/ Install]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Note that ninjhax 1.x is still not obsolete. Even though ninjhax 2.x can be run on 9.3+, this was made possible (amongst other things) by sacrificing the memory remapping exploit used in ninjhax 1.x (rohax). Therefore, things like JIT engines for emulators can only be supported on ninjhax 1.x. Furthermore, ninjhax 2.x does not run on system versions below 9.0.0-X, while ninjhax 1.x does.&lt;br /&gt;
&lt;br /&gt;
==Secondary Exploits==&lt;br /&gt;
Installation of these exploits requires a previously exploited system to install. After installation, they can be used on their own. &#039;&#039;Please&#039;&#039; see the above Payload section regarding what &amp;quot;Supported firmwares&amp;quot; indicates &#039;&#039;exactly&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Works on latest fw&lt;br /&gt;
!  Name&lt;br /&gt;
!  Supported firmwares&lt;br /&gt;
!  Requirements&lt;br /&gt;
!  Author&lt;br /&gt;
!  Install&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [[ironhax]]&lt;br /&gt;
| From &#039;&#039;&#039;9.5.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;10.3.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 28.&lt;br /&gt;
| A copy of &amp;quot;Ironfall: Invasion&amp;quot; downloaded from eShop before August 11th, 2015. Note the updated version that was released on October 13th, 2015 is not supported.&lt;br /&gt;
| smea&lt;br /&gt;
| [http://smealum.github.io/3ds/ Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [http://vegaroxas.github.io/ steelhax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 36.&lt;br /&gt;
| A copy of Steel Diver: Sub Wars&lt;br /&gt;
| Vegaroxas&lt;br /&gt;
| [https://github.com/VegaRoXas/vegaroxas.github.io/raw/master/files/steelhax-installer.zip Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [https://github.com/yellows8/oot3dhax oot3dhax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 36.&lt;br /&gt;
| A gamecard or eShop-install of Legend of Zelda: Ocarina of Time 3D. Besides using the installer app, writing raw saveimages with a save dongle for example is another option. Before compression was introduced in the 2016-7-18 release, the size of the *hax payload meant the exploit can&#039;t coexist with regular saves on a physical version of the game.&lt;br /&gt;
| Yellows8 / smea et al.&lt;br /&gt;
| See [https://smealum.github.io/3ds/ here].&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [[menuhax]]&lt;br /&gt;
| JPN/USA/EUR: From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.2.0-X&#039;&#039;&#039;.&lt;br /&gt;
KOR: From &#039;&#039;&#039;9.6.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.2.0-X&#039;&#039;&#039;.&lt;br /&gt;
| JPN/USA/EUR: Having created [[Home_Menu#Home_Menu_Theme_SD_ExtData|theme extdata]] through opening the official theme selector at least once.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
| [https://github.com/yellows8/3ds_homemenuhax/releases Download]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: darkorange&amp;quot; | Yes, payloads only New3DS(XL)&lt;br /&gt;
| [https://github.com/shinyquagsire23/supermysterychunkhax supermysterychunkhax]&lt;br /&gt;
| From &#039;&#039;&#039;9.9.0-X&#039;&#039;&#039; (USA/JPN) / &#039;&#039;&#039;10.2.0-X&#039;&#039;&#039; (EUR) up to and including &#039;&#039;&#039;11.3.0-X&#039;&#039;&#039;, &#039;&#039;&#039;11.4.0-X&#039;&#039;&#039; only New3DS(XL).&lt;br /&gt;
| A gamecard or eShop-install of Pokémon Super Mystery Dungeon.&lt;br /&gt;
| Shiny Quagsire / SALT team&lt;br /&gt;
| [https://smd.salthax.org/ Install].&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [https://github.com/shinyquagsire23/v_hax (v*)hax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.0.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 33.&lt;br /&gt;
Note that &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; is only required for the Homebrew Launcher - the game itself only requires &#039;&#039;&#039;2.1.0-X&#039;&#039;&#039; for primitive userland code execution.&lt;br /&gt;
| A copy of VVVVVV downloaded after March 2012 (v1). v1.1 patches out the overflow vulnerability used by (v*)hax.&lt;br /&gt;
| Shiny Quagsire / SALT team&lt;br /&gt;
| [https://vvvvvv.salthax.org/ Install].&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [https://github.com/Dazzozo/humblehax humblehax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; (USA/EUR) up to and including &#039;&#039;&#039;11.2.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 35.&lt;br /&gt;
| An eShop-install of Citizens of Earth (either v1 or v2), featured in the Humble &amp;quot;Friends of Nintendo&amp;quot; Bundle.&lt;br /&gt;
| Dazzozo / SALT team&lt;br /&gt;
| [https://citizens.salthax.org/ Install].&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [http://mrnbayoh.github.io/basehaxx/ basehaxx]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.1.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 34.&lt;br /&gt;
| A gamecard or eShop-install of Pokémon Omega Ruby / Alpha Sapphire.&lt;br /&gt;
| MrNbaYoh&lt;br /&gt;
| [http://mrnbayoh.github.io/basehaxx/ install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [https://github.com/yellows8/stickerhax stickerhax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.4.0-X&#039;&#039;&#039;.&lt;br /&gt;
| A gamecard or eShop-install of Paper Mario: Sticker Star.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
| [https://github.com/yellows8/stickerhax Here]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [https://github.com/svanheulen/genhax genhax]&lt;br /&gt;
| (New 3DS only) From &#039;&#039;&#039;9.9.0-X&#039;&#039;&#039;(JPN) or &#039;&#039;&#039;10.3.0-X&#039;&#039;&#039;(EUR/USA) up to and including &#039;&#039;&#039;11.3.0-X&#039;&#039;&#039;.&lt;br /&gt;
| A gamecard or eShop-install of Monster Hunter Generations or Monster Hunter X (without the game updates installed), and an internet connection during installation.&lt;br /&gt;
| svanheulen&lt;br /&gt;
| [https://github.com/svanheulen/genhax_installer Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: lightgreen&amp;quot; | Yes&lt;br /&gt;
| [https://github.com/MrNbaYoh/painthax painthax]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-X&#039;&#039;&#039;.&lt;br /&gt;
| An eShop-install of PixelPaint.&lt;br /&gt;
| MrNbaYoh&lt;br /&gt;
| [https://github.com/MrNbaYoh/painthax/releases/latest install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [https://github.com/yellows8/ctpkpwn ctpkpwn_tfh]&lt;br /&gt;
| From &#039;&#039;&#039;9.9.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-X&#039;&#039;&#039;.&lt;br /&gt;
| A gamecard or eShop-install of &amp;quot;The Legend of Zelda: Tri Force Heroes&amp;quot;, and an Internet connection during installation. Unless you have &amp;quot;CFW&amp;quot;, ctr-httpwn &amp;gt;=v1.2 with the included bosshaxx on a compatible system-version is also required. If installing via ctr-httpwn, you can&#039;t do so on &amp;gt;=v11.4. Note that the exploit itself was not fixed.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
| [https://github.com/yellows8/ctpkpwn/releases Install]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [https://github.com/MrNbaYoh/doodlebomb doodlebomb]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039;(?) up to and including &#039;&#039;&#039;11.4.0-X&#039;&#039;&#039;.&lt;br /&gt;
| An eShop-install of Swapdoodle.&lt;br /&gt;
| MrNbaYoh&lt;br /&gt;
| [https://mrnbayoh.github.io/doodlebomb/ Install]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==Exploits without Homebrew Launcher (Not recommended)==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;u&amp;gt;&#039;&#039;&#039;Warning:&#039;&#039;&#039;&amp;lt;/u&amp;gt; The following exploits can run code, but are missing a 3DSX launcher. They cannot launch any homebrew in the 3DSX 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;
!  Works on latest fw&lt;br /&gt;
!  Name&lt;br /&gt;
!  Supported firmwares&lt;br /&gt;
!  Requirements&lt;br /&gt;
!  Author&lt;br /&gt;
!  Install&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [[browserhax]] (Without the loader in the 3ds_browserhax_common repo)&lt;br /&gt;
| (Old3DS) From &#039;&#039;&#039;5.0.0-2&#039;&#039;&#039; to &#039;&#039;&#039;11.0.0-33&#039;&#039;&#039; (Pre-v5.0 is supported for some versions if you manually modify the source)&lt;br /&gt;
&lt;br /&gt;
(New3DS) From &#039;&#039;&#039;9.0.0-20&#039;&#039;&#039; to &#039;&#039;&#039;11.0.0-33&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
Note that the browser-version-check bypass is only usable prior to [[10.7.0-32]].&lt;br /&gt;
| An USA, EUR, or JPN system.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
| [[browserhax|Install]]&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| Ninjhax (with specialized payloads)&lt;br /&gt;
| Up to &#039;&#039;&#039;9.2.0-20&#039;&#039;&#039;?&lt;br /&gt;
| &lt;br /&gt;
| smea + independent developers&lt;br /&gt;
| N/A&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==Previous Exploits==&lt;br /&gt;
&amp;lt;u&amp;gt;&#039;&#039;&#039;Warning:&#039;&#039;&#039;&amp;lt;/u&amp;gt; These exploits &#039;&#039;&#039;do not work&#039;&#039;&#039;. They are exploits which no longer function at all, regardless of software or firmware revision.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Works on latest fw&lt;br /&gt;
! Name&lt;br /&gt;
! Supported firmwares&lt;br /&gt;
! Requirements&lt;br /&gt;
! Author&lt;br /&gt;
! Install&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No&lt;br /&gt;
| [[tubehax|Tubehax]]&lt;br /&gt;
| None. &#039;&#039;&#039;Was&#039;&#039;&#039;: From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;10.1.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 27.&lt;br /&gt;
| The YouTube application and an Internet connection. As of October 15, 2015, this is no longer usable due to an update being released which fixes the vuln used by tubehax + app update being forced (see [[YouTube|here]]).&lt;br /&gt;
| smea&lt;br /&gt;
| [http://smealum.github.io/3ds/ Install]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==Other Homebrew Loaders==&lt;br /&gt;
The [https://github.com/yellows8/hblauncher_loader hblauncher_loader] title can be used when running under modded-FIRM which allows running unsigned titles, to boot the *hax payloads.&lt;br /&gt;
&lt;br /&gt;
[https://github.com/AuroraWright/Luma3DS Luma3DS], apart from providing signature patches for the installation and use of custom titles, includes the &amp;quot;Rosalina&amp;quot; system module, which among its features allows cleanly loading 3dsx applications as a native process with full ARM11 system permissions, by replacing an installed title&#039;s ExeFS and ExHeader during load time. It is currently the only option for running 3dsx applications on 11.4+ O3DSes; additionally, the *hax 2.x payload is incompatible with Rosalina and therefore so are homebrew applications requiring its target title system.&lt;br /&gt;
&lt;br /&gt;
==Sysmodule Exploits==&lt;br /&gt;
This section is for system-module exploits, which can be run from the *hax payloads.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Works on latest fw&lt;br /&gt;
! Name&lt;br /&gt;
! Supported firmwares&lt;br /&gt;
! Requirements&lt;br /&gt;
! Author&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;background: salmon&amp;quot; | No, still usable pre-v11.4.&lt;br /&gt;
| [https://github.com/yellows8/ctr-httpwn/releases ctr-httpwn]&lt;br /&gt;
| From &#039;&#039;&#039;9.6.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;11.3.0-X&#039;&#039;&#039;. This includes bosshaxx.&lt;br /&gt;
| None&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==WebKit vuln testing==&lt;br /&gt;
See [https://github.com/yellows8/3ds_browserhax_common/issues/28 here].&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=19819</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=19819"/>
		<updated>2017-04-10T15:43:10Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_GAS_DELTAZ_DEPTH */ Add gas depth function bits (found in glDepthFunc)&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 = perspective, 1 = not 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;
| U²&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| V&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| V²&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| (U + V) / 2&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| (U² + V²) / 2&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| sqrt(U² + V²)&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;
&#039;&#039;&#039;Equation values:&#039;&#039;&#039;&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;
Blend equations 5, 6, 7 appear to behave the same as blend equation 0 (Add)&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Function values:&#039;&#039;&#039;&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;
| 8&lt;br /&gt;
| Gas color LUT input&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures gas light shading in the line-of-sight direction, and the input to the gas color LUT.&lt;br /&gt;
&lt;br /&gt;
Color LUT 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;
| Gas density&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Light factor&lt;br /&gt;
|}&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;
| 24-25&lt;br /&gt;
| unsigned, Depth function&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the gas depth direction attenuation proportion, as well as the gas depth function.&lt;br /&gt;
&lt;br /&gt;
Gas 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;
| Greater than/Greater than or equal&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Less than/Less than or equal/Equal/Not equal&lt;br /&gt;
|}&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>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=19805</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=19805"/>
		<updated>2017-04-08T08:31:03Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_GAS_LIGHT_Z_COLOR */ Add missing uniform from Nintendo OpenGL page (&amp;quot;dmp_Gas.colorLutInput&amp;quot;)&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 = perspective, 1 = not 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;
| U²&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| V&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| V²&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| (U + V) / 2&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| (U² + V²) / 2&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| sqrt(U² + V²)&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;
| 8&lt;br /&gt;
| Gas color LUT input&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register configures gas light shading in the line-of-sight direction, and the input to the gas color LUT.&lt;br /&gt;
&lt;br /&gt;
Color LUT 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;
| Gas density&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Light factor&lt;br /&gt;
|}&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>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Shader_Instruction_Set&amp;diff=19770</id>
		<title>GPU/Shader Instruction Set</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=GPU/Shader_Instruction_Set&amp;diff=19770"/>
		<updated>2017-03-18T14:10:30Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Instruction formats */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GPU]]&lt;br /&gt;
&lt;br /&gt;
== Overview ==&lt;br /&gt;
A compiled shader binary is comprised of two parts : the main instruction sequence and the operand descriptor table. These are both sent to the GPU around the same time but using separate [[GPU/Internal_Registers|GPU Commands]]. Instructions (such as format 1 instruction) may reference operand descriptors. When such is the case, the operand descriptor ID is the offset, in words, of the descriptor within the table.&lt;br /&gt;
Both instructions and descriptors are coded in little endian.&lt;br /&gt;
Basic implementations of the following specification can be found at [https://github.com/smealum/aemstro] and [https://github.com/neobrain/nihstro].&lt;br /&gt;
The instruction set seems to have been heavily inspired by Microsoft&#039;s vs_3_0 [http://msdn.microsoft.com/en-us/library/windows/desktop/bb172938%28v=vs.85%29.aspx] and the Direct3D shader code [https://msdn.microsoft.com/en-us/library/windows/hardware/ff552891%28v=vs.85%29.aspx].&lt;br /&gt;
Please note that this page is being written as the instruction set is reverse engineered; as such it may very well contain mistakes.&lt;br /&gt;
&lt;br /&gt;
Debug information found in the code.bin of &amp;quot;Ironfall: Invasion&amp;quot; suggests that there may not be more than 512 instructions and 128 operand descriptors in a shader.&lt;br /&gt;
&lt;br /&gt;
== Nomenclature ==&lt;br /&gt;
&lt;br /&gt;
* opcode names with I appended to them are the same as their non-I version, except they use the inverted instruction format, giving 7 bits to SRC2 (and access to uniforms) and 5 bits to SRC1&lt;br /&gt;
&lt;br /&gt;
* opcode names with U appended to them are the same as their non-U version, except they are executed conditionally based on the value of a uniform boolean.&lt;br /&gt;
&lt;br /&gt;
* opcode names with C appended to them are the same as their non-C version, except they are executed conditionally based on a logical expression specified in the instruction.&lt;br /&gt;
&lt;br /&gt;
== Instruction formats ==&lt;br /&gt;
&lt;br /&gt;
Format 1 : (used for register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1i : (used for register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xE&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC2 (IDX_2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1u : (used for unary register operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|   Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 1c : (used for comparison operations)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC1 (IDX_1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Comparison operator for Y (CMPY)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Comparison operator for X (CMPX)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1B&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 2 : (used for flow control instructions)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Number of instructions (NUM)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0xC&lt;br /&gt;
|  Destination offset (in words) (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Condition boolean operator (CONDOP)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Y reference bit (REFY)&lt;br /&gt;
|-&lt;br /&gt;
|  0x19&lt;br /&gt;
|  0x1&lt;br /&gt;
|  X reference bit (REFX)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 3 : (used for uniform-based conditional flow control instructions)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Number of instructions ? (NUM)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0xC&lt;br /&gt;
|  Destination offset (in words) (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Uniform ID (BOOL/INT)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 4 : (used for SETEMIT)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Winding flag (FLAG_WINDING)&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Primitive emit flag (FLAG_PRIMEMIT)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Vertex ID (VTXID)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  0x6&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 5 : (used for MAD)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 3 register (SRC3)&lt;br /&gt;
|-&lt;br /&gt;
|  0xA&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x11&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC2 (IDX_2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Format 5i : (used for MADI)&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 (bits)&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Operand descriptor ID (DESC)&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x7&lt;br /&gt;
|  Source 3 register (SRC3)&lt;br /&gt;
|-&lt;br /&gt;
|  0xC&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 2 register (SRC2)&lt;br /&gt;
|-&lt;br /&gt;
|  0x11&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Source 1 register (SRC1)&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Address register index for SRC3 (IDX_3)&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  0x5&lt;br /&gt;
|  Destination register (DST)&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  0x3&lt;br /&gt;
|  Opcode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Instructions ==&lt;br /&gt;
Unless noted otherwise, SRC1 and SRC2 refer to their respectively indexed float[4] registers (after swizzling). Similarly, DST refers to its indexed register modulo destination component masking, i.e. an expression like DST=SRC1 might actually just set DST.y to SRC1.y.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Opcode&lt;br /&gt;
!  Format&lt;br /&gt;
!  Name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x00&lt;br /&gt;
|  1&lt;br /&gt;
|  ADD&lt;br /&gt;
|  Adds two vectors component by component; DST[i] = SRC1[i]+SRC2[i] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x01&lt;br /&gt;
|  1&lt;br /&gt;
|  DP3&lt;br /&gt;
|  Computes dot product on 3-component vectors; DST = SRC1.SRC2&lt;br /&gt;
|-&lt;br /&gt;
|  0x02&lt;br /&gt;
|  1&lt;br /&gt;
|  DP4&lt;br /&gt;
|  Computes dot product on 4-component vectors; DST = SRC1.SRC2&lt;br /&gt;
|-&lt;br /&gt;
|  0x03&lt;br /&gt;
|  1&lt;br /&gt;
|  DPH&lt;br /&gt;
|  Computes dot product on a 3-component vector with 1.0 appended to it and a 4-component vector; DST = SRC1.SRC2 (with SRC1 homogenous)&lt;br /&gt;
|-&lt;br /&gt;
|  0x04&lt;br /&gt;
|  1&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x05&lt;br /&gt;
|  1u&lt;br /&gt;
|  EX2&lt;br /&gt;
|  Computes SRC1&#039;s first component exponent with base 2; DST[i] = EXP2(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x06&lt;br /&gt;
|  1u&lt;br /&gt;
|  LG2&lt;br /&gt;
|  Computes SRC1&#039;s first component logarithm with base 2; DST[i] = LOG2(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x07&lt;br /&gt;
|  1u&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x08&lt;br /&gt;
|  1&lt;br /&gt;
|  MUL&lt;br /&gt;
|  Multiplies two vectors component by component; DST[i] = SRC1[i].SRC2[i] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x09&lt;br /&gt;
|  1&lt;br /&gt;
|  SGE&lt;br /&gt;
|  Sets output if SRC1 is greater than or equal to SRC2; DST[i] = (SRC1[i] &amp;gt;= SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0A&lt;br /&gt;
|  1&lt;br /&gt;
|  SLT&lt;br /&gt;
|  Sets output if SRC1 is strictly less than SRC2; DST[i] = (SRC1[i] &amp;lt; SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0B&lt;br /&gt;
|  1u&lt;br /&gt;
|  FLR&lt;br /&gt;
|  Computes SRC1&#039;s floor component by component; DST[i] = FLOOR(SRC1[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0C&lt;br /&gt;
|  1&lt;br /&gt;
|  MAX&lt;br /&gt;
|  Takes the max of two vectors, component by component; DST[i] = MAX(SRC1[i], SRC2[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0D&lt;br /&gt;
|  1&lt;br /&gt;
|  MIN&lt;br /&gt;
|  Takes the min of two vectors, component by component; DST[i] = MIN(SRC1[i], SRC2[i]) for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0E&lt;br /&gt;
|  1u&lt;br /&gt;
|  RCP&lt;br /&gt;
|  Computes the reciprocal of the vector&#039;s first component; DST[i] = 1/SRC1[0] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x0F&lt;br /&gt;
|  1u&lt;br /&gt;
|  RSQ&lt;br /&gt;
|  Computes the reciprocal of the square root of the vector&#039;s first component; DST[i] = 1/sqrt(SRC1[0]) for all i&lt;br /&gt;
|-&lt;br /&gt;
| 0x10&lt;br /&gt;
| ?&lt;br /&gt;
| ???&lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
| 0x11&lt;br /&gt;
| ?&lt;br /&gt;
| ???&lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x12&lt;br /&gt;
|  1u&lt;br /&gt;
|  MOVA&lt;br /&gt;
|  Move to address register; Casts the float uniform given by SRC1 to an integer (truncating the fractional part) and assigns the result to (a0.x, a0.y, _, _), respecting the destination component mask.&lt;br /&gt;
|-&lt;br /&gt;
|  0x13&lt;br /&gt;
|  1u&lt;br /&gt;
|  MOV&lt;br /&gt;
|  Moves value from one register to another; DST = SRC1.&lt;br /&gt;
|-&lt;br /&gt;
|  0x14&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x15&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x18&lt;br /&gt;
|  1i&lt;br /&gt;
|  DPHI&lt;br /&gt;
|  Computes dot product on a 3-component vector with 1.0 appended to it and a 4-component vector; DST = SRC1.SRC2 (with SRC1 homogenous)&lt;br /&gt;
|-&lt;br /&gt;
|  0x19&lt;br /&gt;
|  1i&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1A&lt;br /&gt;
|  1i&lt;br /&gt;
|  SGEI&lt;br /&gt;
|  Sets output if SRC1 is greater than or equal to SRC2; DST[i] = (SRC1[i] &amp;gt;= SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x1B&lt;br /&gt;
|  1i&lt;br /&gt;
|  SLTI&lt;br /&gt;
|  Sets output if SRC1 is strictly less than SRC2; DST[i] = (SRC1[i] &amp;lt; SRC2[i]) ? 1.0 : 0.0 for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x1C&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1D&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1E&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x1F&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x20&lt;br /&gt;
|  ?&lt;br /&gt;
|  ???&lt;br /&gt;
|  ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x21&lt;br /&gt;
|  0&lt;br /&gt;
|  NOP&lt;br /&gt;
|  Does literally nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x22&lt;br /&gt;
|  0&lt;br /&gt;
|  END&lt;br /&gt;
|  Signals the shader unit that processing for this vertex/primitive is done.&lt;br /&gt;
|-&lt;br /&gt;
|  0x23&lt;br /&gt;
|  2&lt;br /&gt;
|  BREAKC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then breaks out of LOOP block.&lt;br /&gt;
|-&lt;br /&gt;
|  0x24&lt;br /&gt;
|  2&lt;br /&gt;
|  CALL&lt;br /&gt;
|  Jumps to DST and executes instructions until it reaches DST+NUM instructions&lt;br /&gt;
|-&lt;br /&gt;
|  0x25&lt;br /&gt;
|  2&lt;br /&gt;
|  CALLC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then jumps to DST and executes instructions until it reaches DST+NUM instructions, else does nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x26&lt;br /&gt;
|  3&lt;br /&gt;
|  CALLU&lt;br /&gt;
|  Jumps to DST and executes instructions until it reaches DST+NUM instructions if BOOL is true&lt;br /&gt;
|-&lt;br /&gt;
|  0x27&lt;br /&gt;
|  3&lt;br /&gt;
|  IFU&lt;br /&gt;
|  If condition BOOL is true, then executes instructions until DST, then jumps to DST+NUM; else, jumps to DST.&lt;br /&gt;
|-&lt;br /&gt;
|  0x28&lt;br /&gt;
|  2&lt;br /&gt;
|  IFC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then executes instructions until DST, then jumps to DST+NUM; else, jumps to DST&lt;br /&gt;
|-&lt;br /&gt;
|  0x29&lt;br /&gt;
|  3&lt;br /&gt;
|  LOOP&lt;br /&gt;
|  Loops over the code between itself and DST (inclusive), performing INT.x+1 iterations in total. First, aL is initialized to INT.y. After each iteration, aL is incremented by INT.z.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2A&lt;br /&gt;
|  0 (no param)&lt;br /&gt;
|  EMIT&lt;br /&gt;
|  (geometry shader only) Emits a vertex (and primitive if FLAG_PRIMEMIT was set in the corresponding SETEMIT). SETEMIT must be called before this.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2B&lt;br /&gt;
|  4&lt;br /&gt;
|  SETEMIT&lt;br /&gt;
|  (geometry shader only) Sets VTXID, FLAG_WINDING and FLAG_PRIMEMIT for the next EMIT instruction. VTXID is the ID of the vertex about to be emitted within the primitive, while FLAG_PRIMEMIT is zero if we are just emitting a single vertex and non-zero if are emitting a vertex and primitive simultaneously. FLAG_WINDING controls the output primitive&#039;s winding. Note that the output vertex buffer (which holds 4 vertices) is &#039;&#039;&#039;not&#039;&#039;&#039; cleared when the primitive is emitted, meaning that vertices from the previous primitive can be reused for the current one. (this is still a working hypothesis and unconfirmed)&lt;br /&gt;
|-&lt;br /&gt;
|  0x2C&lt;br /&gt;
|  2&lt;br /&gt;
|  JMPC&lt;br /&gt;
|  If condition (see [[#Conditions|below]] for details) is true, then jumps to DST, else does nothing.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2D&lt;br /&gt;
|  3&lt;br /&gt;
|  JMPU&lt;br /&gt;
|  If condition BOOL is true, then jumps to DST, else does nothing. Having bit 0 of NUM = 1 will invert the test, jumping if BOOL is false instead.&lt;br /&gt;
|-&lt;br /&gt;
|  0x2E-0x2F&lt;br /&gt;
|  1c&lt;br /&gt;
|  CMP&lt;br /&gt;
|  Sets booleans cmp.x and cmp.y based on the operand&#039;s x and y components and the CMPX and CMPY comparison operators respectively. See [[#Comparison_operator|below]] for details about operators. It&#039;s unknown whether CMP respects the destination component mask or not.&lt;br /&gt;
|-&lt;br /&gt;
|  0x30-0x37&lt;br /&gt;
|  5i&lt;br /&gt;
|  MADI&lt;br /&gt;
|  Multiplies two vectors and adds a third one component by component; DST[i] = SRC3[i] + SRC2[i].SRC1[i] for all i&lt;br /&gt;
|-&lt;br /&gt;
|  0x38-0x3F&lt;br /&gt;
|  5&lt;br /&gt;
|  MAD&lt;br /&gt;
|  Multiplies two vectors and adds a third one component by component; DST[i] = SRC3[i] + SRC2[i].SRC1[i] for all i&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Operand descriptors ==&lt;br /&gt;
Sizes below are in bits, not bytes.&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;
|  0x0&lt;br /&gt;
|  0x4&lt;br /&gt;
|  Destination component mask. Bit 3 = x, 2 = y, 1 = z, 0 = w.&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 1 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 1 component selector&lt;br /&gt;
|-&lt;br /&gt;
|  0xD&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 2 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0xE&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 2 component selector&lt;br /&gt;
|-&lt;br /&gt;
|  0x16&lt;br /&gt;
|  0x1&lt;br /&gt;
|  Source 3 negation bit&lt;br /&gt;
|-&lt;br /&gt;
|  0x17&lt;br /&gt;
|  0x8&lt;br /&gt;
|  Source 3 component selector&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Component selector :&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;
|  0x0&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 3 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 2 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 1 value&lt;br /&gt;
|-&lt;br /&gt;
|  0x6&lt;br /&gt;
|  0x2&lt;br /&gt;
|  Component 0 value&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Component&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  x&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  y&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  z&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  w&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The component selector enables swizzling. For example, component selector 0x1B is equivalent to .xyzw, while 0x55 is equivalent to .yyyy.&lt;br /&gt;
&lt;br /&gt;
Depending on the current shader opcode, source components are disabled implicitly by setting the destination component mask. For example, ADD o0.xy, r0.xyzw, r1.xyzw will not make use of r0&#039;s or r1&#039;s z/w components, while DP4 o0.xy, r0.xyzw, r1.xyzw will use all input components regardless of the used destination component mask.&lt;br /&gt;
&lt;br /&gt;
== Relative addressing ==&lt;br /&gt;
&lt;br /&gt;
There are 3 address registers: a0.x, a0.y and aL (loop counter). For format 1 instructions, when IDX != 0, the value of the corresponding address register is added to SRC1&#039;s value. For example, if IDX = 2, a0.y = 3 and SRC1 = c8, then instead SRC1+a0.y = c11 will be used for the instruction.&lt;br /&gt;
&lt;br /&gt;
a0.x and a0.y are set manually through the MOVA instruction by rounding a float value to integer precision. Hence, they may take negative values.&lt;br /&gt;
&lt;br /&gt;
aL can only be set indirectly by the LOOP instruction. It is still accessible and valid after exiting a LOOP block, though.&lt;br /&gt;
&lt;br /&gt;
== Comparison operator ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  CMPX/CMPY raw value&lt;br /&gt;
!  Operator name&lt;br /&gt;
!  Expression&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  EQ&lt;br /&gt;
|  src1 == src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  NE&lt;br /&gt;
|  src1 != src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  LT&lt;br /&gt;
|  src1 &amp;lt; src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  LE&lt;br /&gt;
|  src1 &amp;lt;= src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x4&lt;br /&gt;
|  GT&lt;br /&gt;
|  src1 &amp;gt; src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x5&lt;br /&gt;
|  GE&lt;br /&gt;
|  src1 &amp;gt;= src2&lt;br /&gt;
|-&lt;br /&gt;
|  0x6&lt;br /&gt;
|  ??&lt;br /&gt;
|  true ?&lt;br /&gt;
|-&lt;br /&gt;
|  0x7&lt;br /&gt;
|  ??&lt;br /&gt;
|  true ?&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
6 and 7 seem to always return true.&lt;br /&gt;
&lt;br /&gt;
== Conditions ==&lt;br /&gt;
&lt;br /&gt;
A number of format 2 instructions are executed conditionally. These conditions are based on two boolean registers which can be set with CMP : cmp.x and cmp.y.&lt;br /&gt;
&lt;br /&gt;
Conditional instructions include 3 parameters : CONDOP, REFX and REFY. REFX and REFY are reference values which are tested for equality against cmp.x and cmp.y, respectively. CONDOP describes how the final truth value is constructed from the results of the two tests. There are four conditional expression formats :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  CONDOP raw value&lt;br /&gt;
!  Expression&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0&lt;br /&gt;
|  &amp;lt;nowiki&amp;gt;cmp.x == REFX || cmp.y == REFY&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
|  OR&lt;br /&gt;
|-&lt;br /&gt;
|  0x1&lt;br /&gt;
|  &amp;lt;nowiki&amp;gt;cmp.x == REFX &amp;amp;&amp;amp; cmp.y == REFY&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
|  AND&lt;br /&gt;
|-&lt;br /&gt;
|  0x2&lt;br /&gt;
|  cmp.x == REFX&lt;br /&gt;
|  X&lt;br /&gt;
|-&lt;br /&gt;
|  0x3&lt;br /&gt;
|  cmp.y == REFY&lt;br /&gt;
|  Y&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Registers ==&lt;br /&gt;
Input attribute registers (v0-v7?) store the per-vertex data given by the CPU and hence are read-only.&lt;br /&gt;
&lt;br /&gt;
Output attribute registers (o0-o6) hold the data to be passed to the later GPU stages and are write-only. Each of the output attribute register components is assigned a semantic by setting the corresponding [[GPU_Internal_Registers]].&lt;br /&gt;
&lt;br /&gt;
Uniform registers hold user-specified data which is constant throughout all processed vertices. There are 96 float[4] uniform registers (c0-c95), eight boolean registers (b0-b7), and four int[4] registers (i0-i3).&lt;br /&gt;
&lt;br /&gt;
Temporary registers (r0-r15) can be used for intermediate calculations and can both be read and written.&lt;br /&gt;
&lt;br /&gt;
Many shader instructions which take float arguments have only 5 bits available for the second argument. They may hence only refer to input attributes or temporary registers. In particular, it&#039;s not possible to pass two float[4] uniforms to these instructions.&lt;br /&gt;
&lt;br /&gt;
It appears that writing twice to the same output register can cause problems (e.g. GPU hangs).&lt;br /&gt;
&lt;br /&gt;
DST mapping :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  DST raw value&lt;br /&gt;
!  Register name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0-0x6&lt;br /&gt;
|  o0-o6&lt;br /&gt;
|  Output registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x10-0x1F&lt;br /&gt;
|  r0-r15&lt;br /&gt;
|  Temporary registers.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
SRC mapping :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  SRC1 raw value&lt;br /&gt;
!  Register name&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
|  0x0-0x7&lt;br /&gt;
|  v0-v7&lt;br /&gt;
|  Input attribute registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x10-0x1F&lt;br /&gt;
|  r0-r15&lt;br /&gt;
|  Temporary registers.&lt;br /&gt;
|-&lt;br /&gt;
|  0x20-0x7F&lt;br /&gt;
|  c0-c95&lt;br /&gt;
|  Vector uniform registers.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Floating-Point Behavior ==&lt;br /&gt;
&lt;br /&gt;
The PICA200 is not IEEE-compliant. It has positive and negative infinities and NaN, but does not seem to have negative 0. Several instructions also have behavior that differs from the IEEE functions. Here are the results from some tests done on hardware:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Computation&lt;br /&gt;
!  Result&lt;br /&gt;
!  Notes&lt;br /&gt;
|-&lt;br /&gt;
|  inf * 0&lt;br /&gt;
|  0&lt;br /&gt;
|  Including inside MUL, MAD, DP4, etc.&lt;br /&gt;
|-&lt;br /&gt;
|  NaN * 0&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  +inf - +inf&lt;br /&gt;
|  NaN&lt;br /&gt;
|  Indicates +inf is real inf, not FLT_MAX&lt;br /&gt;
|-&lt;br /&gt;
|  rsq(rcp(-inf))&lt;br /&gt;
|  +inf&lt;br /&gt;
|  Indicates that there isn&#039;t -0.0.&lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  rcp(0)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rcp(+inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rcp(NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  rsq(-0)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  no -0 so differs from IEEE where rsq(-0) = -inf &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(-2)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(+inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(-inf)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  rsq(NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  max(0, +inf)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(0, -inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(0, NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  max violates IEEE but match GLSL spec&lt;br /&gt;
|-&lt;br /&gt;
|  max(NaN, 0)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  max(-inf, +inf)&lt;br /&gt;
|  +inf&lt;br /&gt;
|  &lt;br /&gt;
&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
|  min(0, +inf)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(0, -inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(0, NaN)&lt;br /&gt;
|  NaN&lt;br /&gt;
|  min violates IEEE but match GLSL spec&lt;br /&gt;
|-&lt;br /&gt;
|  min(NaN, 0)&lt;br /&gt;
|  0&lt;br /&gt;
|  &lt;br /&gt;
|-&lt;br /&gt;
|  min(-inf, +inf)&lt;br /&gt;
|  -inf&lt;br /&gt;
|  &lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=19615</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=19615"/>
		<updated>2017-02-12T20:45:29Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_TEXUNITi_SHADOW */&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 = perspective, 1 = not 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>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=News/Archive&amp;diff=19289</id>
		<title>News/Archive</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=News/Archive&amp;diff=19289"/>
		<updated>2017-01-17T14:52:56Z</updated>

		<summary type="html">&lt;p&gt;Fincs: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;*&#039;&#039;&#039;31 October 2016&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released [https://github.com/yellows8/3ds_dsiwarehax_installer/releases 3ds_dsiwarehax_installer] v1.0. v1.1 was released on November 2nd.&lt;br /&gt;
*&#039;&#039;&#039;24 October 2016&#039;&#039;&#039; Nintendo released system update [[11.2.0-35]].&lt;br /&gt;
*&#039;&#039;&#039;4 October 2016&#039;&#039;&#039; An update for EUR version of VVVVVV was finally released (title was re-added to the eShop versionlist). Likewise for the USA version on the October 11th (this title was already listed in the versionlist however).&lt;br /&gt;
*&#039;&#039;&#039;22 September 2016&#039;&#039;&#039; [[User:shinyquagsire23|Shiny Quagsire]] released an update to [https://smd.salthax.org/ supermysterychunkhax] with [[11.1.0-34]] support.&lt;br /&gt;
*&#039;&#039;&#039;20 September 16&#039;&#039;&#039; [[User:Smea|Smea]] released an update to [http://smealum.github.io/ninjhax2/ Ninjhax 2] with [[11.1.0-34]] support.&lt;br /&gt;
*&#039;&#039;&#039;16 September 16&#039;&#039;&#039; [[User:Plutooo|plutoo]] released an update to [https://plutooo.github.io/freakyhax/ freakyhax] with [[11.1.0-34]] support.&lt;br /&gt;
*&#039;&#039;&#039;15 September 16&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released updated oot3dhax [https://github.com/yellows8/oot3dhax/releases/tag/09-15-16 saveimages] for latest *hax payloads + [[11.1.0-34]] support.&lt;br /&gt;
*&#039;&#039;&#039;13 September 16&#039;&#039;&#039; Nintendo released system update [[11.1.0-34]].&lt;br /&gt;
*&#039;&#039;&#039;20 August 16&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released hblauncher_loader [https://github.com/yellows8/hblauncher_loader/releases/tag/v1.2 v1.2], menuhax [https://github.com/yellows8/3ds_homemenuhax/releases/tag/v3.1 v3.1], and updated the starter-kit. The sploit_installer build from the starter-kit now supports all regions for stickerhax except CHNTWN. This also sends the Home Menu title-version for the initial *hax payload network request, unless the user changed the system-info(like the latest menuhax_manager and hblauncher_loader).&lt;br /&gt;
*&#039;&#039;&#039;9 August 16&#039;&#039;&#039; An updated version of USA SmileBASIC is now available(the updated JPN version was released exactly 2 weeks ago).&lt;br /&gt;
*&#039;&#039;&#039;29 July 16&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released [https://github.com/yellows8/stickerhax stickerhax], which supports &amp;lt;=[[11.0.0-33]].&lt;br /&gt;
*&#039;&#039;&#039;27 July 16&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released new browserhax(see changelog [[browserhax|here]]) and menuhax [https://github.com/yellows8/3ds_homemenuhax/releases v3.0], all of these now support [[11.0.0-33]].&lt;br /&gt;
*&#039;&#039;&#039;26 July 16&#039;&#039;&#039; Various JPN-only eShop app updates were released. This includes JPN SmileBASIC: the update-title was removed from versionlist, and the main-title was updated. Updating an already installed version of the game will currently update to 3.3.1. Uninstalling and redownloading will give you 3.3.2. [https://plutooo.github.io/smilehax/ smilehax] was fixed in [http://smilebasic.com/debug/ 3.3.2].&lt;br /&gt;
*&#039;&#039;&#039;22 July 16&#039;&#039;&#039; [[User:Dazzozo|Dazzozo]] released [https://citizens.salthax.org/ humblehax v2], supporting the Citizens of Earth update released on the eShop 3 days ago.&lt;br /&gt;
*&#039;&#039;&#039;20 July 16&#039;&#039;&#039; [[User:Plutooo|plutoo]] (with help from [[User:Yellows8|Yellows8]]) released [https://plutooo.github.io/smilehax/ smilehax].&lt;br /&gt;
*&#039;&#039;&#039;19 July 16&#039;&#039;&#039; An updated version of the EUR &amp;quot;Citizens of Earth&amp;quot; regular-title is now available on the EUR-eShop, ~2 months after being originally removed. Likewise for USA on the 21st.&lt;br /&gt;
*&#039;&#039;&#039;18 July 16&#039;&#039;&#039; [[User:Smea|Smea]] updated the hosted *hax payload builds(only otherapp for non-KOR) and this [https://smealum.github.io/3ds/ page]. KOR is now supported thanks to d3m3vilurr(system-version &amp;gt;=v9.6). All otherapp payloads were rebuilt+updated, hence these now include a commit for compression(committed by [[User:Yellows8|Yellows8]] with compression code by mtheall). Due to this, oot3dhax+payload can now be installed with multiple other normal save-files, without any issues(via sploit_installer from the starter-kit). [[User:Yellows8|Yellows8]] also updated the [https://smealum.github.io/3ds/ hosted] boot.3dsx to hbmenu 1.1.1.&lt;br /&gt;
*&#039;&#039;&#039;10 July 16&#039;&#039;&#039; MrNbaYoh released [https://mrnbayoh.github.io/basicsploit/ BASICSploit] for version 3.2.1 of SmileBASIC. Currently only the US version is supported. On July 11th the main-app title was removed from USA/JPN eShop: it&#039;s no longer listed on the former, while on the latter it can&#039;t be purchased.&lt;br /&gt;
*&#039;&#039;&#039;26 June 16&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released oot3dhax builds for supporting [[11.0.0-33]], via updated sploit_installer in the [https://smealum.github.io/3ds/ starter-kit] and raw [https://github.com/yellows8/oot3dhax/releases/tag/06-26-16 saveimages]. Note that attempting to run sploit_installer on a 11.0.0-33 system with *hax payload &amp;lt;=v2.7 is equivalent to [[11.0.0-33|trying]] to use the older oot3dhax on that version.&lt;br /&gt;
*&#039;&#039;&#039;3 June 16&#039;&#039;&#039; [[User:Plutooo|plutoo]] released [https://plutooo.github.io/freakyhax/ freakyhax]. The USA game was removed from the eShop &amp;lt;=3-hours later(&amp;quot;... currently unavailable&amp;quot; message).&lt;br /&gt;
*&#039;&#039;&#039;9 May 16&#039;&#039;&#039; Nintendo released system update [[11.0.0-33]].&lt;br /&gt;
*&#039;&#039;&#039;24 March 16&#039;&#039;&#039; Nintendo updated the pages stored on the server used for browser-version-check. Due to almost all of the Old3DS/New3DS pages for non-latest-browser being updated(content is now &amp;quot;99999&amp;quot;), browser versions prior to [[10.7.0-32]] are not usable anymore without using the browser-version-check bypass(fixed with [[10.7.0-32]]). The only exception is New3DS v10.2, it was &amp;quot;updated&amp;quot; but the content is still &amp;quot;0&amp;quot;(this is due to browser-version-check being [[Internet_Browser|broken]] with New3DS v10.2).&lt;br /&gt;
*&#039;&#039;&#039;22 March 16&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released [https://github.com/yellows8/ctr-httpwn/releases ctr-httpwn]. v1.0.1 was released on the 25th for a RootCA cert update.&lt;br /&gt;
*&#039;&#039;&#039;14 March 16&#039;&#039;&#039; Nintendo released system update [[10.7.0-32]].&lt;br /&gt;
*&#039;&#039;&#039;24-25 February 16&#039;&#039;&#039; On the 24th the Old3DS [[Internet_Browser|browser-version-check]] pages were updated so that browser version &amp;gt;=v10.6 is now required. The New3DS pages for this were not changed. About 5 hours later, [[User:Yellows8|Yellows8]] disclosed a bypass for the browser-version-check. User instructions are available [http://yls8.mtheall.com/3dsbrowserhax.php here], details [[3DS_Userland_Flaws|here]].&lt;br /&gt;
*&#039;&#039;&#039;22 February 16&#039;&#039;&#039; Nintendo released system update [[10.6.0-31]].&lt;br /&gt;
*&#039;&#039;&#039;1 February 16&#039;&#039;&#039; As of this date (time zones notwithstanding) following server maintenance Nintendo now checks server-side that users are on current firmware before allowing access to online functionality in games. See [[10.5.0-30|here]] for details.&lt;br /&gt;
*&#039;&#039;&#039;25 January 16&#039;&#039;&#039; Nintendo released system update [[10.5.0-30]].&lt;br /&gt;
*&#039;&#039;&#039;25 January 16&#039;&#039;&#039; [[User:Yellows8|Yellows8]] updated [http://yls8.mtheall.com/3dsbrowserhax.php browserhax], [https://github.com/yellows8/3ds_homemenuhax/releases menuhax], and the oot3dhax [https://github.com/yellows8/oot3dhax/releases saveimages] for v10.4.&lt;br /&gt;
*&#039;&#039;&#039;18 January 16&#039;&#039;&#039; Nintendo released system update [[10.4.0-29]].&lt;br /&gt;
*&#039;&#039;&#039;7 January 16&#039;&#039;&#039; (roughly, not automatically detected) Ironfall v1.0 is no longer downloadable due to the main-CXI content files on CDN being removed (TMD wasn&#039;t removed).&lt;br /&gt;
*&#039;&#039;&#039;27 December 15&#039;&#039;&#039; A 3DS console hacking [https://events.ccc.de/congress/2015/Fahrplan/events/7240.html talk] was at 32C3. A recording can be found [https://www.youtube.com/watch?v=UutYOidFx3c here]. Around the end of the talk, [[User:Yellows8|Yellows8]] released [[browserhax]] and [[menuhax]] compatible with the latest system-version at the time of release ([[10.3.0-28]]). The homebrew [https://smealum.github.io/3ds/ starter-kit] was updated for latest menuhax, and for an option for downloading the old vulnerable version of Ironfall from eShop.&lt;br /&gt;
*&#039;&#039;&#039;15 December 15&#039;&#039;&#039; Nintendo released Smash Bros update v1.1.3 which fixed [[smashbroshax]], see [https://github.com/yellows8/3ds_smashbroshax here] for details. However, [[smashbroshax]] is still possible on latest firmware: simply remove the update from SD card before attempting the exploit.&lt;br /&gt;
*&#039;&#039;&#039;13 December 15&#039;&#039;&#039; WinterMute released [http://devkitpro.org/viewtopic.php?f=13&amp;amp;t=8542 devkitARM release 45].&lt;br /&gt;
*&#039;&#039;&#039;25 November 15&#039;&#039;&#039; [[User:Yellows8|Yellows8]]  released [https://github.com/yellows8/hblauncher_loader/releases hblauncher_loader].&lt;br /&gt;
*&#039;&#039;&#039;17-20 November 15&#039;&#039;&#039; Nintendo released an update for the normal (non-invite-code) Super Smash Bros demos in USA, EUR and JPN, fixing [[smashbroshax]]. Only the demos were updated, the cartridge and eShop version of the full game are still vulnerable.&lt;br /&gt;
*&#039;&#039;&#039;12 November 15&#039;&#039;&#039; [[User:Yellows8|Yellows8]]  released [https://github.com/yellows8/oot3dhax/releases oot3dhax] raw savedata images for gamecards with the latest *hax payloads. The official [https://github.com/smealum/sploit_installer installer] is now [https://smealum.github.io/3ds/ included] in the homebrew starter kit.&lt;br /&gt;
*&#039;&#039;&#039;9 November 15&#039;&#039;&#039; Nintendo released system update [[10.3.0-28]].&lt;br /&gt;
*&#039;&#039;&#039;2 November 15&#039;&#039;&#039; Following an eShop servers maintenance, changes to the [[eShop]] system application require an update of the Homebrew starter kit for eShop access on system versions older than [[10.0.0-27]]. See [[EShop|here]] for details.&lt;br /&gt;
*&#039;&#039;&#039;30 October 15&#039;&#039;&#039; [[User:Yellows8|Yellows8]]  released [https://github.com/yellows8/3ds_homemenuhax/releases menuhax] v2.0.&lt;br /&gt;
*&#039;&#039;&#039;29 October 15&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released [https://github.com/yellows8/3ds_smashbroshax/releases 3ds_smashbroshax] v1.2.&lt;br /&gt;
*&#039;&#039;&#039;26 October 15&#039;&#039;&#039; A [[Internet_Browser#v9.9_dummy_web-browser|dummy web browser]] is now being included in CUPs (cart updates) on Old3DS/New3DS likely starting with games shipping [[9.9.0-26|9.9.0-X]]. NVer is not updated by this.&lt;br /&gt;
*&#039;&#039;&#039;26 October 15&#039;&#039;&#039; The system web-browser on Old3DS/New3DS now displays a &amp;quot;sysupdate required&amp;quot; message on systems with [[9.9.0-26]] or above installed, if the installed browser(?) is not the latest version. See [[Internet_Browser#Forced_system-update|here]] for details.&lt;br /&gt;
*&#039;&#039;&#039;25 October 15&#039;&#039;&#039; [[User:Smea|smea]] released *hax 2.5 payloads, which fixes a number of bugs and adds new features such as screenshot-taking, romhacking and eshop access.&lt;br /&gt;
*&#039;&#039;&#039;20 October 15&#039;&#039;&#039; Nintendo released system update [[10.2.0-28]]. The publicly available versions of [[menuhax]] and [[browserhax]] at the time of sysupdate release, were blocked.&lt;br /&gt;
*&#039;&#039;&#039;15 October 15&#039;&#039;&#039; The [[YouTube]] application was updated with a fix for [[tubehax]]. This update is forced: the app itself checks whether a newer version of the title is available.&lt;br /&gt;
*&#039;&#039;&#039;13 October 15&#039;&#039;&#039; &amp;quot;Ironfall: Invasion&amp;quot; was made available on the eShop again (originally pulled on August 11th). The updated version blocks [[ironhax]].&lt;br /&gt;
*&#039;&#039;&#039;25 September 15&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released [[browserhax]] and [[menuhax]]. On the 26th menuhax v1.2 was [https://github.com/yellows8/3ds_homemenuhax/releases released].&lt;br /&gt;
*&#039;&#039;&#039;14 September 15&#039;&#039;&#039; Nintendo released system update [[10.1.0-27]].&lt;br /&gt;
*&#039;&#039;&#039;11 September 15&#039;&#039;&#039;(11:30 EDT) [[User:Yellows8|Yellows8]] released [[smashbroshax]]. On the 30th v1.1 was [https://github.com/yellows8/3ds_smashbroshax/releases released] for supporting Super Smash Bros v1.1.1.&lt;br /&gt;
*&#039;&#039;&#039;8 September 15&#039;&#039;&#039; Nintendo released system update [[10.0.0-27]].&lt;br /&gt;
*&#039;&#039;&#039;18 July 15&#039;&#039;&#039; smea released [[ninjhax]] 2 beta [http://smealum.github.io/ninjhax2/], enabling ARM11 homebrew execution on Old/New 3DS up to firmware 9.9.0-26.&lt;br /&gt;
*&#039;&#039;&#039;13 July 15&#039;&#039;&#039; Nintendo released system update [[9.9.0-26]].&lt;br /&gt;
*&#039;&#039;&#039;1 June 15&#039;&#039;&#039; Nintendo released system update [[9.8.0-25]].&lt;br /&gt;
*&#039;&#039;&#039;03 May 15&#039;&#039;&#039; smea released regionFOUR [https://github.com/smealum/regionFOUR/blob/master/README.md], enabling region free gaming on latest firmware. (again)&lt;br /&gt;
*&#039;&#039;&#039;20 April 15&#039;&#039;&#039; Nintendo released system update [[9.7.0-25]].&lt;br /&gt;
*&#039;&#039;&#039;23 March 15&#039;&#039;&#039; Nintendo released system update [[9.6.0-24]].&lt;br /&gt;
*&#039;&#039;&#039;2 March 15&#039;&#039;&#039; Nintendo released system update [[9.5.0-23]].&lt;br /&gt;
*&#039;&#039;&#039;15 February 15&#039;&#039;&#039; WinterMute released [http://devkitpro.org/viewtopic.php?f=13&amp;amp;t=8409 devkitARM release 44].&lt;br /&gt;
*&#039;&#039;&#039;2 February 15&#039;&#039;&#039; Nintendo released system update [[9.5.0-22]], which fixes [[3DS System Flaws|firmlaunch-hax]].&lt;br /&gt;
*&#039;&#039;&#039;16 January 15&#039;&#039;&#039; smea released regionthree [https://github.com/smealum/regionthree/blob/master/README.md], enabling region free gaming on latest firmware.&lt;br /&gt;
*&#039;&#039;&#039;24 December 14&#039;&#039;&#039; smea released [[Ninjhax]] 1.1 (&#039;&#039;&#039;NOT&#039;&#039;&#039; a fix for firmware [[9.3.0-21]] or [[9.4.0-21]]).&lt;br /&gt;
*&#039;&#039;&#039;11 December 14&#039;&#039;&#039; Nintendo released system update [[9.4.0-21]].&lt;br /&gt;
*&#039;&#039;&#039;8 December 14&#039;&#039;&#039; Nintendo released system update [[9.3.0-21]], which fixes [[3DS System Flaws|rohax]].&lt;br /&gt;
*&#039;&#039;&#039;20 November 14&#039;&#039;&#039; smea released [[Ninjhax]], the first public [[Homebrew Exploits|homebrew exploit]] compatible with system-versions [[4.0.0-7]]-[[9.2.0-20]].&lt;br /&gt;
*&#039;&#039;&#039;29 October 14&#039;&#039;&#039; Nintendo released system update [[9.2.0-20]].&lt;br /&gt;
*&#039;&#039;&#039;10 October 14&#039;&#039;&#039; Nintendo released system update [[9.1.0-20J]].&lt;br /&gt;
*&#039;&#039;&#039;6 October 14&#039;&#039;&#039; Nintendo released system update [[9.0.0-20]].&lt;br /&gt;
*&#039;&#039;&#039;29 August 14&#039;&#039;&#039; Nintendo announced [[New 3DS]].&lt;br /&gt;
*&#039;&#039;&#039;7 August 14&#039;&#039;&#039; Nintendo released system update [[8.1.0-19]].&lt;br /&gt;
*&#039;&#039;&#039;24 July 14&#039;&#039;&#039; Nintendo released system update [[8.1.0-18]].&lt;br /&gt;
*&#039;&#039;&#039;7 July 14&#039;&#039;&#039; Nintendo released system update [[8.0.0-18]].&lt;br /&gt;
*&#039;&#039;&#039;12 May 14&#039;&#039;&#039; Nintendo released system update [[7.2.0-17]].&lt;br /&gt;
*&#039;&#039;&#039;26 February 14&#039;&#039;&#039; Nintendo released system update [[7.1.0-16]].&lt;br /&gt;
*&#039;&#039;&#039;22 January 14&#039;&#039;&#039; Nintendo released system update [[7.1.0-15]].&lt;br /&gt;
*&#039;&#039;&#039;19 December 13&#039;&#039;&#039; Nintendo released system update [[7.1.0-14]].&lt;br /&gt;
*&#039;&#039;&#039;9 December 13&#039;&#039;&#039; Nintendo released system update [[7.0.0-13]].&lt;br /&gt;
*&#039;&#039;&#039;13 September 13&#039;&#039;&#039; Nintendo released system update [[6.3.0-12]].&lt;br /&gt;
*&#039;&#039;&#039;20 August 13&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v1.5.3]] updated by [[User:Elisherer|Elisherer]] (Enable trimming NCSD)&lt;br /&gt;
*&#039;&#039;&#039;6 August 13&#039;&#039;&#039; Nintendo released system update [[6.2.0-12]].&lt;br /&gt;
*&#039;&#039;&#039;11 July 13&#039;&#039;&#039; Nintendo released system update [[6.1.0-12U]] for only USA.&lt;br /&gt;
*&#039;&#039;&#039;27 June 13&#039;&#039;&#039; Nintendo released system update [[6.1.0-11]] (6.1.0-12 for all regions except USA).&lt;br /&gt;
*&#039;&#039;&#039;17 June 13&#039;&#039;&#039; Nintendo released system update [[6.0.0-11]] (6.0.0-12 for all regions except USA).&lt;br /&gt;
*&#039;&#039;&#039;4 April 13&#039;&#039;&#039; Nintendo released system update [[5.1.0-11]].&lt;br /&gt;
*&#039;&#039;&#039;25 March 13&#039;&#039;&#039; Nintendo released system update [[5.0.0-11]].&lt;br /&gt;
*&#039;&#039;&#039;14 January 13&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v1.5.1]] updated by [[User:Elisherer|Elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;4 December 12&#039;&#039;&#039; Nintendo released system update [[4.5.0-10]].&lt;br /&gt;
*&#039;&#039;&#039;1 December 12&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v1.4]] updated by [[User:Elisherer|Elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;2 November 12&#039;&#039;&#039; Added page for [[Fundraiser|Chip decapping fundraiser]]&lt;br /&gt;
*&#039;&#039;&#039;8 January 13&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v1.5]] updated by [[User:Elisherer|Elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;23 September 12&#039;&#039;&#039; [[005tools|005tools v0.1b]] by [[User:McHaggis|McHaggis]]&lt;br /&gt;
*&#039;&#039;&#039;19 September 12&#039;&#039;&#039; Nintendo released system update [[4.4.0-10]].&lt;br /&gt;
*&#039;&#039;&#039;17 August 12&#039;&#039;&#039; Nintendo released New Super Mario Bros. 2, the first 3DS title released simultaneously in stores and as an [[eShop]] download.&lt;br /&gt;
*&#039;&#039;&#039;28 July 12&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v1.3]] (modified by 3DSGuy) updated by [[User:Elisherer|Elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;24 July 12&#039;&#039;&#039; Nintendo released system update [[4.3.0-10]].&lt;br /&gt;
*&#039;&#039;&#039;26 June 12&#039;&#039;&#039; Nintendo released system update [[4.2.0-9]].&lt;br /&gt;
*&#039;&#039;&#039;19 May 12&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v1.2.1]] updated by [[User:Elisherer|Elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;15 May 12&#039;&#039;&#039; Nintendo released its first implementation of 3DS &#039;[[Title list#0004000E - Add-on Content|Add-on Content]]&#039; with the Mario Kart 1.1 update.&lt;br /&gt;
*&#039;&#039;&#039;14 May 12&#039;&#039;&#039; Nintendo released system update [[4.1.0-8]].&lt;br /&gt;
*&#039;&#039;&#039;24 April 12&#039;&#039;&#039; Nintendo released system update [[4.0.0-7]].&lt;br /&gt;
*&#039;&#039;&#039;08 February 12&#039;&#039;&#039; [[CiTRUS|CiTRUS v0.2]] updated by [[User:Xcution|Xcution]]&lt;br /&gt;
*&#039;&#039;&#039;04 February 12&#039;&#039;&#039; [[CiTRUS|CiTRUS v0.1]] released by [[User:Xcution|Xcution]]&lt;br /&gt;
*&#039;&#039;&#039;02 February 12&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v1.2]] updated by [[User:Elisherer|elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;26 January 12&#039;&#039;&#039; [[Crappy Tiny Reader|CTR - Crappy Tiny Reader v0.07]] updated by [[User:PsyKopaT|PsyKo]]&lt;br /&gt;
*&#039;&#039;&#039;05 January 12&#039;&#039;&#039; [[Crappy Tiny Reader|CTR - Crappy Tiny Reader v0.06]] updated by [[User:PsyKopaT|PsyKo]]&lt;br /&gt;
*&#039;&#039;&#039;21 December 11&#039;&#039;&#039; Nintendo released system update [[3.0.0-6]]&lt;br /&gt;
*&#039;&#039;&#039;21 December 11&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v1.1.1]] updated by [[User:Elisherer|elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;7 December 11&#039;&#039;&#039; [[3DSExplorer|3DSExplorer v0.96]] updated by [[User:Elisherer|elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;4 September 11&#039;&#039;&#039; [[3DSViewer|3DSViewer v0.1]] released by [[User:Elisherer|elisherer]]&lt;br /&gt;
*&#039;&#039;&#039;1 August 11&#039;&#039;&#039; [[3DS Save DeEncrypter3DS|Save DeEncrypter v1.0]] released by [[User:Blite|Blite]]&lt;br /&gt;
*&#039;&#039;&#039;25 July 11&#039;&#039;&#039; Nintendo released system update [[2.1.0-4]].&lt;br /&gt;
*&#039;&#039;&#039;15 June 11&#039;&#039;&#039; Nintendo released system update [[2.1.0-3]].&lt;br /&gt;
*&#039;&#039;&#039;6 June 11&#039;&#039;&#039; Nintendo released system update [[2.0.0-2]].&lt;br /&gt;
*&#039;&#039;&#039;6 April 11&#039;&#039;&#039; [[DSaveManager|DSaveManager v0.1]] released by [[User:Crediar|crediar]]&lt;br /&gt;
*&#039;&#039;&#039;4 April 11&#039;&#039;&#039; [[3DSaveTool|3DSaveTool v0.2b]] released by [[User:Crediar|crediar]]&lt;br /&gt;
*&#039;&#039;&#039;2 April 11&#039;&#039;&#039; [[3DSaveTool|3DSaveTool v0.1]] released by [[User:Crediar|crediar]]&lt;br /&gt;
*&#039;&#039;&#039;28 March 11&#039;&#039;&#039; Fixed 3DBrew wiki issues, now fully operational!&lt;br /&gt;
*&#039;&#039;&#039;18 March 11&#039;&#039;&#039; 3DBrew launched.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== 3DBrew International ==&lt;br /&gt;
Our community is an international community.&lt;br /&gt;
&lt;br /&gt;
We have freedom, and we will express it in our language (but you have to write it in English before ;)!&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=News&amp;diff=19288</id>
		<title>News</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=News&amp;diff=19288"/>
		<updated>2017-01-17T14:52:29Z</updated>

		<summary type="html">&lt;p&gt;Fincs: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
==Adding an item==&lt;br /&gt;
* Log in to the wiki. Editing is disabled if you don&#039;t have an account.&lt;br /&gt;
* Add the news event to the top of the list, using this format for the date: &amp;lt;tt&amp;gt;&amp;lt;nowiki&amp;gt;&#039;&#039;&#039;&amp;lt;/nowiki&amp;gt;{{#time: d F y}}&amp;lt;nowiki&amp;gt;&#039;&#039;&#039; &amp;lt;/nowiki&amp;gt;&amp;lt;/tt&amp;gt;. Please include the application&#039;s creator, version number, and a link to a page on 3DBrew about the application. No external links please.&lt;br /&gt;
* &#039;&#039;&#039;Move the last entry to the [[:News/Archive|news archive]]. There should be no more than 4 entries in the list.&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
==Archives==&lt;br /&gt;
For older news, see the [[:News/Archive|news archive]].&lt;br /&gt;
&lt;br /&gt;
=== News ===&lt;br /&gt;
&amp;lt;!-- Add news below --&amp;gt;&amp;lt;/noinclude&amp;gt;&lt;br /&gt;
*&#039;&#039;&#039;17 January 2017&#039;&#039;&#039; WinterMute released [http://devkitpro.org/viewtopic.php?f=13&amp;amp;t=8643 devkitARM release 46].&lt;br /&gt;
*&#039;&#039;&#039;9 January 2017&#039;&#039;&#039; [[User:Yellows8|Yellows8]] released: new oot3dhax [https://github.com/yellows8/oot3dhax/releases saveimages], ctr-httpwn [https://github.com/yellows8/ctr-httpwn/releases v1.2], menuhax [https://github.com/yellows8/3ds_homemenuhax/releases v3.2], [https://github.com/yellows8/ctpkpwn ctpkpwn_tfh], and others.&lt;br /&gt;
*&#039;&#039;&#039;27 December 2016&#039;&#039;&#039; [https://fahrplan.events.ccc.de/congress/2016/Fahrplan/events/8344.html Nintendo Hacking 2016] lecture at Chaos Communication Congress.&lt;br /&gt;
*&#039;&#039;&#039;26 December 2016&#039;&#039;&#039; [[User:Dazzozo|Dazzozo]] released an update to [https://citizens.salthax.org/ humblehax] with [[11.2.0-35]] support.&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=17932</id>
		<title>Homebrew Applications</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Applications&amp;diff=17932"/>
		<updated>2016-08-10T14:55:46Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Pls stop&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Installing==&lt;br /&gt;
Applications are installed by copying the necessary files directly to the 3ds/ folder in the root of the SD card, or in a subdirectory of &amp;quot;3ds&amp;quot;, in which case said subfolder must be named identically to its executable. Most applications come with two files:&lt;br /&gt;
* (app name).3dsx: The executable.&lt;br /&gt;
* (app name).smdh: The icon/metadata. (Not required in any case, and may be integrated into the .3dsx)&lt;br /&gt;
* (app name).xml: The list of supported targets, i.e. installed titles which the app supports replacing in memory at runtime, thus inheriting its permissions. (Optional)&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. Recent enough versions can freely navigate the filesystem to select an application.&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://homebrew.filfatstudios.com/download/ Latest]&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/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/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;
&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;
| [http://ctrulua.github.io/ ctrµLua]&lt;br /&gt;
| A Lua interpreter for 3DS brought to life by the remnants of the µLua community&lt;br /&gt;
| [[User:Firew0lf|Firew0lf]], Reuh, Negi&lt;br /&gt;
| [https://github.com/ctruLua/ctruLua/releases Here]&lt;br /&gt;
| [https://github.com/ctruLua/ctruLua 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://david.dantoine.org/proyecto/26/ Pituka Classics]&lt;br /&gt;
| The goal is to bring CPC classics using my [http://david.dantoine.org/proyecto/4/ Pituka Emulator-Core] as base with new features to your 3DS.&lt;br /&gt;
| [[User:D_Skywalk|D_Skywalk]]&lt;br /&gt;
| [http://david.dantoine.org/descargas/72 Here]&lt;br /&gt;
| Yes (see core)&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;
| [https://github.com/landm2000/sokoban Sokoban]&lt;br /&gt;
| Puzzle game. Unofficial port of Sokoban for the Nintendo 3DS&lt;br /&gt;
| [https://www.3dbrew.org/wiki/User:Landm Landm]&lt;br /&gt;
| [https://github.com/landm2000/sokoban Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Kaisogen/CookieCollector-3DS- Cookie Collector]&lt;br /&gt;
| Cookie Collector game. Very tiny and not much in it. Good car trip or time waster game. On version 1.2 as of now.&lt;br /&gt;
| [https://twitter.com/Kaisogen Kaisogen]&lt;br /&gt;
| [http://www.mediafire.com/download/qpojx6avkm6oo18/CookieCollector.zip Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 4/5/2016&lt;br /&gt;
|-&lt;br /&gt;
| [https://thp.itch.io/tetrepetete-3ds Tetrepetete 3DS]&lt;br /&gt;
| A game with blocks.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://thp.itch.io/tetrepetete-3ds Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://thp.itch.io/that-rabbit-game-3ds That Rabbit Game 3DS]&lt;br /&gt;
| Inverse duck hunt with accelerometer input and stereoscopic 3D.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://thp.itch.io/that-rabbit-game-3ds Here]&lt;br /&gt;
| No&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| [https://pyug.at/PyWeek/2012-09 One Whale Trip]&lt;br /&gt;
| Five-lane underwater whale swimming/pearl pickup adventure game in Python.&lt;br /&gt;
| [[User:thp|thp]]&lt;br /&gt;
| [https://bitbucket.org/pyugat/pyweek1209/downloads/OneWhaleTrip-2016-07-18-3DS.zip Here]&lt;br /&gt;
| [https://bitbucket.org/pyugat/pyweek1209/src/default/3ds/ 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;
| [http://asie.pl/homebrew atari800-3DS]&lt;br /&gt;
| An Atari 8-bit home computer emulator.&lt;br /&gt;
| asie&lt;br /&gt;
| [http://asie.pl/homebrew Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-7-23 (0.1.1)&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://gbatemp.net/threads/chip8-3ds.434425/ CHIP8-3DS]&lt;br /&gt;
| CHIP-8 emulator with savestates and touch controls.&lt;br /&gt;
| xerpi&lt;br /&gt;
| [https://github.com/nopy4869/CHIP8-2DS/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-7-20&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://easy-rpg.org/blog/2016/05/player-for-nintendo-3ds/ EasyRPG Player]&lt;br /&gt;
| RPG Maker 2000/2003 interpreter&lt;br /&gt;
| Rinnegatamante &amp;amp; EasyRPG Team&lt;br /&gt;
| [https://easy-rpg.org/player/downloads/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| May 2016&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;
| Undergoing rapid development.&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/mgba-emu/mgba mGBA]&lt;br /&gt;
| A GBA emulator that runs well 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;
===Title managers===&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/Steveice10/FBI FBI]&lt;br /&gt;
| Open source CIA (un)installer and launcher.&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases?after=2.0.0 Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2015-12-2 (1.4.17)&lt;br /&gt;
|-&lt;br /&gt;
| [https://github.com/Steveice10/FBI FBI 2]&lt;br /&gt;
| Multipurpose file/title/ticket/save manager&lt;br /&gt;
| [[User:Steveice10|Steveice10]]&lt;br /&gt;
| [https://github.com/Steveice10/FBI/releases/ Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| Undergoing rapid development.&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.7&lt;br /&gt;
| [[User:Rinnegatamante|Rinnegatamante]]&lt;br /&gt;
| [http://rinnegatamante.it/site/3ds_hbs.php Here]&lt;br /&gt;
| No&lt;br /&gt;
| 2016-4-13 (1.6)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Save managers===&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;
| save_manager&lt;br /&gt;
| Proof of concept save exporter/importer&lt;br /&gt;
| [[User:profi200|profi200]]&lt;br /&gt;
| [http://gbatemp.net/attachments/save_manager_-with_smdh-zip.24349/ Here]&lt;br /&gt;
| [https://gist.github.com/profi200/d0d092c11d0eb0692748 Yes]&lt;br /&gt;
| 2015-9-13&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;
| 2015-10-16 (0.10.42d)&lt;br /&gt;
|-&lt;br /&gt;
| [https://gbatemp.net/threads/release-jks-savemanager-homebrew-cia-save-manager.413143/ JK&#039;s Save Manager]&lt;br /&gt;
| Save/Extdata Manager&lt;br /&gt;
| JK_&lt;br /&gt;
| [https://github.com/J-D-K/JKSM/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
| 2016-6-30&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===File servers===&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/mtheall/ftpd ftpd (ftBrony)]&lt;br /&gt;
| A FTP server.&lt;br /&gt;
| [https://github.com/mtheall mtheall]&lt;br /&gt;
| [https://github.com/mtheall/ftpd/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;
&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>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Setting_up_Development_Environment&amp;diff=17888</id>
		<title>Setting up Development Environment</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Setting_up_Development_Environment&amp;diff=17888"/>
		<updated>2016-08-04T22:34:32Z</updated>

		<summary type="html">&lt;p&gt;Fincs: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= Setup =&lt;br /&gt;
* Install [http://devkitpro.org/ devkitARM]. If it&#039;s already installed, update it.&lt;br /&gt;
** On Windows, there&#039;s a [http://sourceforge.net/projects/devkitpro/files/Automated%20Installer/ graphical installer].&lt;br /&gt;
** On Unix-like platforms such as Linux/macOS, there&#039;s a [http://sourceforge.net/projects/devkitpro/files/Automated%20Installer/devkitARMupdate.pl/download Perl script]. Make sure you also select libctru and the 3ds examples when installing.&lt;br /&gt;
* Depending on the kind of homebrew you want to develop, you may be interested in installing and using additional libraries and tools which don&#039;t ship alongside devkitARM/libctru. A list of them can be found in [[Homebrew Libraries and Tools]].&lt;br /&gt;
&lt;br /&gt;
==Windows==&lt;br /&gt;
devkitPro provides Win32-native precompiled versions of devkitARM which can be run directly on Windows.&lt;br /&gt;
* [http://sourceforge.net/projects/devkitpro/files/Automated%20Installer/ download the latest version of the graphical installer] from SourceForge and run it, following the instructions as you go.&lt;br /&gt;
* An Internet connection is required.&lt;br /&gt;
* You will want to make sure devkitARM is selected during the installation process to develop for the 3DS (and also the DS and GBA) - you can also install devkitPPC (for GameCube/Wii development) and devkitPSP (for PlayStation Portable development) if you wish.&lt;br /&gt;
* Once the installer has finished, launch MSYS from:&lt;br /&gt;
** Windows 7 and earlier: Start -&amp;gt; All Programs -&amp;gt; devkitPro -&amp;gt; MSYS&lt;br /&gt;
** Windows 8 and 8.1: Right click on the Start screen and select &#039;All Apps&#039;. You should find MSYS there.&lt;br /&gt;
** Windows 10 (pre-Anniversary Update): Start -&amp;gt; All Apps -&amp;gt; devkitPro -&amp;gt; MSYS&lt;br /&gt;
** Windows 10 (post-Anniversary Update): Start -&amp;gt; devkitPro -&amp;gt; MSYS&lt;br /&gt;
&lt;br /&gt;
Alternatively starting with Windows 10 Anniversary Update (Version 1607), the [https://msdn.microsoft.com/en-us/commandline/wsl/install_guide Windows Subsystem for Linux (WSL)] may also be used to run the Linux version of devkitARM. Due to the fact that GCC was originally designed for Unix-like platforms its use may yield performance and convenience improvements. For instructions on how to set up devkitARM under WSL refer to the &#039;&#039;Unix-like platforms&#039;&#039; section.&lt;br /&gt;
&lt;br /&gt;
==Unix-like platforms==&lt;br /&gt;
Currently devkitPro provides precompiled versions of devkitARM for the following Unix-like platforms: Linux (x86/x64), macOS (universal binary). Note that Linux x64 binaries are usable under WSL.&lt;br /&gt;
&lt;br /&gt;
* First, you need to install curl so the installer can download the devkitARM packages, and you should also install Git - you&#039;ll need it to update ctrulib or share your code on GitHub, among many other things.&lt;br /&gt;
&lt;br /&gt;
* Find your way into a shell (eg. by opening a Terminal window), and follow the instructions for your OS:&lt;br /&gt;
** Debian/Ubuntu/Linux Mint/WSL: &amp;lt;code&amp;gt;sudo apt-get install git curl&amp;lt;/code&amp;gt;&lt;br /&gt;
** Fedora/CentOS/RHEL: &amp;lt;code&amp;gt;sudo yum install git curl&amp;lt;/code&amp;gt;&lt;br /&gt;
** openSUSE: &amp;lt;code&amp;gt;sudo zypper install git curl&amp;lt;/code&amp;gt;&lt;br /&gt;
** macOS: Download Git from [http://git-scm.com/download/mac] and install it. Curl is included with the OS.&lt;br /&gt;
&lt;br /&gt;
* Next, we need to download, make executable and run the devkitARM updater (don&#039;t worry, the updater is also the installer.)&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
curl -L http://sourceforge.net/projects/devkitpro/files/Automated%20Installer/devkitARMupdate.pl/download -o devkitARMupdate.pl&lt;br /&gt;
chmod +x ./devkitARMupdate.pl&lt;br /&gt;
sudo ./devkitARMupdate.pl /opt/devkitpro&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* Finally, we need to tell your shell where to find the devkitARM binaries.&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
echo &amp;quot;export DEVKITPRO=/opt/devkitpro&amp;quot; &amp;gt;&amp;gt; ~/.bashrc&lt;br /&gt;
echo &amp;quot;export DEVKITARM=/opt/devkitpro/devkitARM&amp;quot; &amp;gt;&amp;gt; ~/.bashrc&lt;br /&gt;
echo &amp;quot;export PATH=$PATH:/opt/devkitpro/devkitARM/bin&amp;quot; &amp;gt;&amp;gt; ~/.bashrc&lt;br /&gt;
source ~/.bashrc&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
= Building the examples =&lt;br /&gt;
3DS examples are still being created; however, there are a growing number of examples available from the [https://github.com/devkitPro/3ds-examples devkitPro/3ds-examples GitHub repository].&lt;br /&gt;
There are now too many to list here in detail, so go ahead and browse them.&lt;br /&gt;
&lt;br /&gt;
* To download these, if you installed Git (as you will have if you followed the above instructions), simply type &amp;lt;code&amp;gt;git clone https://github.com/devkitPro/3ds-examples.git&amp;lt;/code&amp;gt; into your shell in the directory you wish to store the 3ds-examples folder in.&lt;br /&gt;
** To overwrite the (almost certainly outdated) examples installed by the devkitPro updater, type &amp;lt;code&amp;gt;git clone https://github.com/devkitPro/3ds-examples.git $DEVKITPRO/examples/3ds&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
These can be built from the command line.&lt;br /&gt;
&lt;br /&gt;
To start a new homebrew project from the &amp;lt;code&amp;gt;bash&amp;lt;/code&amp;gt; shell, simply type the following (replacing &amp;lt;code&amp;gt;&#039;&#039;&#039;~/projects/my3dsproject&#039;&#039;&#039;&amp;lt;/code&amp;gt; with the place you would like your project to be stored, with &amp;lt;code&amp;gt;~&amp;lt;/code&amp;gt; meaning your HOME directory):&lt;br /&gt;
 cp -r $DEVKITPRO/examples/3ds/templates/application &#039;&#039;&#039;~/projects/my3dsproject&#039;&#039;&#039;&lt;br /&gt;
 cd &#039;&#039;&#039;~/projects/my3dsproject&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
To compile it, type &amp;lt;code&amp;gt;make&amp;lt;/code&amp;gt; in the project directory.&lt;br /&gt;
To run it on your 3DS, start the Homebrew Launcher, press Y to open the network loader, then on your PC type: &amp;lt;code&amp;gt;$DEVKITARM/bin/3dslink -a &#039;&#039;&#039;192.168.X.X&#039;&#039;&#039; &#039;&#039;&#039;my3dsproject&#039;&#039;&#039;.3dsx&amp;lt;/code&amp;gt;, replacing &#039;&#039;&#039;192.168.X.X&#039;&#039;&#039; with your 3DS&#039;s IP address (displayed in the network loader screen) and &#039;&#039;&#039;my3dsproject&#039;&#039;&#039; with the name of the folder your project is in (ie. the folder you have the source folder in and the README file.)&lt;br /&gt;
Don&#039;t type the full path, just the last segment - eg. for &amp;lt;code&amp;gt;C:\a\b\&#039;&#039;&#039;verygood3dsapp&#039;&#039;&#039;&amp;lt;/code&amp;gt;, you would type &amp;lt;code&amp;gt;&#039;&#039;&#039;verygood3dsapp&#039;&#039;&#039;.3dsx&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
If all goes well, you&#039;ll soon see your application running on your 3DS.&lt;br /&gt;
&lt;br /&gt;
==Building the examples on Linux with Netbeans==&lt;br /&gt;
* Go to File-&amp;gt;New Project...&lt;br /&gt;
* Select C/C++ Project with existing code&lt;br /&gt;
* Navigate to the examples directory and select the folder for the project you want to build; eg.    /home/vtsingaras/3ds/examples/app_launch&lt;br /&gt;
* Leave Configuration Mode to &#039;Automatic&#039; and click &#039;Finish&#039;.&lt;br /&gt;
* It will fail to build. Now edit Makefile and insert these two lines, adjusting for your devkitpro path, at the top:&lt;br /&gt;
&amp;lt;pre&amp;gt;export DEVKITPRO=/opt/devkitpro&lt;br /&gt;
export DEVKITARM=/opt/devkitpro/devkitARM&amp;lt;/pre&amp;gt;&lt;br /&gt;
* Right-click the project and go to Properties-&amp;gt;Code Assistance and click C Compiler.&lt;br /&gt;
* In include directories enter &lt;br /&gt;
&amp;lt;pre&amp;gt;/opt/devkitpro/devkitARM/include;/opt/devkitpro/ctrulib/libctru/include&amp;lt;/pre&amp;gt;&lt;br /&gt;
adjusting again for your devkitPro path.&lt;br /&gt;
* Do the same for &#039;C++ Compiler&#039;.&lt;br /&gt;
* Go to &#039;Run&#039; and click &#039;Clean and Build Project&#039;.&lt;br /&gt;
* Now right-click on the project and select Code Assistance-&amp;gt;Reparse Project.&lt;br /&gt;
&lt;br /&gt;
Now you can use Netbeans&#039; code completion feature and build your project from the Run menu.&lt;br /&gt;
&lt;br /&gt;
= Building homebrew for distribution =&lt;br /&gt;
To build your homebrew, open a Bash shell as described above, browse to the folder of the homebrew you wish to compile, and run &amp;lt;code&amp;gt;make&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
* This will build a .elf file and a .3dsx file (the homebrew executable itself) together with a .smdh file (the icon).&lt;br /&gt;
** The Homebrew Launcher can only run homebrew in the 3DSX format, and can only display SMDH icons.&lt;br /&gt;
&lt;br /&gt;
* To build a CCI (.3ds) file, you need to strip the .elf file and use makerom on it (with the provided RSF file):&lt;br /&gt;
 arm-none-eabi-strip &#039;&#039;&#039;[ELF file]&#039;&#039;&#039;&lt;br /&gt;
 makerom -f cci -o &#039;&#039;&#039;[.3ds file]&#039;&#039;&#039; -rsf &#039;&#039;&#039;[RSF file]&#039;&#039;&#039; -target t -exefslogo -elf &#039;&#039;&#039;[ELF file]&#039;&#039;&#039; -icon &#039;&#039;&#039;[icon file]&#039;&#039;&#039; -banner &#039;&#039;&#039;[banner file]&#039;&#039;&#039;&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Libraries_and_Tools&amp;diff=17860</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=17860"/>
		<updated>2016-07-31T13:19:07Z</updated>

		<summary type="html">&lt;p&gt;Fincs: &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;
==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 libctru and citro3d)&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/fincs/citro3d citro3d]&lt;br /&gt;
| Stateful PICA200 GPU wrapper library for the Nintendo 3DS&lt;br /&gt;
| [https://github.com/fincs fincs]&lt;br /&gt;
| [https://github.com/fincs/citro3d/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/Parx-3DS Three-DS, computers]&lt;br /&gt;
| Canvas/GDI Parx-Pas tested in FreePascal, public stubs &lt;br /&gt;
| [https://twitter.com/Kenny_D_Lee Author &amp;amp; Pioneer]&lt;br /&gt;
| [http://flying-dutchmen.github.io/3DS-Sails Begin]&lt;br /&gt;
| No&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;
| [https://github.com/BtheDestroyer/SpriteTools SpriteTools]&lt;br /&gt;
| Extension to sf2d that adds things like animations&lt;br /&gt;
| [https://github.com/BtheDestroyer BtheDestroyer]&lt;br /&gt;
| [https://github.com/BtheDestroyer/SpriteTools/Releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==PC 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;br /&gt;
&lt;br /&gt;
==3DS 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;
| [https://github.com/neobrain/braindump braindump]&lt;br /&gt;
| Tool to dump ExeFS/RomFS data from games and other applications&lt;br /&gt;
| [https://github.com/neobrain neobrain]&lt;br /&gt;
| [https://github.com/neobrain/braindump/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=SVC&amp;diff=16114</id>
		<title>SVC</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=SVC&amp;diff=16114"/>
		<updated>2016-03-21T23:20:16Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Undo revision 16113 by Neobrain (talk) Sizes in CodeSetInfo are specified in pages, not bytes.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= System calls =&lt;br /&gt;
&#039;&#039;&#039;Note: The argument-lists here apply to the official syscall wrapper-functions that are found in userland processes. The actual ordering passed to the kernel via the SVC instruction is documented in [[Kernel_ABI|Kernel ABI]].&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Id&lt;br /&gt;
!  NF ARM11&lt;br /&gt;
!  NF ARM9&lt;br /&gt;
!  TF ARM11&lt;br /&gt;
!  Description&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; width=&amp;quot;200&amp;quot; |  Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0x01 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ControlMemory(u32* outaddr, u32 addr0, u32 addr1, u32 size, [[#enum_MemoryOperation|MemoryOperation]] operation, [[#enum_MemoryPermission|MemoryPermission]] permissions)&lt;br /&gt;
| Outaddr is usually the same as the input addr0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x02 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result QueryMemory(MemoryInfo* info, PageInfo* out, u32 Addr)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x03 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| void ExitProcess(void)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x04 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetProcessAffinityMask(u8* affinitymask, Handle process, s32 processorcount)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x05 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SetProcessAffinityMask(Handle process, u8* affinitymask, s32 processorcount)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x06 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetProcessIdealProcessor(s32 *idealprocessor, Handle process)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x07 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SetProcessIdealProcessor(Handle process, s32 idealprocessor)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x08 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#CreateThread|CreateThread]](Handle* thread, func entrypoint, u32 arg, u32 stacktop, s32 threadpriority, s32 processorid)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x09 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| void [[Multi-threading#ExitThread|ExitThread]](void)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x0A &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| void [[Multi-threading#SleepThread|SleepThread]](s64 nanoseconds)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x0B &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#GetThreadPriority|GetThreadPriority]](s32* priority, Handle thread)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x0C &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#SetThreadPriority|SetThreadPriority]](Handle thread, s32 priority)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x0D &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result [[Multi-threading#GetThreadAffinityMask|GetThreadAffinityMask]](u8* affinitymask, Handle thread, s32 processorcount)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x0E &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result [[Multi-threading#SetThreadAffinityMask|SetThreadAffinityMask]](Handle thread, u8* affinitymask, s32 processorcount)&lt;br /&gt;
| Replaced with a stub in ARM11 NATIVE_FIRM kernel beginning with [[8.0.0-18]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x0F &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result [[Multi-threading#GetThreadIdealProcessor|GetThreadIdealProcessor]](s32* processorid, Handle thread)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x10 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result [[Multi-threading#SetThreadIdealProcessor|SetThreadIdealProcessor]](Handle thread, s32 processorid)&lt;br /&gt;
| Replaced with a stub in ARM11 NATIVE_FIRM kernel beginning with [[8.0.0-18]].&lt;br /&gt;
|-&lt;br /&gt;
| 0x11 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| s32 GetCurrentProcessorNumber(void)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x12 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result Run(Handle process, StartupInfo* info)&lt;br /&gt;
| This starts the main() thread. Buf+0 is main-thread priority, Buf+4 is main-thread stack-size.&lt;br /&gt;
|-&lt;br /&gt;
| 0x13 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#CreateMutex|CreateMutex]](Handle* mutex, bool initialLocked)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x14 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#ReleaseMutex|ReleaseMutex]](Handle mutex)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x15 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#CreateSemaphore|CreateSemaphore]](Handle* semaphore, s32 initialCount, s32 maxCount)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x16 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#ReleaseSemaphore|ReleaseSemaphore]](s32* count, Handle semaphore, s32 releaseCount)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x17 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#CreateEvent|CreateEvent]](Handle* event, ResetType resettype)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x18 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#SignalEvent|SignalEvent]](Handle event)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x19 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#ClearEvent|ClearEvent]](Handle event)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x1A &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result CreateTimer(Handle* timer, ResetType resettype)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x1B &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result SetTimer(Handle timer, s64 initial, s64 interval)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x1C &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result CancelTimer(Handle timer)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x1D &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result ClearTimer(Handle timer)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x1E &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result CreateMemoryBlock(Handle* memblock, u32 addr, u32 size, [[#enum_MemoryPermission|MemoryPermission]] mypermission, [[#enum_MemoryPermission|MemoryPermission]] otherpermission)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x1F &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result MapMemoryBlock(Handle memblock, u32 addr, [[#enum_MemoryPermission|MemoryPermission]] mypermissions, [[#enum_MemoryPermission|MemoryPermission]] otherpermission)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x20 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result UnmapMemoryBlock(Handle memblock, u32 addr)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x21 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#Address_Arbiters|CreateAddressArbiter]](Handle* arbiter)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x22 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#Address_Arbiters|ArbitrateAddress]](Handle arbiter, u32 addr, ArbitrationType type, s32 value, s64 nanoseconds)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x23 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result CloseHandle(Handle handle)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x24 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result WaitSynchronization1(Handle handle, s64 nanoseconds)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x25 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result WaitSynchronizationN(s32* out, Handle* handles, s32 handlecount, bool waitAll, s64 nanoseconds)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x26 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SignalAndWait(s32* out, Handle signal, Handle* handles, s32 handleCount, bool waitAll, s64 nanoseconds)&lt;br /&gt;
| Stubbed&lt;br /&gt;
|-&lt;br /&gt;
| 0x27 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result DuplicateHandle(Handle* out, Handle original)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x28 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| s64 GetSystemTick(void) (This returns the total CPU ticks elapsed since the CPU was powered-on)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x29 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetHandleInfo(s64* out, Handle handle, HandleInfoType type)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x2A &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result GetSystemInfo(s64* out, SystemInfoType type, s32 param)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x2B &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result GetProcessInfo(s64* out, Handle process, ProcessInfoType type)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x2C &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#GetThreadInfo|GetThreadInfo]](s64* out, Handle thread, ThreadInfoType type)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x2D &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ConnectToPort(Handle* out, const char* portName)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x2E &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SendSyncRequest1(Handle session)&lt;br /&gt;
| Stubbed&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x2F &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SendSyncRequest2(Handle session)&lt;br /&gt;
| Stubbed&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x30 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SendSyncRequest3(Handle session)&lt;br /&gt;
| Stubbed&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x31 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SendSyncRequest4(Handle session)&lt;br /&gt;
| Stubbed&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x32 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SendSyncRequest(Handle session)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x33 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result OpenProcess(Handle* process, u32 processId)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x34 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result [[Multi-threading#OpenThread|OpenThread]](Handle* thread, Handle process, u32 threadId)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x35 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result GetProcessId(u32* processId, Handle process)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x36 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result [[Multi-threading#GetProcessIdOfThread|GetProcessIdOfThread]](u32* processId, Handle thread)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x37 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result [[Multi-threading#GetThreadId|GetThreadId]](u32* threadId, Handle thread)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x38 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetResourceLimit(Handle* resourceLimit, Handle process)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x39 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetResourceLimitLimitValues(s64* values, Handle resourceLimit, LimitableResource* names, s32 nameCount)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x3A &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetResourceLimitCurrentValues(s64* values, Handle resourceLimit, LimitableResource* names, s32 nameCount)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x3B &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result [[Multi-threading#GetThreadContext|GetThreadContext]](ThreadContext* context, Handle thread)&lt;br /&gt;
| Stubbed&lt;br /&gt;
|-&lt;br /&gt;
| 0x3C &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Break(BreakReason)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x3D &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| OutputDebugString(void const, int)&lt;br /&gt;
| Does nothing on non-debug units.&lt;br /&gt;
|-&lt;br /&gt;
| 0x3E &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| ControlPerformanceCounter(unsigned long long, int, unsigned int, unsigned long long)&lt;br /&gt;
|&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
| 0x47 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result CreatePort(Handle* portServer, Handle* portClient,  const char* name, s32 maxSessions)&lt;br /&gt;
| Setting name=NULL creates a private port not accessible from svcConnectToPort.&lt;br /&gt;
|-&lt;br /&gt;
| 0x48 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result CreateSessionToPort(Handle* session, Handle port)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x49 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result CreateSession(Handle* sessionServer, Handle* sessionClient)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x4A &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result AcceptSession(Handle* session, Handle port)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x4B &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ReplyAndReceive1(s32* index, Handle* handles, s32 handleCount, Handle replyTarget)&lt;br /&gt;
| Stubbed.&lt;br /&gt;
|-&lt;br /&gt;
| 0x4C &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ReplyAndReceive2(s32* index, Handle* handles, s32 handleCount, Handle replyTarget)&lt;br /&gt;
| Stubbed.&lt;br /&gt;
|-&lt;br /&gt;
| 0x4D &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ReplyAndReceive3(s32* index, Handle* handles, s32 handleCount, Handle replyTarget)&lt;br /&gt;
| Stubbed.&lt;br /&gt;
|-&lt;br /&gt;
| 0x4E &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ReplyAndReceive4(s32* index, Handle* handles, s32 handleCount, Handle replyTarget)&lt;br /&gt;
| Stubbed.&lt;br /&gt;
|-&lt;br /&gt;
| 0x4F &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ReplyAndReceive(s32* index, Handle* handles, s32 handleCount, Handle replyTarget)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x50 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result BindInterrupt(Interrupt name, Handle syncObject, s32 priority, bool isManualClear)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x51 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result UnbindInterrupt(Interrupt name, Handle syncObject)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x52 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result InvalidateProcessDataCache(Handle process, void* addr, u32 size)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x53 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result StoreProcessDataCache(Handle process, void const* addr, u32 size)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x54 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result FlushProcessDataCache(Handle process, void const* addr, u32 size)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x55 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result StartInterProcessDma(Handle* dma, Handle dstProcess, void* dst, Handle srcProcess, const void* src, u32 size, const DmaConfig&amp;amp; config)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x56 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result StopDma(Handle dma)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x57 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| Result GetDmaState(DmaState* state, Handle dma)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x58&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| RestartDma(nn::Handle, void *, void  const*, unsigned int, signed char)&lt;br /&gt;
|&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
| 0x60 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result DebugActiveProcess(Handle* debug, u32 processID)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x61 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result BreakDebugProcess(Handle debug)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x62 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result TerminateDebugProcess(Handle debug)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x63 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetProcessDebugEvent(DebugEventInfo* info, Handle debug)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x64 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ContinueDebugEvent(Handle debug, u32 flags)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x65 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetProcessList(s32* processCount, u32* processIds, s32 processIdMaxCount)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x66 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetThreadList(s32* threadCount, u32* threadIds, s32 threadIdMaxCount, Handle domain)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x67 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result GetDebugThreadContext(ThreadContext* context, Handle debug, u32 threadId, u32 controlFlags)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x68 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SetDebugThreadContext(Handle debug, u32 threadId, ThreadContext* context, u32 controlFlags)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x69 &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result QueryDebugProcessMemory(MemoryInfo* blockInfo, PageInfo* pageInfo, Handle process, u32 addr)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x6A &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ReadProcessMemory(void* buffer, Handle debug, u32 addr, u32 size)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x6B &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result WriteProcessMemory(Handle debug, void const* buffer, u32 addr, u32 size)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x6C &lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SetHardwareBreakPoint(s32 registerId, u32 control, u32 value)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x6D&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| [[Multi-threading#GetDebugThreadParam|GetDebugThreadParam]](long long *, int *, nn::Handle, unsigned int, nn::dmnt::DebugThreadParam)&lt;br /&gt;
| Disabled on regular kernel.&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
| 0x70&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result ControlProcessMemory(Handle KProcess, unsigned int Addr0, unsigned int Addr1, unsigned int Size, unsigned int Type, unsigned int Permissions)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x71&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result MapProcessMemory(Handle KProcess, unsigned int StartAddr, unsigned int EndAddr)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x72&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result UnmapProcessMemory(Handle KProcess, unsigned int StartAddr, unsigned int EndAddr)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x73&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result CreateCodeSet(Handle* handle_out, struct CodeSetInfo, u32 code_ptr, u32 ro_ptr, u32 data_ptr)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x74&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result RandomStub()&lt;br /&gt;
| Stubbed&lt;br /&gt;
|-&lt;br /&gt;
| 0x75&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result CreateProcess(Handle* handle_out, Handle codeset_handle, u32 [[NCCH/Extended_Header#ARM11_Kernel_Capabilities|arm11kernelcaps_ptr]], u32 arm11kernelcaps_num)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x76&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| TerminateProcess(Handle)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x77&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SetProcessResourceLimits(Handle KProcess, Handle KResourceLimit)&lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| 0x78&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result CreateResourceLimit(Handle *KResourceLimit)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x79&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result SetResourceLimitValues(Handle res_limit, LimitableResource* resource_type_list, s64* resource_list, u32 count)&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0x7A&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| AddCodeSegment (unsigned int Addr, unsigned int Size)&lt;br /&gt;
| Stubbed on NATIVE_FIRM beginning with [[2.0.0-2]]. Used during TWL_FIRM boot.&lt;br /&gt;
|-&lt;br /&gt;
| 0x7B&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Backdoor(unsigned int CodeAddress)&lt;br /&gt;
| This is used on ARM9 NATIVE_FIRM. No ARM11 processes have access to it without some form of kernelhax.&lt;br /&gt;
|-&lt;br /&gt;
| 0x7C&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| KernelSetState(unsigned int Type, unsigned int Param0, unsigned int Param1, unsigned int Param2)&lt;br /&gt;
| The type determines the meaning of each param&lt;br /&gt;
|-&lt;br /&gt;
| 0x7D&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| style=&amp;quot;background: red&amp;quot; | No&lt;br /&gt;
| Result QueryProcessMemory(MemInfo *Info, unsigned int *Out, Handle KProcess, unsigned int Addr)&lt;br /&gt;
|&lt;br /&gt;
|- style=&amp;quot;border-top: double&amp;quot;&lt;br /&gt;
| 0xFF&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| style=&amp;quot;background: green&amp;quot; | Yes&lt;br /&gt;
| ???&lt;br /&gt;
| Debug related? The svcaccesscontrol mask doesn&#039;t apply for this SVC. Stubbed on ARM9 NATIVE_FIRM.&lt;br /&gt;
|}&lt;br /&gt;
NF: NATIVE_FIRM. TF: TWL_FIRM.&lt;br /&gt;
&lt;br /&gt;
Note that &amp;quot;stubbed&amp;quot; here means that the SVC only returns an error, as in the following snippet:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;ROM:FFF04D98                 LDR             R0, =0xF8C007F4&lt;br /&gt;
ROM:FFF04D9C                 BX              LR&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
= Types and structures =&lt;br /&gt;
&lt;br /&gt;
== enum MemoryState ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Memory state flags&lt;br /&gt;
!  Value&lt;br /&gt;
|-&lt;br /&gt;
| FREE&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| RESERVED&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| IO&lt;br /&gt;
| 2&lt;br /&gt;
|-&lt;br /&gt;
| STATIC&lt;br /&gt;
| 3&lt;br /&gt;
|-&lt;br /&gt;
| CODE&lt;br /&gt;
| 4&lt;br /&gt;
|-&lt;br /&gt;
| PRIVATE&lt;br /&gt;
| 5&lt;br /&gt;
|-&lt;br /&gt;
| SHARED&lt;br /&gt;
| 6&lt;br /&gt;
|-&lt;br /&gt;
| CONTINUOUS&lt;br /&gt;
| 7&lt;br /&gt;
|-&lt;br /&gt;
| ALIASED&lt;br /&gt;
| 8&lt;br /&gt;
|-&lt;br /&gt;
| ALIAS&lt;br /&gt;
| 9&lt;br /&gt;
|-&lt;br /&gt;
| ALIAS CODE&lt;br /&gt;
| 10&lt;br /&gt;
|-&lt;br /&gt;
| LOCKED&lt;br /&gt;
| 11&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== enum PageFlags ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Page flags&lt;br /&gt;
!  Bit&lt;br /&gt;
|-&lt;br /&gt;
| LOCKED&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| CHANGED&lt;br /&gt;
| 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== enum MemoryOperation ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Memory operation&lt;br /&gt;
!  Id&lt;br /&gt;
|-&lt;br /&gt;
| FREE&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| RESERVE&lt;br /&gt;
| 2&lt;br /&gt;
|-&lt;br /&gt;
| COMMIT&lt;br /&gt;
| 3&lt;br /&gt;
|-&lt;br /&gt;
| MAP&lt;br /&gt;
| 4&lt;br /&gt;
|-&lt;br /&gt;
| UNMAP&lt;br /&gt;
| 5&lt;br /&gt;
|-&lt;br /&gt;
| PROTECT&lt;br /&gt;
| 6&lt;br /&gt;
|-&lt;br /&gt;
| REGION APP&lt;br /&gt;
| 0x100&lt;br /&gt;
|-&lt;br /&gt;
| REGION SYSTEM&lt;br /&gt;
| 0x200&lt;br /&gt;
|-&lt;br /&gt;
| REGION BASE&lt;br /&gt;
| 0x300&lt;br /&gt;
|-&lt;br /&gt;
| LINEAR&lt;br /&gt;
| 0x10000&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The LINEAR memory-operation indicates that the mapped physical address is always MappedVAddr+0x0C000000, thus this memory can be used for hardware devices&#039; DMA(such as the [[GPU]]). Addr0+size for this must be within the 0x14000000-0x1C000000 range when Addr0 is non-zero(Addr1 must be zero), Addr0 isn&#039;t actually used by svcControlMemory for mapping memory: Addr0 is not used by the kernel after doing address-range checks. The kernel determines what physical-address to use by allocating memory from FCRAM(about the same way as other memory), which is then used to determine the virtual-address.&lt;br /&gt;
&lt;br /&gt;
[[8.0.0-18]] added a new memory mapping(0x30000000-0x38000000) for LINEAR memory, this replaces the original mapping for newer titles. The kernel uses the new mapping when the process memory-region is BASE, or when the process kernel-release-version field is &amp;gt;=0x022c(2.44 / system-version [[8.0.0-18]]).&lt;br /&gt;
&lt;br /&gt;
The input mem-region value for svcControlMemory is only used(when non-zero) when the PID is value 1, for the [[FIRM]] ARM11 &amp;quot;loader&amp;quot; module.&lt;br /&gt;
&lt;br /&gt;
== enum MemoryPermission ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Memory permission&lt;br /&gt;
!  Id&lt;br /&gt;
|-&lt;br /&gt;
| NONE&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| R&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| W&lt;br /&gt;
| 2&lt;br /&gt;
|-&lt;br /&gt;
| RW&lt;br /&gt;
| 3&lt;br /&gt;
|-&lt;br /&gt;
| X&lt;br /&gt;
| 4&lt;br /&gt;
|-&lt;br /&gt;
| RX&lt;br /&gt;
| 5&lt;br /&gt;
|-&lt;br /&gt;
| WX&lt;br /&gt;
| 6&lt;br /&gt;
|-&lt;br /&gt;
| RWX&lt;br /&gt;
| 7&lt;br /&gt;
|-&lt;br /&gt;
| DONTCARE&lt;br /&gt;
| 0x10000000&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== enum ResetType ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Reset type&lt;br /&gt;
!  Id&lt;br /&gt;
|-&lt;br /&gt;
| ONESHOT&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| STICKY&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| PULSE&lt;br /&gt;
| 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== struct MemoryInfo ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Base process virtual address&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Size&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Permission&lt;br /&gt;
|-&lt;br /&gt;
| enum MemoryState&lt;br /&gt;
| State&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== struct PageInfo ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Flags&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== struct StartupInfo ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| s32&lt;br /&gt;
| Priority&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Stack size&lt;br /&gt;
|-&lt;br /&gt;
| s32&lt;br /&gt;
| argc&lt;br /&gt;
|-&lt;br /&gt;
| s16*&lt;br /&gt;
| argv&lt;br /&gt;
|-&lt;br /&gt;
| s16*&lt;br /&gt;
| envp&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== enum BreakReason ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
! Break Reason&lt;br /&gt;
! Value&lt;br /&gt;
|-&lt;br /&gt;
| PANIC&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| ASSERT&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| USER&lt;br /&gt;
| 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== struct CodeSetInfo ==&lt;br /&gt;
All addresses are given virtual for the process to be created.&lt;br /&gt;
All sizes are given in 0x1000-pages.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u8[8]&lt;br /&gt;
| Codeset Name&lt;br /&gt;
|-&lt;br /&gt;
| u16&lt;br /&gt;
| Unknown, this is written to field 0x5A of KCodeSet&lt;br /&gt;
|-&lt;br /&gt;
| u16&lt;br /&gt;
| Unknown/padding&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Unknown/padding&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| .text addr&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| .text size&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| .rodata start&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| .rodata size&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| RW addr (.data + .bss)&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| RW size (.data + .bss)&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Total .text pages&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Total .rodata pages&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Total RW pages (.data + .bss)&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Unknown/padding&lt;br /&gt;
|-&lt;br /&gt;
| u8[8]&lt;br /&gt;
| Program ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== struct DebugEventInfo ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Event type&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Thread ID (not used in all events)&lt;br /&gt;
|-&lt;br /&gt;
| u32[2]&lt;br /&gt;
| Unknown/padding&lt;br /&gt;
|-&lt;br /&gt;
| u32[6]&lt;br /&gt;
| Event-specific data (see below)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Event type&lt;br /&gt;
!  Id&lt;br /&gt;
|-&lt;br /&gt;
| PROCESS&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| CREATE THREAD&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| EXIT THREAD&lt;br /&gt;
| 2&lt;br /&gt;
|-&lt;br /&gt;
| EXIT PROCESS&lt;br /&gt;
| 3&lt;br /&gt;
|-&lt;br /&gt;
| EXCEPTION&lt;br /&gt;
| 4&lt;br /&gt;
|-&lt;br /&gt;
| DLL LOAD&lt;br /&gt;
| 5&lt;br /&gt;
|-&lt;br /&gt;
| DLL UNLOAD&lt;br /&gt;
| 6&lt;br /&gt;
|-&lt;br /&gt;
| SCHEDULE IN&lt;br /&gt;
| 7&lt;br /&gt;
|-&lt;br /&gt;
| SCHEDULE OUT&lt;br /&gt;
| 8&lt;br /&gt;
|-&lt;br /&gt;
| SYSCALL IN&lt;br /&gt;
| 9&lt;br /&gt;
|-&lt;br /&gt;
| SYSCALL OUT&lt;br /&gt;
| 10&lt;br /&gt;
|-&lt;br /&gt;
| OUTPUT STRING&lt;br /&gt;
| 11&lt;br /&gt;
|-&lt;br /&gt;
| MAP&lt;br /&gt;
| 12&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== PROCESS event ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u64&lt;br /&gt;
| Program ID&lt;br /&gt;
|-&lt;br /&gt;
| char[8]&lt;br /&gt;
| Process name&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Process ID&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| 0 = newly created process, 1 = attached process&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== CREATE THREAD event ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Creator thread ID&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Base address (?)&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Entrypoint&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== EXIT THREAD/PROCESS events ===&lt;br /&gt;
&lt;br /&gt;
A single u32 reason field is used.&lt;br /&gt;
&lt;br /&gt;
Thread exit reasons:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Reason&lt;br /&gt;
!  Id&lt;br /&gt;
|-&lt;br /&gt;
| (None)&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| TERMINATE&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| EXIT PROCESS&lt;br /&gt;
| 2&lt;br /&gt;
|-&lt;br /&gt;
| TERMINATE PROCESS&lt;br /&gt;
| 3&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Process exit reasons:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Reason&lt;br /&gt;
!  Id&lt;br /&gt;
|-&lt;br /&gt;
| (None)&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| TERMINATE&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| UNHANDLED EXCEPTION&lt;br /&gt;
| 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== EXCEPTION event ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Exception type&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Exception address&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Argument (type-specific)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Exception types:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Reason&lt;br /&gt;
!  Id&lt;br /&gt;
!  Argument&lt;br /&gt;
|-&lt;br /&gt;
| UNDEFINED INSTRUCTION&lt;br /&gt;
| 0&lt;br /&gt;
| (None)&lt;br /&gt;
|-&lt;br /&gt;
| (Unknown)&lt;br /&gt;
| 1&lt;br /&gt;
| (None)&lt;br /&gt;
|-&lt;br /&gt;
| (Unknown, mem-related)&lt;br /&gt;
| 2&lt;br /&gt;
| Address&lt;br /&gt;
|-&lt;br /&gt;
| (Unknown, mem-related)&lt;br /&gt;
| 3&lt;br /&gt;
| Address&lt;br /&gt;
|-&lt;br /&gt;
| ATTACH BREAK&lt;br /&gt;
| 4&lt;br /&gt;
| (None)&lt;br /&gt;
|-&lt;br /&gt;
| BREAKPOINT&lt;br /&gt;
| 5&lt;br /&gt;
| (None)&lt;br /&gt;
|-&lt;br /&gt;
| USER BREAK&lt;br /&gt;
| 6&lt;br /&gt;
| User break type&lt;br /&gt;
|-&lt;br /&gt;
| DEBUGGER BREAK&lt;br /&gt;
| 7&lt;br /&gt;
| (None)&lt;br /&gt;
|-&lt;br /&gt;
| UNDEFINED SYSCALL&lt;br /&gt;
| 8&lt;br /&gt;
| Attempted syscall ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
User break types:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Reason&lt;br /&gt;
!  Id&lt;br /&gt;
|-&lt;br /&gt;
| PANIC&lt;br /&gt;
| 0&lt;br /&gt;
|-&lt;br /&gt;
| ASSERT&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| USER&lt;br /&gt;
| 2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== SCHEDULER/SYSCALL IN/OUT events ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u64&lt;br /&gt;
| Clock tick&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Syscall (only for SYSCALL events)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== OUTPUT STRING event ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| String address&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| String size&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== MAP event ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Type&lt;br /&gt;
!  Field&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Mapped address&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| Mapped size&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| MemoryPermission&lt;br /&gt;
|-&lt;br /&gt;
| u32&lt;br /&gt;
| MemoryState&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=svcSetHardwareBreakPoint=&lt;br /&gt;
This is essentially an interface for writing values to the debug-unit (B/W)RP registers. registerId range 0..5 = breakpoints(BRP0-5), 0x100..0x101 = watchpoints(WRP0-1), anything outside of these ranges will result in an error. This is used for both adding and removing/disabling breakpoints/watchpoints, hence the raw control value parameter.&lt;br /&gt;
&lt;br /&gt;
Here the kernel sets bit15 in the DSCR, to enable monitor-mode debugging.&lt;br /&gt;
&lt;br /&gt;
Regardless of whether this is for a BRP, when bit21 is set in the control input parameter(BRP type = contextID), the kernel will load the target process [[KProcess|contextID]] and use that internally for the value field. The target process is specified via a [[KDebug]] handle passed as the &amp;quot;value&amp;quot; parameter.&lt;br /&gt;
&lt;br /&gt;
Lastly, the kernel disables the specified (B/W)RP, then writes the value parameter / loaded contextID to the (B/W)VR, then writes the input control value to the (B/W)CR.&lt;br /&gt;
&lt;br /&gt;
= Processes =&lt;br /&gt;
Each process is given an array of [[NCCH/Extended_Header#ARM11_Kernel_Capabilities|kernel capability descriptors]] upon creation (see CreateProcess). Official software forwards the descriptors specified in the [[NCCH#Extended_Header|NCCH exheader]].&lt;br /&gt;
&lt;br /&gt;
Any process can only use SVCs which are enabled in its kernel capability descriptors. This is enforced by the ARM11 kernel SVC handler by checking the syscall access control mask stored on the SVC-mode stack. If the SVC isn&#039;t enabled, a kernelpanic() is triggered. Each process has a separate SVC-mode stack; this stack and the syscall access mask stored here are initialized when the process is started. Applications normally only have access to SVCs &amp;lt;=0x3D, however not all SVCs &amp;lt;=0x3D are accessible to the application. The majority of the SVCs accessible to applications are unused by the application.&lt;br /&gt;
&lt;br /&gt;
Each process has a separate handle-table, the size of which is stored in the kernel capability descriptor. The handles in a handle-table can&#039;t be used in the context of other processes, since those handles don&#039;t exist in other handle-tables.&lt;br /&gt;
&lt;br /&gt;
0xFFFF8001 is a handle alias for the current KProcess, and 0xFFFF8000 is a handle alias for the current KThread.&lt;br /&gt;
&lt;br /&gt;
Calling svcBreak on retail will only terminate the process which called this SVC.&lt;br /&gt;
&lt;br /&gt;
= Threads =&lt;br /&gt;
For svcCreateThread the input address used for Entrypoint_Param and StackTop are normally the same, however these can be arbitrary. For the main thread the Entrypoint_Param is value 0.&lt;br /&gt;
&lt;br /&gt;
Using CloseHandle() with a KThread handle will terminate the specified thread, only if the reference count reaches 0.&lt;br /&gt;
&lt;br /&gt;
Lower priority values give the thread higher priority. For userland apps, priorities between 0x18 and 0x3F are allowed. The priority of the app&#039;s main thread seems to be 0x30.&lt;br /&gt;
&lt;br /&gt;
The thread scheduler is cooperative, therefore if a thread takes up all the CPU time (for example if it enters an endless loop), all the other threads that run on the same CPU core won&#039;t get a chance to run. The main way of yielding another thread is using an address arbiter.&lt;br /&gt;
&lt;br /&gt;
= Memory Mapping =&lt;br /&gt;
ControlMemory and MapMemoryBlock can be used to map memory pages, these two SVCs only support mapping execute-never R/W pages. The input permissions parameter for these SVCs must therefore be &amp;lt;=3, where value zero is used when un-mapping memory. Furthermore it appears that only regular heap pages can be mirrored (it won&#039;t work for TLS, stack, .data, .text, for example).&lt;br /&gt;
&lt;br /&gt;
Bitmask 0xF00 for ControlMemory parameter MemoryType is the memory-type, when this is zero the memory-type is loaded from the kernel flags stored in the exheader ARM11 kernel descriptors, for the process using the SVC.&lt;br /&gt;
&lt;br /&gt;
ControlMemory parameter MemoryType with value 0x10003 is used for mapping the GSP [[Memory_layout|heap]]. The low 8-bits are the type: 1 is for un-mapping memory, 3 for mapping memory. Type4 is used to mirror the RW memory at Addr1, to Addr0. Type4 will return an error if Addr1 is located in read-only memory. Addr1 is not used for type1 and type3.&lt;br /&gt;
&lt;br /&gt;
The ARM11 kernel does not allow processes to create shared memory blocks via svcCreateMemoryBlock, when the process memorytype(from the kernel flags stored in the exheader kernel descriptor) is the application memorytype, and when addr=0. It&#039;s unknown how the kernel handles addr=0 when the memorytype is not the application memorytype. When addr is non-zero, it must be located in memory which is already mapped. Furthermore, it appears that only regular heap pages (allocated using svcControlMemory op=COMMIT) are accepted as valid addrs.&lt;br /&gt;
&lt;br /&gt;
ControlProcessMemory maps memory in the specified process, this is the only SVC which allows mapping executable memory. Format of the permissions field for memory mapping SVCs: bit0=R, bit1=W, bit2=X. Type6 sets the Addr0 memory permissions to the input permissions, for already mapped memory. Type is the MemoryOperation enum, without the memory-type/memory-region. ControlProcessMemory only supports type4, type5, and type6. ControlProcessMemory does not support using the current KProcess handle alias.&lt;br /&gt;
&lt;br /&gt;
MapProcessMemory maps RW memory starting at address 0x00100000 in the specified KProcess, at the specified StartAddr in the current process. MapProcessMemory then maps 0x08000000 in the specified process, to StartAddr+0x7f00000 in the current process. UnmapProcessMemory unmaps the memory which was mapped by MapProcessMemory.&lt;br /&gt;
&lt;br /&gt;
Note that with the MAP MemoryOperation, the kernel will refuse to MAP memory for the specified addr1, when addr1 was already used with another MAP operation as addr1. The kernel also doesn&#039;t allow memory to be freed via the FREE MemoryOperation, when other virtual-memory is mapped to this same memory(when the MAP MemoryOperation was used with this memory with addr1).&lt;br /&gt;
&lt;br /&gt;
= [[DMA]] =&lt;br /&gt;
The CTRSDK code for using svcStartInterProcessDma will execute svcBreak when svcStartInterProcessDma returns an error(except for certain error value(s)). Therefore on retail, triggering a svcStartInterProcessDma via a system-module which results in an error from svcStartInterProcessDma will result in the system-module terminating.&lt;br /&gt;
&lt;br /&gt;
= Debugging =&lt;br /&gt;
DebugActiveProcess is used to attach to a process for debugging. This SVC can only be used when the target process&#039; ARM11 descriptors stored in the exheader have the kernel flag for &amp;quot;Enable debug&amp;quot; set. Otherwise when that flag is clear, the kernel flags for the process using this SVC must have the &amp;quot;Force debug&amp;quot; flag set.&lt;br /&gt;
&lt;br /&gt;
= KernelSetState =&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Type&lt;br /&gt;
!  Enabled for the NATIVE_FIRM ARM11 kernel&lt;br /&gt;
!  Enabled for the TWL_FIRM ARM11 kernel&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| This initializes the programID for launching [[FIRM]], then triggers launching [[FIRM]]. Param0 is unused. Param1 is the programID-low, and the programID-high is 0x00040138. Param2 is used only with the [[New_3DS]] kernel, pm-module uses value 0 with this. With New3DS kernel, it forces the programIDlow to be the New3DS NATIVE_FIRM, when the input programIDlow is for the Old3DS NATIVE_FIRM and Param2==0.&lt;br /&gt;
On New3DS, the kernel disables the additional New3DS cache hw prior to calling the firmlaunch function from the &amp;lt;handler for the KernelSetState-types called via funcptr&amp;gt;.&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| Unknown, does nothing with the TWL_FIRM ARM11 kernel.&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| Unknown.&lt;br /&gt;
On New3DS, the kernel disables the additional New3DS cache hw, when it&#039;s actually enabled, prior to executing the rest of the code from the &amp;lt;handler for the KernelSetState-types called via funcptr&amp;gt;.&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| This used for initializing the 0x1000-byte buffer used by the launched [[FIRM]]. Param2 is unused. When Param0 is value 1, this buffer is copied to the beginning of FCRAM at 0xF0000000, and Param1 is unused. When Param0 is value 0, this kernel buffer is mapped to process address Param1.&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
| Param0-Param3 are unused. This unmaps(?) the following virtual memory by writing value physaddr(where physaddr base is 0x80000000) to the L1 MMU table entries: 0x00300000..0x04300000, 0x08000000..0x0FE00000, and 0x10000000..0xF8000000.&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| ?&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| Debug related?&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| This triggers an MCU (hard) reboot. Param0-3 are unused. This reboot is triggered via device address 0x4A on the second [[I2C]] bus (the MCU). Register address 0x20 is written to with value 4. This code will not return.&lt;br /&gt;
On New3DS, the kernel disables the additional New3DS cache hw prior to calling the reboot function from the &amp;lt;handler for the KernelSetState-types called via funcptr&amp;gt;.&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| Alternate unused FIRM launch code-path, with different [[PXI]] FIFO word constants.&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Yes, implemented at some point after system-version v4.5.&lt;br /&gt;
| ?&lt;br /&gt;
| Unknown&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Yes&lt;br /&gt;
| ?&lt;br /&gt;
| ConfigureNew3DSCPU. Only available for the [[New_3DS]] kernel. The actual code for processing this runs under the &amp;lt;handler for the KernelSetState-types called via funcptr&amp;gt;, which runs on all ARM11 cores. Param0 = input value. Only bit0-1 are used here. Bit 0 enables higher core clock, and bit 1 enables additional (L2) cache. This configures the hardware [[PDN_Registers|register]] for the flags listed [[NCCH/Extended_Header#Flag1|here]], among other code which uses the MPCore private memory region registers.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= GetSystemInfo =&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  SystemInfoType value&lt;br /&gt;
!  s32 param&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 0&lt;br /&gt;
| This writes the total used memory size in the following memory regions to out: APPLICATION, SYSTEM, and BASE.&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 1&lt;br /&gt;
| This writes the total used memory size in the APPLICATION memory region to out.&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 2&lt;br /&gt;
| This writes the total used memory size in the SYSTEM memory region to out.&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| 3&lt;br /&gt;
| This writes the total used memory size in the BASE memory region to out.&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Unused&lt;br /&gt;
| This writes the FCRAM memory [[Memory_Allocation#FCRAM_Region_Data|used by the kernel]] to out.&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Unused&lt;br /&gt;
| This writes the total number of threads which were directly launched by the kernel, to out. No longer exists with some kernel version?&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unused&lt;br /&gt;
| This writes the total number of processes which were directly launched by the kernel, to out. For the NATIVE_FIRM/SAFE_MODE_FIRM ARM11 kernel, this is normally 5, for processes sm, fs, pm, loader, and pxi.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= GetProcessInfo =&lt;br /&gt;
Input:&lt;br /&gt;
 R0 = unused&lt;br /&gt;
 R1 = Handle process&lt;br /&gt;
 R2 = ProcessInfoType type&lt;br /&gt;
&lt;br /&gt;
Output:&lt;br /&gt;
 R0 = Result&lt;br /&gt;
 R1 = output value lower word&lt;br /&gt;
 R2 = output value upper word&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  ProcessInfoType value&lt;br /&gt;
!  Available since system version&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 9-19&lt;br /&gt;
| [[8.0.0-18]]&lt;br /&gt;
| This only returns error 0xD8E007ED.&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| [[8.0.0-18]]&lt;br /&gt;
| low u32 = (0x20000000 - &amp;lt;LINEAR virtual-memory base for this process&amp;gt;). That is, the output value is the value which can be added to LINEAR memory vaddrs for converting to physical-memory addrs.&lt;br /&gt;
|-&lt;br /&gt;
| 21-23&lt;br /&gt;
| [[8.0.0-18]]&lt;br /&gt;
| This only returns error 0xE0E01BF4.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= GetHandleInfo =&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  HandleInfoType value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| This returns the time in ticks the KProcess referenced by the handle was created. If a KProcess handle was not given, it will write whatever was in r5, r6 when the svc was called.&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Get internal refcount-1 for kernel object (u32), and also a boolean if the refcount-1 is negative (u32).&lt;br /&gt;
|-&lt;br /&gt;
| 0x32107&lt;br /&gt;
| Returns (u64) 0.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= svc7B Backdoor =&lt;br /&gt;
This saves SVC-mode SP+LR on the user-mode stack, then sets the SVC-mode SP to the user-mode SP. This then calls the specified code in SVC-mode. Once the called code returns, this pops the saved SP+LR off the stack for restoring the SVC-mode SP, then returns from the svc7b handler. Note that this svc7b handler does not disable IRQs, if any IRQs/context-switches occur while the SVC-mode SP is set to the user-mode one here, the ARM11-kernel will crash(which hangs the whole ARM11-side system).&lt;br /&gt;
&lt;br /&gt;
= Kernel error-codes =&lt;br /&gt;
See [[Error codes]].&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Error-code value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x09401BFE&lt;br /&gt;
| Timeout occurred with svcWaitSynchronization*, when timeout is not ~0.&lt;br /&gt;
|-&lt;br /&gt;
| 0xC8601801&lt;br /&gt;
| No more unused/free synchronization objects left to use in a given object&#039;s linked list.  (KEvent, KMutex, KTimer, KSemaphore, KAddressArbiter, KThread)&lt;br /&gt;
|-&lt;br /&gt;
| 0xC8601802&lt;br /&gt;
| No more unused/free KSharedMemory objects left to use in the KSharedMemory linked list - out of blocks&lt;br /&gt;
|-&lt;br /&gt;
| 0xC8601809&lt;br /&gt;
| No more unused/free KSessions left to use in the KSession linked list - out of sessions&lt;br /&gt;
|-&lt;br /&gt;
| 0xC860180A&lt;br /&gt;
| Not enough free memory available for memory allocation.&lt;br /&gt;
|-&lt;br /&gt;
| 0xC920181A&lt;br /&gt;
| The session was closed by the other process..&lt;br /&gt;
|-&lt;br /&gt;
| 0xD0401834&lt;br /&gt;
| Max connections to port have been exceeded&lt;br /&gt;
|-&lt;br /&gt;
| 0xD88007FA&lt;br /&gt;
| Returned if no KObjectName object in the linked list  of such objects matches the port name provided to the svc. &lt;br /&gt;
|-&lt;br /&gt;
| 0xD8E007ED&lt;br /&gt;
| This indicates that a value is outside of the enum being used.&lt;br /&gt;
|-&lt;br /&gt;
| 0xD8E007F1&lt;br /&gt;
| This error indicates Misaligned address.&lt;br /&gt;
|-&lt;br /&gt;
| 0xD8E007F7&lt;br /&gt;
| This error indicates that the input handle used with the SVC does not exist in the process handle-table, or that the handle kernel object type does not match the type used by the SVC.&lt;br /&gt;
|-&lt;br /&gt;
| 0xD9000402&lt;br /&gt;
| Invalid memory permissions for input/output buffers, for svcStartInterProcessDma.&lt;br /&gt;
|-&lt;br /&gt;
| 0xD9001814&lt;br /&gt;
| Failed unprivileged load or store - wrong permissions on memory&lt;br /&gt;
|-&lt;br /&gt;
| 0xD9001BF7&lt;br /&gt;
| This error is returned when the kernel retrieves a pointer to a kernel object, but the object type doesn&#039;t match the desired one.&lt;br /&gt;
|-&lt;br /&gt;
| 0xD92007EA&lt;br /&gt;
| This error is returned when a process attempts to use svcCreateMemoryBlock when the process memorytype is the application memorytype, and when addr=0.&lt;br /&gt;
|-&lt;br /&gt;
| 0xE0E01BF5&lt;br /&gt;
| This indicates an invalid address was used.&lt;br /&gt;
|-&lt;br /&gt;
| 0xF8C007F4&lt;br /&gt;
| Invalid type/param0-param3 input for svcKernelSetState. This is also returned for those syscalls marked as stubs.&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=15599</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=15599"/>
		<updated>2016-01-23T23:51:44Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_SH_BOOLUNIFORM */  In the end, 0=false 1=true. Previous behaviour was caused by a combination of bugs in homebrew libraries.&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;
| unsigned, X&lt;br /&gt;
|-&lt;br /&gt;
| 16-25&lt;br /&gt;
| unsigned, 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)&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;
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>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Releases&amp;diff=14977</id>
		<title>Homebrew Releases</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Releases&amp;diff=14977"/>
		<updated>2015-12-13T10:42:47Z</updated>

		<summary type="html">&lt;p&gt;Fincs: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;*&#039;&#039;&#039;13 December 15&#039;&#039;&#039; fincs released [https://github.com/fincs/citro3d citro3d]&lt;br /&gt;
*&#039;&#039;&#039;23 February 15&#039;&#039;&#039; filfat released [[Homebrew Applications|DownloadMii 1.0.5.10]]&lt;br /&gt;
*&#039;&#039;&#039;15 January 15&#039;&#039;&#039; filfat released [[Homebrew Applications|DownloadMii 1.0.0.0]]&lt;br /&gt;
*&#039;&#039;&#039;6 January 15&#039;&#039;&#039; Yellows8 released [[Homebrew Applications|3ds_homemenu_extdatatool v1.1]]&lt;br /&gt;
*&#039;&#039;&#039;30 December 14&#039;&#039;&#039; Yellows8 released [[Homebrew Applications|3ds_homemenu_extdatatool v1.0]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Libraries_and_Tools&amp;diff=14976</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=14976"/>
		<updated>2015-12-13T10:39:41Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Libraries */&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;
==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/fincs/citro3d citro3d]&lt;br /&gt;
| Stateful PICA200 GPU wrapper library for the Nintendo 3DS&lt;br /&gt;
| [https://github.com/fincs fincs]&lt;br /&gt;
| [https://github.com/fincs/citro3d/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;
==PC 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;br /&gt;
&lt;br /&gt;
==3DS 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;
| [https://github.com/neobrain/braindump braindump]&lt;br /&gt;
| Tool to dump ExeFS/RomFS data from games and other applications&lt;br /&gt;
| [https://github.com/neobrain neobrain]&lt;br /&gt;
| [https://github.com/neobrain/braindump/releases Here]&lt;br /&gt;
| Yes&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Talk:GPU/Internal_Registers&amp;diff=14880</id>
		<title>Talk:GPU/Internal Registers</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Talk:GPU/Internal_Registers&amp;diff=14880"/>
		<updated>2015-12-05T18:15:42Z</updated>

		<summary type="html">&lt;p&gt;Fincs: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;s&amp;gt;FYI, fixed-point numbers are often denoted as &amp;quot;fixedX.Y&amp;quot;, with X the non-fractional and Y the fractional bits. Also note that one wouldn&#039;t speak about &amp;quot;fixed-point&amp;quot; numbers when Y=0 (just say &amp;quot;X-bit integer&amp;quot; instead). I found the latter a bit confusing in the recent changes, since it sounded like &amp;quot;Z bias&amp;quot; was a fixed-point number with unspecified fractional bits. [[User:Neobrain|Neobrain]] 12:07, 3 December 2015 (CET)&amp;lt;/s&amp;gt;&lt;br /&gt;
&lt;br /&gt;
@Steveice: &amp;lt;s&amp;gt;Regarding the recent GPUREG_SH_BOOLUNIFORM confusion, I agree that your version is the more sensible variant. However, note that technically it depends on the semantics defined in [[Shader_Instruction_Set#Comparison_operator]]: Switching between your version (0=false) and the original one (1=false) is equivalent to e.g. replacing the CONDOP=0 semantic &amp;quot; cmp.x == REFX || cmp.y == REFY &amp;quot; with &amp;quot; !cmp.x == REFX || !cmp.y == REFY&amp;quot;. In other words,  this change implicltly changed the documented semantics of shader conditions. Hence I wonder whether the Shader Instruction Set needs any adjustments with the new documentation on GPUREG_SH_BOOLUNIFORM. &amp;lt;/s&amp;gt; Actually, I mixed up stuff. What actually would need to be fixed up is the semantics of IFU, but that would yield a counterintuitive notion of conditional execution. [[User:Neobrain|Neobrain]] 19:55, 5 December 2015 (CET)&lt;br /&gt;
&lt;br /&gt;
The behaviour of the ifu command actually suggests 0=true and 1=false. Earlier today, upon seeing the change in the wiki, I did tests with the command. It turned out the positive block is executed when the bit is cleared, and the negative block is executed when the bit is set; as it was previously documented. Note the wording in the Shader Instruction Set page: &amp;quot;If condition BOOL is true, then executes instructions until DST, then jumps to DST+NUM; else, jumps to DST.&amp;quot; --[[User:Fincs|Fincs]] 20:15, 5 December 2015 (CET)&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14878</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=14878"/>
		<updated>2015-12-05T18:05:19Z</updated>

		<summary type="html">&lt;p&gt;Fincs: It is not. The behaviour of the ifu command suggests otherwise: 0=true 1=false. I tested it earlier this morning.&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_DATA0|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_DATA1|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_DATA2|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;
| unsigned, X&lt;br /&gt;
|-&lt;br /&gt;
| 16-25&lt;br /&gt;
| unsigned, 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)&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;
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_DATA0 ===&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, Vertex attribute element 1&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 2 (lower 8 bits)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Accepts the first part of the 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_FIXEDATTRIB_DATA1 ===&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, Vertex attribute element 2 (upper 16 bits)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 3 (lower 16 bits)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Accepts the second part of the 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_FIXEDATTRIB_DATA2 ===&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, Vertex attribute element 3 (upper 8 bits)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 4&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Accepts the third part of the 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 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Boolean register b1 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| unsigned, Boolean register b2 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| unsigned, Boolean register b3 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| unsigned, Boolean register b4 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| unsigned, Boolean register b5 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| unsigned, Boolean register b6 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| unsigned, Boolean register b7 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Boolean register b8 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, Boolean register b9 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, Boolean register b10 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| unsigned, Boolean register b11 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| unsigned, Boolean register b12 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| unsigned, Boolean register b13 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| unsigned, Boolean register b14 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| unsigned, Boolean register b15 value (0 = true, 1 = false)&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>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14875</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=14875"/>
		<updated>2015-12-05T11:43:42Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_SH_BOOLUNIFORM */&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_DATA0|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_DATA1|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_DATA2|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;
| unsigned, X&lt;br /&gt;
|-&lt;br /&gt;
| 16-25&lt;br /&gt;
| unsigned, 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)&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;
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_DATA0 ===&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, Vertex attribute element 1&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 2 (lower 8 bits)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Accepts the first part of the 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_FIXEDATTRIB_DATA1 ===&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, Vertex attribute element 2 (upper 16 bits)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 3 (lower 16 bits)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Accepts the second part of the 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_FIXEDATTRIB_DATA2 ===&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, Vertex attribute element 3 (upper 8 bits)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| float1.7.16, Vertex attribute element 4&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Accepts the third part of the 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 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| unsigned, Boolean register b1 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| unsigned, Boolean register b2 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| unsigned, Boolean register b3 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| unsigned, Boolean register b4 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| unsigned, Boolean register b5 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| unsigned, Boolean register b6 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| unsigned, Boolean register b7 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| unsigned, Boolean register b8 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| unsigned, Boolean register b9 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| unsigned, Boolean register b10 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| unsigned, Boolean register b11 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| unsigned, Boolean register b12 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| unsigned, Boolean register b13 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| unsigned, Boolean register b14 value (0 = true, 1 = false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| unsigned, Boolean register b15 value (0 = true, 1 = false)&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>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14770</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=14770"/>
		<updated>2015-12-01T10:31:17Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Framebuffer registers (0x100-0x13F) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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_PROTEX0|GPUREG_TEXUNIT3_PROTEX0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX1|GPUREG_TEXUNIT3_PROTEX1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX2|GPUREG_TEXUNIT3_PROTEX2]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX3|GPUREG_TEXUNIT3_PROTEX3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX4|GPUREG_TEXUNIT3_PROTEX4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX5|GPUREG_TEXUNIT3_PROTEX5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_PROTEX_LUT|GPUREG_PROTEX_LUT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA0|GPUREG_PROTEX_LUT_DATA0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA1|GPUREG_PROTEX_LUT_DATA1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA2|GPUREG_PROTEX_LUT_DATA2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA3|GPUREG_PROTEX_LUT_DATA3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA4|GPUREG_PROTEX_LUT_DATA4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA5|GPUREG_PROTEX_LUT_DATA5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA6|GPUREG_PROTEX_LUT_DATA6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA7|GPUREG_PROTEX_LUT_DATA7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_DATA0|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_DATA1|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_DATA2|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_DATA3|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_DATA4|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_DATA5|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_DATA6|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_DATA7|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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
| Culling mode&lt;br /&gt;
|}&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;
| float24, width / 2&lt;br /&gt;
|}&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;
| float31, 2 / width&lt;br /&gt;
|}&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;
| float24, height / 2&lt;br /&gt;
|}&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;
| float31, 2 / height&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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;
| float24, Clipping plane coefficient&lt;br /&gt;
|}&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;
| float24, Near - Far&lt;br /&gt;
|}&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;
| float24, Near&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Number of following attributes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&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;
{| 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;
| Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The semantic ids are:&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;
| Early depth function&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Trigger (0 = idle, 1 = clear)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Use texture coordinates (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&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;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X1&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y1&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X2&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y2&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Clear value&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-11&lt;br /&gt;
| Width&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&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;
| &#039;position.z&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| &#039;color&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| &#039;texcoord0&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| &#039;texcoord1&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| &#039;texcoord2&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &#039;texcoord0.w&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| &#039;normquat&#039; or &#039;view&#039; component present&lt;br /&gt;
|}&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;
| Texture 0 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Texture 1 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Texture 2 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| Texture 3 coordinates (0 = texture 0, 1 = texture 1, 2 = texture 2)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Texture 3 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Texture 2 coordinates (0 = texture 2, 1 = texture 1)&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Clear texture cache (0 = don&#039;t clear, 1 = clear)&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;
| Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Alpha&lt;br /&gt;
|}&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-15&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Width&lt;br /&gt;
|}&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;
| Magnification filter&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Minification filter&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| ETC1 (0 = not ETC1, 2 = ETC1)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| Wrap T&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| Wrap S&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Shadow (Texture 0 only, 0 = not shadow, 1 = shadow)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Mipmap filter&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| Type (Texture 0 only)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| fixed13 (8 fractional bits), Bias&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Max Level&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Min Level&lt;br /&gt;
|}&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;
{| 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;
| Physical Address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&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;
| Perspective (0 = not perspective, 1 = perspective)&lt;br /&gt;
|-&lt;br /&gt;
| 1-23&lt;br /&gt;
| upper 23 bits of unsigned fixed24, Z bias&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Z scale&lt;br /&gt;
|}&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-31&lt;br /&gt;
| [[GPU_Textures#Texture_color_types|Format]]&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;, texture unit for bumpmapping&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;, texture unit for shadow mapping&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&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 lut_RR is enabled but not lut_RG or lut_RB, the output of lut_RR is used for the three components; Red, Green and Blue.&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
| lut_D0, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
| lut_FR, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
| lut_D0, lut_D1, lut_RR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
| lut_D0, lut_D1, lut_FR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
| All except for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
| All except for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
| All except for lut_RB and lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
lut_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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry, used to implement linear interpolation (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14769</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=14769"/>
		<updated>2015-12-01T10:13:15Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Whoops #3&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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_PROTEX0|GPUREG_TEXUNIT3_PROTEX0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX1|GPUREG_TEXUNIT3_PROTEX1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX2|GPUREG_TEXUNIT3_PROTEX2]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX3|GPUREG_TEXUNIT3_PROTEX3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX4|GPUREG_TEXUNIT3_PROTEX4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX5|GPUREG_TEXUNIT3_PROTEX5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_PROTEX_LUT|GPUREG_PROTEX_LUT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA0|GPUREG_PROTEX_LUT_DATA0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA1|GPUREG_PROTEX_LUT_DATA1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA2|GPUREG_PROTEX_LUT_DATA2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA3|GPUREG_PROTEX_LUT_DATA3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA4|GPUREG_PROTEX_LUT_DATA4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA5|GPUREG_PROTEX_LUT_DATA5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA6|GPUREG_PROTEX_LUT_DATA6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA7|GPUREG_PROTEX_LUT_DATA7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_DATA0|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_DATA1|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_DATA2|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_DATA3|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_DATA4|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_DATA5|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_DATA6|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_DATA7|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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_EARLY_DEPTH_TEST2|GPUREG_EARLY_DEPTH_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
| Culling mode&lt;br /&gt;
|}&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;
| float24, width / 2&lt;br /&gt;
|}&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;
| float31, 2 / width&lt;br /&gt;
|}&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;
| float24, height / 2&lt;br /&gt;
|}&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;
| float31, 2 / height&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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;
| float24, Clipping plane coefficient&lt;br /&gt;
|}&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;
| float24, Near - Far&lt;br /&gt;
|}&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;
| float24, Near&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Number of following attributes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&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;
{| 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;
| Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The semantic ids are:&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;
| Early depth function&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Trigger (0 = idle, 1 = clear)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Use texture coordinates (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&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;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X1&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y1&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X2&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y2&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Clear value&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-11&lt;br /&gt;
| Width&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&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;
| &#039;position.z&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| &#039;color&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| &#039;texcoord0&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| &#039;texcoord1&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| &#039;texcoord2&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &#039;texcoord0.w&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| &#039;normquat&#039; or &#039;view&#039; component present&lt;br /&gt;
|}&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;
| Texture 0 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Texture 1 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Texture 2 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| Texture 3 coordinates (0 = texture 0, 1 = texture 1, 2 = texture 2)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Texture 3 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Texture 2 coordinates (0 = texture 2, 1 = texture 1)&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Clear texture cache (0 = don&#039;t clear, 1 = clear)&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;
| Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Alpha&lt;br /&gt;
|}&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-15&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Width&lt;br /&gt;
|}&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;
| Magnification filter&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Minification filter&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| ETC1 (0 = not ETC1, 2 = ETC1)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| Wrap T&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| Wrap S&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Shadow (Texture 0 only, 0 = not shadow, 1 = shadow)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Mipmap filter&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| Type (Texture 0 only)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| fixed13 (8 fractional bits), Bias&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Max Level&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Min Level&lt;br /&gt;
|}&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;
{| 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;
| Physical Address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&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;
| Perspective (0 = not perspective, 1 = perspective)&lt;br /&gt;
|-&lt;br /&gt;
| 1-23&lt;br /&gt;
| upper 23 bits of unsigned fixed24, Z bias&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Z scale&lt;br /&gt;
|}&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-31&lt;br /&gt;
| [[GPU_Textures#Texture_color_types|Format]]&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;, texture unit for bumpmapping&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;, texture unit for shadow mapping&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&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 lut_RR is enabled but not lut_RG or lut_RB, the output of lut_RR is used for the three components; Red, Green and Blue.&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
| lut_D0, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
| lut_FR, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
| lut_D0, lut_D1, lut_RR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
| lut_D0, lut_D1, lut_FR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
| All except for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
| All except for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
| All except for lut_RB and lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
lut_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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry, used to implement linear interpolation (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14768</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=14768"/>
		<updated>2015-12-01T10:10:58Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Whoops #2&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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_RENDER_BUF_RESOLUTION1|GPUREG_RENDER_BUF_RESOLUTION1]]&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_PROTEX0|GPUREG_TEXUNIT3_PROTEX0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX1|GPUREG_TEXUNIT3_PROTEX1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX2|GPUREG_TEXUNIT3_PROTEX2]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX3|GPUREG_TEXUNIT3_PROTEX3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX4|GPUREG_TEXUNIT3_PROTEX4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX5|GPUREG_TEXUNIT3_PROTEX5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_PROTEX_LUT|GPUREG_PROTEX_LUT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA0|GPUREG_PROTEX_LUT_DATA0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA1|GPUREG_PROTEX_LUT_DATA1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA2|GPUREG_PROTEX_LUT_DATA2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA3|GPUREG_PROTEX_LUT_DATA3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA4|GPUREG_PROTEX_LUT_DATA4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA5|GPUREG_PROTEX_LUT_DATA5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA6|GPUREG_PROTEX_LUT_DATA6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA7|GPUREG_PROTEX_LUT_DATA7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_DATA0|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_DATA1|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_DATA2|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_DATA3|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_DATA4|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_DATA5|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_DATA6|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_DATA7|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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_EARLY_DEPTH_TEST2|GPUREG_EARLY_DEPTH_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
| Culling mode&lt;br /&gt;
|}&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;
| float24, width / 2&lt;br /&gt;
|}&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;
| float31, 2 / width&lt;br /&gt;
|}&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;
| float24, height / 2&lt;br /&gt;
|}&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;
| float31, 2 / height&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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;
| float24, Clipping plane coefficient&lt;br /&gt;
|}&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;
| float24, Near - Far&lt;br /&gt;
|}&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;
| float24, Near&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Number of following attributes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&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;
{| 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;
| Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The semantic ids are:&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;
| Early depth function&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Trigger (0 = idle, 1 = clear)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Use texture coordinates (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&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;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X1&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y1&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X2&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y2&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Clear value&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_RENDER_BUF_RESOLUTION1 ===&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;
| Width&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&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;
| &#039;position.z&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| &#039;color&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| &#039;texcoord0&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| &#039;texcoord1&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| &#039;texcoord2&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &#039;texcoord0.w&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| &#039;normquat&#039; or &#039;view&#039; component present&lt;br /&gt;
|}&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;
| Texture 0 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Texture 1 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Texture 2 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| Texture 3 coordinates (0 = texture 0, 1 = texture 1, 2 = texture 2)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Texture 3 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Texture 2 coordinates (0 = texture 2, 1 = texture 1)&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Clear texture cache (0 = don&#039;t clear, 1 = clear)&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;
| Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Alpha&lt;br /&gt;
|}&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-15&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Width&lt;br /&gt;
|}&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;
| Magnification filter&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Minification filter&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| ETC1 (0 = not ETC1, 2 = ETC1)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| Wrap T&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| Wrap S&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Shadow (Texture 0 only, 0 = not shadow, 1 = shadow)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Mipmap filter&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| Type (Texture 0 only)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| fixed13 (8 fractional bits), Bias&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Max Level&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Min Level&lt;br /&gt;
|}&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;
{| 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;
| Physical Address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&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;
| Perspective (0 = not perspective, 1 = perspective)&lt;br /&gt;
|-&lt;br /&gt;
| 1-23&lt;br /&gt;
| upper 23 bits of unsigned fixed24, Z bias&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Z scale&lt;br /&gt;
|}&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-31&lt;br /&gt;
| [[GPU_Textures#Texture_color_types|Format]]&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;, texture unit for bumpmapping&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;, texture unit for shadow mapping&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&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 lut_RR is enabled but not lut_RG or lut_RB, the output of lut_RR is used for the three components; Red, Green and Blue.&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
| lut_D0, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
| lut_FR, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
| lut_D0, lut_D1, lut_RR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
| lut_D0, lut_D1, lut_FR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
| All except for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
| All except for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
| All except for lut_RB and lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
lut_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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry, used to implement linear interpolation (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14767</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=14767"/>
		<updated>2015-12-01T10:08:28Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Whoops /* Rasterizer registers (0x040-0x07F) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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_EARLY_DEPTH_DATA|GPUREG_EARLY_DEPTH_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_RENDER_BUF_RESOLUTION1|GPUREG_RENDER_BUF_RESOLUTION1]]&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_PROTEX0|GPUREG_TEXUNIT3_PROTEX0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX1|GPUREG_TEXUNIT3_PROTEX1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX2|GPUREG_TEXUNIT3_PROTEX2]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX3|GPUREG_TEXUNIT3_PROTEX3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX4|GPUREG_TEXUNIT3_PROTEX4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX5|GPUREG_TEXUNIT3_PROTEX5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_PROTEX_LUT|GPUREG_PROTEX_LUT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA0|GPUREG_PROTEX_LUT_DATA0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA1|GPUREG_PROTEX_LUT_DATA1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA2|GPUREG_PROTEX_LUT_DATA2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA3|GPUREG_PROTEX_LUT_DATA3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA4|GPUREG_PROTEX_LUT_DATA4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA5|GPUREG_PROTEX_LUT_DATA5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA6|GPUREG_PROTEX_LUT_DATA6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA7|GPUREG_PROTEX_LUT_DATA7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_DATA0|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_DATA1|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_DATA2|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_DATA3|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_DATA4|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_DATA5|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_DATA6|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_DATA7|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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_EARLY_DEPTH_TEST2|GPUREG_EARLY_DEPTH_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
| Culling mode&lt;br /&gt;
|}&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;
| float24, width / 2&lt;br /&gt;
|}&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;
| float31, 2 / width&lt;br /&gt;
|}&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;
| float24, height / 2&lt;br /&gt;
|}&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;
| float31, 2 / height&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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;
| float24, Clipping plane coefficient&lt;br /&gt;
|}&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;
| float24, Near - Far&lt;br /&gt;
|}&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;
| float24, Near&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Number of following attributes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&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;
{| 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;
| Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The semantic ids are:&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;
| Early depth function&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Trigger (0 = idle, 1 = clear)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Use texture coordinates (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&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;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X1&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y1&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X2&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y2&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_EARLY_DEPTH_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;
| Clear value&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_RENDER_BUF_RESOLUTION1 ===&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;
| Width&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&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;
| &#039;position.z&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| &#039;color&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| &#039;texcoord0&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| &#039;texcoord1&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| &#039;texcoord2&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &#039;texcoord0.w&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| &#039;normquat&#039; or &#039;view&#039; component present&lt;br /&gt;
|}&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;
| Texture 0 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Texture 1 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Texture 2 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| Texture 3 coordinates (0 = texture 0, 1 = texture 1, 2 = texture 2)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Texture 3 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Texture 2 coordinates (0 = texture 2, 1 = texture 1)&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Clear texture cache (0 = don&#039;t clear, 1 = clear)&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;
| Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Alpha&lt;br /&gt;
|}&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-15&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Width&lt;br /&gt;
|}&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;
| Magnification filter&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Minification filter&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| ETC1 (0 = not ETC1, 2 = ETC1)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| Wrap T&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| Wrap S&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Shadow (Texture 0 only, 0 = not shadow, 1 = shadow)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Mipmap filter&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| Type (Texture 0 only)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| fixed13 (8 fractional bits), Bias&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Max Level&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Min Level&lt;br /&gt;
|}&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;
{| 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;
| Physical Address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&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;
| Perspective (0 = not perspective, 1 = perspective)&lt;br /&gt;
|-&lt;br /&gt;
| 1-23&lt;br /&gt;
| upper 23 bits of unsigned fixed24, Z bias&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Z scale&lt;br /&gt;
|}&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-31&lt;br /&gt;
| [[GPU_Textures#Texture_color_types|Format]]&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;, texture unit for bumpmapping&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;, texture unit for shadow mapping&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&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 lut_RR is enabled but not lut_RG or lut_RB, the output of lut_RR is used for the three components; Red, Green and Blue.&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
| lut_D0, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
| lut_FR, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
| lut_D0, lut_D1, lut_RR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
| lut_D0, lut_D1, lut_FR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
| All except for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
| All except for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
| All except for lut_RB and lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
lut_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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry, used to implement linear interpolation (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14766</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=14766"/>
		<updated>2015-12-01T10:07:55Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Rasterizer registers (0x040-0x07F) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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_DATA1]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAGOP_CLIP_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_FRAGOP_CLIP_DATAi|GPUREG_FRAGOP_CLIP_DATA2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_FRAGOP_CLIP_DATAi|GPUREG_FRAGOP_CLIP_DATA3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_FRAGOP_CLIP_DATAi|GPUREG_FRAGOP_CLIP_DATA4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAGOP_CLIP_DATA3&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_EARLY_DEPTH_DATA|GPUREG_EARLY_DEPTH_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_RENDER_BUF_RESOLUTION1|GPUREG_RENDER_BUF_RESOLUTION1]]&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_PROTEX0|GPUREG_TEXUNIT3_PROTEX0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX1|GPUREG_TEXUNIT3_PROTEX1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX2|GPUREG_TEXUNIT3_PROTEX2]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX3|GPUREG_TEXUNIT3_PROTEX3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX4|GPUREG_TEXUNIT3_PROTEX4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX5|GPUREG_TEXUNIT3_PROTEX5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_PROTEX_LUT|GPUREG_PROTEX_LUT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA0|GPUREG_PROTEX_LUT_DATA0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA1|GPUREG_PROTEX_LUT_DATA1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA2|GPUREG_PROTEX_LUT_DATA2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA3|GPUREG_PROTEX_LUT_DATA3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA4|GPUREG_PROTEX_LUT_DATA4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA5|GPUREG_PROTEX_LUT_DATA5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA6|GPUREG_PROTEX_LUT_DATA6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA7|GPUREG_PROTEX_LUT_DATA7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_DATA0|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_DATA1|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_DATA2|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_DATA3|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_DATA4|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_DATA5|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_DATA6|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_DATA7|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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_EARLY_DEPTH_TEST2|GPUREG_EARLY_DEPTH_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
| Culling mode&lt;br /&gt;
|}&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;
| float24, width / 2&lt;br /&gt;
|}&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;
| float31, 2 / width&lt;br /&gt;
|}&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;
| float24, height / 2&lt;br /&gt;
|}&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;
| float31, 2 / height&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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;
| float24, Clipping plane coefficient&lt;br /&gt;
|}&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;
| float24, Near - Far&lt;br /&gt;
|}&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;
| float24, Near&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Number of following attributes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&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;
{| 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;
| Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The semantic ids are:&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;
| Early depth function&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Trigger (0 = idle, 1 = clear)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Use texture coordinates (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&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;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X1&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y1&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X2&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y2&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_EARLY_DEPTH_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;
| Clear value&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_RENDER_BUF_RESOLUTION1 ===&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;
| Width&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&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;
| &#039;position.z&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| &#039;color&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| &#039;texcoord0&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| &#039;texcoord1&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| &#039;texcoord2&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &#039;texcoord0.w&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| &#039;normquat&#039; or &#039;view&#039; component present&lt;br /&gt;
|}&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;
| Texture 0 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Texture 1 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Texture 2 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| Texture 3 coordinates (0 = texture 0, 1 = texture 1, 2 = texture 2)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Texture 3 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Texture 2 coordinates (0 = texture 2, 1 = texture 1)&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Clear texture cache (0 = don&#039;t clear, 1 = clear)&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;
| Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Alpha&lt;br /&gt;
|}&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-15&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Width&lt;br /&gt;
|}&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;
| Magnification filter&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Minification filter&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| ETC1 (0 = not ETC1, 2 = ETC1)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| Wrap T&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| Wrap S&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Shadow (Texture 0 only, 0 = not shadow, 1 = shadow)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Mipmap filter&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| Type (Texture 0 only)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| fixed13 (8 fractional bits), Bias&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Max Level&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Min Level&lt;br /&gt;
|}&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;
{| 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;
| Physical Address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&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;
| Perspective (0 = not perspective, 1 = perspective)&lt;br /&gt;
|-&lt;br /&gt;
| 1-23&lt;br /&gt;
| upper 23 bits of unsigned fixed24, Z bias&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Z scale&lt;br /&gt;
|}&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-31&lt;br /&gt;
| [[GPU_Textures#Texture_color_types|Format]]&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;, texture unit for bumpmapping&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;, texture unit for shadow mapping&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&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 lut_RR is enabled but not lut_RG or lut_RB, the output of lut_RR is used for the three components; Red, Green and Blue.&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
| lut_D0, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
| lut_FR, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
| lut_D0, lut_D1, lut_RR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
| lut_D0, lut_D1, lut_FR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
| All except for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
| All except for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
| All except for lut_RB and lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
lut_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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry, used to implement linear interpolation (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14765</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=14765"/>
		<updated>2015-12-01T10:05:57Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Adapt new GPU register names to homebrew naming conventions&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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_DATA1]]&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_DATA2]]&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_DATA3]]&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_DATA4]]&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_EARLY_DEPTH_DATA|GPUREG_EARLY_DEPTH_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_RENDER_BUF_RESOLUTION1|GPUREG_RENDER_BUF_RESOLUTION1]]&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_PROTEX0|GPUREG_TEXUNIT3_PROTEX0]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX1|GPUREG_TEXUNIT3_PROTEX1]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX2|GPUREG_TEXUNIT3_PROTEX2]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX3|GPUREG_TEXUNIT3_PROTEX3]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX4|GPUREG_TEXUNIT3_PROTEX4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_TEXUNIT3_PROTEX5|GPUREG_TEXUNIT3_PROTEX5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_PROTEX_LUT|GPUREG_PROTEX_LUT]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA0|GPUREG_PROTEX_LUT_DATA0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA1|GPUREG_PROTEX_LUT_DATA1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA2|GPUREG_PROTEX_LUT_DATA2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA3|GPUREG_PROTEX_LUT_DATA3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA4|GPUREG_PROTEX_LUT_DATA4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA5|GPUREG_PROTEX_LUT_DATA5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA6|GPUREG_PROTEX_LUT_DATA6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_PROTEX_LUT_DATA7|GPUREG_PROTEX_LUT_DATA7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_DATA0|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_DATA1|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_DATA2|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_DATA3|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_DATA4|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_DATA5|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_DATA6|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_DATA7|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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_EARLY_DEPTH_TEST2|GPUREG_EARLY_DEPTH_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
| Culling mode&lt;br /&gt;
|}&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;
| float24, width / 2&lt;br /&gt;
|}&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;
| float31, 2 / width&lt;br /&gt;
|}&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;
| float24, height / 2&lt;br /&gt;
|}&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;
| float31, 2 / height&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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;
| float24, Clipping plane coefficient&lt;br /&gt;
|}&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;
| float24, Near - Far&lt;br /&gt;
|}&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;
| float24, Near&lt;br /&gt;
|}&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-31&lt;br /&gt;
| Number of following attributes&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&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;
{| 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;
| Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The semantic ids are:&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;
| Early depth function&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Trigger (0 = idle, 1 = clear)&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Use texture coordinates (0 = don&#039;t use, 1 = use)&lt;br /&gt;
|}&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;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X1&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y1&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X2&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y2&lt;br /&gt;
|}&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-15&lt;br /&gt;
| X&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_EARLY_DEPTH_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;
| Clear value&lt;br /&gt;
|}&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_RENDER_BUF_RESOLUTION1 ===&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;
| Width&lt;br /&gt;
|-&lt;br /&gt;
| 12-23&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| 0x1&lt;br /&gt;
|}&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;
| &#039;position.z&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| &#039;color&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| &#039;texcoord0&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| &#039;texcoord1&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| &#039;texcoord2&#039; component present&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &#039;texcoord0.w&#039; present&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| &#039;normquat&#039; or &#039;view&#039; component present&lt;br /&gt;
|}&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;
| Texture 0 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Texture 1 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Texture 2 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 8-9&lt;br /&gt;
| Texture 3 coordinates (0 = texture 0, 1 = texture 1, 2 = texture 2)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Texture 3 enabled&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Texture 2 coordinates (0 = texture 2, 1 = texture 1)&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Clear texture cache (0 = don&#039;t clear, 1 = clear)&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;
| Red&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Green&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Blue&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Alpha&lt;br /&gt;
|}&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-15&lt;br /&gt;
| Height&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Width&lt;br /&gt;
|}&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;
| Magnification filter&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Minification filter&lt;br /&gt;
|-&lt;br /&gt;
| 4-5&lt;br /&gt;
| ETC1 (0 = not ETC1, 2 = ETC1)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| Wrap T&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| Wrap S&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Shadow (Texture 0 only, 0 = not shadow, 1 = shadow)&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Mipmap filter&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| Type (Texture 0 only)&lt;br /&gt;
|}&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-15&lt;br /&gt;
| fixed13 (8 fractional bits), Bias&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Max Level&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Min Level&lt;br /&gt;
|}&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;
{| 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;
| Physical Address &amp;gt;&amp;gt; 3&lt;br /&gt;
|}&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;
| Perspective (0 = not perspective, 1 = perspective)&lt;br /&gt;
|-&lt;br /&gt;
| 1-23&lt;br /&gt;
| upper 23 bits of unsigned fixed24, Z bias&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Z scale&lt;br /&gt;
|}&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-31&lt;br /&gt;
| [[GPU_Textures#Texture_color_types|Format]]&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-1&lt;br /&gt;
| Enabled (0 = disabled, 1 = enabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;, texture unit for bumpmapping&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;, texture unit for shadow mapping&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&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 lut_RR is enabled but not lut_RG or lut_RB, the output of lut_RR is used for the three components; Red, Green and Blue.&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
| lut_D0, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
| lut_FR, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
| lut_D0, lut_D1, lut_RR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
| lut_D0, lut_D1, lut_FR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
| All except for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
| All except for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
| All except for lut_RB and lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
lut_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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry, used to implement linear interpolation (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Main_Page/Navigation&amp;diff=14727</id>
		<title>Main Page/Navigation</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Main_Page/Navigation&amp;diff=14727"/>
		<updated>2015-11-28T12:21:31Z</updated>

		<summary type="html">&lt;p&gt;Fincs: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Main page box|Navigation|Main Page/Navigation}}&lt;br /&gt;
&amp;lt;div style=&amp;quot;margin: -.3em -1em -1em -1em;&amp;quot;&amp;gt;&lt;br /&gt;
{| width=&amp;quot;100%&amp;quot; bgcolor=&amp;quot;#fff&amp;quot; border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;2px&amp;quot; cellspacing=&amp;quot;2px&amp;quot; style=&amp;quot;margin:auto;&amp;quot;&lt;br /&gt;
|- align=&amp;quot;center&amp;quot; bgcolor=&amp;quot;#e7eef6&amp;quot;&lt;br /&gt;
! width=&amp;quot;33%&amp;quot; | &#039;&#039;&#039;General&#039;&#039;&#039; &amp;lt;!-- Stuff not directly related to reverse-engineering, system documentation, and homebrew --&amp;gt;&lt;br /&gt;
! width=&amp;quot;33%&amp;quot; | &#039;&#039;&#039;Homebrew&#039;&#039;&#039; &amp;lt;!-- Homebrew and exploitation --&amp;gt;&lt;br /&gt;
! width=&amp;quot;33%&amp;quot; | &#039;&#039;&#039;3DS hardware&#039;&#039;&#039; &amp;lt;!-- 3DS Hardware and its interfaces --&amp;gt;&lt;br /&gt;
|- valign=&amp;quot;top&amp;quot; style=&amp;quot;background: #F5FAFF;&amp;quot;&lt;br /&gt;
| &lt;br /&gt;
*[[Glossary]]&lt;br /&gt;
*[[FAQ]]&lt;br /&gt;
*[[Friend code]]&lt;br /&gt;
*[[Games]]&lt;br /&gt;
*[[Serials]]&lt;br /&gt;
*[[:Category:PC utilities|PC Utilities]]&lt;br /&gt;
|&lt;br /&gt;
*[[Homebrew Exploits]]&lt;br /&gt;
*[[Homebrew Applications]]&lt;br /&gt;
*[[Homebrew Libraries and Tools]]&lt;br /&gt;
*[[3DS System Flaws]]&lt;br /&gt;
*[[3DS Userland Flaws]]&lt;br /&gt;
|&lt;br /&gt;
*[[Hardware]]&lt;br /&gt;
*[[GPU]]&lt;br /&gt;
*[[Peripherals]]&lt;br /&gt;
*[[Gamecards]]&lt;br /&gt;
*[[Video Capture]]&lt;br /&gt;
*[[IO|IO registers]] &lt;br /&gt;
|}&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div style=&amp;quot;margin: -.3em -1em -1em -1em; margin-top: +1em&amp;quot;&amp;gt;&lt;br /&gt;
{| width=&amp;quot;100%&amp;quot; bgcolor=&amp;quot;#fff&amp;quot; border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;2px&amp;quot; cellspacing=&amp;quot;2px&amp;quot; style=&amp;quot;margin:auto;&amp;quot;&lt;br /&gt;
|- align=&amp;quot;center&amp;quot; bgcolor=&amp;quot;#e7eef6&amp;quot;&lt;br /&gt;
! width=&amp;quot;33%&amp;quot; | &#039;&#039;&#039;3DS operating system&#039;&#039;&#039;  &amp;lt;!-- Content related to FIRM data --&amp;gt;&lt;br /&gt;
! width=&amp;quot;33%&amp;quot; | &#039;&#039;&#039;3DS software stack&#039;&#039;&#039; &amp;lt;!-- Generic system software built on top of the kernel interfaces --&amp;gt;&lt;br /&gt;
! width=&amp;quot;33%&amp;quot; | &#039;&#039;&#039;3DS content&#039;&#039;&#039; &amp;lt;!-- Files used commonly within the system --&amp;gt;&lt;br /&gt;
|- valign=&amp;quot;top&amp;quot; style=&amp;quot;background: #F5FAFF;&amp;quot;&lt;br /&gt;
| &lt;br /&gt;
*[[Memory layout]] &lt;br /&gt;
*[[Services API]]&lt;br /&gt;
*[[SVC|System calls]] &lt;br /&gt;
*[[:Category:Kernel_objects|Kernel objects]]&lt;br /&gt;
*[[Kernel]]&lt;br /&gt;
*[[Bootloader]]&lt;br /&gt;
|&lt;br /&gt;
*[[Nintendo Software]]&lt;br /&gt;
*[[3DS Development Unit Software]]&lt;br /&gt;
*[[Title list]]&lt;br /&gt;
*[[Title metadata]]&lt;br /&gt;
*[[Update Data]]&lt;br /&gt;
|&lt;br /&gt;
*[[SD Filesystem]]&lt;br /&gt;
*[[Flash Filesystem]]&lt;br /&gt;
*[[Savegames]]&lt;br /&gt;
*[[:Category:File_formats|File Formats]] ([[NCSD|CCI]]/[[NCCH#CXI|CXI]]/[[CIA]])&lt;br /&gt;
* [[PRUDP]]&lt;br /&gt;
|}&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
{{box-footer-empty}}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=14719</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=14719"/>
		<updated>2015-11-26T21:47:13Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Fragment lighting registers */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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;
|&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_0047|GPUREG_0047]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_0048|GPUREG_0048]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_0049|GPUREG_0049]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_004A|GPUREG_004A]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_004B|GPUREG_004B]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_FRAG_OP_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_FRAG_OP_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_0061|GPUREG_0061]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_0062|GPUREG_0062]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_0063|GPUREG_0063]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_0064|GPUREG_0064]]&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_006A|GPUREG_006A]]&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_006D|GPUREG_006D]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM2|GPUREG_FRAMEBUFFER_DIM2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_006F|GPUREG_006F]]&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_ENABLE|GPUREG_TEXUNIT_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_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_TEXUNIT0_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_TEXUNIT0_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_0084|GPUREG_0084]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_LOC|GPUREG_TEXUNIT0_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_0086|GPUREG_0086]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_0087|GPUREG_0087]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_0088|GPUREG_0088]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_0089|GPUREG_0089]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_008A|GPUREG_008A]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_008B|GPUREG_008B]]&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_TEXUNIT0_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_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_TEXUNIT1_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_TEXUNIT1_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_TEXUNIT1_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_0094|GPUREG_0094]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_LOC|GPUREG_TEXUNIT1_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_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_TEXUNIT2_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_TEXUNIT2_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_TEXUNIT2_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_009C|GPUREG_009C]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_LOC|GPUREG_TEXUNIT2_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_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_00A8|GPUREG_00A8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_00A9|GPUREG_00A9]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_00AA|GPUREG_00AA]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_00AB|GPUREG_00AB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_00AC|GPUREG_00AC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_00AD|GPUREG_00AD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_00AF|GPUREG_00AF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_00B0|GPUREG_00B0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_00B1|GPUREG_00B1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_00B2|GPUREG_00B2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_00B3|GPUREG_00B3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_00B4|GPUREG_00B4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_00B5|GPUREG_00B5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_00B6|GPUREG_00B6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_00B7|GPUREG_00B7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_00E1|GPUREG_00E1]]&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_00E4|GPUREG_00E4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_00E5|GPUREG_00E5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_00E6|GPUREG_00E6]]&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_00E8|GPUREG_00E8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_00E9|GPUREG_00E9]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_00EA|GPUREG_00EA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_00EB|GPUREG_00EB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_00EC|GPUREG_00EC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_00ED|GPUREG_00ED]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_00EE|GPUREG_00EE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_00EF|GPUREG_00EF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_OP_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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_0118|GPUREG_0118]]&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_0120|GPUREG_0120]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_0121|GPUREG_0121]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_0122|GPUREG_0122]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_0123|GPUREG_0123]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_0124|GPUREG_0124]]&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_0126|GPUREG_0126]]&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_0130|GPUREG_0130]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_022D|GPUREG_022D]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0231|GPUREG_0231]]&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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0242|GPUREG_0242]]&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_0244|GPUREG_0244]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_0245|GPUREG_0245]]&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_024A|GPUREG_024A]]&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_0251|GPUREG_0251]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_0252|GPUREG_0252]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_0253|GPUREG_0253]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_0254|GPUREG_0254]]&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_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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&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;
{| 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;
| Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The semantic ids are:&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;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;, texture unit for bumpmapping&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;, texture unit for shadow mapping&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&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 lut_RR is enabled but not lut_RG or lut_RB, the output of lut_RR is used for the three components; Red, Green and Blue.&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
| lut_D0, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
| lut_FR, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
| lut_D0, lut_D1, lut_RR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
| lut_D0, lut_D1, lut_FR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
| All except for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
| All except for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
| All except for lut_RB and lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
lut_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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry, used to implement linear interpolation (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light. The attenuation factor is lut_DA(clip(bias + scale*distance, 0.0, 1.0)).&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Filesystem_services&amp;diff=14411</id>
		<title>Filesystem services</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Filesystem_services&amp;diff=14411"/>
		<updated>2015-10-31T19:12:41Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* DirectoryEntry */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:Services]]&lt;br /&gt;
&lt;br /&gt;
= Filesystem service &amp;quot;fs:USER&amp;quot; =&lt;br /&gt;
You can at most have 32 FS archive handles.&lt;br /&gt;
&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;
!  Description&lt;br /&gt;
!   scope=&amp;quot;col&amp;quot; width=&amp;quot;400&amp;quot; | Required [[NCCH/Extended_Header|exheader]] access info bitmask&lt;br /&gt;
|-&lt;br /&gt;
| 0x000100C6&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Dummy1|Dummy1]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x040100C4&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Control|Control]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08010002&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Initialize|Initialize]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x080201C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:OpenFile|OpenFile]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08030204&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:OpenFileDirectly|OpenFileDirectly]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08040142&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:DeleteFile|DeleteFile]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08050244&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:RenameFile|RenameFile]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08060142&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:DeleteDirectory|DeleteDirectory]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08070142&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:DeleteDirectoryRecursively|DeleteDirectoryRecursively]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08080202&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CreateFile|CreateFile]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08090182&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CreateDirectory|CreateDirectory]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x080A0244&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:RenameDirectory|RenameDirectory]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x080B0102&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:OpenDirectory|OpenDirectory]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x080C00C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:OpenArchive|OpenArchive]]&lt;br /&gt;
| Each archive ID code has separate access info bitmasks, if it has any&lt;br /&gt;
|-&lt;br /&gt;
| 0x080D0144&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:ControlArchive|ControlArchive]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x080E0080&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CloseArchive|CloseArchive]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x080F0180&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_2_0_FormatThisUserSaveData|Obsoleted_2_0_FormatThisUserSaveData]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08100200&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_CreateSystemSaveData|Obsoleted_3_0_CreateSystemSaveData]]&lt;br /&gt;
| 0x4, for when the input saveID doesn&#039;t match the exheader saveID&lt;br /&gt;
|-&lt;br /&gt;
| 0x08110040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_DeleteSystemSaveData|Obsoleted_3_0_DeleteSystemSaveData]]&lt;br /&gt;
| 0x1004, for when the input saveID doesn&#039;t match the exheader saveID&lt;br /&gt;
|-&lt;br /&gt;
| 0x08120080&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetFreeBytes|GetFreeBytes]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08130000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetCardType|GetCardType]]&lt;br /&gt;
| 0x1017&lt;br /&gt;
|-&lt;br /&gt;
| 0x08140000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetSdmcArchiveResource|GetSdmcArchiveResource]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08150000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetNandArchiveResource|GetNandArchiveResource]]&lt;br /&gt;
| 0x1007&lt;br /&gt;
|-&lt;br /&gt;
| 0x08160000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetSdmcFatfsError|GetSdmcFatfsError]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08170000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:IsSdmcDetected|IsSdmcDetected]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08180000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:IsSdmcWritable|IsSdmcWritable]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08190042&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetSdmcCid|GetSdmcCid]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x081A0042&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetNandCid|GetNandCid]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x081B0000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetSdmcSpeedInfo|GetSdmcSpeedInfo]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x081C0000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetNandSpeedInfo|GetNandSpeedInfo]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x081D0042&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetSdmcLog|GetSdmcLog]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x081E0042&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetNandLog|GetNandLog]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x081F0000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:ClearSdmcLog|ClearSdmcLog]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08200000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:ClearNandLog|ClearNandLog]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08210000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardSlotIsInserted|CardSlotIsInserted]]&lt;br /&gt;
| 0x1017&lt;br /&gt;
|-&lt;br /&gt;
| 0x08220000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardSlotPowerOn|CardSlotPowerOn]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08230000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardSlotPowerOff|CardSlotPowerOff]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08240000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardSlotGetCardIFPowerStatus|CardSlotGetCardIFPowerStatus]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08250040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectCommand|CardNorDirectCommand]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08260080&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectCommandWithAddress|CardNorDirectCommandWithAddress]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08270082&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectRead|CardNorDirectRead]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x082800C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectReadWithAddress|CardNorDirectReadWithAddress]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08290082&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectWrite|CardNorDirectWrite]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x082A00C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectWriteWithAddress|CardNorDirectWriteWithAddress]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x082B00C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectRead_4xIO|CardNorDirectRead_4xIO]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x082C0082&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectCpuWriteWithoutVerify|CardNorDirectCpuWriteWithoutVerify]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x082D0040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CardNorDirectSectorEraseWithoutVerify|CardNorDirectSectorEraseWithoutVerify]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x082E0040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetProductInfo|GetProductInfo]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x082F0040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetProgramLaunchInfo|GetProgramLaunchInfo]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x08300182&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_CreateExtSaveData|Obsoleted_3_0_CreateExtSaveData]]&lt;br /&gt;
| 0xC, for when the input extdataID doesn&#039;t match the exheader extdataID&lt;br /&gt;
|-&lt;br /&gt;
| 0x08310180&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_CreateSharedExtSaveData|Obsoleted_3_0_CreateSharedExtSaveData]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x08320102&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_ReadExtSaveDataIcon|Obsoleted_3_0_ReadExtSaveDataIcon]]&lt;br /&gt;
| 0x100D, for when the input extdataID doesn&#039;t match the exheader extdataID&lt;br /&gt;
|-&lt;br /&gt;
| 0x08330082&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_EnumerateExtSaveData|Obsoleted_3_0_EnumerateExtSaveData]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x08340082&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_EnumerateSharedExtSaveData|Obsoleted_3_0_EnumerateSharedExtSaveData]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x08350080&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_DeleteExtSaveData|Obsoleted_3_0_DeleteExtSaveData]]&lt;br /&gt;
| 0x100D, for when the input extdataID doesn&#039;t match the exheader extdataID&lt;br /&gt;
|-&lt;br /&gt;
| 0x08360080&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_DeleteSharedExtSaveData|Obsoleted_3_0_DeleteSharedExtSaveData]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x08370040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:SetCardSpiBaudRate|SetCardSpiBaudRate]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08380040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:SetCardSpiBusMode|SetCardSpiBusMode]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x08390000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:SendInitializeInfoTo9|SendInitializeInfoTo9]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x083A0100&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetSpecialContentIndex|GetSpecialContentIndex]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x083B00C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetLegacyRomHeader|GetLegacyRomHeader]]&lt;br /&gt;
| 0x1015&lt;br /&gt;
|-&lt;br /&gt;
| 0x083C00C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetLegacyBannerData|GetLegacyBannerData]]&lt;br /&gt;
| 0x1015&lt;br /&gt;
|-&lt;br /&gt;
| 0x083D0100&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CheckAuthorityToAccessExtSaveData|CheckAuthorityToAccessExtSaveData]]&lt;br /&gt;
| 0x44&lt;br /&gt;
|-&lt;br /&gt;
| 0x083E00C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:QueryTotalQuotaSize|QueryTotalQuotaSize]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x083F00C0&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_3_0_GetExtDataBlockSize|Obsoleted_3_0_GetExtDataBlockSize]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08400040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:AbnegateAccessRight|AbnegateAccessRight]]&lt;br /&gt;
|?&lt;br /&gt;
|-&lt;br /&gt;
| 0x08410000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:DeleteSdmcRoot|DeleteSdmcRoot]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x08420040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:DeleteAllExtSaveDataOnNand|DeleteAllExtSaveDataOnNand]]&lt;br /&gt;
| 0x1005&lt;br /&gt;
|-&lt;br /&gt;
| 0x08430000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:InitializeCtrFileSystem|InitializeCtrFileSystem]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08440000&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:CreateSeed|CreateSeed]]&lt;br /&gt;
| 0x2&lt;br /&gt;
|-&lt;br /&gt;
| 0x084500C2&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetFormatInfo|GetFormatInfo]]&lt;br /&gt;
|?&lt;br /&gt;
|-&lt;br /&gt;
| 0x08460102&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetLegacyRomHeader2|GetLegacyRomHeader2]]&lt;br /&gt;
| 0x1015&lt;br /&gt;
|-&lt;br /&gt;
| 0x08470180&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:Obsoleted_2_0_FormatCtrCardUserSaveData|Obsoleted_2_0_FormatCtrCardUserSaveData]]&lt;br /&gt;
| 0x6&lt;br /&gt;
|-&lt;br /&gt;
| 0x08480042&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetSdmcCtrRootPath|GetSdmcCtrRootPath]]&lt;br /&gt;
| 0x100D&lt;br /&gt;
|-&lt;br /&gt;
| 0x08490040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetArchiveResource|GetArchiveResource]]&lt;br /&gt;
|?&lt;br /&gt;
|-&lt;br /&gt;
| 0x084A0002&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:ExportIntegrityVerificationSeed|ExportIntegrityVerificationSeed]]&lt;br /&gt;
| 0x4000&lt;br /&gt;
|-&lt;br /&gt;
| 0x084B0002&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:ImportIntegrityVerificationSeed|ImportIntegrityVerificationSeed]]&lt;br /&gt;
| 0x4000&lt;br /&gt;
|-&lt;br /&gt;
| 0x084C0242&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:FormatSaveData|FormatSaveData]]&lt;br /&gt;
| 0x6, in some cases this write isn&#039;t needed however&lt;br /&gt;
|-&lt;br /&gt;
| 0x084D0102&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetLegacySubBannerData|GetLegacySubBannerData]]&lt;br /&gt;
| 0x1015&lt;br /&gt;
|-&lt;br /&gt;
| 0x084E0342&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:UpdateSha256Context|UpdateSha256Context]]&lt;br /&gt;
| 0x5&lt;br /&gt;
|-&lt;br /&gt;
| 0x084F0102&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:ReadSpecialFile|ReadSpecialFile]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08500040&lt;br /&gt;
|?&lt;br /&gt;
| [[FS:GetSpecialFileSize|GetSpecialFileSize]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08510242&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:CreateExtSaveData|CreateExtSaveData]]&lt;br /&gt;
| Shared extdata: 0x101005. Regular extdata in certain cases: 0xC&lt;br /&gt;
|-&lt;br /&gt;
| 0x08520100&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:DeleteExtSaveData|DeleteExtSaveData]]&lt;br /&gt;
| Shared extdata: 0x101005. Regular extdata in certain cases: 0x10100D&lt;br /&gt;
|-&lt;br /&gt;
| 0x08530142&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:ReadExtSaveDataIcon|ReadExtSaveDataIcon]]&lt;br /&gt;
| 0x10100D (this doesn&#039;t apply in certain cases, however)&lt;br /&gt;
|-&lt;br /&gt;
| 0x085400C0&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:GetExtDataBlockSize|GetExtDataBlockSize]]&lt;br /&gt;
| 0x10100D (this doesn&#039;t apply in certain cases, however)&lt;br /&gt;
|-&lt;br /&gt;
| 0x08550102&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:EnumerateExtSaveData|EnumerateExtSaveData]]&lt;br /&gt;
| 0x101005&lt;br /&gt;
|-&lt;br /&gt;
| 0x08560200&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:CreateSystemSaveData|CreateSystemSaveData]]&lt;br /&gt;
| 0x4 (this doesn&#039;t apply in certain cases, however)&lt;br /&gt;
|-&lt;br /&gt;
| 0x08570080&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:DeleteSystemSaveData|DeleteSystemSaveData]]&lt;br /&gt;
| 0x1004 (this doesn&#039;t apply in certain cases, however)&lt;br /&gt;
|-&lt;br /&gt;
| 0x08580000&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:StartDeviceMoveAsSource|StartDeviceMoveAsSource]]&lt;br /&gt;
| 0x2004&lt;br /&gt;
|-&lt;br /&gt;
| 0x08590200&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:StartDeviceMoveAsDestination|StartDeviceMoveAsDestination]]&lt;br /&gt;
| 0x2004&lt;br /&gt;
|-&lt;br /&gt;
| 0x085A00C0&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:SetArchivePriority|SetArchivePriority]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x085B0080&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:GetArchivePriority|GetArchivePriority]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x085C00C0&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:SetCtrCardLatencyParameter|SetCtrCardLatencyParameter]]&lt;br /&gt;
| 0xE&lt;br /&gt;
|-&lt;br /&gt;
| 0x085D01C0&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:SetFsCompatibilityInfo|SetFsCompatibilityInfo]]&lt;br /&gt;
| 0x100001&lt;br /&gt;
|-&lt;br /&gt;
| 0x085E0040&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:ResetCardCompatibilityParameter|ResetCardCompatibilityParameter]]&lt;br /&gt;
| 0xE&lt;br /&gt;
|-&lt;br /&gt;
| 0x085F0040&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:SwitchCleanupInvalidSaveData|SwitchCleanupInvalidSaveData]]&lt;br /&gt;
| 0x12004&lt;br /&gt;
|-&lt;br /&gt;
| 0x08600042&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:EnumerateSystemSaveData|EnumerateSystemSaveData]]&lt;br /&gt;
| 0x2004&lt;br /&gt;
|-&lt;br /&gt;
| 0x08610042&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:InitializeWithSdkVersion|InitializeWithSdkVersion]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08620040&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:SetPriority|SetPriority]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08630000&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:GetPriority|GetPriority]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08640000&lt;br /&gt;
| [[3.0.0-5]]&lt;br /&gt;
| [[FS:Obsoleted_4_0_GetNandInfo|Obsoleted_4_0_GetNandInfo]]&lt;br /&gt;
| Stubbed, this returns an error&lt;br /&gt;
|-&lt;br /&gt;
| 0x08650140&lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| [[FS:SetSaveDataSecureValue|SetSaveDataSecureValue]]&lt;br /&gt;
| 0x121004 (in certain cases this doesn&#039;t apply, however)&lt;br /&gt;
|-&lt;br /&gt;
| 0x086600C0&lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| [[FS:GetSaveDataSecureValue|GetSaveDataSecureValue]]&lt;br /&gt;
| 0x121004 (in certain cases this doesn&#039;t apply, however)&lt;br /&gt;
|-&lt;br /&gt;
| 0x086700C4&lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| [[FS:ControlSecureSave|ControlSecureSave]]&lt;br /&gt;
| 0x121004&lt;br /&gt;
|-&lt;br /&gt;
| 0x08680000&lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| [[FS:GetMediaType|GetMediaType]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x08690000&lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| [[FS:Obsoleted_4_0_GetNandEraseCount|Obsoleted_4_0_GetNandEraseCount]]&lt;br /&gt;
| Stubbed, this returns an error.&lt;br /&gt;
|-&lt;br /&gt;
| 0x086A0082&lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| [[FS:ReadNandReport|ReadNandReport]]&lt;br /&gt;
| None&lt;br /&gt;
|-&lt;br /&gt;
| 0x086B00C2&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
| 00121004&lt;br /&gt;
|-&lt;br /&gt;
| 0x086C00C2&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
| 00121004&lt;br /&gt;
|-&lt;br /&gt;
| 0x086D0040&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
| 00020004&lt;br /&gt;
|-&lt;br /&gt;
| 0x086E00C0&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
|None?&lt;br /&gt;
|-&lt;br /&gt;
| 0x086F0040&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
| 0xE&lt;br /&gt;
|-&lt;br /&gt;
| 0x087000C2&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
|None?&lt;br /&gt;
|-&lt;br /&gt;
| 0x08710100&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
| 0xC&lt;br /&gt;
|-&lt;br /&gt;
| 0x087201C0&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
| 00080004&lt;br /&gt;
|-&lt;br /&gt;
| 0x087300C0&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
| 00080004&lt;br /&gt;
|-&lt;br /&gt;
| 0x08740000&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
| 00080004&lt;br /&gt;
|-&lt;br /&gt;
| 0x08750140&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
|None?&lt;br /&gt;
|-&lt;br /&gt;
| 0x087600C0&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
|None?&lt;br /&gt;
|-&lt;br /&gt;
| 0x08770100&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
|-&lt;br /&gt;
| 0x087800C0&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
|?&lt;br /&gt;
|-&lt;br /&gt;
| 0x087900C2&lt;br /&gt;
| ?&lt;br /&gt;
| Same as GetLegacyBannerData, except for the last parameter this passes u8 value 0x1 instead of 0x0, for the FSPXI command.&lt;br /&gt;
| 0x00101015&lt;br /&gt;
|-&lt;br /&gt;
| 0x087A....&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| ?&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x087B....&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Wrapper for the code internally used for command &amp;lt;0x087A....&amp;gt;.&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x087C....&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Eventually calls same code as command &amp;lt;0x087A....&amp;gt;.&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x087D0000&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Writes an u32 from state to cmdreply[2]. Probably the total number of titles in the SEEDDB?&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x087E0042&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Eventually calls same code as command &amp;lt;0x087A....&amp;gt;. Writes a list of titleIDs to the outbuf, this is for titles with content-lock-seed(s) stored in SEEDDB. (u32 total_titleids_probably, ((Size&amp;lt;&amp;lt;4)  &amp;lt;nowiki&amp;gt;|&amp;lt;/nowiki&amp;gt; 12), outbufptr)&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x087F....&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| ?&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x0880....&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Eventually calls same code as command &amp;lt;0x087A....&amp;gt;.&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x0881....&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Eventually calls same code as command &amp;lt;0x087A....&amp;gt;.&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x0882....&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Eventually calls same code as command &amp;lt;0x087A....&amp;gt;.&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x08830000&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Writes an output value to cmdreply[2].&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x08840042&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Eventually calls same code as command &amp;lt;0x087A....&amp;gt;.&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|-&lt;br /&gt;
| 0x0885....&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| ?&lt;br /&gt;
| 0x00200000&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Note: The question marks from Dummy1 to GetSpecialFileSize on the &amp;quot;available since system version&amp;quot; field are mainly there because I think that most of these are necessary for the main system to function, so theoretically that would mean that since the creation of the 3DS these were available, or since launch if that makes more sense. But because of the peculiar nature of some of the functions, they will remain question marks until they can be confirmed 100%.&lt;br /&gt;
&lt;br /&gt;
When access rights are required for a command, at least one of the bits in the process access info specified in the above table for the command must be set. Error 0xD9004676 is returned when a process attempts to use a command which it doesn&#039;t have access rights for the command. The exheader access info field is all zero&#039;s for most applications. Note that the permissions listed in the above table is for system-version v2.x, therefore permission bit(s) added with newer FIRM may be missing from this.&lt;br /&gt;
&lt;br /&gt;
Each session for fs:USER has separate permissions, initially these are set to all zero&#039;s for new fs:USER sessions. The permissions/etc for fs:USER sessions are initialized via [[FS:Initialize]](loaded from the user process exheader).&lt;br /&gt;
&lt;br /&gt;
=File service=&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;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x000100C6&lt;br /&gt;
| [[FSFile:Dummy1|Dummy1]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x040100C4&lt;br /&gt;
| [[FSFile:Control|Control]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08010100&lt;br /&gt;
| [[FSFile:OpenSubFile|OpenSubFile]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x080200C2&lt;br /&gt;
| [[FSFile:Read|Read]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08030102&lt;br /&gt;
| [[FSFile:Write|Write]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08040000&lt;br /&gt;
| [[FSFile:GetSize|GetSize]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08050080&lt;br /&gt;
| [[FSFile:SetSize|SetSize]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08060000&lt;br /&gt;
| [[FSFile:GetAttributes|GetAttributes]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08070040&lt;br /&gt;
| [[FSFile:SetAttributes|SetAttributes]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08080000&lt;br /&gt;
| [[FSFile:Close|Close]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08090000&lt;br /&gt;
| [[FSFile:Flush|Flush]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x080A0040&lt;br /&gt;
| [[FSFile:SetPriority|SetPriority]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x080B0000&lt;br /&gt;
| [[FSFile:GetPriority|GetPriority]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x080C0000&lt;br /&gt;
| [[FSFile:OpenLinkFile|OpenLinkFile]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x0C010100&lt;br /&gt;
| ? (takes two u64(?), outputs u64)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=Directory service=&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;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x000100C6&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| [[FSDir:Dummy1|Dummy1]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x040100C4&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| [[FSDir:Control|Control]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08010042&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| [[FSDir:Read|Read]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08020000&lt;br /&gt;
| [[1.0.0-0]]&lt;br /&gt;
| [[FSDir:Close|Close]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08030040&lt;br /&gt;
| ?&lt;br /&gt;
| [[FSDir:SetPriority|SetPriority]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x08040000&lt;br /&gt;
| ?&lt;br /&gt;
| [[FSDir:GetPriority|GetPriority]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= Filesystem service &amp;quot;fs:LDR&amp;quot; =&lt;br /&gt;
This service is identical to fs:USER, except [[FS:OpenArchive]] archive 0x2345678E can only be accessed with fs:LDR.&lt;br /&gt;
&lt;br /&gt;
= ProgramRegistry service &amp;quot;fs:REG&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;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x000100C6&lt;br /&gt;
| [[FSReg:Dummy1|Dummy1]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x040103C0&lt;br /&gt;
| [[FSReg:Register|Register]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x04020040&lt;br /&gt;
| [[FSReg:Unregister|Unregister]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x040300C0&lt;br /&gt;
| [[FSReg:GetProgramInfo|GetProgramInfo]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x04040100&lt;br /&gt;
| [[FSReg:LoadProgram|LoadProgram]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x04050080&lt;br /&gt;
| [[FSReg:UnloadProgram|UnloadProgram]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x04060080&lt;br /&gt;
| [[FSReg:CheckHostLoadId|CheckHostLoadId]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Only one session can be opened for this service at a time, hence no other processes can use this due to [[Process_Manager_Services|pm-module]] using this.&lt;br /&gt;
&lt;br /&gt;
=SEEDDB=&lt;br /&gt;
With [[9.6.0-24|9.6.0-X]] new [[System_SaveData]] with saveID 0001000F was added, this seems to be handled by FS-module itself, probably via the new service-cmds added to fsuser. [[Home Menu]] and [[NIM_Services|NIM]] module have access to those commands.&lt;br /&gt;
&lt;br /&gt;
The SEEDDB savedata contains the title-unique seed-data used for the new [[NCCH]] keyY generation added with FIRM [[9.6.0-24|9.6.0-X]].&lt;br /&gt;
&lt;br /&gt;
= Common Types =&lt;br /&gt;
== MediaType ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| NAND&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| SD&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Game Card&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenFlags ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Bit&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| Read&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Write&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Create&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Attributes ==&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;
| 0x0&lt;br /&gt;
| 0x1&lt;br /&gt;
| Is Directory&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| 0x1&lt;br /&gt;
| Is Hidden&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| 0x1&lt;br /&gt;
| Is Archive&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| 0x1&lt;br /&gt;
| Is Read-Only&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== DirectoryEntry ==&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;
| 0x0&lt;br /&gt;
| 0x20C&lt;br /&gt;
| UTF-16 Entry Name&lt;br /&gt;
|-&lt;br /&gt;
| 0x20C&lt;br /&gt;
| 0xA&lt;br /&gt;
| 8.3 short filename name&lt;br /&gt;
|-&lt;br /&gt;
| 0x216&lt;br /&gt;
| 0x4&lt;br /&gt;
| 8.3 short filename extension&lt;br /&gt;
|-&lt;br /&gt;
| 0x21A&lt;br /&gt;
| 0x1&lt;br /&gt;
| Always 1&lt;br /&gt;
|-&lt;br /&gt;
| 0x21B&lt;br /&gt;
| 0x1&lt;br /&gt;
| Reserved&lt;br /&gt;
|-&lt;br /&gt;
| 0x21C&lt;br /&gt;
| 0x4&lt;br /&gt;
| [[Filesystem_services#Attributes|Attributes]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x220&lt;br /&gt;
| 0x8&lt;br /&gt;
| Entry Size&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ArchiveResource ==&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;
| 0x0&lt;br /&gt;
| 0x4&lt;br /&gt;
| Sector byte-size&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| 0x4&lt;br /&gt;
| Cluster byte-size&lt;br /&gt;
|-&lt;br /&gt;
| 0x8&lt;br /&gt;
| 0x4&lt;br /&gt;
| Partition capacity in clusters&lt;br /&gt;
|-&lt;br /&gt;
| 0xC&lt;br /&gt;
| 0x4&lt;br /&gt;
| Available free space in clusters&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ArchiveId ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Idcode&lt;br /&gt;
!  Description&lt;br /&gt;
!  Accessible via [[Filesystem_services|FS]]&lt;br /&gt;
!  Accessible via [[Filesystem_services_PXI|FSPXI]]&lt;br /&gt;
!  Requires binary [[FS:OpenFile|Lowpath]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x00000003&lt;br /&gt;
| Application RomFS&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x00000004&lt;br /&gt;
| SaveData (the saveID/mediatype for this is loaded from data originally from the user process&#039; exheader)&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x00000006&lt;br /&gt;
| ExtSaveData&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x00000007&lt;br /&gt;
| Shared ExtSaveData&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x00000008&lt;br /&gt;
| SystemSaveData&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x00000009&lt;br /&gt;
| SDMC&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x0000000A&lt;br /&gt;
| SDMC Write-Only&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x12345678&lt;br /&gt;
| ExtSaveData for BOSS&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x12345679&lt;br /&gt;
| CARD SPI FS&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x1234567B&lt;br /&gt;
| ExtSaveData, and ExtSaveData for BOSS&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x1234567C&lt;br /&gt;
| SystemSaveData&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x1234567D&lt;br /&gt;
| NAND RW&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x1234567E&lt;br /&gt;
| NAND RO&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x1234567F&lt;br /&gt;
| NAND RO Write FS&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x12345680&lt;br /&gt;
| Unknown. There&#039;s code for this in spider v9.9, but that code isn&#039;t actually used.&lt;br /&gt;
| Yes&lt;br /&gt;
| ?&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x12345682&lt;br /&gt;
| Unknown. There&#039;s code for this in spider v9.9, but that code isn&#039;t actually used.&lt;br /&gt;
| Yes&lt;br /&gt;
| ?&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x2345678A&lt;br /&gt;
| User/GameCard SaveData (for check), and other uses (FS can only mount the latter; includes ExeFS and RomFS) (lo hi mediatype reserved)&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x2345678B&lt;br /&gt;
| ?&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x2345678C&lt;br /&gt;
| ?&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x2345678D&lt;br /&gt;
| ?&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x2345678E&lt;br /&gt;
| FSPXI: Similar to archive 0x2345678A. For fs:LDR(used by the &amp;quot;loader&amp;quot; FIRM ARM11-process), only ExeFS. Not accessible with fs:USER.&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890AB&lt;br /&gt;
| NAND CTR FS&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890AC&lt;br /&gt;
| TWL PHOTO&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890AD&lt;br /&gt;
| ?&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890AE&lt;br /&gt;
| NAND TWL FS&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890AF&lt;br /&gt;
| NAND W FS&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890B0&lt;br /&gt;
| ?&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890B1&lt;br /&gt;
| Gamecard SaveData (for check). This is a wrapper for UserSaveDataForCheck: the OpenArchive code for that is called with archive-lowpath TID=0/mediatype=2(gamecard).&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890B2&lt;br /&gt;
| UserSaveData (for check). This is the same as the regular SaveData archive, except with this the savedata ID and mediatype is loaded from the input archive lowpath.&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 0x567890B4&lt;br /&gt;
| ? SaveData from Demo Version of Retail Game&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
| No&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Archives listed as not requiring a binary lowpath, use lowpath type [[FS:OpenFile|empty]].&lt;br /&gt;
&lt;br /&gt;
Archives CTR NAND, NAND RO Write FS, TWL NAND, NAND W FS, and CARD SPI FS require the corresponding process exheader access control mount flag to be set, in the exheader for any of the currently running ARM11 processes, for [[Filesystem_services_PXI|FSPXI]]. The access rights checked by [[Filesystem services|FS]] module for archive mounting with fs:USER, are stored in the process&#039; exheader accessinfo.&lt;br /&gt;
&lt;br /&gt;
The CARDSPI archive allows access to the gamecard CARD1 raw savedata flash(aka &amp;quot;cardspi:/&amp;quot; in [[FIRM|Process9]]), the file lowpath must be WCHAR &amp;quot;/&amp;quot;. The &amp;quot;NAND W FS&amp;quot; archive allows access to the raw NAND image(aka &amp;quot;wnand:/&amp;quot; in Process9), the file lowpath must be WCHAR &amp;quot;/&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
== PathType ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| INVALID - Specifies an invalid path.&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| EMPTY - Specifies an empty path.&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| BINARY - Non-text based path. Meaning is per-archive.&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| CHAR - Text-based path with 8-bit characters.&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| WCHAR - Text-based path with 16-bit characters.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Binary LowPath ===&lt;br /&gt;
The format of the data that a binary LowPath points to is custom per archive.&lt;br /&gt;
&lt;br /&gt;
==== SystemSaveData Archive Path Data Format ====&lt;br /&gt;
===== FS =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Index word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0 &lt;br /&gt;
| [[Mediatypes|Mediatype]] (must be zero for NAND)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| saveid&lt;br /&gt;
|}&lt;br /&gt;
The file/directory lowpath is a text lowpath in the [[Savegames|savegame]] filesystem.&lt;br /&gt;
&lt;br /&gt;
===== FSPXI =====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Index word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0 &lt;br /&gt;
| u8 [[Mediatypes|Mediatype]] (must be zero for NAND)&lt;br /&gt;
|}&lt;br /&gt;
The file lowpath is a binary lowpath containing the u64 saveid, however the high word of the saveid is always zero. The mounted file is the cleartext savegame image. Up to 32 SystemSaveData image files can be opened under a single mounted FSPXI archive.&lt;br /&gt;
&lt;br /&gt;
==== UserSaveDataForCheck Archive Path Data Format ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Index word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0 &lt;br /&gt;
| [[Mediatypes|Mediatype]] (must be non-zero)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Lower word saveid&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Upper word saveid&lt;br /&gt;
|}&lt;br /&gt;
The file/directory lowpath for this FS archive is a text path in the [[Savegames|savegame]] filesystem.&lt;br /&gt;
&lt;br /&gt;
==== ExtSaveData Archive Path Data Format ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Index word&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0 &lt;br /&gt;
| [[Mediatypes|Mediatype]]&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Lower word saveid&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Upper word saveid&lt;br /&gt;
|}&lt;br /&gt;
For FS, the file/directory lowpath is a text path in the [[extdata]] filesystem. For FSPXI, the file lowpath is a text path relative to the &amp;quot;/extdata/&amp;lt;ExtdataIDHigh&amp;gt;/&amp;lt;ExtdataIDLow&amp;gt;&amp;quot; directory on SD/NAND, for the cleartext extdata image to mount.&lt;br /&gt;
&lt;br /&gt;
==== [[RomFS]] ====&lt;br /&gt;
The raw FS image for the main CXI RomFS(for the current app this is accessible via archiveid 0x3) can be accessed via an all-zero 0xc-byte binary file-lowpath. This allows access to the raw level-3 IVFC image: the user process must handle parsing the filesystem used in this image itself.&lt;br /&gt;
&lt;br /&gt;
In this scenario, OpenFile returns a handle to the RomFS archive.&lt;br /&gt;
&lt;br /&gt;
== ProgramInfo ==&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;
| 0x0&lt;br /&gt;
| 0x8&lt;br /&gt;
| Program ID&lt;br /&gt;
|-&lt;br /&gt;
| 0x8&lt;br /&gt;
| 0x1&lt;br /&gt;
| [[Filesystem_services#MediaType|Media Type]]&lt;br /&gt;
|-&lt;br /&gt;
| 0xC&lt;br /&gt;
| 0x4&lt;br /&gt;
| Reserved&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ProductInfo ==&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;
| 0x0&lt;br /&gt;
| 0x10&lt;br /&gt;
| Product Code&lt;br /&gt;
|-&lt;br /&gt;
| 0x10&lt;br /&gt;
| 0x2&lt;br /&gt;
| Company Code&lt;br /&gt;
|-&lt;br /&gt;
| 0x12&lt;br /&gt;
| 0x2&lt;br /&gt;
| Remaster Version&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IntegrityVerificationSeed ==&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;
|  0x0&lt;br /&gt;
|  0x10&lt;br /&gt;
|  AES-CBC MAC over a SHA256 hash, which hashes the first 0x110-bytes of the cleartext SEED.&lt;br /&gt;
|-&lt;br /&gt;
|  0x10&lt;br /&gt;
|  0x120&lt;br /&gt;
|  The [[nand/private/movable.sed]], encrypted with AES-CTR using the above MAC for the counter.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ExtSaveDataInfo ==&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;
| 0x0&lt;br /&gt;
| 0x1&lt;br /&gt;
| [[Filesystem_services#MediaType|Media Type]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| 0x1&lt;br /&gt;
| Unknown&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| 0x2&lt;br /&gt;
| Reserved&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| 0x8&lt;br /&gt;
| Save ID&lt;br /&gt;
|-&lt;br /&gt;
| 0xC&lt;br /&gt;
| 0x4&lt;br /&gt;
| Reserved&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== SystemSaveDataInfo ==&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;
| 0x0&lt;br /&gt;
| 0x1&lt;br /&gt;
| [[Filesystem_services#MediaType|Media Type]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| 0x1&lt;br /&gt;
| Unknown&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| 0x2&lt;br /&gt;
| Reserved&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| 0x4&lt;br /&gt;
| Save ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== SecureValueSlot ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x1000&lt;br /&gt;
| SD Application&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== CardSpiBaudRate ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| 512KHz&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| 1MHz&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| 2MHz&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| 4MHz&lt;br /&gt;
|-&lt;br /&gt;
| 0x4&lt;br /&gt;
| 8MHz&lt;br /&gt;
|-&lt;br /&gt;
| 0x5&lt;br /&gt;
| 16MHz&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== CardSpiBusMode ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0&lt;br /&gt;
| 1-bit&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| 4-bit&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== SpecialContentType ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Value&lt;br /&gt;
!  Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x1&lt;br /&gt;
| Update&lt;br /&gt;
|-&lt;br /&gt;
| 0x2&lt;br /&gt;
| Manual&lt;br /&gt;
|-&lt;br /&gt;
| 0x3&lt;br /&gt;
| DLP Child&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== DeviceMoveContext ==&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;
|  0x0&lt;br /&gt;
|  0x10&lt;br /&gt;
|  IVs&lt;br /&gt;
|-&lt;br /&gt;
|  0x10&lt;br /&gt;
|  0x10&lt;br /&gt;
|  Encrypt Parameter&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=Errors=&lt;br /&gt;
See [[Filesystem_services_PXI]].&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=3DS_System_Flaws&amp;diff=13383</id>
		<title>3DS System Flaws</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=3DS_System_Flaws&amp;diff=13383"/>
		<updated>2015-09-27T08:30:42Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Kernel11 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Exploits are used to execute unofficial code (homebrew) on the Nintendo 3DS. This page is a list of publicly known system flaws, for userland applications/applets flaws see [[3DS_Userland_Flaws|here]].&lt;br /&gt;
&lt;br /&gt;
=Stale / Rejected Efforts=&lt;br /&gt;
* Neimod has been working on a RAM dumping setup for a little while now. He&#039;s de-soldered the 3DS&#039;s RAM chip and hooked it and the RAM pinouts on the 3DS&#039; PCB up to a custom RAM dumping setup. A while ago he published photos showing his setup to be working quite well, with the 3DS successfully booting up. However, his flickr stream is now private along with most of his work.&lt;br /&gt;
&lt;br /&gt;
* Someone (who will remain unnamed) has released CFW and CIA installers, all of which is copied from the work of others, or copyrighted material.&lt;br /&gt;
&lt;br /&gt;
==Tips and info==&lt;br /&gt;
The 3DS uses the XN feature of the ARM11 processor. There&#039;s no official way from applications to enable executable permission for memory containing arbitrary unsigned code(there&#039;s a [[SVC]] for this, but only [[RO_Services|RO-module]] has access to it). An usable userland exploit would still be useful: you could only do return-oriented-programming with it initially. From ROP one could then exploit system flaw(s), see below.&lt;br /&gt;
&lt;br /&gt;
SD card [[extdata]] and SD savegames can be attacked, for consoles where the console-unique [[Nand/private/movable.sed|movable.sed]] was dumped(accessing SD data is far easier by running code on the target 3DS however).&lt;br /&gt;
&lt;br /&gt;
=System flaws=&lt;br /&gt;
== Hardware ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Fixed with hardware model/revision&lt;br /&gt;
!  Newest hardware model/revision this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| ARM9/ARM11 bootrom vectors point at unitialized RAM&lt;br /&gt;
| ARM9&#039;s and ARM11&#039;s exception vectors are hardcoded to point at the CPU&#039;s internal memory (0x08000000 region for ARM9, AXIWRAM for ARM11). While the bootrom does set them up to point to an endless loop at some point during boot, it does not do so immediately. As such, a carefully-timed fault injection (via hardware) to trigger an exception (such as an invalid instruction) will cause execution to fall into ARM9 RAM. &lt;br /&gt;
Since RAM isn&#039;t cleared on boot (see below), one can immediately start execution of their own code here to dump bootrom, OTP, etc.&lt;br /&gt;
The ARM9 bootrom does the following at reset:  reset vector branches to another instruction, then branches to bootrom+0x8000. Hence, there&#039;s no way to know for certain when exactly the ARM9 exception-vector data stored in memory gets initialized.&lt;br /&gt;
&lt;br /&gt;
This requires *very* *precise* timing for triggering the hardware fault: it&#039;s unknown if anyone actually exploited this successfully at the time of writing(the one who attempted+discovered it *originally* as listed in this wiki section hasn&#039;t).&lt;br /&gt;
| None: all available 3DS models at the time of writing have the exact same ARM9/ARM11 bootrom for the unprotected areas.&lt;br /&gt;
| New3DS&lt;br /&gt;
| End of February 2014&lt;br /&gt;
| [[User:Derrek|derrek]], WulfyStylez (May 2015) independently&lt;br /&gt;
|-&lt;br /&gt;
| Missing AES key clearing&lt;br /&gt;
| The hardware AES engine does not clear keys when doing a hard reset/reboot.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| August 2014&lt;br /&gt;
| Mathieulh/Others&lt;br /&gt;
|-&lt;br /&gt;
| No RAM clearing on reboots&lt;br /&gt;
| On an MCU-triggered reboot all RAM including FCRAM/ARM9 memory/AXIWRAM keeps its contents.&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| March 2014&lt;br /&gt;
| [[User:Derrek|derrek]]&lt;br /&gt;
|-&lt;br /&gt;
| 32bits of actual console-unique TWLNAND keydata&lt;br /&gt;
| On retail the 8-bytes at ARM9 address [[Memory_layout|0x01FFB808]] are XORed with hard-coded data, to generate the TWL console-unique keys, including TWLNAND. On Old3DS the high u32 is always 0x0, while on New3DS that u32 is always 0x2. On top of this, the lower u32&#039;s highest bit is always ORed. only 31 bits of the TWL console-unique keydata / TWL consoleID are actually console-unique.&lt;br /&gt;
This allows one to easily bruteforce the TWL console-unique keydata with *just* data from TWLNAND. On DSi the actual console-unique data for key generation is 8-bytes(all bytes actually set).&lt;br /&gt;
| None&lt;br /&gt;
| New3DS&lt;br /&gt;
| 2012?&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| DSi / 3DS-TWL key-generator&lt;br /&gt;
| After using the key generator to generate the normal-key, you could overwrite parts of the normal-key with your own data and then recover the key-generator output by comparing the new crypto output with the original crypto output. From the normal-key outputs, you could deduce the TWL key-generator function.&lt;br /&gt;
This applies to the keyX/keyY too.&lt;br /&gt;
&lt;br /&gt;
This attack does not work for the 3DS key-generator because keyslots 0-3 are only for TWL keys.&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| 2011&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ARM9 software ==&lt;br /&gt;
=== arm9loader ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| Missing verification-block for the 9.6 keys&lt;br /&gt;
| Starting with [[9.6.0-24|9.6.0-X]] a new set of NAND-based keys were introduced. However, no verification block was added to verify that the new key read from NAND is correct. This was technically an issue from [[9.5.0-22|9.5.0-X]] with the original sector+0 keydata, however the below is only possible with [[9.6.0-24|9.6.0-X]] since keyslots 0x15 and 0x16 are generated from different 0x11 keyXs.&lt;br /&gt;
&lt;br /&gt;
Writing an incorrect key to NAND will cause arm9loader to decrypt the ARM9 kernel as garbage and then jump to it.&lt;br /&gt;
&lt;br /&gt;
This allows an hardware-based attack where you can boot into an older exploited firmware, fill all memory with NOP sleds/jump-instructions, and then reboot into executing garbage. By automating this process with various input keydata, eventually you&#039;ll find some garbage that jumps to your code.&lt;br /&gt;
&lt;br /&gt;
This should give very early ARM9 code execution (pre-ARM9 kernel). As such, it is possible to dump RSA keyslots with this and calculate the 6.x [[Savegames#6.0.0-11_Savegame_keyY|save]], and 7.x [[NCCH]] keys. This cannot be used to recover keys initialized by arm9loader itself. This is due to it wiping the area used for its stack during NAND sector decryption and keyslot init. &lt;br /&gt;
&lt;br /&gt;
Due to FIRMs on both Old and New 3DS using the same RSA data, this can be exploited on Old3DS as well, but only if one already has the actual plaintext normalkey from New3DS NAND sector 0x96 offset-0 and has dumped the OTP area of the Old3DS.&lt;br /&gt;
| Recovery of 6.x [[Savegames#6.0.0-11_Savegame_keyY|save key]]/7.x [[NCCH]] key&lt;br /&gt;
| None&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| March, 2015&lt;br /&gt;
| plutoo&lt;br /&gt;
|-&lt;br /&gt;
| Uncleared New3DS keyslot 0x11&lt;br /&gt;
| Originally the New3DS [[FIRM]] arm9bin loader only cleared keyslot 0x11 when it gets executed at firmlaunch. This was fixed with [[9.5.0-22|9.5.0-X]] by completely clearing keyslot 0x11 immediately after the loader finishes using keyslot 0x11.&lt;br /&gt;
This means that any ARM9 code that can execute before the loader clears the keyslot at firmlaunch(including firmlaunch-hax) can get access to the uncleared keyslot 0x11, which then allows one to generate all &amp;lt;=v9.5 New3DS keyXs which are generated by keyslot 0x11.&lt;br /&gt;
&lt;br /&gt;
Therefore, to completely fix this the loader would have to generate more keys using different keyslot 0x11 keydata. This was done with [[9.6.0-24|9.6.0-X]].&lt;br /&gt;
| New3DS keyXs generation&lt;br /&gt;
| Mostly fixed with [[9.5.0-22|9.5.0-X]], completely fixed with new keys with [[9.6.0-24|9.6.0-X]].&lt;br /&gt;
| &lt;br /&gt;
| February 3, 2015 (one day after [[9.5.0-22|9.5.0-X]] release)&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Process9 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| FAT FS code null-deref&lt;br /&gt;
| When FSFile:Read is used with a file which is corrupted on a FAT filesystem(in particular SD), Process9 can crash. This particular crash is caused by a function returning NULL instead of an actual ptr due to an error. The caller of that function doesn&#039;t check for NULL which then triggers a read based at NULL.&lt;br /&gt;
&lt;br /&gt;
Sample &amp;quot;fsck.vfat -n -v -V &amp;lt;fat image backup&amp;gt;&amp;quot; output for the above crash:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;...&lt;br /&gt;
Starting check/repair pass.&lt;br /&gt;
&amp;lt;FilePath0&amp;gt; and&lt;br /&gt;
&amp;lt;FilePath1&amp;gt;&lt;br /&gt;
 share clusters.&lt;br /&gt;
 Truncating second to 3375104 bytes.&lt;br /&gt;
&amp;lt;FilePath1&amp;gt;&lt;br /&gt;
 File size is 2787392 bytes, cluster chain length is 16384 bytes.&lt;br /&gt;
 Truncating file to 16384 bytes.&lt;br /&gt;
Checking for unused clusters.&lt;br /&gt;
Reclaimed 1 unused cluster (16384 bytes).&lt;br /&gt;
Checking free cluster summary.&lt;br /&gt;
Free cluster summary wrong (1404490 vs. really 1404491)&lt;br /&gt;
 Auto-correcting.&lt;br /&gt;
Starting verification pass.&lt;br /&gt;
Checking for unused clusters.&lt;br /&gt;
Leaving filesystem unchanged.&amp;lt;/pre&amp;gt;&lt;br /&gt;
| Useless null-based-read&lt;br /&gt;
| None&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| July 8-9, 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| RSA signature padding checks&lt;br /&gt;
| The TWL_FIRM RSA sig padding check code used for all TWL RSA sig-checks has issues, see [[FIRM|here]].&lt;br /&gt;
The main 3DS RSA padding check code(non-certificate, including NATIVE_FIRM) uses the function used with the above to extract more padding + the actual hash from the additional padding. This isn&#039;t really a problem here because there&#039;s proper padding check code which is executed prior to this.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.5.0-22|9.5.0-X]]&lt;br /&gt;
| March 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| firmlaunch-hax: FIRM header ToCToU&lt;br /&gt;
| This can&#039;t be exploited from ARM11 userland.&lt;br /&gt;
During [[FIRM]] launch, the only FIRM header the ARM9 uses at all is stored in FCRAM, this is 0x200-bytes(the actual used FIRM RSA signature is read to the Process9 stack however). The ARM9 doesn&#039;t expect &amp;quot;anything&amp;quot; besides the ARM9 to access this data.&lt;br /&gt;
With [[9.5.0-22]] the address of this FIRM header was changed from a FCRAM address, to ARM9-only address 0x01fffc00.&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[9.5.0-22]]&lt;br /&gt;
| &lt;br /&gt;
| 2012, 3 days after [[User:Yellows8|Yellows8]] started Process9 code RE.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| Uninitialized data output for (PXI) command replies&lt;br /&gt;
| PXI commands for various services(including some [[Filesystem_services_PXI|here]] and many others) can write uninitialized data (like from ARM registers) to the command reply. This happens with stubbed commands, but this can also occur with certain commands when returning an error.&lt;br /&gt;
Certain ARM11 service commands have this same issue as well.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.3.0-21|9.3.0-X]]&lt;br /&gt;
| ?&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[Filesystem_services_PXI|FSPXI]] OpenArchive SD permissions&lt;br /&gt;
| Process9 does not use the exheader ARM9 access-mount permission flag for SD at all.&lt;br /&gt;
This would mean ARM11-kernelmode code / fs-module itself could directly use FSPXI to access SD card without ARM9 checking for SD access, but this is rather useless since a process is usually running with SD access(Home Menu for example) anyway.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.3.0-21|9.3.0-X]]&lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[AMPXI:ExportDSiWare]] export path&lt;br /&gt;
| Process9 allocates memory on Process9 heap for the export path then verifies that the actual allocated size matches the input size. Then Process9 copies the input path from FCRAM to this buffer, and uses it with the Process9 FS openfile code, which use paths in the form of &amp;quot;&amp;lt;mountpoint&amp;gt;:/&amp;lt;path&amp;gt;&amp;quot;.&lt;br /&gt;
Process9 does not check the contents of this path at all before passing it to the FS code, besides writing a NUL-terminator to the end of the buffer.&lt;br /&gt;
| Exporting of DSiWare to arbitrary Process9 file-paths, such as &amp;quot;nand:/&amp;lt;path&amp;gt;&amp;quot; etc. This isn&#039;t really useful since the data which gets written can&#039;t be controlled.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.5.0-22]]&lt;br /&gt;
| April 2013&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[DSiWare_Exports]] [[CTCert]] verification&lt;br /&gt;
| Just like DSi originally did, 3DS verifies the APCert for DSiWare on SD with the CTCert also in the DSiWare .bin. On DSi this was fixed with with system-version 1.4.2 by verifying with the actual console-unique cert instead(stored in NAND), while on 3DS it&#039;s still not(?) fixed.&lt;br /&gt;
On 3DS however this is rather useless, due to the entire DSiWare .bin being encrypted with the console-unique movable.sed keyY.&lt;br /&gt;
| When the movable.sed keyY for the target 3DS is known and the target 3DS CTCert private-key is unknown, importing of modified DSiWare SD .bin files.&lt;br /&gt;
| Unknown, probably none.&lt;br /&gt;
| ?&lt;br /&gt;
| April 2013&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[Gamecard_Services_PXI]] unchecked REG_CTRCARDCNT transfer-size&lt;br /&gt;
| The u8 REG_CTRCARDCNT transfer-size parameter for the [[Gamecard_Services_PXI]] read/write CTRCARD commands is used as an index for an array of u16 values. Before [[5.0.0-11|5.0.0-X]] this u8 value wasn&#039;t checked, thus out-of-bounds reads could be triggered(which is rather useless in this case).&lt;br /&gt;
| Out-of-bounds read for a value which gets written to a register.&lt;br /&gt;
| [[5.0.0-11|5.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| 2013?&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[PXI_Registers|PXI]] cmdbuf buffer overrun&lt;br /&gt;
| The Process9 code responsible [[PXI_Registers|PXI]] communications didn&#039;t verify the size of the incoming command before writing it to a C++ member variable. &lt;br /&gt;
| Probably ARM9 code execution&lt;br /&gt;
| [[5.0.0-11|5.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| March 2015, original timeframe if any unknown&lt;br /&gt;
| plutoo/[[User:Yellows8|Yellows8]]/maybe others(?)&lt;br /&gt;
|-&lt;br /&gt;
| [[Application_Manager_Services_PXI|PXIAM]] command 0x003D0108(See also [[Application_Manager_Services|this]])&lt;br /&gt;
| When handling this command, Process9 allocates a 0x2800-byte heap buffer, then copies the 4 FCRAM input buffers to this heap buffer without checking the sizes at all(only the buffers with non-zero sizes are copied). Starting with [[5.0.0-11|5.0.0-X]], the total combined size of the input data must be &amp;lt;=0x2800.&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[5.0.0-11|5.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| May 2013&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[Process_Services_PXI|PS RSA]] commands buffer overflows&lt;br /&gt;
| pxips9 cmd1(not accessible via ps:ps) and VerifyRsaSha256: unchecked copy to a buffer in Process9&#039;s .bss, from the input FCRAM buffer. The buffer is located before the pxi cmdhandler threads&#039; stacks. SignRsaSha256 also has a buf overflow, but this isn&#039;t exploitable.&lt;br /&gt;
The buffer for this is the buffer for the signature data. With v5.0, the signature buffer was moved to stack, with a check for the signature data size. When the signature data size is too large, Process9 uses [[SVC|svcBreak]].&lt;br /&gt;
| ARM9 code execution&lt;br /&gt;
| [[5.0.0-11|5.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[PXI_Registers|PXI]] pxi_id bad check&lt;br /&gt;
| The Process9 code responsible for [[PXI_Registers|PXI]] communications read pxi_id as a signed char. There were two flaws:&lt;br /&gt;
* They used it as index to a lookup-table without checking the value at all.&lt;br /&gt;
* Another function verified that pxi_id &amp;lt; 7, allowing negative values to pass the check. This would also cause an out-of-range table-lookup.&lt;br /&gt;
| Maybe ARM9 code execution&lt;br /&gt;
| [[3.0.0-5|3.0.0-5]]&lt;br /&gt;
|&lt;br /&gt;
| March 2015, originally 2012 for the first issue at least&lt;br /&gt;
| plutoo, [[User:Yellows8|Yellows8]], maybe others(?)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Kernel9 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[CONFIG Registers#CFG_SYSPROT9|CFG_SYSPROT9]] bit1 not set by Kernel9&lt;br /&gt;
| Old versions of Kernel9 never set bit1 of [[CONFIG Registers#CFG_SYSPROT9|CFG_SYSPROT9]]. This leaves the [[OTP Registers|0x10012000]]-region unprotected (this region should be locked early during boot!). Since it&#039;s never locked, you can dump it once you get ARM9 code execution. See [[OTP Registers|here]] regarding the data stored there.&lt;br /&gt;
&lt;br /&gt;
From [[3.0.0-5|3.0.0-X]] this was fixed by setting the bit in Kernel9 after poking some registers in that region. On New3DS arm9loader sets this bit instead of Kernel9.&lt;br /&gt;
| Dumping of the [[OTP Registers|OTP]] area&lt;br /&gt;
| [[3.0.0-5|3.0.0-X]]&lt;br /&gt;
|&lt;br /&gt;
| February 2015&lt;br /&gt;
| plutoo, Normmatt independently&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ARM11 software ==&lt;br /&gt;
=== Kernel11 ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
|  [[SVC]] table too small&lt;br /&gt;
|  The table of function pointers for SVC&#039;s only contains entries up to 0x7D, but the biggest allowed SVC for the table is 0x7F. Thus, executing SVC7E or SVC7F would make the SVC-handler read after the buffer, and interpret some ARM instructions as function pointers.&lt;br /&gt;
&lt;br /&gt;
However, this would require patching the kernel .text or modifying SVC-access-control. Even if you could get these to execute, they would still jump to memory that isn&#039;t mapped as executable.&lt;br /&gt;
| &lt;br /&gt;
|  None&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| 2012&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
|  [[SVC|svcBackdoor (0x7B)]]&lt;br /&gt;
|  This backdoor allows executing SVC-mode code at the user-specified code-address. This is used by Process9, using this on the ARM11(with NATIVE_FIRM) requires patching the kernel .text or modifying SVC-access-control.&lt;br /&gt;
| See description&lt;br /&gt;
|  None&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
|&lt;br /&gt;
| Everyone&lt;br /&gt;
|-&lt;br /&gt;
| [[Memory_layout#ARM11_Detailed_virtual_memory_map|0xEFF00000]] / 0xDFF00000 ARM11 kernel virtual-memory&lt;br /&gt;
| The ARM11 kernel-mode 0xEFF00000/0xDFF00000 virtual-memory(size 0x100000) is mapped to phys-mem 0x1FF00000(entire DSP-mem + entire AXIWRAM), with permissions RW-. This is used during ARM11 kernel startup, this never seems to be used after that, however.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
|  AffinityMask/processorid validation&lt;br /&gt;
|  With [[10.0.0-27|10.0.0-X]] the following functions were updated: svcGetThreadAffinityMask, svcGetProcessAffinityMask, svcSetProcessAffinityMask, and svcCreateThread. The code changes for all but svcCreateThread are identical.&lt;br /&gt;
The original code with the first 3 did the following: &lt;br /&gt;
* if(u32_processorcount &amp;gt; ~0x80000001)return 0xe0e01bfd;&lt;br /&gt;
* if(s32_processorcount &amp;gt; &amp;lt;total_cores&amp;gt;)return 0xd8e007fd;&lt;br /&gt;
The following code replaced the above:&lt;br /&gt;
* if(u32_processorcount &amp;gt;= &amp;lt;total_cores+1&amp;gt;)return 0xd8e007fd;&lt;br /&gt;
In theory the latter should catch everything that the former did, so it&#039;s unknown if this was really a security issue.&lt;br /&gt;
&lt;br /&gt;
The svcCreateThread changes with [[10.0.0-27|10.0.0-X]] definitely did fix a security issue.&lt;br /&gt;
* Original code: &amp;quot;if(s32_processorid &amp;gt; &amp;lt;total_cores&amp;gt;)return 0xd8e007fd;&amp;quot;&lt;br /&gt;
* New code: &amp;quot;if(s32_processorid &amp;gt;= &amp;lt;total_cores&amp;gt; || s32_processorid &amp;lt;= -4)return 0xd8e007fd;&amp;quot;&lt;br /&gt;
This fixed an off-by-one issue: if one would use processorid=total_cores, which isn&#039;t actually a valid value, svcCreateThread would accept that value on &amp;lt;[[10.0.0-27|10.0.0-X]]. This results in data being written out-of-bounds(baseaddr = arrayaddr + entrysize*processorid), which has the following result:&lt;br /&gt;
* Old3DS: Useless kernel-mode crash due to accessing unmapped memory.&lt;br /&gt;
* New3DS: uncontrolled data write into a kernel-mode L1 MMU-table. This isn&#039;t really useful: the data can&#039;t be controlled, and the data which gets overwritten is all-zero anyway(this isn&#039;t anywhere near MMU L1 entries for actually mapped memory).&lt;br /&gt;
| Nothing useful&lt;br /&gt;
|  [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| [[10.0.0-27|10.0.0-X]]&lt;br /&gt;
| svcCreateThread issue: May 31, 2015. The rest: September 8, 2015, via v9.6-&amp;gt;v10.0 ARM11-kernel code-diff.&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| memchunkhax&lt;br /&gt;
| The kernel originally did not validate the data stored in the FCRAM kernel heap [[Memchunkhdr|memchunk-headers]] for free-memory at all. Exploiting this requires raw R/W access to these memchunk-headers, like physical-memory access with gspwn.&lt;br /&gt;
&lt;br /&gt;
There are &#039;&#039;multiple&#039;&#039; ways to exploit this, but the end-result for most of these is the same: overwrite code in AXIWRAM via the 0xEFF00000/0xDFF00000 kernel virtual-memory mapping.&lt;br /&gt;
&lt;br /&gt;
This was fixed in [[9.3.0-21|9.3.0-X]] by checking that the memchunk(including size, next, and prev ptrs) is located within the currently used heap memory. The kernel may also check that the next/prev ptrs are valid compared to other memchunk-headers basically. When any of these checks fail, kernelpanic() is called.&lt;br /&gt;
| When combined with other flaws: ARM11-kernelmode code execution&lt;br /&gt;
| [[9.3.0-21|9.3.0-21]]&lt;br /&gt;
| &lt;br /&gt;
| February 2014&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| Multiple [[KLinkedListNode|KLinkedListNode]] SlabHeap use after free bugs&lt;br /&gt;
| The ARM11-kernel did access the &#039;key&#039; field of [[KLinkedListNode|KLinkedListNode]] objects, which are located on the SlabHeap, after freeing them. Thus, triggering an allocation of a new [[KLinkedListNode|KLinkedListNode]] object at the right time could result in a type-confusion. Pseudo-code:&lt;br /&gt;
SlabHeap_free(KLinkedListNode);&lt;br /&gt;
KObject *obj = KLinkedListNode-&amp;gt;key;  // the object there might have changed!&lt;br /&gt;
This bug appeared all over the place.&lt;br /&gt;
| ARM11-kernelmode code exec maybe&lt;br /&gt;
| [[8.0.0-18|8.0.0-18]]&lt;br /&gt;
| &lt;br /&gt;
| April 2015&lt;br /&gt;
| [[User:Derrek|derrek]]&lt;br /&gt;
|-&lt;br /&gt;
| PXI [[RPC_Command_Structure|Command]] input/output buffer permissions&lt;br /&gt;
| Originally the ARM11-kernel didn&#039;t check permissions for PXI input/output buffers for commands. Starting with [[6.0.0-11|6.0.0]] PXI input/output buffers must have RW permissions, otherwise kernelpanic is triggered.&lt;br /&gt;
| &lt;br /&gt;
| [[6.0.0-11|6.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcStartInterProcessDma]]&lt;br /&gt;
| For svcStartInterProcessDma, the kernel code had the following flaws:&lt;br /&gt;
&lt;br /&gt;
* Originally the ARM11-kernel read the input DmaConfig structure directly in kernel-mode(ldr(b/h) instructions), without checking whether the DmaConfig address is readable under userland. This was fixed by copying that structure to the SVC-mode stack, using the ldrbt instruction.&lt;br /&gt;
&lt;br /&gt;
* Integer overflows for srcaddr+size and dstaddr+size are now checked(with [[6.0.0-11]]), which were not checked before.&lt;br /&gt;
&lt;br /&gt;
* The kernel now also checks whether the srcaddr/dstaddr (+size) is within userland memory (0x20000000), the kernel now (with [[6.0.0-11]]) returns an error when the address is beyond userland memory. Using an address &amp;gt;=0x20000000 would result in the kernel reading from the process L1 MMU table, beyond the memory allocated for that MMU table(for vaddr-&amp;gt;physaddr conversion). &lt;br /&gt;
| &lt;br /&gt;
| [[6.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| DmaConfig issue: unknown. The rest: 2014&lt;br /&gt;
| plutoo, [[User:Yellows8|Yellows8]] independently&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcControlMemory]] Parameter checks&lt;br /&gt;
| For svcControlMemory the parameter check had these two flaws:&lt;br /&gt;
&lt;br /&gt;
* The allowed range for addr0, addr1, size parameters depends on which MemoryOperation is being specified. The limitation for GSP heap was only checked if op=(u32)0x10003. By setting a random bit in op that has no meaning (like bit17?), op would instead be (u32)0x30003, and the range-check would be less strict and not accurate. However, the kernel doesn&#039;t actually use the input address for LINEAR memory-mapping at all besides the range-checks, so this isn&#039;t actually useful. This was fixed in the kernel by just checking for the LINEAR bit, instead of comparing the entire MemoryOperation value with 0x10003.&lt;br /&gt;
&lt;br /&gt;
* Integer overflows on (addr0+size) are now checked that previously weren&#039;t (this also applies to most other address checks elsewhere in the kernel).&lt;br /&gt;
&lt;br /&gt;
| &lt;br /&gt;
| [[5.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| plutoo&lt;br /&gt;
|-&lt;br /&gt;
| [[RPC_Command_Structure|Command]] request/response buffer overflow&lt;br /&gt;
| Originally the kernel did not check the word-values from the command-header. Starting with [[5.0.0-11]], the kernel will trigger a kernelpanic() when the total word-size of the entire command(including the cmd-header) is larger than 0x40-words (0x100-bytes). This allows overwriting threadlocalstorage+0x180 in the destination thread. However, since the data written there would be translate parameters (such as header-words + buffer addresses), exploiting this would likely be very difficult, if possible at all.&lt;br /&gt;
&lt;br /&gt;
If the two words at threadlocalstorage+0x180 could be overwritten with controlled data this way, one could then use a command with a buffer-header of &amp;lt;nowiki&amp;gt;((size&amp;lt;&amp;lt;14) | 2)&amp;lt;/nowiki&amp;gt; to write arbitrary memory to any RW userland memory in the destination process.&lt;br /&gt;
| &lt;br /&gt;
| [[5.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| v4.1 FIRM -&amp;gt; v5.0 code diff&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|SVC stack allocation overflows]]&lt;br /&gt;
| &lt;br /&gt;
* Syscalls that allocate a variable-length array on stack, only checked bit31 before multiplying by 4/16 (when calculating how much memory to allocate). If a large integer was passed as input to one of these syscalls, an integer overflow would occur, and too little memory would have been allocated on stack resulting in a buffer overrun. &lt;br /&gt;
* The alignment (size+7)&amp;amp;~7 calculation before allocation was not checked for integer overflow.&lt;br /&gt;
&lt;br /&gt;
This might allow for ARM11 kernel code-execution.&lt;br /&gt;
&lt;br /&gt;
(Applies to svcSetResourceLimitValues, svcGetThreadList, svcGetProcessList, svcReplyAndReceive, svcWaitSynchronizationN.)&lt;br /&gt;
| &lt;br /&gt;
| [[5.0.0-11]]&lt;br /&gt;
| &lt;br /&gt;
| v4.1 FIRM -&amp;gt; v5.0 code diff&lt;br /&gt;
| plutoo, [[User:Yellows8|Yellows8]] complementary&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcControlMemory]] MemoryOperation MAP memory-permissions&lt;br /&gt;
| svcControlMemory with MemoryOperation=MAP allows mapping the already-mapped process virtual-mem at addr1, to addr0. The lowest address permitted for addr1 is 0x00100000. Originally the ARM11 kernel didn&#039;t check memory permissions for addr1. Therefore .text as addr1 could be mapped elsewhere as RW- memory, which allowed ARM11 userland code-execution.&lt;br /&gt;
| &lt;br /&gt;
| [[4.1.0-8]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[RPC_Command_Structure|Command]] input/output buffer permissions&lt;br /&gt;
| Originally the ARM11 kernel didn&#039;t check memory permissions for the input/output buffers for commands. Starting with [[4.0.0-7]] the ARM11 kernel will trigger a kernelpanic() if the input/output buffers don&#039;t have the required memory permissions. For example, this allowed a FSUSER file-read to .text, which therefore allowed ARM11-userland code execution.&lt;br /&gt;
| &lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[SVC|svcReadProcessMemory/svcWriteProcessMemory memory]] permissions&lt;br /&gt;
| Originally the kernel only checked the first page(0x1000-bytes) of the src/dst buffers, for svcReadProcessMemory and svcWriteProcessMemory. There is no known retail processes which have access to these SVCs.&lt;br /&gt;
| &lt;br /&gt;
| [[4.0.0-7]]&lt;br /&gt;
| &lt;br /&gt;
| 2012?&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== [[FIRM]] Sysmodules ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in [[FIRM]] system version&lt;br /&gt;
!  Last [[FIRM]] system version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[Services|&amp;quot;srv:pm&amp;quot;]] process registration&lt;br /&gt;
| Originally any process had access to the port &amp;quot;srv:pm&amp;quot;. The PID&#039;s used for the (un)registration commands are not checked either. This allowed any process to re-register itself with &amp;quot;srv:pm&amp;quot;, and therefore allowed the process to give itself access to any service, bypassing the exheader service-access-control list.&lt;br /&gt;
&lt;br /&gt;
This was fixed in [[7.0.0-13]]: starting with [[7.0.0-13]] &amp;quot;srv:pm&amp;quot; is now a service instead of a globally accessible port. Only processes with PID&#039;s less than 6 (in other words: fs, ldr, sm, pm, pxi modules) have access to it. With [[7.0.0-13]] there can only be one session for &amp;quot;srv:pm&amp;quot; open at a time(this is used by pm module), svcBreak will be executed if more sessions are opened by the processes which can access this.&lt;br /&gt;
&lt;br /&gt;
This flaw was needed for exploiting the &amp;lt;=v4.x Process9 PXI vulnerabilities from ARM11 userland ROP, since most applications don&#039;t have access to those service(s).&lt;br /&gt;
| Access to arbitrary services&lt;br /&gt;
| [[7.0.0-13]]&lt;br /&gt;
| &lt;br /&gt;
| 2012&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| FSDIR null-deref&lt;br /&gt;
| [[Filesystem_services|FS]]-module may crash in some cases when handling directory reading. The trigger seems to be due to using [[FSDir:Close]] without closing the dir-handle afterwards?(Perhaps this is caused by out-of-memory?) This seems to be useless since it&#039;s just a null-deref.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| May 19(?)-20, 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Standalone Sysmodules ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in system-module system-version&lt;br /&gt;
!  Last system-module system-version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Timeframe this was added to wiki&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[SPI_Services|SPI]] service out-of-bounds write&lt;br /&gt;
| cmd1 has out-of-bounds write allowing overwrite of some static variables in .data.&lt;br /&gt;
| &lt;br /&gt;
| None&lt;br /&gt;
| [[9.5.0-22]]&lt;br /&gt;
| March 2015&lt;br /&gt;
| &lt;br /&gt;
| plutoo&lt;br /&gt;
|-&lt;br /&gt;
| [[NFC_Services|NFC]] module service command buf-overflows&lt;br /&gt;
| NFC module copies data with certain commands, from command input buffers to stack without checking the size. These commands include the following, it&#039;s unknown if there&#039;s more commands with similar issues: &amp;quot;nfc:dev&amp;quot; &amp;lt;0x000C....&amp;gt; and &amp;quot;nfc:s&amp;quot; &amp;lt;0x0037....&amp;gt;.&lt;br /&gt;
Since both of these commands are stubbed in the Old3DS NFC module from the very first version(those just return an error), these issues only affect the New3DS NFC module.&lt;br /&gt;
&lt;br /&gt;
There&#039;s no known retail titles which have access to either of these services.&lt;br /&gt;
| ROP under NFC module.&lt;br /&gt;
| New3DS: None&lt;br /&gt;
| New3DS: [[9.5.0-22]]&lt;br /&gt;
| December 2014?&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[News_Services|NEWSS]] service command notificationID validation failure&lt;br /&gt;
| This module does not validate the input notificationID for &amp;lt;nowiki&amp;gt;&amp;quot;news:s&amp;quot;&amp;lt;/nowiki&amp;gt; service commands. This is an out-of-bounds array index bug. For example, [[NEWSS:SetNotificationHeader]] could be used to exploit news module: this copies the input data(size is properly checked) to: out = newsdb_savedata+0x10 + (someu32array[notificationID]*0x70).&lt;br /&gt;
| ROP under news module.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.7.0-25|9.7.0-X]]&lt;br /&gt;
| December 2014&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[NWMUDS:DecryptBeaconData]] heap buffer overflow&lt;br /&gt;
| input_size = 0x1E * &amp;lt;value the u8 from input_[[NWM_Services|networkstruct]]+0x1D&amp;gt;. Then input_tag0 is copied to a heap buffer. When input_size is larger than 0xFA-bytes, it will then copy input_tag1 to &amp;lt;end_address_of_previous_outbuf&amp;gt;, with size=input_size-0xFA.&lt;br /&gt;
&lt;br /&gt;
This can be triggered by either using this command directly, or by boadcasting a wifi beacon which triggers it while a 3DS system running the target process is in range, when the process is scanning for hosts to connect to. Processes will only pass tag data to this command when the wlancommID and other thing(s) match the values for the process.&lt;br /&gt;
&lt;br /&gt;
There&#039;s no known way to actually exploit this for getting ROP under NWM-module, at the time of originally adding this to the wiki. This is because the data which gets copied out-of-bounds *and* actually causes crash(es), can&#039;t be controlled it seems(with just broadcasting a beacon at least). It&#039;s unknown whether this could be exploited from just using NWMUDS service-cmd(s) directly.&lt;br /&gt;
| Without any actual way to exploit this: NWM-module DoS, resulting in process termination(process crash). This breaks *everything* involving wifi comms, a reboot is required to recover from this.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.0.0-20]]&lt;br /&gt;
| ~September 23, 2014(see the [[NWMUDS:DecryptBeaconData]] page history)&lt;br /&gt;
| August 3, 2015&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[HID_Services|HID]] module shared-mem&lt;br /&gt;
| HID module does not validate the index values in [[HID_Shared_Memory|sharedmem]](just changes index to 0 when index == maxval when updating), therefore large values will result in HID module writing HID data to arbitrary addresses.&lt;br /&gt;
| ROP under HID module, but this is *very* unlikely to be exploitable since the data written is HID data.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.3.0-21]]&lt;br /&gt;
| 2014?&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| gspwn&lt;br /&gt;
| GSP module does not validate addresses given to the GPU. This allows a user-mode application/applet to read/write to a large part of physical FCRAM using GPU DMA. From this, you can overwrite the .text segment of the application you&#039;re running under, and gain real code-execution from a ROP-chain. Normally applets&#039; .text([[Home Menu]], [[Internet Browser]], etc) is located beyond the area accessible by the GPU, except for [[RO_Services|CROs]] used by applets([[Internet Browser]] for example).&lt;br /&gt;
&lt;br /&gt;
FCRAM is gpu-accessible up to physaddr 0x26800000 on Old3DS, and 0x2DC00000 on New3DS. This is BASE_memregion_start(aka SYSTEM_memregion_end)-0x400000 with the default memory-layout on Old3DS/New3DS.&lt;br /&gt;
| User-mode code execution.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.6.0-24|9.6.0-X]]&lt;br /&gt;
| Early 2014&lt;br /&gt;
| &lt;br /&gt;
| smea, [[User:Yellows8|Yellows8]]/others before then&lt;br /&gt;
|-&lt;br /&gt;
| rohax&lt;br /&gt;
| Using gspwn, it is possible to overwrite a loaded [[CRO0]]/[[CRR0]] after its RSA-signature has been validated. Badly validated [[CRO0]] header leads to arbitrary read/write of memory in the ro-process. This gives code-execution in the ro module, who has access to [[SVC|syscalls]] 0x70-0x72, 0x7D.&lt;br /&gt;
&lt;br /&gt;
This was fixed after [[ninjhax]] release by adding checks on [[CRO0]]-based pointers before writing to them.&lt;br /&gt;
| Memory-mapping syscalls.&lt;br /&gt;
| [[9.3.0-21]]&lt;br /&gt;
| [[9.4.0-21]]&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| smea, plutoo joint effort&lt;br /&gt;
|-&lt;br /&gt;
| Region free&lt;br /&gt;
| Only [[Home Menu]] itself checks gamecards&#039; region when launching them. Therefore, any application launch that is done directly with [[NS]] without signaling Home Menu to launch the app, will result in region checks being bypassed.&lt;br /&gt;
This essentially means launching the gamecard with the [[NS_and_APT_Services|&amp;quot;ns:s&amp;quot;]] service. The main way to exploit this is to trigger a FIRM launch with an application specified, either with a normal FIRM launch or a hardware [[NSS:RebootSystem|reboot]].&lt;br /&gt;
| Launching gamecards from any region + bypassing Home Menu gamecard-sysupdate installation&lt;br /&gt;
| None&lt;br /&gt;
| Last tested with [[10.1.0-27|10.1.0-X]].&lt;br /&gt;
| June(?) 2014&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|-&lt;br /&gt;
| [[NWM_Services|NWM]] service-cmd state null-ptr deref&lt;br /&gt;
| The NWMUDS service command code loads a ptr from .data, adds an offset to that, then passes that as the state address for the actual command-handler function. The value of the ptr loaded from .data is not checked, therefore this will cause crashes due to that being 0x0 when NWMUDS was not properly initialized.&lt;br /&gt;
It&#039;s unknown whether any NWM services besides NWMUDS have this issue.&lt;br /&gt;
| This is rather useless since it&#039;s only a crash caused by a state ptr based at 0x0.&lt;br /&gt;
| None&lt;br /&gt;
| [[9.0.0-20]]&lt;br /&gt;
| 2013?&lt;br /&gt;
| &lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== General/CTRSDK ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Summary&lt;br /&gt;
!  Description&lt;br /&gt;
!  Successful exploitation result&lt;br /&gt;
!  Fixed in version&lt;br /&gt;
!  Last version this flaw was checked for&lt;br /&gt;
!  Timeframe this was discovered&lt;br /&gt;
!  Discovered by&lt;br /&gt;
|-&lt;br /&gt;
| [[NWM_Services|UDS]] beacon additional-data buffer overflow&lt;br /&gt;
| Originally CTRSDK did not validate the UDS additional-data size before using that size to copy the additional-data to a [[NWM_Services|networkstruct]]. This was eventually fixed.&lt;br /&gt;
This was discovered while doing code RE with an old dlp-module version. It&#039;s unknown in what specific CTRSDK version this was fixed, or even what system-version updated titles with a fixed version.&lt;br /&gt;
&lt;br /&gt;
It&#039;s unknown if there&#039;s any titles using a vulnerable CTRSDK version which are also exploitable with this(dlp module can&#039;t be exploited with this).&lt;br /&gt;
&lt;br /&gt;
The maximum number of bytes that can be written beyond the end of the outbuf is 0x37-bytes, with additionaldata_size=0xFF.&lt;br /&gt;
| Perhaps ROP, very difficult if possible with anything at all&lt;br /&gt;
| ?&lt;br /&gt;
| &lt;br /&gt;
| September(?) 2014&lt;br /&gt;
| [[User:Yellows8|Yellows8]]&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=KHeapChunkHeader&amp;diff=13382</id>
		<title>KHeapChunkHeader</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=KHeapChunkHeader&amp;diff=13382"/>
		<updated>2015-09-27T08:30:02Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Undo revision 13380 by Neobrain (talk) Stop vandalising the wiki please&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:Kernel objects]]&lt;br /&gt;
{{stub}}&lt;br /&gt;
memchunkhdr = a data structure describing chunks of memory allocated by the ARM11 kernel.&lt;br /&gt;
&lt;br /&gt;
Here is some code describing the layout of a memory chunk header.&lt;br /&gt;
&lt;br /&gt;
    struct MemoryChunkHeader {&lt;br /&gt;
        int num_pages; // size of this chunk in terms of small pages&lt;br /&gt;
        void* next;&lt;br /&gt;
        void* prev;&lt;br /&gt;
        int unk1;&lt;br /&gt;
        int unk2;&lt;br /&gt;
    };&lt;br /&gt;
&lt;br /&gt;
The &amp;quot;next&amp;quot; and &amp;quot;prev&amp;quot; members are used to implement a linked-list. In fact, chances are this is actually a kernel object inherited from [[KLinkedList]].&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=News&amp;diff=13327</id>
		<title>News</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=News&amp;diff=13327"/>
		<updated>2015-09-23T10:31:49Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Undo revision 13326 by 100pcrack (talk) (Vandalism)&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
==Adding an item==&lt;br /&gt;
* Log in to the wiki. Editing is disabled if you don&#039;t have an account.&lt;br /&gt;
* Add the news event to the top of the list, using this format for the date: &amp;lt;tt&amp;gt;&amp;lt;nowiki&amp;gt;&#039;&#039;&#039;&amp;lt;/nowiki&amp;gt;{{#time: d F y}}&amp;lt;nowiki&amp;gt;&#039;&#039;&#039; &amp;lt;/nowiki&amp;gt;&amp;lt;/tt&amp;gt;. Please include the application&#039;s creator, version number, and a link to a page on 3DBrew about the application. No external links please.&lt;br /&gt;
* &#039;&#039;&#039;Move the last entry to the [[:News/Archive|news archive]]. There should be no more than 4 entrees in the list.&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
==Archives==&lt;br /&gt;
For older news, see the [[:News/Archive|news archive]].&lt;br /&gt;
&lt;br /&gt;
=== News ===&lt;br /&gt;
&amp;lt;!-- Add news below --&amp;gt;&amp;lt;/noinclude&amp;gt;&lt;br /&gt;
*&#039;&#039;&#039;14 September 15&#039;&#039;&#039; Nintendo released system update [[10.1.0-27]].&lt;br /&gt;
*&#039;&#039;&#039;8 September 15&#039;&#039;&#039; Nintendo released system update [[10.0.0-27]].&lt;br /&gt;
*&#039;&#039;&#039;18 July 15&#039;&#039;&#039; smea released [[ninjhax]] 2 beta [http://smealum.github.io/ninjhax2/], enabling ARM11 homebrew execution on Old/New 3DS up to firmware 9.9.0-26.&lt;br /&gt;
*&#039;&#039;&#039;13 July 15&#039;&#039;&#039; Nintendo released system update [[9.9.0-26]].&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=13296</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=13296"/>
		<updated>2015-09-15T17:06:17Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_LIGHTING_CONFIG0 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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;
|&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_0047|GPUREG_0047]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_0048|GPUREG_0048]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_0049|GPUREG_0049]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_004A|GPUREG_004A]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_004B|GPUREG_004B]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_FRAG_OP_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_FRAG_OP_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_0061|GPUREG_0061]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_0062|GPUREG_0062]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_0063|GPUREG_0063]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_0064|GPUREG_0064]]&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_006A|GPUREG_006A]]&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_006D|GPUREG_006D]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM2|GPUREG_FRAMEBUFFER_DIM2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_006F|GPUREG_006F]]&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_ENABLE|GPUREG_TEXUNIT_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_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_TEXUNIT0_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_TEXUNIT0_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_0084|GPUREG_0084]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_LOC|GPUREG_TEXUNIT0_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_0086|GPUREG_0086]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_0087|GPUREG_0087]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_0088|GPUREG_0088]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_0089|GPUREG_0089]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_008A|GPUREG_008A]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_008B|GPUREG_008B]]&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_TEXUNIT0_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_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_TEXUNIT1_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_TEXUNIT1_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_TEXUNIT1_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_0094|GPUREG_0094]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_LOC|GPUREG_TEXUNIT1_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_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_TEXUNIT2_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_TEXUNIT2_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_TEXUNIT2_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_009C|GPUREG_009C]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_LOC|GPUREG_TEXUNIT2_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_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_00A8|GPUREG_00A8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_00A9|GPUREG_00A9]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_00AA|GPUREG_00AA]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_00AB|GPUREG_00AB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_00AC|GPUREG_00AC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_00AD|GPUREG_00AD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_00AF|GPUREG_00AF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_00B0|GPUREG_00B0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_00B1|GPUREG_00B1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_00B2|GPUREG_00B2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_00B3|GPUREG_00B3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_00B4|GPUREG_00B4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_00B5|GPUREG_00B5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_00B6|GPUREG_00B6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_00B7|GPUREG_00B7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_00E1|GPUREG_00E1]]&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_00E4|GPUREG_00E4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_00E5|GPUREG_00E5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_00E6|GPUREG_00E6]]&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_00E8|GPUREG_00E8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_00E9|GPUREG_00E9]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_00EA|GPUREG_00EA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_00EB|GPUREG_00EB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_00EC|GPUREG_00EC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_00ED|GPUREG_00ED]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_00EE|GPUREG_00EE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_00EF|GPUREG_00EF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_OP_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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_0118|GPUREG_0118]]&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_0120|GPUREG_0120]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_0121|GPUREG_0121]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_0122|GPUREG_0122]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_0123|GPUREG_0123]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_0124|GPUREG_0124]]&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_0126|GPUREG_0126]]&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_0130|GPUREG_0130]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_022D|GPUREG_022D]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0231|GPUREG_0231]]&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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0242|GPUREG_0242]]&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_0244|GPUREG_0244]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_0245|GPUREG_0245]]&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_024A|GPUREG_024A]]&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_0251|GPUREG_0251]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_0252|GPUREG_0252]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_0253|GPUREG_0253]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_0254|GPUREG_0254]]&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_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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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_SH_OUTMAP_O&#039;&#039;i&#039;&#039; ===&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;
{| 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;
| Semantic for the x component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Semantic for the y component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Semantic for the z component of the register.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Semantic for the w component of the register.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
The semantic ids are:&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;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&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.&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
| lut_D0, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
| lut_FR, lut_RR, lut_SP, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
| lut_D0, lut_D1, lut_RR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
| lut_D0, lut_D1, lut_FR, lut_DA&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
| All except for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
| All except for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
| All except for lut_RB and lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
| All&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Input selector for lut_DA&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_RR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| abs() flag for the input of lut_DA (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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Scaler selector for lut_DA&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light .&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=13282</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=13282"/>
		<updated>2015-09-14T13:52:43Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_LIGHTx_CONFIG */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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;
|&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_0047|GPUREG_0047]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_0048|GPUREG_0048]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_0049|GPUREG_0049]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_004A|GPUREG_004A]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_004B|GPUREG_004B]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_FRAG_OP_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_FRAG_OP_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_O0|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_O1|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_O2|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_O3|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_O4|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_O5|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_O6|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_0061|GPUREG_0061]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_0062|GPUREG_0062]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_0063|GPUREG_0063]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_0064|GPUREG_0064]]&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_006A|GPUREG_006A]]&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_006D|GPUREG_006D]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM2|GPUREG_FRAMEBUFFER_DIM2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_006F|GPUREG_006F]]&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_ENABLE|GPUREG_TEXUNIT_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_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_TEXUNIT0_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_TEXUNIT0_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_0084|GPUREG_0084]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_LOC|GPUREG_TEXUNIT0_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_0086|GPUREG_0086]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_0087|GPUREG_0087]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_0088|GPUREG_0088]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_0089|GPUREG_0089]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_008A|GPUREG_008A]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_008B|GPUREG_008B]]&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_TEXUNIT0_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_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_TEXUNIT1_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_TEXUNIT1_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_TEXUNIT1_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_0094|GPUREG_0094]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_LOC|GPUREG_TEXUNIT1_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_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_TEXUNIT2_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_TEXUNIT2_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_TEXUNIT2_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_009C|GPUREG_009C]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_LOC|GPUREG_TEXUNIT2_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_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_00A8|GPUREG_00A8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_00A9|GPUREG_00A9]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_00AA|GPUREG_00AA]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_00AB|GPUREG_00AB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_00AC|GPUREG_00AC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_00AD|GPUREG_00AD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_00AF|GPUREG_00AF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_00B0|GPUREG_00B0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_00B1|GPUREG_00B1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_00B2|GPUREG_00B2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_00B3|GPUREG_00B3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_00B4|GPUREG_00B4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_00B5|GPUREG_00B5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_00B6|GPUREG_00B6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_00B7|GPUREG_00B7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_00E1|GPUREG_00E1]]&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_00E4|GPUREG_00E4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_00E5|GPUREG_00E5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_00E6|GPUREG_00E6]]&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_00E8|GPUREG_00E8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_00E9|GPUREG_00E9]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_00EA|GPUREG_00EA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_00EB|GPUREG_00EB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_00EC|GPUREG_00EC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_00ED|GPUREG_00ED]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_00EE|GPUREG_00EE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_00EF|GPUREG_00EF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_OP_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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_0118|GPUREG_0118]]&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_0120|GPUREG_0120]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_0121|GPUREG_0121]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_0122|GPUREG_0122]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_0123|GPUREG_0123]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_0124|GPUREG_0124]]&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_0126|GPUREG_0126]]&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_0130|GPUREG_0130]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_022D|GPUREG_022D]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0231|GPUREG_0231]]&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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0242|GPUREG_0242]]&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_0244|GPUREG_0244]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_0245|GPUREG_0245]]&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_024A|GPUREG_024A]]&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_0251|GPUREG_0251]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_0252|GPUREG_0252]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_0253|GPUREG_0253]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_0254|GPUREG_0254]]&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_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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Input selector for lut_DA&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_RR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| abs() flag for the input of lut_DA (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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Scaler selector for lut_DA&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = positional light, 1 = directional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light .&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=13281</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=13281"/>
		<updated>2015-09-14T08:48:35Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_LIGHTING_LUTINPUT_ABS */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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;
|&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_0047|GPUREG_0047]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_0048|GPUREG_0048]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_0049|GPUREG_0049]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_004A|GPUREG_004A]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_004B|GPUREG_004B]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_FRAG_OP_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_FRAG_OP_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_O0|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_O1|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_O2|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_O3|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_O4|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_O5|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_O6|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_0061|GPUREG_0061]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_0062|GPUREG_0062]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_0063|GPUREG_0063]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_0064|GPUREG_0064]]&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_006A|GPUREG_006A]]&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_006D|GPUREG_006D]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM2|GPUREG_FRAMEBUFFER_DIM2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_006F|GPUREG_006F]]&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_ENABLE|GPUREG_TEXUNIT_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_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_TEXUNIT0_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_TEXUNIT0_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_0084|GPUREG_0084]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_LOC|GPUREG_TEXUNIT0_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_0086|GPUREG_0086]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_0087|GPUREG_0087]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_0088|GPUREG_0088]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_0089|GPUREG_0089]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_008A|GPUREG_008A]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_008B|GPUREG_008B]]&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_TEXUNIT0_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_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_TEXUNIT1_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_TEXUNIT1_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_TEXUNIT1_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_0094|GPUREG_0094]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_LOC|GPUREG_TEXUNIT1_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_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_TEXUNIT2_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_TEXUNIT2_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_TEXUNIT2_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_009C|GPUREG_009C]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_LOC|GPUREG_TEXUNIT2_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_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_00A8|GPUREG_00A8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_00A9|GPUREG_00A9]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_00AA|GPUREG_00AA]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_00AB|GPUREG_00AB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_00AC|GPUREG_00AC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_00AD|GPUREG_00AD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_00AF|GPUREG_00AF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_00B0|GPUREG_00B0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_00B1|GPUREG_00B1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_00B2|GPUREG_00B2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_00B3|GPUREG_00B3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_00B4|GPUREG_00B4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_00B5|GPUREG_00B5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_00B6|GPUREG_00B6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_00B7|GPUREG_00B7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_00E1|GPUREG_00E1]]&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_00E4|GPUREG_00E4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_00E5|GPUREG_00E5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_00E6|GPUREG_00E6]]&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_00E8|GPUREG_00E8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_00E9|GPUREG_00E9]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_00EA|GPUREG_00EA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_00EB|GPUREG_00EB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_00EC|GPUREG_00EC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_00ED|GPUREG_00ED]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_00EE|GPUREG_00EE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_00EF|GPUREG_00EF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_OP_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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_0118|GPUREG_0118]]&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_0120|GPUREG_0120]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_0121|GPUREG_0121]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_0122|GPUREG_0122]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_0123|GPUREG_0123]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_0124|GPUREG_0124]]&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_0126|GPUREG_0126]]&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_0130|GPUREG_0130]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_022D|GPUREG_022D]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0231|GPUREG_0231]]&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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0242|GPUREG_0242]]&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_0244|GPUREG_0244]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_0245|GPUREG_0245]]&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_024A|GPUREG_024A]]&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_0251|GPUREG_0251]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_0252|GPUREG_0252]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_0253|GPUREG_0253]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_0254|GPUREG_0254]]&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_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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Input selector for lut_DA&lt;br /&gt;
|}&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_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;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| abs() flag for the input of lut_RR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| abs() flag for the input of lut_DA (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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Scaler selector for lut_DA&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = directional light, 1 = positional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light .&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=13280</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=13280"/>
		<updated>2015-09-14T08:31:05Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* GPUREG_LIGHTING_NUM_LIGHTS */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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;
|&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_0047|GPUREG_0047]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_0048|GPUREG_0048]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_0049|GPUREG_0049]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_004A|GPUREG_004A]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_004B|GPUREG_004B]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_FRAG_OP_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_FRAG_OP_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_O0|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_O1|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_O2|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_O3|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_O4|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_O5|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_O6|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_0061|GPUREG_0061]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_0062|GPUREG_0062]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_0063|GPUREG_0063]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_0064|GPUREG_0064]]&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_006A|GPUREG_006A]]&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_006D|GPUREG_006D]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM2|GPUREG_FRAMEBUFFER_DIM2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_006F|GPUREG_006F]]&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_ENABLE|GPUREG_TEXUNIT_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_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_TEXUNIT0_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_TEXUNIT0_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_0084|GPUREG_0084]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_LOC|GPUREG_TEXUNIT0_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_0086|GPUREG_0086]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_0087|GPUREG_0087]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_0088|GPUREG_0088]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_0089|GPUREG_0089]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_008A|GPUREG_008A]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_008B|GPUREG_008B]]&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_TEXUNIT0_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_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_TEXUNIT1_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_TEXUNIT1_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_TEXUNIT1_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_0094|GPUREG_0094]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_LOC|GPUREG_TEXUNIT1_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_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_TEXUNIT2_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_TEXUNIT2_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_TEXUNIT2_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_009C|GPUREG_009C]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_LOC|GPUREG_TEXUNIT2_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_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_00A8|GPUREG_00A8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_00A9|GPUREG_00A9]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_00AA|GPUREG_00AA]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_00AB|GPUREG_00AB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_00AC|GPUREG_00AC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_00AD|GPUREG_00AD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_00AF|GPUREG_00AF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_00B0|GPUREG_00B0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_00B1|GPUREG_00B1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_00B2|GPUREG_00B2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_00B3|GPUREG_00B3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_00B4|GPUREG_00B4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_00B5|GPUREG_00B5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_00B6|GPUREG_00B6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_00B7|GPUREG_00B7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_00E1|GPUREG_00E1]]&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_00E4|GPUREG_00E4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_00E5|GPUREG_00E5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_00E6|GPUREG_00E6]]&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_00E8|GPUREG_00E8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_00E9|GPUREG_00E9]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_00EA|GPUREG_00EA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_00EB|GPUREG_00EB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_00EC|GPUREG_00EC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_00ED|GPUREG_00ED]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_00EE|GPUREG_00EE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_00EF|GPUREG_00EF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_OP_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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_0118|GPUREG_0118]]&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_0120|GPUREG_0120]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_0121|GPUREG_0121]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_0122|GPUREG_0122]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_0123|GPUREG_0123]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_0124|GPUREG_0124]]&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_0126|GPUREG_0126]]&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_0130|GPUREG_0130]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_022D|GPUREG_022D]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0231|GPUREG_0231]]&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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0242|GPUREG_0242]]&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_0244|GPUREG_0244]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_0245|GPUREG_0245]]&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_024A|GPUREG_024A]]&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_0251|GPUREG_0251]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_0252|GPUREG_0252]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_0253|GPUREG_0253]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_0254|GPUREG_0254]]&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_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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights minus one (0..7) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Input selector for lut_DA&lt;br /&gt;
|}&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_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;
| 0&lt;br /&gt;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| abs() flag for the input of lut_RR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| abs() flag for the input of lut_DA (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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Scaler selector for lut_DA&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = directional light, 1 = positional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light .&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=13269</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=13269"/>
		<updated>2015-09-13T12:47:00Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Fragment lighting, part 2&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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;
|&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_0047|GPUREG_0047]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_0048|GPUREG_0048]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_0049|GPUREG_0049]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_004A|GPUREG_004A]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_004B|GPUREG_004B]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_FRAG_OP_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_FRAG_OP_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_O0|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_O1|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_O2|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_O3|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_O4|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_O5|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_O6|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_0061|GPUREG_0061]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_0062|GPUREG_0062]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_0063|GPUREG_0063]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_0064|GPUREG_0064]]&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_006A|GPUREG_006A]]&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_006D|GPUREG_006D]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM2|GPUREG_FRAMEBUFFER_DIM2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_006F|GPUREG_006F]]&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_ENABLE|GPUREG_TEXUNIT_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_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_TEXUNIT0_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_TEXUNIT0_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_0084|GPUREG_0084]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_LOC|GPUREG_TEXUNIT0_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_0086|GPUREG_0086]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_0087|GPUREG_0087]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_0088|GPUREG_0088]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_0089|GPUREG_0089]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_008A|GPUREG_008A]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_008B|GPUREG_008B]]&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_TEXUNIT0_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_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_TEXUNIT1_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_TEXUNIT1_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_TEXUNIT1_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_0094|GPUREG_0094]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_LOC|GPUREG_TEXUNIT1_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_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_TEXUNIT2_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_TEXUNIT2_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_TEXUNIT2_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_009C|GPUREG_009C]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_LOC|GPUREG_TEXUNIT2_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_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_00A8|GPUREG_00A8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_00A9|GPUREG_00A9]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_00AA|GPUREG_00AA]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_00AB|GPUREG_00AB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_00AC|GPUREG_00AC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_00AD|GPUREG_00AD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_00AF|GPUREG_00AF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_00B0|GPUREG_00B0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_00B1|GPUREG_00B1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_00B2|GPUREG_00B2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_00B3|GPUREG_00B3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_00B4|GPUREG_00B4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_00B5|GPUREG_00B5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_00B6|GPUREG_00B6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_00B7|GPUREG_00B7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_00E1|GPUREG_00E1]]&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_00E4|GPUREG_00E4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_00E5|GPUREG_00E5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_00E6|GPUREG_00E6]]&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_00E8|GPUREG_00E8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_00E9|GPUREG_00E9]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_00EA|GPUREG_00EA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_00EB|GPUREG_00EB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_00EC|GPUREG_00EC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_00ED|GPUREG_00ED]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_00EE|GPUREG_00EE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_00EF|GPUREG_00EF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_OP_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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_0118|GPUREG_0118]]&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_0120|GPUREG_0120]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_0121|GPUREG_0121]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_0122|GPUREG_0122]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_0123|GPUREG_0123]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_0124|GPUREG_0124]]&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_0126|GPUREG_0126]]&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_0130|GPUREG_0130]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_ATTENUATION_BIAS|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_LIGHTx_ATTENUATION_SCALE|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_022D|GPUREG_022D]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0231|GPUREG_0231]]&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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0242|GPUREG_0242]]&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_0244|GPUREG_0244]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_0245|GPUREG_0245]]&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_024A|GPUREG_024A]]&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_0251|GPUREG_0251]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_0252|GPUREG_0252]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_0253|GPUREG_0253]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_0254|GPUREG_0254]]&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_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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights (0..8) is written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Input selector for lut_DA&lt;br /&gt;
|}&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_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;
| 0&lt;br /&gt;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| abs() flag for the input of lut_RR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| abs() flag for the input of lut_DA (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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Scaler selector for lut_DA&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output of a LUT.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_INDEX ===&lt;br /&gt;
&lt;br /&gt;
This register controls which LUT and what offset into it the LUT_DATA register writes to.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&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;
| Blue component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 10-17&lt;br /&gt;
| Green component (0..255)&lt;br /&gt;
|-&lt;br /&gt;
| 20-27&lt;br /&gt;
| Red component (0..255)&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_LIGHTx_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;
| Light type (0 = directional light, 1 = positional light)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Two side diffuse (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Geometric factor 0 (0=disable, 1=enable)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Geometric factor 1 (0=disable, 1=enable)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| X coordinate (float16 = 1.5.10)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Y coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| Z coordinate (float16 = 1.5.10)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _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_LIGHTx_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;
| X coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|-&lt;br /&gt;
| 16-28&lt;br /&gt;
| Y coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _Z) represent the spot direction (unitary) vector of the corresponding light .&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_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;
| Z coordinate (2.11 signed fixed point) (Usually the input value is negated)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
These registers (along with _XY) represent the spot direction (unitary) vector of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_BIAS ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation bias value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_ATTENUATION_SCALE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the distance attenuation scale value (float20 = 1.7.12) of the corresponding light.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_AMBIENT ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the ambient color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_ambient*lightX_ambient.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_DIFFUSE ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the diffuse color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_diffuse*lightX_diffuse.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR0 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular0 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular0*lightX_specular0.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTx_SPECULAR1 ===&lt;br /&gt;
&lt;br /&gt;
These registers contain the specular1 color (same format as GPUREG_LIGHTING_AMBIENT) of the corresponding light. Usually set to material_specular1*lightX_specular1.&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=13268</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=13268"/>
		<updated>2015-09-13T12:19:28Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Fragment lighting, part 1&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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;
|&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_0047|GPUREG_0047]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_0048|GPUREG_0048]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_0049|GPUREG_0049]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_004A|GPUREG_004A]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_004B|GPUREG_004B]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_FRAG_OP_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_FRAG_OP_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_O0|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_O1|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_O2|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_O3|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_O4|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_O5|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_O6|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_0061|GPUREG_0061]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_0062|GPUREG_0062]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_0063|GPUREG_0063]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_0064|GPUREG_0064]]&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_006A|GPUREG_006A]]&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_006D|GPUREG_006D]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM2|GPUREG_FRAMEBUFFER_DIM2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_006F|GPUREG_006F]]&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_ENABLE|GPUREG_TEXUNIT_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_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_TEXUNIT0_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_TEXUNIT0_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_0084|GPUREG_0084]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_LOC|GPUREG_TEXUNIT0_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_0086|GPUREG_0086]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_0087|GPUREG_0087]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_0088|GPUREG_0088]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_0089|GPUREG_0089]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_008A|GPUREG_008A]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_008B|GPUREG_008B]]&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_TEXUNIT0_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_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_TEXUNIT1_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_TEXUNIT1_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_TEXUNIT1_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_0094|GPUREG_0094]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_LOC|GPUREG_TEXUNIT1_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_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_TEXUNIT2_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_TEXUNIT2_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_TEXUNIT2_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_009C|GPUREG_009C]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_LOC|GPUREG_TEXUNIT2_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_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_00A8|GPUREG_00A8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_00A9|GPUREG_00A9]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_00AA|GPUREG_00AA]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_00AB|GPUREG_00AB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_00AC|GPUREG_00AC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_00AD|GPUREG_00AD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_00AF|GPUREG_00AF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_00B0|GPUREG_00B0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_00B1|GPUREG_00B1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_00B2|GPUREG_00B2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_00B3|GPUREG_00B3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_00B4|GPUREG_00B4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_00B5|GPUREG_00B5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_00B6|GPUREG_00B6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_00B7|GPUREG_00B7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_00E1|GPUREG_00E1]]&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_00E4|GPUREG_00E4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_00E5|GPUREG_00E5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_00E6|GPUREG_00E6]]&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_00E8|GPUREG_00E8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_00E9|GPUREG_00E9]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_00EA|GPUREG_00EA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_00EB|GPUREG_00EB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_00EC|GPUREG_00EC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_00ED|GPUREG_00ED]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_00EE|GPUREG_00EE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_00EF|GPUREG_00EF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_OP_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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_0118|GPUREG_0118]]&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_0120|GPUREG_0120]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_0121|GPUREG_0121]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_0122|GPUREG_0122]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_0123|GPUREG_0123]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_0124|GPUREG_0124]]&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_0126|GPUREG_0126]]&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_0130|GPUREG_0130]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_LIGHTx_SPECULARy|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_LIGHTx_SPECULARy|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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_LIGHTx_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_0150|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_0151|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_0152|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_0153|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_0154|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_0155|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_0156|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_0157|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_0159|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_015A|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_015B|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_0160|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_0161|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_0162|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_0163|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_0164|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_0165|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_0166|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_0167|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_0169|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_016A|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_016B|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_0170|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_0171|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_0172|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_0173|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_0174|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_0175|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_0176|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_0177|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_0179|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_017A|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_017B|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_0180|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_0181|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_0182|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_0183|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_0184|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_0185|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_0186|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_0187|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_0189|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_018A|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_018B|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_0190|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_0191|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_0192|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_0193|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_0194|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_0195|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_0196|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_0197|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_0199|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_019A|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_019B|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_01A0|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_01A1|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_01A2|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_01A3|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_01A4|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_01A5|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_01A6|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_01A7|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_01A9|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_01AA|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_01AB|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_01B0|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_01B1|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_01B2|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_01B3|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_01B4|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_01B5|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_01B6|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_01B7|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_01B9|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_01BA|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_01BB|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_DATA|GPUREG_LIGHTING_LUT_DATA]]&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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_022D|GPUREG_022D]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0231|GPUREG_0231]]&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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0242|GPUREG_0242]]&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_0244|GPUREG_0244]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_0245|GPUREG_0245]]&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_024A|GPUREG_024A]]&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_0251|GPUREG_0251]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_0252|GPUREG_0252]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_0253|GPUREG_0253]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_0254|GPUREG_0254]]&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_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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE0 ===&lt;br /&gt;
&lt;br /&gt;
This register is set to 0 when fragment lighting is disabled, and to 1 when it is enabled.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_ENABLE1 ===&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_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;
| Shadow factor enable, usually set to bit16 OR bit18 OR bit19&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 2-3&lt;br /&gt;
| &amp;quot;Fresnel selector&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| &amp;quot;Config&amp;quot;, &amp;quot;Light env config&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Unknown, set to 4&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| &amp;quot;Shadow primary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| &amp;quot;Shadow secondary&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| &amp;quot;Invert shadow&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| &amp;quot;Shadow alpha&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 20-21&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 22-23&lt;br /&gt;
| &amp;quot;Bump selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 24-25&lt;br /&gt;
| &amp;quot;Shadow selector&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Unknown, set to 0&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| &amp;quot;Clamp highlights&amp;quot;, 0=disabled, 1=enabled&lt;br /&gt;
|-&lt;br /&gt;
| 28-29&lt;br /&gt;
| &amp;quot;Bump mode&amp;quot;, &amp;quot;Light env texy usage&amp;quot; (see below)&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| &amp;quot;Bump renorm&amp;quot;, 0=enabled, 1=disabled&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Fresnel selector constants:&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;
| NO_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| PRI_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| SEC_ALPHA_FRESNEL&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| PRI_SEC_ALPHA_FRESNEL&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Light env config constants:&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;
| LIGHT_ENV_LAYER_CONFIG0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG1&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG2&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG3&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG4&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG5&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG6&lt;br /&gt;
|-&lt;br /&gt;
| 8 (sic)&lt;br /&gt;
| LIGHT_ENV_LAYER_CONFIG7&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bump mode constants:&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;
| BUMP_NOT_USED&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| BUMP_AS_BUMP&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| BUMP_AS_TANG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Bit 30 is set when bump mode is not zero.&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 16&lt;br /&gt;
| Disable bit for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 17&lt;br /&gt;
| Disable bit for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 18&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 19&lt;br /&gt;
| Disable bit for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 20&lt;br /&gt;
| Disable bit for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 21&lt;br /&gt;
| Disable bit for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 22&lt;br /&gt;
| Disable bit for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Unknown, set to 1&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_NUM_LIGHTS ===&lt;br /&gt;
&lt;br /&gt;
The number of active lights (0..8) are written to this register.&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;
| ID of the 1st enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 4-6&lt;br /&gt;
| ID of the 2nd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| ID of the 3rd enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 12-14&lt;br /&gt;
| ID of the 4th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 16-18&lt;br /&gt;
| ID of the 5th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 20-22&lt;br /&gt;
| ID of the 6th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 24-26&lt;br /&gt;
| ID of the 7th enabled light (0..7)&lt;br /&gt;
|-&lt;br /&gt;
| 28-30&lt;br /&gt;
| ID of the 8th enabled light (0..7)&lt;br /&gt;
|}&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-3&lt;br /&gt;
| Input selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Input selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Input selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Input selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Input selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Input selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Input selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Input selector for lut_DA&lt;br /&gt;
|}&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_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;
| 0&lt;br /&gt;
| abs() flag for the input of lut_D0 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| abs() flag for the input of lut_D1 (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| abs() flag for the input of lut_SP (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| abs() flag for the input of lut_FR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| abs() flag for the input of lut_RB (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| abs() flag for the input of lut_RG (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| abs() flag for the input of lut_RR (0=enabled, 1=disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| abs() flag for the input of lut_DA (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_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-3&lt;br /&gt;
| Scaler selector for lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Scaler selector for lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Scaler selector for lut_SP&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Scaler selector for lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Scaler selector for lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Scaler selector for lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Scaler selector for lut_RR&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Scaler selector for lut_DA&lt;br /&gt;
|}&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;
This register controls the scaling that is applied to the output (or maybe the input?) of a LUT.&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;
| Starting entry offset (0...255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-10&lt;br /&gt;
| LUT ID (context=0) or Light ID (context=1,2)&lt;br /&gt;
|-&lt;br /&gt;
| 11-12&lt;br /&gt;
| Context ID&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
LUT ID 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;
| lut_D0&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_D1&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| lut_FR&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| lut_RB&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| lut_RG&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| lut_RR&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Context ID 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;
| LUTs common to all lights - writes to the LUT selected by the ID&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| lut_SP - writes to the LUT specific to the selected light&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| lut_DA - writes to the LUT specific to the selected light&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_LIGHTING_LUT_DATA ===&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;
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;
| Entry value (12bit fractional number; floatval = x / 4096; however 0xFFF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 12-22&lt;br /&gt;
| Absolute value of the difference between the next entry and this entry (11bit fractional number; floatval = x / 2048; however 0x7FF is treated as 1.0)&lt;br /&gt;
|-&lt;br /&gt;
| 23&lt;br /&gt;
| Sign bit of the difference (0=positive, 1=negative)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=GPU/Internal_Registers&amp;diff=13267</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=13267"/>
		<updated>2015-09-13T10:40:10Z</updated>

		<summary type="html">&lt;p&gt;Fincs: /* Fragment lighting registers (0x140-0x1FF) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:GFX]]&lt;br /&gt;
(this page is hugely WIP)&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;
=== 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_GSH_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_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]] so that a consecutively writing command based at 02C0 will write its first parameter to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]] and ever subsequent ones to [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&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;
|&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_0047|GPUREG_0047]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP&lt;br /&gt;
|-&lt;br /&gt;
| 0048&lt;br /&gt;
| [[#GPUREG_0048|GPUREG_0048]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0049&lt;br /&gt;
| [[#GPUREG_0049|GPUREG_0049]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 004A&lt;br /&gt;
| [[#GPUREG_004A|GPUREG_004A]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_CLIP_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 004B&lt;br /&gt;
| [[#GPUREG_004B|GPUREG_004B]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_FRAG_OP_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_FRAG_OP_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_O0|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_O1|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_O2|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_O3|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_O4|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_O5|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_O6|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_0061|GPUREG_0061]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0062&lt;br /&gt;
| [[#GPUREG_0062|GPUREG_0062]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_EARLY_DEPTH_TEST1&lt;br /&gt;
|-&lt;br /&gt;
| 0063&lt;br /&gt;
| [[#GPUREG_0063|GPUREG_0063]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0064&lt;br /&gt;
| [[#GPUREG_0064|GPUREG_0064]]&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_006A|GPUREG_006A]]&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_006D|GPUREG_006D]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_WSCALE&lt;br /&gt;
|-&lt;br /&gt;
| 006E&lt;br /&gt;
| [[#GPUREG_FRAMEBUFFER_DIM2|GPUREG_FRAMEBUFFER_DIM2]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_RENDER_BUF_RESOLUTION1&lt;br /&gt;
|-&lt;br /&gt;
| 006F&lt;br /&gt;
| [[#GPUREG_006F|GPUREG_006F]]&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_ENABLE|GPUREG_TEXUNIT_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0081&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_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_TEXUNIT0_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_TEXUNIT0_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_0084|GPUREG_0084]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE0_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0085&lt;br /&gt;
| [[#GPUREG_TEXUNIT0_LOC|GPUREG_TEXUNIT0_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR1&lt;br /&gt;
|-&lt;br /&gt;
| 0086&lt;br /&gt;
| [[#GPUREG_0086|GPUREG_0086]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR2&lt;br /&gt;
|-&lt;br /&gt;
| 0087&lt;br /&gt;
| [[#GPUREG_0087|GPUREG_0087]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR3&lt;br /&gt;
|-&lt;br /&gt;
| 0088&lt;br /&gt;
| [[#GPUREG_0088|GPUREG_0088]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR4&lt;br /&gt;
|-&lt;br /&gt;
| 0089&lt;br /&gt;
| [[#GPUREG_0089|GPUREG_0089]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR5&lt;br /&gt;
|-&lt;br /&gt;
| 008A&lt;br /&gt;
| [[#GPUREG_008A|GPUREG_008A]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE0_ADDR6&lt;br /&gt;
|-&lt;br /&gt;
| 008B&lt;br /&gt;
| [[#GPUREG_008B|GPUREG_008B]]&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_TEXUNIT0_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_008F|GPUREG_008F]]&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_TEXUNIT1_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_TEXUNIT1_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_TEXUNIT1_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_0094|GPUREG_0094]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE1_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 0095&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_LOC|GPUREG_TEXUNIT1_LOC]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_TEXTURE1_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0096&lt;br /&gt;
| [[#GPUREG_TEXUNIT1_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_TEXUNIT2_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_TEXUNIT2_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_TEXUNIT2_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_009C|GPUREG_009C]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE2_LOD&lt;br /&gt;
|-&lt;br /&gt;
| 009D&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_LOC|GPUREG_TEXUNIT2_LOC]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_TEXTURE2_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 009E&lt;br /&gt;
| [[#GPUREG_TEXUNIT2_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_00A8|GPUREG_00A8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX0&lt;br /&gt;
|-&lt;br /&gt;
| 00A9&lt;br /&gt;
| [[#GPUREG_00A9|GPUREG_00A9]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX1&lt;br /&gt;
|-&lt;br /&gt;
| 00AA&lt;br /&gt;
| [[#GPUREG_00AA|GPUREG_00AA]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX2&lt;br /&gt;
|-&lt;br /&gt;
| 00AB&lt;br /&gt;
| [[#GPUREG_00AB|GPUREG_00AB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX3&lt;br /&gt;
|-&lt;br /&gt;
| 00AC&lt;br /&gt;
| [[#GPUREG_00AC|GPUREG_00AC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX4&lt;br /&gt;
|-&lt;br /&gt;
| 00AD&lt;br /&gt;
| [[#GPUREG_00AD|GPUREG_00AD]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_TEXTURE3_PROTEX5&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_00AF|GPUREG_00AF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_PROTEX_LUT&lt;br /&gt;
|-&lt;br /&gt;
| 00B0&lt;br /&gt;
| [[#GPUREG_00B0|GPUREG_00B0]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00B1&lt;br /&gt;
| [[#GPUREG_00B1|GPUREG_00B1]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00B2&lt;br /&gt;
| [[#GPUREG_00B2|GPUREG_00B2]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00B3&lt;br /&gt;
| [[#GPUREG_00B3|GPUREG_00B3]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00B4&lt;br /&gt;
| [[#GPUREG_00B4|GPUREG_00B4]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00B5&lt;br /&gt;
| [[#GPUREG_00B5|GPUREG_00B5]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00B6&lt;br /&gt;
| [[#GPUREG_00B6|GPUREG_00B6]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00B7&lt;br /&gt;
| [[#GPUREG_00B7|GPUREG_00B7]]&lt;br /&gt;
| ?&lt;br /&gt;
|PICA_REG_PROTEX_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV0_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV1_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV2_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_TEXENV3_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_00E1|GPUREG_00E1]]&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_00E4|GPUREG_00E4]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ATTENUATION&lt;br /&gt;
|-&lt;br /&gt;
| 00E5&lt;br /&gt;
| [[#GPUREG_00E5|GPUREG_00E5]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_ACCMAX&lt;br /&gt;
|-&lt;br /&gt;
| 00E6&lt;br /&gt;
| [[#GPUREG_00E6|GPUREG_00E6]]&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_00E8|GPUREG_00E8]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 00E9&lt;br /&gt;
| [[#GPUREG_00E9|GPUREG_00E9]]&lt;br /&gt;
|? &lt;br /&gt;
|PICA_REG_FOG_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 00EA&lt;br /&gt;
| [[#GPUREG_00EA|GPUREG_00EA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 00EB&lt;br /&gt;
| [[#GPUREG_00EB|GPUREG_00EB]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 00EC&lt;br /&gt;
| [[#GPUREG_00EC|GPUREG_00EC]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 00ED&lt;br /&gt;
| [[#GPUREG_00ED|GPUREG_00ED]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 00EE&lt;br /&gt;
| [[#GPUREG_00EE|GPUREG_00EE]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 00EF&lt;br /&gt;
| [[#GPUREG_00EF|GPUREG_00EF]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FOG_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 00F0&lt;br /&gt;
| [[#GPUREG_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV4_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_TEXENV5_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_BLEND_ENABLE|GPUREG_BLEND_ENABLE]]&lt;br /&gt;
|&lt;br /&gt;
|PICA_REG_COLOR_OPERATION&lt;br /&gt;
|-&lt;br /&gt;
| 0101&lt;br /&gt;
| [[#GPUREG_BLEND_CONFIG|GPUREG_BLEND_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_BLEND_FUNC&lt;br /&gt;
|-&lt;br /&gt;
| 0102&lt;br /&gt;
| [[#GPUREG_LOGICOP_CONFIG|GPUREG_LOGICOP_CONFIG]]&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_ALPHATEST_CONFIG|GPUREG_ALPHATEST_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_FRAG_OP_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_ACTION|GPUREG_STENCIL_ACTION]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_STENCIL_OP&lt;br /&gt;
|-&lt;br /&gt;
| 0107&lt;br /&gt;
| [[#GPUREG_DEPTHTEST_CONFIG|GPUREG_DEPTHTEST_CONFIG]]&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_0118|GPUREG_0118]]&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_0120|GPUREG_0120]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_XY&lt;br /&gt;
|-&lt;br /&gt;
| 0121&lt;br /&gt;
| [[#GPUREG_0121|GPUREG_0121]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z&lt;br /&gt;
|-&lt;br /&gt;
| 0122&lt;br /&gt;
| [[#GPUREG_0122|GPUREG_0122]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LIGHT_Z_COLOR&lt;br /&gt;
|-&lt;br /&gt;
| 0123&lt;br /&gt;
| [[#GPUREG_0123|GPUREG_0123]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GAS_LUT_INDEX&lt;br /&gt;
|-&lt;br /&gt;
| 0124&lt;br /&gt;
| [[#GPUREG_0124|GPUREG_0124]]&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_0126|GPUREG_0126]]&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_0130|GPUREG_0130]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_OP_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_0140|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_0141|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_0142|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_0143|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_0144|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_0145|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_0146|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_0147|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_0149|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_014A|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_014B|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_0150|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_0151|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_0152|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_0153|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_0154|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_0155|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_0156|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_0157|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_0159|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_015A|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_015B|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_0160|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_0161|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_0162|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_0163|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_0164|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_0165|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_0166|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_0167|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_0169|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_016A|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_016B|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_0170|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_0171|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_0172|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_0173|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_0174|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_0175|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_0176|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_0177|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_0179|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_017A|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_017B|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_0180|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_0181|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_0182|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_0183|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_0184|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_0185|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_0186|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_0187|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_0189|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_018A|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_018B|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_0190|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_0191|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_0192|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_0193|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_0194|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_0195|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_0196|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_0197|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_0199|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_019A|GPUREG_LIGHT5_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 019B&lt;br /&gt;
| [[#GPUREG_019B|GPUREG_LIGHT5_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_01A0|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_01A1|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_01A2|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_01A3|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_01A4|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_01A5|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_01A6|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_01A7|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_01A9|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_01AA|GPUREG_LIGHT6_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01AB&lt;br /&gt;
| [[#GPUREG_01AB|GPUREG_LIGHT6_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_01B0|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_01B1|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_01B2|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_01B3|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_01B4|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_01B5|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_01B6|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_01B7|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_01B9|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_01BA|GPUREG_LIGHT7_ATTENUATION_BIAS]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 01BB&lt;br /&gt;
| [[#GPUREG_01BB|GPUREG_LIGHT7_ATTENUATION_SCALE]]&lt;br /&gt;
| &lt;br /&gt;
|&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_01C0|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_01C2|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_01C3|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_01C4|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_01C5|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_01C6|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_01C8|GPUREG_LIGHTING_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 01C9&lt;br /&gt;
| [[#GPUREG_01C9|GPUREG_LIGHTING_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 01CA&lt;br /&gt;
| [[#GPUREG_01CA|GPUREG_LIGHTING_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 01CB&lt;br /&gt;
| [[#GPUREG_01CB|GPUREG_LIGHTING_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 01CC&lt;br /&gt;
| [[#GPUREG_01CC|GPUREG_LIGHTING_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 01CD&lt;br /&gt;
| [[#GPUREG_01CD|GPUREG_LIGHTING_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 01CE&lt;br /&gt;
| [[#GPUREG_01CE|GPUREG_LIGHTING_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 01CF&lt;br /&gt;
| [[#GPUREG_01CF|GPUREG_LIGHTING_LUT_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_FRAG_LIGHT_LUT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 01D0&lt;br /&gt;
| [[#GPUREG_01D0|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_01D1|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_01D2|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_01D9|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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER0_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_ATTRIBBUFFER1_OFFSET|GPUREG_ATTRIBBUFFER1_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0207&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG1|GPUREG_ATTRIBBUFFER1_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0208&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER1_CONFIG2|GPUREG_ATTRIBBUFFER1_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0209&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_OFFSET|GPUREG_ATTRIBBUFFER2_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG1|GPUREG_ATTRIBBUFFER2_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER2_CONFIG2|GPUREG_ATTRIBBUFFER2_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_OFFSET|GPUREG_ATTRIBBUFFER3_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG1|GPUREG_ATTRIBBUFFER3_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER3_CONFIG2|GPUREG_ATTRIBBUFFER3_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 020F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_OFFSET|GPUREG_ATTRIBBUFFER4_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0210&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG1|GPUREG_ATTRIBBUFFER4_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0211&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER4_CONFIG2|GPUREG_ATTRIBBUFFER4_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0212&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_OFFSET|GPUREG_ATTRIBBUFFER5_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0213&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG1|GPUREG_ATTRIBBUFFER5_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0214&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER5_CONFIG2|GPUREG_ATTRIBBUFFER5_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0215&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_OFFSET|GPUREG_ATTRIBBUFFER6_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0216&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG1|GPUREG_ATTRIBBUFFER6_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0217&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER6_CONFIG2|GPUREG_ATTRIBBUFFER6_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0218&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_OFFSET|GPUREG_ATTRIBBUFFER7_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0219&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG1|GPUREG_ATTRIBBUFFER7_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021A&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER7_CONFIG2|GPUREG_ATTRIBBUFFER7_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021B&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_OFFSET|GPUREG_ATTRIBBUFFER8_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021C&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG1|GPUREG_ATTRIBBUFFER8_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021D&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER8_CONFIG2|GPUREG_ATTRIBBUFFER8_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021E&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_OFFSET|GPUREG_ATTRIBBUFFER9_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 021F&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG1|GPUREG_ATTRIBBUFFER9_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0220&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER9_CONFIG2|GPUREG_ATTRIBBUFFER9_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0221&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_OFFSET|GPUREG_ATTRIBBUFFER10_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0222&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG1|GPUREG_ATTRIBBUFFER10_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0223&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER10_CONFIG2|GPUREG_ATTRIBBUFFER10_CONFIG2]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0224&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_OFFSET|GPUREG_ATTRIBBUFFER11_OFFSET]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0225&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_CONFIG1|GPUREG_ATTRIBBUFFER11_CONFIG1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0226&lt;br /&gt;
| [[#GPUREG_ATTRIBBUFFER11_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_022D|GPUREG_022D]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0231|GPUREG_0231]]&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_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 0234&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_FIXED_ATTR_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0235&lt;br /&gt;
| [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]&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;
|&lt;br /&gt;
|-&lt;br /&gt;
| 0239&lt;br /&gt;
| [[#GPUREG_CMDBUF_SIZE1|GPUREG_CMDBUF_SIZE1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023A&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR0|GPUREG_CMDBUF_ADDR0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023B&lt;br /&gt;
| [[#GPUREG_CMDBUF_ADDR1|GPUREG_CMDBUF_ADDR1]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023C&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP0|GPUREG_CMDBUF_JUMP0]]&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 023D&lt;br /&gt;
| [[#GPUREG_CMDBUF_JUMP1|GPUREG_CMDBUF_JUMP1]]&lt;br /&gt;
| &lt;br /&gt;
|&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_0242|GPUREG_0242]]&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_0244|GPUREG_0244]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_COM_MODE&lt;br /&gt;
|-&lt;br /&gt;
| 0245&lt;br /&gt;
| [[#GPUREG_0245|GPUREG_0245]]&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_024A|GPUREG_024A]]&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_0251|GPUREG_0251]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_VS_OUT_REG_NUM2&lt;br /&gt;
|-&lt;br /&gt;
| 0252&lt;br /&gt;
| [[#GPUREG_0252|GPUREG_0252]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_GS_MISC_REG0&lt;br /&gt;
|-&lt;br /&gt;
| 0253&lt;br /&gt;
| [[#GPUREG_0253|GPUREG_0253]]&lt;br /&gt;
|?&lt;br /&gt;
|PICA_REG_DRAW_MODE1&lt;br /&gt;
|-&lt;br /&gt;
| 0254&lt;br /&gt;
| [[#GPUREG_0254|GPUREG_0254]]&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_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_GSH_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_GSH_INTUNIFORM_I0|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_GSH_INTUNIFORM_I1|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_GSH_INTUNIFORM_I2|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_GSH_INTUNIFORM_I3|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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_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_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_ADDR&lt;br /&gt;
|-&lt;br /&gt;
| 0291&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_INDEX|GPUREG_GSH_FLOATUNIFORM_INDEX]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 0292&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 0293&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 0294&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 0295&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 0296&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 0297&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 0298&lt;br /&gt;
| [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_FLOAT_DATA8&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_GSH_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_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 029D&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 029E&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 029F&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02A0&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02A1&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02A2&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02A3&lt;br /&gt;
| [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]]&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_GSH_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_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02A7&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02A8&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02A9&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02AA&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02AB&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02AC&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_GS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02AD&lt;br /&gt;
| [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]]&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_VSH_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_VSH_INTUNIFORM_I0|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_VSH_INTUNIFORM_I1|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_VSH_INTUNIFORM_I2|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_VSH_INTUNIFORM_I3|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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_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_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02C2&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02C3&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02C4&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02C5&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02C6&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02C7&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA7&lt;br /&gt;
|-&lt;br /&gt;
| 02C8&lt;br /&gt;
| [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_FLOAT_DATA8&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_VSH_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_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02CD&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02CE&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02CF&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02D0&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02D1&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02D2&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02D3&lt;br /&gt;
| [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]]&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_VSH_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_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA0&lt;br /&gt;
|-&lt;br /&gt;
| 02D7&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA1&lt;br /&gt;
|-&lt;br /&gt;
| 02D8&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA2&lt;br /&gt;
|-&lt;br /&gt;
| 02D9&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA3&lt;br /&gt;
|-&lt;br /&gt;
| 02DA&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA4&lt;br /&gt;
|-&lt;br /&gt;
| 02DB&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA5&lt;br /&gt;
|-&lt;br /&gt;
| 02DC&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&lt;br /&gt;
| &lt;br /&gt;
|PICA_REG_VS_PROG_SWIZZLE_DATA6&lt;br /&gt;
|-&lt;br /&gt;
| 02DD&lt;br /&gt;
| [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]]&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;
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;
== Texturing registers ==&lt;br /&gt;
&lt;br /&gt;
== Framebuffer registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_INVALIDATE ===&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;
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_DEPTHBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
The format the current depth buffer should be written into. Following values are possible:&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;
| 1&lt;br /&gt;
| ?? seems to freeze the GPU&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 (stencil is within bit 24-31)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_COLORBUFFER_FORMAT ===&lt;br /&gt;
&lt;br /&gt;
Describes the format of the current color buffer used for 3D rendering.&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;
| Pixel size (0=16-bit, 1=24-bit, 2=32-bit, 3=64-bit?)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Framebuffer Format (0=GL_RGBA8, 1=GL_RGB8, 2=GL_RGB5_A1, 3=GL_R5_G6_B5, 4=GL_RGBA4).&lt;br /&gt;
Note that these values are slightly different from those in [[GPU#Framebuffer_color_formats]].&lt;br /&gt;
&lt;br /&gt;
Color components are laid out in reverse byte order, with the most significant bits used first.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FRAMEBUFFER_BLOCK32 ===&lt;br /&gt;
&lt;br /&gt;
When set to 0, use regular 8x8 tiling format for the framebuffer, compatible with textures. When set to 1, use a 32x32 tiling format. To untile the color buffer when using this 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;
== Fragment lighting registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_01C4 ===&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;
| Disable bit for frag light source 0 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Disable bit for frag light source 1 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Disable bit for frag light source 2 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Disable bit for frag light source 3 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Disable bit for frag light source 4 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Disable bit for frag light source 5 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Disable bit for frag light source 6 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Disable bit for frag light source 7 shadows&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Disable bit for frag light source 0 spot&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Disable bit for frag light source 1 spot&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Disable bit for frag light source 2 spot&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Disable bit for frag light source 3 spot&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Disable bit for frag light source 4 spot&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Disable bit for frag light source 5 spot&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Disable bit for frag light source 6 spot&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Disable bit for frag light source 7 spot&lt;br /&gt;
|-&lt;br /&gt;
| 24&lt;br /&gt;
| Disable bit for frag light source 0 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 25&lt;br /&gt;
| Disable bit for frag light source 1 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 26&lt;br /&gt;
| Disable bit for frag light source 2 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 27&lt;br /&gt;
| Disable bit for frag light source 3 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 28&lt;br /&gt;
| Disable bit for frag light source 4 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| Disable bit for frag light source 5 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| Disable bit for frag light source 6 distance attenuation&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Disable bit for frag light source 7 distance attenuation&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry pipeline registers ==&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-7&lt;br /&gt;
| Geometry stage mode. (0=Vertex shader only, 2=Vertex shader + geometry shader)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Unknown. Seems to skip every other triangle when used with indexed rendering and without geoshaders. Has no effect with non-indexed rendering without geoshaders. &#039;&#039;&#039;If this is 0, you don&#039;t need to use GPU_UNKPRIM with DrawElements.&#039;&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| 9-15&lt;br /&gt;
| No effect.&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Unknown.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. Often set to 0.&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;
=== GPUREG_FIXEDATTRIB_INDEX ===&lt;br /&gt;
&lt;br /&gt;
See [[GPU/Fixed Vertex Attributes]] and [[GPU/Immediate-Mode Vertex Submission]] for usage info.&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;
| Sets the active fixed attribute index. This is the fixed attribute which will be set when writing to [[#GPUREG_FIXEDATTRIB_DATA|GPUREG_FIXEDATTRIB_DATA]]. Valid values are 0-11. If the special value 0xF is written here, this sets up immediate-mode vertex submission instead, and writes to the data register will input vertex data directly into the pipeline.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_FIXEDATTRIB_DATA ===&lt;br /&gt;
&lt;br /&gt;
Accepts a packed 4-tuple of float24 values (in the same format used for [[#GPUREG_VSH_FLOATUNIFORM_DATA|specifying shader uniforms]]). This is stored as the fixed attribute value for the attribute currently specified in the index register. Attributes are always specified as a 4-tuple of floats, regardless of the format configured in [[#GPUREG_ATTRIBBUFFERS_FORMAT_HIGH|GPUREG_ATTRIBBUFFERS_FORMAT_HIGH]].&lt;br /&gt;
&lt;br /&gt;
If immediate-mode vertex submission is enabled (by writing 0xF to the index register) then vertex data is input here directly. The index register does not need to be re-set after each write.&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-7&lt;br /&gt;
| Writing 0x01 to this field ends the current triangle strip or fan. This is necessary before using these kinds of primitives with [[GPU:Immediate-Mode Vertex Submission|immediate-mode]], but most games seem to write to it before every draw call.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Geometry shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Value of geometry shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of geometry shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of geometry shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of geometry shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of geometry shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of geometry shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of geometry shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of geometry shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of geometry shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of geometry shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of geometry shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of geometry shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of geometry shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of geometry shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of geometry shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of geometry shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I0 ===&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;
| Value for geometry shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I1 ===&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;
| Value for geometry shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I2 ===&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;
| Value for geometry shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_INTUNIFORM_I3 ===&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;
| Value for geometry shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for geometry shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for geometry shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for geometry shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the geometry shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 8 for geometry shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the geometry shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the input primitive size in registers, though it is not a limit on the number of input registers which can be accessed from the geometry shader.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Geometry shader unit entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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 entrypoint, it can also be used to set this single shader unit to run from a different entrypoint than the other three even when running a vertex shader.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Index of geometry shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of geometry shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of geometry shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of geometry shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of geometry shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of geometry shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of geometry shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of geometry shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the geometry shader 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.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the geometry shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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;
| Enable bit for geometry shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for geometry shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for geometry shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for geometry shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for geometry shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for geometry shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for geometry shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the geometry shader unit&#039;s output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 geometry shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 geometry shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 geometry shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 geometry shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_GSH_FLOATUNIFORM_DATA|GPUREG_GSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_FLOATUNIFORM_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;
| Float vec4 geometry shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 geometry shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_GSH_FLOATUNIFORM_CONFIG|GPUREG_GSH_FLOATUNIFORM_CONFIG]].&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_GSH_CODETRANSFER_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-11&lt;br /&gt;
| Target geometry shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader code data transferred through [[#GPUREG_GSH_CODETRANSFER_DATA|GPUREG_GSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_CODETRANSFER_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;
| Geometry shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader code memory bank at the offset initially set by [[#GPUREG_GSH_CODETRANSFER_CONFIG|GPUREG_GSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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-6&lt;br /&gt;
| Target geometry shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming geometry shader operand descriptor data transferred through [[#GPUREG_GSH_OPDESCS_DATA|GPUREG_GSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_GSH_OPDESCS_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;
| Geometry shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer geometry shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU geometry shader operand descriptor memory bank at the offset initially set by [[#GPUREG_GSH_OPDESCS_CONFIG|GPUREG_GSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
== Vertex shader registers ==&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Value of vertex shader unit&#039;s b0 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Value of vertex shader unit&#039;s b1 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Value of vertex shader unit&#039;s b2 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Value of vertex shader unit&#039;s b3 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Value of vertex shader unit&#039;s b4 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Value of vertex shader unit&#039;s b5 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Value of vertex shader unit&#039;s b6 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Value of vertex shader unit&#039;s b7 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Value of vertex shader unit&#039;s b8 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Value of vertex shader unit&#039;s b9 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Value of vertex shader unit&#039;s b10 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Value of vertex shader unit&#039;s b11 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Value of vertex shader unit&#039;s b12 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Value of vertex shader unit&#039;s b13 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Value of vertex shader unit&#039;s b14 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Value of vertex shader unit&#039;s b15 boolean register. (0=true, 1=false)&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader unit&#039;s boolean registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I0 ===&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;
| Value for vertex shader&#039;s i0.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i0.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i0.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i0.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i0 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I1 ===&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;
| Value for vertex shader&#039;s i1.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i1.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i1.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i1.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i1 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I2 ===&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;
| Value for vertex shader&#039;s i2.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i2.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i2.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i2.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i2 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_INTUNIFORM_I3 ===&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;
| Value for vertex shader&#039;s i3.x (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 8-15&lt;br /&gt;
| Value for vertex shader&#039;s i3.y (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 16-23&lt;br /&gt;
| Value for vertex shader&#039;s i3.z (u8, 0-255)&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Value for vertex shader&#039;s i3.w (u8, 0-255)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the vertex shader&#039;s i3 integer register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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-7&lt;br /&gt;
| Input buffer stride minus 1, in float vec4 registers. (value 0 means a stride of 1 float vec4 register)&lt;br /&gt;
|-&lt;br /&gt;
| 8-23&lt;br /&gt;
| Unknown. These bits typically aren&#039;t updated by games.&lt;br /&gt;
|-&lt;br /&gt;
| 24-31&lt;br /&gt;
| Unknown. This is typically set to 0xA for vertex shaders.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to configure the vertex shader&#039;s input buffer. In the context of a geometry shader, the stride parameter can be interpreted as the number of attributes per vertex.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Vertex shader entrypoint, in words.&lt;br /&gt;
|-&lt;br /&gt;
| 16-31&lt;br /&gt;
| Unknown. This seems to always be set to 0x7FFF, and other values may cause the GPU to hang&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This sets the entrypoint for the program running on 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_VSH_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;
| Index of vertex shader input register which the 1st attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 2nd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 3rd attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 4th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 5th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 6th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 7th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 8th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for the first 8 attributes.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 1st attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Index of vertex shader input register which the 9th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 4-7&lt;br /&gt;
| Index of vertex shader input register which the 10th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 8-11&lt;br /&gt;
| Index of vertex shader input register which the 11th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 12-15&lt;br /&gt;
| Index of vertex shader input register which the 12th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 16-19&lt;br /&gt;
| Index of vertex shader input register which the 13th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 20-23&lt;br /&gt;
| Index of vertex shader input register which the 14th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 24-27&lt;br /&gt;
| Index of vertex shader input register which the 15th attribute will be stored in.&lt;br /&gt;
|-&lt;br /&gt;
| 28-31&lt;br /&gt;
| Index of vertex shader input register which the 16th attribute will be stored in.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the vertex shader input register index which will correspond to each attribute contained by the input buffer for attributes 8 through 15.&lt;br /&gt;
For example, having bits 0-3 set to 5 means that, in the vertex shader program, v5 will contain the input buffer&#039;s 9th attribute.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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;
| Enable bit for vertex shader&#039;s o0 output register. (1 = o0 enabled, 0 = o0 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| Enable bit for vertex shader&#039;s o1 output register. (1 = o1 enabled, 0 = o1 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| Enable bit for vertex shader&#039;s o2 output register. (1 = o2 enabled, 0 = o2 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| Enable bit for vertex shader&#039;s o3 output register. (1 = o3 enabled, 0 = o3 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| Enable bit for vertex shader&#039;s o4 output register. (1 = o4 enabled, 0 = o4 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| Enable bit for vertex shader&#039;s o5 output register. (1 = o5 enabled, 0 = o5 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| Enable bit for vertex shader&#039;s o6 output register. (1 = o6 enabled, 0 = o6 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| Enable bit for vertex shader&#039;s o7 output register. (1 = o7 enabled, 0 = o7 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| Enable bit for vertex shader&#039;s o8 output register. (1 = o8 enabled, 0 = o8 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 9&lt;br /&gt;
| Enable bit for vertex shader&#039;s o9 output register. (1 = o9 enabled, 0 = o9 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 10&lt;br /&gt;
| Enable bit for vertex shader&#039;s o10 output register. (1 = o10 enabled, 0 = o10 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Enable bit for vertex shader&#039;s o11 output register. (1 = o11 enabled, 0 = o11 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| Enable bit for vertex shader&#039;s o12 output register. (1 = o12 enabled, 0 = o12 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| Enable bit for vertex shader&#039;s o13 output register. (1 = o13 enabled, 0 = o13 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| Enable bit for vertex shader&#039;s o14 output register. (1 = o14 enabled, 0 = o14 disabled)&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| Enable bit for vertex shader&#039;s o15 output register. (1 = o15 enabled, 0 = o15 disabled)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register toggles the vertex shader units&#039; output registers.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_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&lt;br /&gt;
| Code data transfer end signal bit.&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 vertex shader code. It is unknown whether this register is used for other functions.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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-6&lt;br /&gt;
| Target float vec4 vertex shader uniform ID for transfer. (range 0-95, where 0 = c0 and 95 = c95)&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Float vec4 vertex shader uniform data transfer mode. (0 = float24, 1 = float32)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register sets the target float vec4 vertex shader uniform ID and transfer mode for the data transfer system. As such it is typically used right before [[#GPUREG_VSH_FLOATUNIFORM_DATA|GPUREG_VSH_FLOATUNIFORM_DATA]], though writing to one register does not make writing to the other mandatory.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_FLOATUNIFORM_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;
| Float vec4 vertex shader uniform data. (format depends on transfer mode, see below for details)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the value of float vec4 vertex shader uniform registers. The data format which should be written to it depends on the transfer mode set with [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]]. This register functions as a FIFO queue : after each time a uniform register is successfully set, the target uniform ID value is incremented, meaning that groups of uniforms with contiguous register IDs can be set with only one initial write to [[#GPUREG_VSH_FLOATUNIFORM_CONFIG|GPUREG_VSH_FLOATUNIFORM_CONFIG]].&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_VSH_CODETRANSFER_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-11&lt;br /&gt;
| Target vertex shader code offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader code data transferred through [[#GPUREG_VSH_CODETRANSFER_DATA|GPUREG_VSH_CODETRANSFER_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
NOTE : as we do not yet know what a shader program&#039;s maximum size is yet, we also do not know how many bits the code offset parameter holds. The biggest shader binary observed so far was 2422 instructions long. The [[Shader_Instruction_Set#Instruction_formats|shader control flow instructions]] only have room to address 12 bits though, so it&#039;s likely that the maximum is 4095.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_CODETRANSFER_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;
| Vertex shader instruction data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader code data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader code memory bank at the offset initially set by [[#GPUREG_VSH_CODETRANSFER_CONFIG|GPUREG_VSH_CODETRANSFER_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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-6&lt;br /&gt;
| Target vertex shader operand descriptor offset for data transfer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to set the offset at which upcoming vertex shader operand descriptor data transferred through [[#GPUREG_VSH_OPDESCS_DATA|GPUREG_VSH_OPDESCS_DATA]] should be written.&lt;br /&gt;
&lt;br /&gt;
=== GPUREG_VSH_OPDESCS_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;
| Vertex shader operand descriptor data.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This register is used to transfer vertex shader operand descriptor data. This register behaves as a FIFO queue : each write to this register writes the provided value to the GPU vertex shader operand descriptor memory bank at the offset initially set by [[#GPUREG_VSH_OPDESCS_CONFIG|GPUREG_VSH_OPDESCS_CONFIG]]. The offset in question is incremented after each write to this register.&lt;br /&gt;
&lt;br /&gt;
[[Category:GPU]]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Libraries_and_Tools&amp;diff=13196</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=13196"/>
		<updated>2015-09-05T07:46:57Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Update picasso download link&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;
&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;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Homebrew_Exploits&amp;diff=13156</id>
		<title>Homebrew Exploits</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Homebrew_Exploits&amp;diff=13156"/>
		<updated>2015-08-25T21:01:52Z</updated>

		<summary type="html">&lt;p&gt;Fincs: No kernel exploit was ever used ninjhax 1.x&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Self-Exploitable==&lt;br /&gt;
The following homebrew exploits can be executed on a previously un-exploited system.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!  Name&lt;br /&gt;
!  Supported firmwares&lt;br /&gt;
!  Requirements&lt;br /&gt;
!  Author&lt;br /&gt;
!  Install&lt;br /&gt;
|-&lt;br /&gt;
| [[ninjhax]] (1.1b)&lt;br /&gt;
| From &#039;&#039;&#039;4.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;9.2.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; is between 7 and 20. &lt;br /&gt;
| A cartridge or eShop version (JPN-only) of &amp;quot;Cubic Ninja&amp;quot;.&lt;br /&gt;
| smea&lt;br /&gt;
| [http://smealum.net/ninjhax/ Install]&lt;br /&gt;
|-&lt;br /&gt;
| [[ninjhax2.1]]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;9.9.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 26. &lt;br /&gt;
| A copy of &amp;quot;Cubic Ninja&amp;quot; (cartridge or eShop version).&lt;br /&gt;
| smea&lt;br /&gt;
| [http://smealum.github.io/ninjhax2/ Install]&lt;br /&gt;
|-&lt;br /&gt;
| [[tubehax]]&lt;br /&gt;
| From &#039;&#039;&#039;9.0.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;9.9.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 26.&lt;br /&gt;
| The YouTube application and an internet connection.&lt;br /&gt;
| smea&lt;br /&gt;
| [http://smealum.github.io/3ds/ Install]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Note that ninjhax 1.x is still not obsolete. Even though ninjhax 2.x can be run on 9.3+, this was made possible (amongst other things) by sacrificing the memory remapping exploit used in ninjhax 1.x (rohax). Therefore, things like JIT engines for emulators can only be supported on ninjhax 1.x.&lt;br /&gt;
&lt;br /&gt;
==Secondary Exploits==&lt;br /&gt;
Installation of these exploits requires a previously exploited system.&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Name&lt;br /&gt;
!  Supported firmwares&lt;br /&gt;
!  Requirements&lt;br /&gt;
!  Author&lt;br /&gt;
!  Install&lt;br /&gt;
|-&lt;br /&gt;
| [[ironhax]]&lt;br /&gt;
| From &#039;&#039;&#039;9.5.0-X&#039;&#039;&#039; up to and including &#039;&#039;&#039;9.9.0-X&#039;&#039;&#039;, for &#039;&#039;&#039;X&#039;&#039;&#039; up to and including 26.&lt;br /&gt;
| A copy of &amp;quot;Ironfall: Invasion&amp;quot; (not available on eShop as of August 11th, 2015) and a self-exploitable title.&lt;br /&gt;
| smea&lt;br /&gt;
| [http://smealum.github.io/3ds/ Install]&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Ironhax&amp;diff=13150</id>
		<title>Ironhax</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Ironhax&amp;diff=13150"/>
		<updated>2015-08-24T11:58:53Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Proofread&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Ironhax is an exploit in the USA/EUR eShop game &amp;quot;IronFall: Invasion&amp;quot; that allows people to load 3DS homebrew on system versions 9.5-9.9. &amp;quot;IronFall: Invasion&amp;quot; is not available for download anymore as it was removed from Nintendo eShop as of August 11th, 2015, so a previously downloaded copy is necessary in order to use the exploit. Unlike other exploits this is a secondary exploit, meaning in order to install it the use of another exploit with the Homebrew Launcher is required. The Ironhax installer requires internet, afterwards the installed exploit will work without internet.&lt;br /&gt;
&lt;br /&gt;
Download Ironhax Installer: [http://smealum.github.io/ninjhax2/installer.zip Ironhax Installer]&lt;br /&gt;
&lt;br /&gt;
Setup instructions available here: [http://smealum.github.io/3ds/ 3DS homebrew official site] (scroll down to the IronFall section down the page).&lt;br /&gt;
&lt;br /&gt;
Like other exploits, Ironhax will launch boot.3dsx from the root of the SD card so make sure you have the Homebrew Launcher which is included with the 3DS homebrew starter kit which is available here: [https://smealum.github.io/ninjhax2/starter.zip 3DS homebrew starter kit]&lt;br /&gt;
&lt;br /&gt;
Sometimes the 3DS might get stuck at a blue screen or a white screen (bottom touch screen) and if this happens force shut your 3DS down by holding the power button until the blue light turns off and then try the whole exploit again.&lt;br /&gt;
&lt;br /&gt;
Also keep in mind that Ironhax is a Userland exploit, meaning that it has only ARM11 access and doesn&#039;t have kernel. This means we can&#039;t modify the system but that doesn&#039;t mean we can&#039;t do some awesome homebrew! Regionfree, emulators, custom homemenu themes, playcoin hacks, etc. are all available!&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
	<entry>
		<id>https://www.3dbrew.org/w/index.php?title=Setting_up_Development_Environment&amp;diff=13129</id>
		<title>Setting up Development Environment</title>
		<link rel="alternate" type="text/html" href="https://www.3dbrew.org/w/index.php?title=Setting_up_Development_Environment&amp;diff=13129"/>
		<updated>2015-08-23T11:27:38Z</updated>

		<summary type="html">&lt;p&gt;Fincs: Replace &amp;quot;Optional Tools and Libraries&amp;quot; section with a link to &amp;quot;Homebrew Libraries and Tools&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= Setup =&lt;br /&gt;
* Install [http://devkitpro.org/ devkitARM]. If it&#039;s already installed, update it. On Windows there&#039;s a GUI installer. On Linux/Mac there&#039;s a perl-script. Make sure you also select ctrulib when installing.&lt;br /&gt;
* Download the files in the [https://github.com/smealum/ctrulib/archive/master.zip ctrulib repository] (even though the library has already been installed) because the repository contains a 3DS project template and examples.&lt;br /&gt;
* Depending on the kind of homebrew you want to develop, you may be interested in installing and using additional libraries and tools which don&#039;t ship alongside devkitARM/libctru. A list of them can be found in [[Homebrew Libraries and Tools]].&lt;br /&gt;
&lt;br /&gt;
==Linux==&lt;br /&gt;
* First get the devkitARM updater Perl script for Linux.&lt;br /&gt;
* Run it with superuser privileges if your /opt directory is not marked world read-writeable.&lt;br /&gt;
* Get ctrulib from Smealum&#039;s GitHub repository, build and install it.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;sudo apt-get install git curl&lt;br /&gt;
curl -L http://sourceforge.net/projects/devkitpro/files/Automated%20Installer/devkitARMupdate.pl/download -o devkitARMupdate.pl&lt;br /&gt;
chmod +x ./devkitARMupdate.pl&lt;br /&gt;
sudo -s&lt;br /&gt;
./devkitARMupdate.pl /opt/devkitpro&lt;br /&gt;
cd /opt/devkitpro&lt;br /&gt;
git clone https://github.com/smealum/ctrulib.git&lt;br /&gt;
cd ctrulib/libctru&lt;br /&gt;
export DEVKITPRO=/opt/devkitpro&lt;br /&gt;
export DEVKITARM=$DEVKITPRO/devkitARM&lt;br /&gt;
make&lt;br /&gt;
make install&lt;br /&gt;
exit&lt;br /&gt;
echo &amp;quot;export DEVKITPRO=/opt/devkitpro&amp;quot; &amp;gt;&amp;gt; ~/.bashrc&lt;br /&gt;
echo &amp;quot;export DEVKITARM=\$DEVKITPRO/devkitARM&amp;quot; &amp;gt;&amp;gt; ~/.bashrc&lt;br /&gt;
echo &amp;quot;export PATH=\$PATH:\$DEVKITARM/bin&amp;quot; &amp;gt;&amp;gt; ~/.bashrc&lt;br /&gt;
source ~/.bashrc&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
= Building the examples =&lt;br /&gt;
3DS examples are still being created. Currently there are a few examples in the separate ctrulib download under the &amp;quot;examples&amp;quot; folder.&lt;br /&gt;
&lt;br /&gt;
* &#039;&#039;&#039;arm11u:&#039;&#039;&#039; simple homebrew example&lt;br /&gt;
* &#039;&#039;&#039;sdmc:&#039;&#039;&#039; demonstrates how to access files on the SD card&lt;br /&gt;
* &#039;&#039;&#039;mic:&#039;&#039;&#039; demonstrates how to read sound from the microphone&lt;br /&gt;
* &#039;&#039;&#039;gpu:&#039;&#039;&#039; demonstrates how to render 3D geometry with the GPU&lt;br /&gt;
&lt;br /&gt;
==Building the examples on Linux with Netbeans==&lt;br /&gt;
* Go to File-&amp;gt;New Project...&lt;br /&gt;
* Select C/C++ Project with existing code&lt;br /&gt;
* Navigate to the examples directory and select the folder for the project you want to build; eg.    /home/vtsingaras/3ds/examples/app_launch&lt;br /&gt;
* Leave Configuration Mode to &#039;Automatic&#039; and click &#039;Finish&#039;.&lt;br /&gt;
* It will fail to build. Now edit Makefile and insert these two lines, adjusting for your devkitpro path, at the top:&lt;br /&gt;
&amp;lt;pre&amp;gt;export DEVKITPRO=/opt/devkitpro&lt;br /&gt;
export DEVKITARM=/opt/devkitpro/devkitARM&amp;lt;/pre&amp;gt;&lt;br /&gt;
* Right-click the project and go to Properties-&amp;gt;Code Assistance and click C Compiler.&lt;br /&gt;
* In include directories enter &lt;br /&gt;
&amp;lt;pre&amp;gt;/opt/devkitpro/devkitARM/include;/opt/devkitpro/ctrulib/libctru/include&amp;lt;/pre&amp;gt;&lt;br /&gt;
adjusting again for your devkitPro path.&lt;br /&gt;
* Do the same for &#039;C++ Compiler&#039;.&lt;br /&gt;
* Go to &#039;Run&#039; and click &#039;Clean and Build Project&#039;.&lt;br /&gt;
* Now right-click on the project and select Code Assistance-&amp;gt;Reparse Project.&lt;br /&gt;
&lt;br /&gt;
Now you can use Netbeans&#039; code completion feature and build your project from the Run menu.&lt;br /&gt;
&lt;br /&gt;
= Building homebrew for distribution =&lt;br /&gt;
To build your homebrew open a terminal, browse to your homebrew&#039;s folder and run make.&lt;br /&gt;
&lt;br /&gt;
* This will build a .elf file and a .3dsx file together with an icon. The icon and .3dsx file are the format required for the [[Homebrew Channel]].&lt;br /&gt;
&lt;br /&gt;
* To build a Gateway-compatible .3ds file you need to strip the .elf file and use makerom on it (with the provided RSF file):&lt;br /&gt;
 arm-none-eabi-strip [ELF file]&lt;br /&gt;
 makerom -f cci -o [.3ds file] -rsf [RSF file] -target d -exefslogo -elf [ELF file] -icon [icon file] -banner [banner file]&lt;/div&gt;</summary>
		<author><name>Fincs</name></author>
	</entry>
</feed>