diff options
Diffstat (limited to 'src/nve0_shader.h')
-rw-r--r-- | src/nve0_shader.h | 404 |
1 files changed, 404 insertions, 0 deletions
diff --git a/src/nve0_shader.h b/src/nve0_shader.h new file mode 100644 index 0000000..8f36279 --- /dev/null +++ b/src/nve0_shader.h @@ -0,0 +1,404 @@ +#ifndef __NVE0_SHADER_H__ +#define __NVE0_SHADER_H__ + +static uint32_t +NVE0VP_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 +NVE0FP_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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 0x00001de7, + 0x80000000, /* exit */ +}; + +static uint32_t +NVE0FP_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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 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 +NVE0FP_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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 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 +NVE0FP_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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 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 +NVE0FP_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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 0x0000dde4, + 0x28000000, /* mov b32 $r3 $r0 */ + 0x00009de4, + 0x28000000, /* mov b32 $r2 $r0 */ + 0x00005de4, + 0x28000000, /* mov b32 $r1 $r0 */ + 0x00001de7, + 0x80000000, /* exit */ +}; + +static uint32_t +NVE0FP_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 } */ + 0x00001de6, + 0xf0000000, /* texbar */ + 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 +NVE0FP_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, + 0x00001de6, + 0xf0000000, /* texbar */ + 0x00015c40, + 0x58004000, + 0x1050dc20, + 0x50004000, + 0x20511c20, + 0x50004000, + 0x30515c20, + 0x50004000, + 0x0bf01c40, + 0xc07e0090, + 0x0bf05c40, + 0xc07e0094, + 0xfc001e86, + 0x80130001, + 0x00001de6, + 0xf0000000, /* texbar */ + 0x4000dc40, + 0x30064000, + 0x50011c40, + 0x30084000, + 0x60015c40, + 0x300a4000, + 0x70101c40, + 0x30064000, + 0x90109c40, + 0x300a4000, + 0x80105c40, + 0x30084000, + 0x00001de7, + 0x80000000, +}; + +#endif |