Ben Skeggs | 19a1e90 | 2008-06-11 14:59:19 +1000 | [diff] [blame] | 1 | #ifndef __NV50_PROGRAM_H__ |
| 2 | #define __NV50_PROGRAM_H__ |
Ben Skeggs | 47b418b | 2007-12-05 14:01:01 +1100 | [diff] [blame] | 3 | |
| 4 | #include "pipe/p_state.h" |
Ben Skeggs | fda01b5 | 2008-08-07 11:26:17 +1000 | [diff] [blame] | 5 | #include "tgsi/tgsi_scan.h" |
Ben Skeggs | 47b418b | 2007-12-05 14:01:01 +1100 | [diff] [blame] | 6 | |
Ben Skeggs | 40137ea | 2008-06-12 12:16:43 +1000 | [diff] [blame] | 7 | struct nv50_program_exec { |
| 8 | struct nv50_program_exec *next; |
| 9 | |
| 10 | unsigned inst[2]; |
| 11 | struct { |
| 12 | int index; |
| 13 | unsigned mask; |
| 14 | unsigned shift; |
| 15 | } param; |
| 16 | }; |
| 17 | |
Christoph Bumiller | 6516594 | 2009-09-14 20:23:39 +0200 | [diff] [blame] | 18 | struct nv50_sreg4 { |
| 19 | uint8_t hw; |
Christoph Bumiller | 7494b82 | 2009-11-29 13:33:16 +0100 | [diff] [blame] | 20 | uint8_t id; /* tgsi index, nv50 needs them sorted: flat ones last */ |
Christoph Bumiller | 6516594 | 2009-09-14 20:23:39 +0200 | [diff] [blame] | 21 | |
| 22 | uint8_t mask; |
| 23 | boolean linear; |
| 24 | }; |
| 25 | |
Ben Skeggs | f722fd9 | 2008-06-01 22:41:40 +1000 | [diff] [blame] | 26 | struct nv50_program { |
| 27 | struct pipe_shader_state pipe; |
| 28 | struct tgsi_shader_info info; |
| 29 | boolean translated; |
| 30 | |
Ben Skeggs | b5bbf09 | 2008-06-09 13:09:55 +1000 | [diff] [blame] | 31 | unsigned type; |
Ben Skeggs | 40137ea | 2008-06-12 12:16:43 +1000 | [diff] [blame] | 32 | struct nv50_program_exec *exec_head; |
| 33 | struct nv50_program_exec *exec_tail; |
| 34 | unsigned exec_size; |
Christoph Bumiller | 750c6ca | 2009-09-15 11:56:58 +0200 | [diff] [blame] | 35 | struct nouveau_resource *data[1]; |
| 36 | unsigned data_start[1]; |
Ben Skeggs | f722fd9 | 2008-06-01 22:41:40 +1000 | [diff] [blame] | 37 | |
Ben Skeggs | 072fdc1 | 2009-06-04 16:13:56 +1000 | [diff] [blame] | 38 | struct nouveau_bo *bo; |
Ben Skeggs | f722fd9 | 2008-06-01 22:41:40 +1000 | [diff] [blame] | 39 | |
Christoph Bumiller | 1778dda | 2009-12-14 11:10:16 +0100 | [diff] [blame] | 40 | uint32_t *immd; |
Ben Skeggs | f722fd9 | 2008-06-01 22:41:40 +1000 | [diff] [blame] | 41 | unsigned immd_nr; |
Ben Skeggs | aea1669 | 2008-06-12 12:39:35 +1000 | [diff] [blame] | 42 | unsigned param_nr; |
Ben Skeggs | f722fd9 | 2008-06-01 22:41:40 +1000 | [diff] [blame] | 43 | |
Ben Skeggs | 8ec6415 | 2008-06-03 12:37:29 +1000 | [diff] [blame] | 44 | struct { |
| 45 | unsigned high_temp; |
Ben Skeggs | fea0b16 | 2008-06-16 12:55:53 +1000 | [diff] [blame] | 46 | unsigned high_result; |
Christoph Bumiller | 6516594 | 2009-09-14 20:23:39 +0200 | [diff] [blame] | 47 | |
| 48 | uint32_t attr[2]; |
| 49 | uint32_t regs[4]; |
| 50 | |
| 51 | /* for VPs, io_nr doesn't count 'private' results (PSIZ etc.) */ |
| 52 | unsigned io_nr; |
| 53 | struct nv50_sreg4 io[PIPE_MAX_SHADER_OUTPUTS]; |
| 54 | |
| 55 | /* FP colour inputs, VP/GP back colour outputs */ |
| 56 | struct nv50_sreg4 two_side[2]; |
| 57 | |
| 58 | /* VP only */ |
| 59 | uint8_t clpd, clpd_nr; |
Christoph Bumiller | 06dac41 | 2009-09-15 11:49:41 +0200 | [diff] [blame] | 60 | uint8_t psiz; |
Christoph Bumiller | d29f555 | 2009-12-24 12:39:42 +0100 | [diff] [blame] | 61 | uint8_t edgeflag_in; |
Ben Skeggs | f722fd9 | 2008-06-01 22:41:40 +1000 | [diff] [blame] | 62 | } cfg; |
| 63 | }; |
Ben Skeggs | 47b418b | 2007-12-05 14:01:01 +1100 | [diff] [blame] | 64 | |
| 65 | #endif |