summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBen Skeggs <bskeggs@redhat.com>2012-03-29 15:28:03 +1000
committerBen Skeggs <bskeggs@redhat.com>2012-04-14 02:07:56 +1000
commit007dd62a8c5244bc5e71fe8f32520fb35b67a237 (patch)
treee4015b291f5f6fdb0ab226d721be52f32e936f63 /src
parent1c7651532975cf738b3aac4ec3c3b46187e24eea (diff)
nvc0: punt shaders out to a header file
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'src')
-rw-r--r--src/nvc0_accel.c369
-rw-r--r--src/nvc0_shader.h389
2 files changed, 398 insertions, 360 deletions
diff --git a/src/nvc0_accel.c b/src/nvc0_accel.c
index 31e2507..cbd6377 100644
--- a/src/nvc0_accel.c
+++ b/src/nvc0_accel.c
@@ -22,6 +22,7 @@
#include "nv_include.h"
#include "nvc0_accel.h"
+#include "nvc0_shader.h"
Bool
NVAccelInitM2MF_NVC0(ScrnInfoPtr pScrn)
@@ -205,41 +206,7 @@ NVAccelInit3D_NVC0(ScrnInfoPtr pScrn)
PUSH_DATA (push, (bo->offset + CODE_OFFSET) >> 32);
PUSH_DATA (push, (bo->offset + CODE_OFFSET));
- PUSH_DATAu(push, bo, PVP_PASS, 20 + 7 * 2);
- PUSH_DATA (push, 0x00020461);
- PUSH_DATA (push, 0);
- PUSH_DATA (push, 0);
- PUSH_DATA (push, 0);
- PUSH_DATA (push, 0xff000);
- PUSH_DATA (push, 0x00000000); /* VP_ATTR_EN[0x000] */
- PUSH_DATA (push, 0x0001033f); /* VP_ATTR_EN[0x080] */
- PUSH_DATA (push, 0x00000000); /* VP_ATTR_EN[0x100] */
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000); /* VP_ATTR_EN[0x200] */
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000); /* VP_ATTR_EN[0x300] */
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x0033f000); /* VP_EXPORT_EN[0x040] */
- PUSH_DATA (push, 0x00000000); /* VP_EXPORT_EN[0x0c0] */
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000); /* VP_EXPORT_EN[0x2c0] */
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0xfff01c66);
- PUSH_DATA (push, 0x06000080); /* vfetch { $r0,1,2,3 } b128 a[0x80] */
- PUSH_DATA (push, 0xfff11c26);
- PUSH_DATA (push, 0x06000090); /* vfetch { $r4,5 } b64 a[0x90] */
- PUSH_DATA (push, 0xfff19c26);
- PUSH_DATA (push, 0x060000a0); /* vfetch { $r6,7 } b64 a[0xa0] */
- PUSH_DATA (push, 0x03f01c66);
- PUSH_DATA (push, 0x0a7e0070); /* export v[0x70] { $r0 $r1 $r2 $r3 } */
- PUSH_DATA (push, 0x13f01c26);
- PUSH_DATA (push, 0x0a7e0080); /* export v[0x80] { $r4 $r5 } */
- PUSH_DATA (push, 0x1bf01c26);
- PUSH_DATA (push, 0x0a7e0090); /* export v[0x90] { $r6 $r7 } */
- PUSH_DATA (push, 0x00001de7);
- PUSH_DATA (push, 0x80000000); /* exit */
+ NVC0PushProgram(pNv, PVP_PASS, NVC0VP_Passthrough);
BEGIN_NVC0(push, NVC0_3D(SP_SELECT(1)), 2);
PUSH_DATA (push, 0x11);
@@ -251,331 +218,13 @@ NVAccelInit3D_NVC0(ScrnInfoPtr pScrn)
BEGIN_NVC0(push, SUBC_3D(0x2600), 1);
PUSH_DATA (push, 1);
- PUSH_DATAu(push, bo, PFP_S, 20 + 6 * 2);
- PUSH_DATA (push, 0x00021462);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x80000000);
- PUSH_DATA (push, 0x0000000a);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x0000000f);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0xfff01c00);
- PUSH_DATA (push, 0xc07e007c); /* linterp f32 $r0 v[$r63+0x7c] */
- PUSH_DATA (push, 0x10001c00);
- PUSH_DATA (push, 0xc8000000); /* rcp f32 $r0 $r0 */
- PUSH_DATA (push, 0x03f05c40);
- PUSH_DATA (push, 0xc07e0084); /* pinterp f32 $r1 $r0 v[$r63+0x84] */
- PUSH_DATA (push, 0x03f01c40);
- PUSH_DATA (push, 0xc07e0080); /* pinterp f32 $r0 $r0 v[$r63+0x80] */
- PUSH_DATA (push, 0xfc001e86);
- PUSH_DATA (push, 0x8013c000); /* tex { $r0,1,2,3 } $t0 { $r0,1 } */
- PUSH_DATA (push, 0x00001de7);
- PUSH_DATA (push, 0x80000000); /* exit */
-
- PUSH_DATAu(push, bo, PFP_C, 20 + 13 * 2);
- PUSH_DATA (push, 0x00021462);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x80000000);
- PUSH_DATA (push, 0x00000a0a);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x0000000f);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0xfff01c00);
- PUSH_DATA (push, 0xc07e007c); /* linterp f32 $r0 v[$r63+0x7c] */
- PUSH_DATA (push, 0x10001c00);
- PUSH_DATA (push, 0xc8000000); /* rcp f32 $r0 $r0 */
- PUSH_DATA (push, 0x03f0dc40);
- PUSH_DATA (push, 0xc07e0094); /* pinterp f32 $r3 $r0 v[$r63+0x94] */
- PUSH_DATA (push, 0x03f09c40);
- PUSH_DATA (push, 0xc07e0090); /* pinterp f32 $r2 $r0 v[$r63+0x90] */
- PUSH_DATA (push, 0xfc211e86);
- PUSH_DATA (push, 0x80120001); /* tex { _,_,_,$r4 } $t1 { $r2,3 } */
- PUSH_DATA (push, 0x03f05c40);
- PUSH_DATA (push, 0xc07e0084); /* pinterp f32 $r1 $r0 v[$r63+0x84] */
- PUSH_DATA (push, 0x03f01c40);
- PUSH_DATA (push, 0xc07e0080); /* pinterp f32 $r0 $r0 v[$r63+0x80] */
- PUSH_DATA (push, 0xfc001e86);
- PUSH_DATA (push, 0x8013c000); /* tex { $r0,1,2,3 } $t0 { $r0,1 } */
- PUSH_DATA (push, 0x1030dc40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r3 $r3 $r4 */
- PUSH_DATA (push, 0x10209c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r2 $r2 $r4 */
- PUSH_DATA (push, 0x10105c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r1 $r1 $r4 */
- PUSH_DATA (push, 0x10001c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r0 $r0 $r4 */
- PUSH_DATA (push, 0x00001de7);
- PUSH_DATA (push, 0x80000000); /* exit */
-
- PUSH_DATAu(push, bo, PFP_CCA, 20 + 13 * 2);
- PUSH_DATA (push, 0x00021462); /* 0x0000c000 = USES_KIL, MULTI_COLORS */
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x80000000); /* FRAG_COORD_UMASK = 0x8 */
- PUSH_DATA (push, 0x00000a0a); /* FP_INTERP[0x080], 0022 0022 */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x0c0], 0 = OFF */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x100], 1 = FLAT */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x140], 2 = PERSPECTIVE */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x180], 3 = LINEAR */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x1c0] */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x200] */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x240] */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x280] */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x2c0] */
- PUSH_DATA (push, 0x00000000); /* FP_INTERP[0x300] */
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x0000000f); /* FP_RESULT_MASK (0x8000 Face ?) */
- PUSH_DATA (push, 0x00000000); /* 0x2 = FragDepth, 0x1 = SampleMask */
- PUSH_DATA (push, 0xfff01c00);
- PUSH_DATA (push, 0xc07e007c); /* linterp f32 $r0 v[$r63+0x7c] */
- PUSH_DATA (push, 0x10001c00);
- PUSH_DATA (push, 0xc8000000); /* rcp f32 $r0 $r0 */
- PUSH_DATA (push, 0x03f0dc40);
- PUSH_DATA (push, 0xc07e0094); /* pinterp f32 $r3 $r0 v[$r63+0x94] */
- PUSH_DATA (push, 0x03f09c40);
- PUSH_DATA (push, 0xc07e0090); /* pinterp f32 $r2 $r0 v[$r63+0x90] */
- PUSH_DATA (push, 0xfc211e86);
- PUSH_DATA (push, 0x8013c001); /* tex { $r4,5,6,7 } $t1 { $r2,3 } */
- PUSH_DATA (push, 0x03f05c40);
- PUSH_DATA (push, 0xc07e0084); /* pinterp f32 $r1 $r0 v[$r63+0x84] */
- PUSH_DATA (push, 0x03f01c40);
- PUSH_DATA (push, 0xc07e0080); /* pinterp f32 $r0 $r0 v[$r63+0x80] */
- PUSH_DATA (push, 0xfc001e86);
- PUSH_DATA (push, 0x8013c000); /* tex { $r0,1,2,3 } $t0 { $r0,1 } */
- PUSH_DATA (push, 0x1c30dc40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r3 $r3 $r7 */
- PUSH_DATA (push, 0x18209c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r2 $r2 $r6 */
- PUSH_DATA (push, 0x14105c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r1 $r1 $r5 */
- PUSH_DATA (push, 0x10001c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r0 $r0 $r4 */
- PUSH_DATA (push, 0x00001de7);
- PUSH_DATA (push, 0x80000000); /* exit */
-
- PUSH_DATAu(push, bo, PFP_CCASA, 20 + 13 * 2);
- PUSH_DATA (push, 0x00021462);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x80000000);
- PUSH_DATA (push, 0x00000a0a);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x0000000f);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0xfff01c00);
- PUSH_DATA (push, 0xc07e007c); /* linterp f32 $r0 v[$r63+0x7c] */
- PUSH_DATA (push, 0x10001c00);
- PUSH_DATA (push, 0xc8000000); /* rcp f32 $r0 $r0 */
- PUSH_DATA (push, 0x03f0dc40);
- PUSH_DATA (push, 0xc07e0084); /* pinterp f32 $r3 $r0 v[$r63+0x84] */
- PUSH_DATA (push, 0x03f09c40);
- PUSH_DATA (push, 0xc07e0080); /* pinterp f32 $r2 $r0 v[$r63+0x80] */
- PUSH_DATA (push, 0xfc211e86);
- PUSH_DATA (push, 0x80120000); /* tex { _,_,_,$r4 } $t0 { $r2,3 } */
- PUSH_DATA (push, 0x03f05c40);
- PUSH_DATA (push, 0xc07e0094); /* pinterp f32 $r1 $r0 v[$r63+0x94] */
- PUSH_DATA (push, 0x03f01c40);
- PUSH_DATA (push, 0xc07e0090); /* pinterp f32 $r0 $r0 v[$r63+0x90] */
- PUSH_DATA (push, 0xfc001e86);
- PUSH_DATA (push, 0x8013c001); /* tex { $r0,1,2,3 } $t1 { $r0,1 } */
- PUSH_DATA (push, 0x1030dc40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r3 $r3 $r4 */
- PUSH_DATA (push, 0x10209c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r2 $r2 $r4 */
- PUSH_DATA (push, 0x10105c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r1 $r1 $r4 */
- PUSH_DATA (push, 0x10001c40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r0 $r0 $r4 */
- PUSH_DATA (push, 0x00001de7);
- PUSH_DATA (push, 0x80000000); /* exit */
-
- PUSH_DATAu(push, bo, PFP_S_A8, 20 + 9 * 2);
- PUSH_DATA (push, 0x00021462);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x80000000);
- PUSH_DATA (push, 0x0000000a);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x0000000f);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0xfff01c00);
- PUSH_DATA (push, 0xc07e007c); /* linterp f32 $r0 v[$r63+0x7c] */
- PUSH_DATA (push, 0x10001c00);
- PUSH_DATA (push, 0xc8000000); /* rcp f32 $r0 $r0 */
- PUSH_DATA (push, 0x03f05c40);
- PUSH_DATA (push, 0xc07e0084); /* pinterp f32 $r1 $r0 v[$r63+0x84] */
- PUSH_DATA (push, 0x03f01c40);
- PUSH_DATA (push, 0xc07e0080); /* pinterp f32 $r0 $r0 v[$r63+0x80] */
- PUSH_DATA (push, 0xfc001e86);
- PUSH_DATA (push, 0x80120000); /* tex { _ _ _ $r0 } $t0 { $r0 $r1 } */
- PUSH_DATA (push, 0x0000dde4);
- PUSH_DATA (push, 0x28000000); /* mov b32 $r3 $r0 */
- PUSH_DATA (push, 0x00009de4);
- PUSH_DATA (push, 0x28000000); /* mov b32 $r2 $r0 */
- PUSH_DATA (push, 0x00005de4);
- PUSH_DATA (push, 0x28000000); /* mov b32 $r1 $r0 */
- PUSH_DATA (push, 0x00001de7);
- PUSH_DATA (push, 0x80000000); /* exit */
-
- PUSH_DATAu(push, bo, PFP_C_A8, 20 + 13 * 2);
- PUSH_DATA (push, 0x00021462);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x80000000);
- PUSH_DATA (push, 0x00000a0a);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x0000000f);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0xfff01c00);
- PUSH_DATA (push, 0xc07e007c); /* linterp f32 $r0 v[$r63+0x7c] */
- PUSH_DATA (push, 0x10001c00);
- PUSH_DATA (push, 0xc8000000); /* rcp f32 $r0 $r0 */
- PUSH_DATA (push, 0x03f0dc40);
- PUSH_DATA (push, 0xc07e0094); /* pinterp f32 $r3 $r0 v[$r63+0x94] */
- PUSH_DATA (push, 0x03f09c40);
- PUSH_DATA (push, 0xc07e0090); /* pinterp f32 $r2 $r0 v[$r63+0x90] */
- PUSH_DATA (push, 0xfc205e86);
- PUSH_DATA (push, 0x80120001); /* tex { _ _ _ $r1 } $t1 { $r2 $r3 } */
- PUSH_DATA (push, 0x03f0dc40);
- PUSH_DATA (push, 0xc07e0084); /* pinterp f32 $r3 $r0 v[$r63+0x84] */
- PUSH_DATA (push, 0x03f09c40);
- PUSH_DATA (push, 0xc07e0080); /* pinterp f32 $r2 $r0 v[$r63+0x80] */
- PUSH_DATA (push, 0xfc201e86);
- PUSH_DATA (push, 0x80120000); /* tex { _ _ _ $r0 } $t0 { $r2 $r3 } */
- PUSH_DATA (push, 0x0400dc40);
- PUSH_DATA (push, 0x58000000); /* mul ftz rn f32 $r3 $r0 $r1 */
- PUSH_DATA (push, 0x0c009de4);
- PUSH_DATA (push, 0x28000000); /* mov b32 $r2 $r3 */
- PUSH_DATA (push, 0x0c005de4);
- PUSH_DATA (push, 0x28000000); /* mov b32 $r1 $r3 */
- PUSH_DATA (push, 0x0c001de4);
- PUSH_DATA (push, 0x28000000); /* mov b32 $r0 $r3 */
- PUSH_DATA (push, 0x00001de7);
- PUSH_DATA (push, 0x80000000); /* exit */
-
- PUSH_DATAu(push, bo, PFP_NV12, 20 + 19 * 2);
- PUSH_DATA (push, 0x00021462);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x80000000);
- PUSH_DATA (push, 0x00000a0a);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0x0000000f);
- PUSH_DATA (push, 0x00000000);
- PUSH_DATA (push, 0xfff09c00);
- PUSH_DATA (push, 0xc07e007c);
- PUSH_DATA (push, 0x10209c00);
- PUSH_DATA (push, 0xc8000000);
- PUSH_DATA (push, 0x0bf01c40);
- PUSH_DATA (push, 0xc07e0080);
- PUSH_DATA (push, 0x0bf05c40);
- PUSH_DATA (push, 0xc07e0084);
- PUSH_DATA (push, 0xfc001e86);
- PUSH_DATA (push, 0x80120000);
- PUSH_DATA (push, 0x00015c40);
- PUSH_DATA (push, 0x58004000);
- PUSH_DATA (push, 0x1050dc20);
- PUSH_DATA (push, 0x50004000);
- PUSH_DATA (push, 0x20511c20);
- PUSH_DATA (push, 0x50004000);
- PUSH_DATA (push, 0x30515c20);
- PUSH_DATA (push, 0x50004000);
- PUSH_DATA (push, 0x0bf01c40);
- PUSH_DATA (push, 0xc07e0090);
- PUSH_DATA (push, 0x0bf05c40);
- PUSH_DATA (push, 0xc07e0094);
- PUSH_DATA (push, 0xfc001e86);
- PUSH_DATA (push, 0x80130001);
- PUSH_DATA (push, 0x4000dc40);
- PUSH_DATA (push, 0x30064000);
- PUSH_DATA (push, 0x50011c40);
- PUSH_DATA (push, 0x30084000);
- PUSH_DATA (push, 0x60015c40);
- PUSH_DATA (push, 0x300a4000);
- PUSH_DATA (push, 0x70101c40);
- PUSH_DATA (push, 0x30064000);
- PUSH_DATA (push, 0x90109c40);
- PUSH_DATA (push, 0x300a4000);
- PUSH_DATA (push, 0x80105c40);
- PUSH_DATA (push, 0x30084000);
- PUSH_DATA (push, 0x00001de7);
- PUSH_DATA (push, 0x80000000);
+ NVC0PushProgram(pNv, PFP_S, NVC0FP_Source);
+ NVC0PushProgram(pNv, PFP_C, NVC0FP_Composite);
+ NVC0PushProgram(pNv, PFP_CCA, NVC0FP_CAComposite);
+ NVC0PushProgram(pNv, PFP_CCASA, NVC0FP_CACompositeSrcAlpha);
+ NVC0PushProgram(pNv, PFP_S_A8, NVC0FP_Source_A8);
+ NVC0PushProgram(pNv, PFP_C_A8, NVC0FP_Composite_A8);
+ NVC0PushProgram(pNv, PFP_NV12, NVC0FP_NV12);
BEGIN_NVC0(push, SUBC_3D(0x021c), 1); /* CODE_FLUSH ? */
PUSH_DATA (push, 0x1111);
diff --git a/src/nvc0_shader.h b/src/nvc0_shader.h
new file mode 100644
index 0000000..f97b74b
--- /dev/null
+++ b/src/nvc0_shader.h
@@ -0,0 +1,389 @@
+#ifndef __NVC0_SHADER_H__
+#define __NVC0_SHADER_H__
+
+#define NVC0PushProgram(pNv,addr,code) do { \
+ const unsigned size = sizeof(code) / sizeof(code[0]); \
+ PUSH_DATAu((pNv)->pushbuf, (pNv)->tesla_scratch, (addr), size); \
+ PUSH_DATAp((pNv)->pushbuf, (code), size); \
+ ErrorF("20 + %d * 2\n", (size - 20) / 2); \
+} while(0)
+
+static uint32_t
+NVC0VP_Passthrough[] = {
+ 0x00020461,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x000ff000,
+ 0x00000000, /* VP_ATTR_EN[0x000] */
+ 0x0001033f, /* VP_ATTR_EN[0x080] */
+ 0x00000000, /* VP_ATTR_EN[0x100] */
+ 0x00000000,
+ 0x00000000, /* VP_ATTR_EN[0x200] */
+ 0x00000000,
+ 0x00000000, /* VP_ATTR_EN[0x300] */
+ 0x00000000,
+ 0x0033f000, /* VP_EXPORT_EN[0x040] */
+ 0x00000000, /* VP_EXPORT_EN[0x0c0] */
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000, /* VP_EXPORT_EN[0x2c0] */
+ 0x00000000,
+ 0xfff01c66,
+ 0x06000080, /* vfetch { $r0,1,2,3 } b128 a[0x80] */
+ 0xfff11c26,
+ 0x06000090, /* vfetch { $r4,5 } b64 a[0x90] */
+ 0xfff19c26,
+ 0x060000a0, /* vfetch { $r6,7 } b64 a[0xa0] */
+ 0x03f01c66,
+ 0x0a7e0070, /* export v[0x70] { $r0 $r1 $r2 $r3 } */
+ 0x13f01c26,
+ 0x0a7e0080, /* export v[0x80] { $r4 $r5 } */
+ 0x1bf01c26,
+ 0x0a7e0090, /* export v[0x90] { $r6 $r7 } */
+ 0x00001de7,
+ 0x80000000, /* exit */
+};
+
+static uint32_t
+NVC0FP_Source[] = {
+ 0x00021462,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x80000000,
+ 0x0000000a,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x0000000f,
+ 0x00000000,
+ 0xfff01c00,
+ 0xc07e007c, /* linterp f32 $r0 v[$r63+0x7c] */
+ 0x10001c00,
+ 0xc8000000, /* rcp f32 $r0 $r0 */
+ 0x03f05c40,
+ 0xc07e0084, /* pinterp f32 $r1 $r0 v[$r63+0x84] */
+ 0x03f01c40,
+ 0xc07e0080, /* pinterp f32 $r0 $r0 v[$r63+0x80] */
+ 0xfc001e86,
+ 0x8013c000, /* tex { $r0,1,2,3 } $t0 { $r0,1 } */
+ 0x00001de7,
+ 0x80000000, /* exit */
+};
+
+static uint32_t
+NVC0FP_Composite[] = {
+ 0x00021462,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x80000000,
+ 0x00000a0a,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x0000000f,
+ 0x00000000,
+ 0xfff01c00,
+ 0xc07e007c, /* linterp f32 $r0 v[$r63+0x7c] */
+ 0x10001c00,
+ 0xc8000000, /* rcp f32 $r0 $r0 */
+ 0x03f0dc40,
+ 0xc07e0094, /* pinterp f32 $r3 $r0 v[$r63+0x94] */
+ 0x03f09c40,
+ 0xc07e0090, /* pinterp f32 $r2 $r0 v[$r63+0x90] */
+ 0xfc211e86,
+ 0x80120001, /* tex { _,_,_,$r4 } $t1 { $r2,3 } */
+ 0x03f05c40,
+ 0xc07e0084, /* pinterp f32 $r1 $r0 v[$r63+0x84] */
+ 0x03f01c40,
+ 0xc07e0080, /* pinterp f32 $r0 $r0 v[$r63+0x80] */
+ 0xfc001e86,
+ 0x8013c000, /* tex { $r0,1,2,3 } $t0 { $r0,1 } */
+ 0x1030dc40,
+ 0x58000000, /* mul ftz rn f32 $r3 $r3 $r4 */
+ 0x10209c40,
+ 0x58000000, /* mul ftz rn f32 $r2 $r2 $r4 */
+ 0x10105c40,
+ 0x58000000, /* mul ftz rn f32 $r1 $r1 $r4 */
+ 0x10001c40,
+ 0x58000000, /* mul ftz rn f32 $r0 $r0 $r4 */
+ 0x00001de7,
+ 0x80000000, /* exit */
+};
+
+static uint32_t
+NVC0FP_CAComposite[] = {
+ 0x00021462, /* 0x0000c000 = USES_KIL, MULTI_COLORS */
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x80000000, /* FRAG_COORD_UMASK = 0x8 */
+ 0x00000a0a, /* FP_INTERP[0x080], 0022 0022 */
+ 0x00000000, /* FP_INTERP[0x0c0], 0 = OFF */
+ 0x00000000, /* FP_INTERP[0x100], 1 = FLAT */
+ 0x00000000, /* FP_INTERP[0x140], 2 = PERSPECTIVE */
+ 0x00000000, /* FP_INTERP[0x180], 3 = LINEAR */
+ 0x00000000, /* FP_INTERP[0x1c0] */
+ 0x00000000, /* FP_INTERP[0x200] */
+ 0x00000000, /* FP_INTERP[0x240] */
+ 0x00000000, /* FP_INTERP[0x280] */
+ 0x00000000, /* FP_INTERP[0x2c0] */
+ 0x00000000, /* FP_INTERP[0x300] */
+ 0x00000000,
+ 0x0000000f, /* FP_RESULT_MASK (0x8000 Face ?) */
+ 0x00000000, /* 0x2 = FragDepth, 0x1 = SampleMask */
+ 0xfff01c00,
+ 0xc07e007c, /* linterp f32 $r0 v[$r63+0x7c] */
+ 0x10001c00,
+ 0xc8000000, /* rcp f32 $r0 $r0 */
+ 0x03f0dc40,
+ 0xc07e0094, /* pinterp f32 $r3 $r0 v[$r63+0x94] */
+ 0x03f09c40,
+ 0xc07e0090, /* pinterp f32 $r2 $r0 v[$r63+0x90] */
+ 0xfc211e86,
+ 0x8013c001, /* tex { $r4,5,6,7 } $t1 { $r2,3 } */
+ 0x03f05c40,
+ 0xc07e0084, /* pinterp f32 $r1 $r0 v[$r63+0x84] */
+ 0x03f01c40,
+ 0xc07e0080, /* pinterp f32 $r0 $r0 v[$r63+0x80] */
+ 0xfc001e86,
+ 0x8013c000, /* tex { $r0,1,2,3 } $t0 { $r0,1 } */
+ 0x1c30dc40,
+ 0x58000000, /* mul ftz rn f32 $r3 $r3 $r7 */
+ 0x18209c40,
+ 0x58000000, /* mul ftz rn f32 $r2 $r2 $r6 */
+ 0x14105c40,
+ 0x58000000, /* mul ftz rn f32 $r1 $r1 $r5 */
+ 0x10001c40,
+ 0x58000000, /* mul ftz rn f32 $r0 $r0 $r4 */
+ 0x00001de7,
+ 0x80000000, /* exit */
+};
+
+static uint32_t
+NVC0FP_CACompositeSrcAlpha[] = {
+ 0x00021462,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x80000000,
+ 0x00000a0a,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x0000000f,
+ 0x00000000,
+ 0xfff01c00,
+ 0xc07e007c, /* linterp f32 $r0 v[$r63+0x7c] */
+ 0x10001c00,
+ 0xc8000000, /* rcp f32 $r0 $r0 */
+ 0x03f0dc40,
+ 0xc07e0084, /* pinterp f32 $r3 $r0 v[$r63+0x84] */
+ 0x03f09c40,
+ 0xc07e0080, /* pinterp f32 $r2 $r0 v[$r63+0x80] */
+ 0xfc211e86,
+ 0x80120000, /* tex { _,_,_,$r4 } $t0 { $r2,3 } */
+ 0x03f05c40,
+ 0xc07e0094, /* pinterp f32 $r1 $r0 v[$r63+0x94] */
+ 0x03f01c40,
+ 0xc07e0090, /* pinterp f32 $r0 $r0 v[$r63+0x90] */
+ 0xfc001e86,
+ 0x8013c001, /* tex { $r0,1,2,3 } $t1 { $r0,1 } */
+ 0x1030dc40,
+ 0x58000000, /* mul ftz rn f32 $r3 $r3 $r4 */
+ 0x10209c40,
+ 0x58000000, /* mul ftz rn f32 $r2 $r2 $r4 */
+ 0x10105c40,
+ 0x58000000, /* mul ftz rn f32 $r1 $r1 $r4 */
+ 0x10001c40,
+ 0x58000000, /* mul ftz rn f32 $r0 $r0 $r4 */
+ 0x00001de7,
+ 0x80000000, /* exit */
+};
+
+static uint32_t
+NVC0FP_Source_A8[] = {
+ 0x00021462,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x80000000,
+ 0x0000000a,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x0000000f,
+ 0x00000000,
+ 0xfff01c00,
+ 0xc07e007c, /* linterp f32 $r0 v[$r63+0x7c] */
+ 0x10001c00,
+ 0xc8000000, /* rcp f32 $r0 $r0 */
+ 0x03f05c40,
+ 0xc07e0084, /* pinterp f32 $r1 $r0 v[$r63+0x84] */
+ 0x03f01c40,
+ 0xc07e0080, /* pinterp f32 $r0 $r0 v[$r63+0x80] */
+ 0xfc001e86,
+ 0x80120000, /* tex { _ _ _ $r0 } $t0 { $r0 $r1 } */
+ 0x0000dde4,
+ 0x28000000, /* mov b32 $r3 $r0 */
+ 0x00009de4,
+ 0x28000000, /* mov b32 $r2 $r0 */
+ 0x00005de4,
+ 0x28000000, /* mov b32 $r1 $r0 */
+ 0x00001de7,
+ 0x80000000, /* exit */
+};
+
+static uint32_t
+NVC0FP_Composite_A8[] = {
+ 0x00021462,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x80000000,
+ 0x00000a0a,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x0000000f,
+ 0x00000000,
+ 0xfff01c00,
+ 0xc07e007c, /* linterp f32 $r0 v[$r63+0x7c] */
+ 0x10001c00,
+ 0xc8000000, /* rcp f32 $r0 $r0 */
+ 0x03f0dc40,
+ 0xc07e0094, /* pinterp f32 $r3 $r0 v[$r63+0x94] */
+ 0x03f09c40,
+ 0xc07e0090, /* pinterp f32 $r2 $r0 v[$r63+0x90] */
+ 0xfc205e86,
+ 0x80120001, /* tex { _ _ _ $r1 } $t1 { $r2 $r3 } */
+ 0x03f0dc40,
+ 0xc07e0084, /* pinterp f32 $r3 $r0 v[$r63+0x84] */
+ 0x03f09c40,
+ 0xc07e0080, /* pinterp f32 $r2 $r0 v[$r63+0x80] */
+ 0xfc201e86,
+ 0x80120000, /* tex { _ _ _ $r0 } $t0 { $r2 $r3 } */
+ 0x0400dc40,
+ 0x58000000, /* mul ftz rn f32 $r3 $r0 $r1 */
+ 0x0c009de4,
+ 0x28000000, /* mov b32 $r2 $r3 */
+ 0x0c005de4,
+ 0x28000000, /* mov b32 $r1 $r3 */
+ 0x0c001de4,
+ 0x28000000, /* mov b32 $r0 $r3 */
+ 0x00001de7,
+ 0x80000000, /* exit */
+};
+
+static uint32_t
+NVC0FP_NV12[] = {
+ 0x00021462,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x80000000,
+ 0x00000a0a,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x00000000,
+ 0x0000000f,
+ 0x00000000,
+ 0xfff09c00,
+ 0xc07e007c,
+ 0x10209c00,
+ 0xc8000000,
+ 0x0bf01c40,
+ 0xc07e0080,
+ 0x0bf05c40,
+ 0xc07e0084,
+ 0xfc001e86,
+ 0x80120000,
+ 0x00015c40,
+ 0x58004000,
+ 0x1050dc20,
+ 0x50004000,
+ 0x20511c20,
+ 0x50004000,
+ 0x30515c20,
+ 0x50004000,
+ 0x0bf01c40,
+ 0xc07e0090,
+ 0x0bf05c40,
+ 0xc07e0094,
+ 0xfc001e86,
+ 0x80130001,
+ 0x4000dc40,
+ 0x30064000,
+ 0x50011c40,
+ 0x30084000,
+ 0x60015c40,
+ 0x300a4000,
+ 0x70101c40,
+ 0x30064000,
+ 0x90109c40,
+ 0x300a4000,
+ 0x80105c40,
+ 0x30084000,
+ 0x00001de7,
+ 0x80000000,
+};
+
+#endif