diff options
author | Matt Turner <[email protected]> | 2014-02-20 08:18:22 -0800 |
---|---|---|
committer | Matt Turner <[email protected]> | 2014-06-01 13:29:23 -0700 |
commit | 27e12a8ea933e2f978e0ce9286422e6025c7377d (patch) | |
tree | 8ced4c9ea829d07c2a27fb70fc1db11a78435b5f /src/mesa/drivers/dri | |
parent | 1b60391ed48dc18b034fc3dc837919f4c8b7905c (diff) |
i965/fs: Store the number of sources an fs_inst has.
Reviewed-by: Chris Forbes <[email protected]>
Reviewed-by: Tapani Pälli <[email protected]>
Reviewed-by: Kenneth Graunke <[email protected]>
Diffstat (limited to 'src/mesa/drivers/dri')
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_fs.cpp | 21 | ||||
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_fs.h | 3 |
2 files changed, 13 insertions, 11 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_fs.cpp b/src/mesa/drivers/dri/i965/brw_fs.cpp index 48231082929..5a7e270aba4 100644 --- a/src/mesa/drivers/dri/i965/brw_fs.cpp +++ b/src/mesa/drivers/dri/i965/brw_fs.cpp @@ -52,11 +52,12 @@ extern "C" { #include "glsl/glsl_types.h" void -fs_inst::init() +fs_inst::init(int sources) { memset(this, 0, sizeof(*this)); - this->src = ralloc_array(this, fs_reg, 3); + this->sources = sources; + this->src = ralloc_array(this, fs_reg, sources); this->conditional_mod = BRW_CONDITIONAL_NONE; @@ -73,19 +74,19 @@ fs_inst::init() fs_inst::fs_inst() { - init(); + init(3); this->opcode = BRW_OPCODE_NOP; } fs_inst::fs_inst(enum opcode opcode) { - init(); + init(3); this->opcode = opcode; } fs_inst::fs_inst(enum opcode opcode, fs_reg dst) { - init(); + init(3); this->opcode = opcode; this->dst = dst; @@ -95,7 +96,7 @@ fs_inst::fs_inst(enum opcode opcode, fs_reg dst) fs_inst::fs_inst(enum opcode opcode, fs_reg dst, fs_reg src0) { - init(); + init(3); this->opcode = opcode; this->dst = dst; this->src[0] = src0; @@ -108,7 +109,7 @@ fs_inst::fs_inst(enum opcode opcode, fs_reg dst, fs_reg src0) fs_inst::fs_inst(enum opcode opcode, fs_reg dst, fs_reg src0, fs_reg src1) { - init(); + init(3); this->opcode = opcode; this->dst = dst; this->src[0] = src0; @@ -125,7 +126,7 @@ fs_inst::fs_inst(enum opcode opcode, fs_reg dst, fs_reg src0, fs_reg src1) fs_inst::fs_inst(enum opcode opcode, fs_reg dst, fs_reg src0, fs_reg src1, fs_reg src2) { - init(); + init(3); this->opcode = opcode; this->dst = dst; this->src[0] = src0; @@ -146,9 +147,9 @@ fs_inst::fs_inst(const fs_inst &that) { memcpy(this, &that, sizeof(that)); - this->src = ralloc_array(this, fs_reg, 3); + this->src = ralloc_array(this, fs_reg, that.sources); - for (int i = 0; i < 3; i++) + for (int i = 0; i < that.sources; i++) this->src[i] = that.src[i]; } diff --git a/src/mesa/drivers/dri/i965/brw_fs.h b/src/mesa/drivers/dri/i965/brw_fs.h index 11a5c7c6159..4f8a2b22ad8 100644 --- a/src/mesa/drivers/dri/i965/brw_fs.h +++ b/src/mesa/drivers/dri/i965/brw_fs.h @@ -190,7 +190,7 @@ class fs_inst : public backend_instruction { public: DECLARE_RALLOC_CXX_OPERATORS(fs_inst) - void init(); + void init(int sources); fs_inst(); fs_inst(enum opcode opcode); @@ -216,6 +216,7 @@ public: uint32_t texture_offset; /**< Texture offset bitfield */ uint32_t offset; /* spill/unspill offset */ + uint8_t sources; /**< Number of fs_reg sources. */ uint8_t conditional_mod; /**< BRW_CONDITIONAL_* */ /* Chooses which flag subregister (f0.0 or f0.1) is used for conditional |