diff options
author | Samuel Iglesias Gonsálvez <[email protected]> | 2017-04-25 12:18:17 +0200 |
---|---|---|
committer | Samuel Iglesias Gonsálvez <[email protected]> | 2017-05-03 15:32:39 +0200 |
commit | aaeb1c99beed39d85c300ebdb8a7bf056ee6717c (patch) | |
tree | ced45559a30aee15b5dcdff3855c7c4edc3b0e0e /src/intel | |
parent | 7f728bce811fc283e672e3a07b008bb7b52de35e (diff) |
i965/vec4: fix register width for DF VGRF and UNIFORM
On gen7, the swizzles used in DF align16 instructions works for element
size of 32 bits, so we can address only 2 consecutive DFs. As we assumed that
in the rest of the code and prepare the instructions for this (scalarize_df()),
we need to set it to two again.
However, for DF align1 instructions, a width of 2 is wrong as we are not
reading the data we want. For example, an uniform would have a region of
<0, 2, 1> so it would repeat the first 2 DFs, when we wanted to access
to the first 4.
This patch sets the default one to 4 and then modifies the width of
align16 instruction's DF sources when we translate the logical swizzle
to the physical one.
v2:
- Remove conditional (Curro).
Signed-off-by: Samuel Iglesias Gonsálvez <[email protected]>
Cc: "17.1" <[email protected]>
Reviewed-by: Francisco Jerez <[email protected]>
Diffstat (limited to 'src/intel')
-rw-r--r-- | src/intel/compiler/brw_vec4.cpp | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/src/intel/compiler/brw_vec4.cpp b/src/intel/compiler/brw_vec4.cpp index e27be8fc254..70487d3c151 100644 --- a/src/intel/compiler/brw_vec4.cpp +++ b/src/intel/compiler/brw_vec4.cpp @@ -1975,9 +1975,7 @@ vec4_visitor::convert_to_hw_regs() struct brw_reg reg; switch (src.file) { case VGRF: { - const unsigned type_size = type_sz(src.type); - const unsigned width = REG_SIZE / 2 / MAX2(4, type_size); - reg = byte_offset(brw_vecn_grf(width, src.nr, 0), src.offset); + reg = byte_offset(brw_vecn_grf(4, src.nr, 0), src.offset); reg.type = src.type; reg.abs = src.abs; reg.negate = src.negate; @@ -1985,12 +1983,11 @@ vec4_visitor::convert_to_hw_regs() } case UNIFORM: { - const unsigned width = REG_SIZE / 2 / MAX2(4, type_sz(src.type)); reg = stride(byte_offset(brw_vec4_grf( prog_data->base.dispatch_grf_start_reg + src.nr / 2, src.nr % 2 * 4), src.offset), - 0, width, 1); + 0, 4, 1); reg.type = src.type; reg.abs = src.abs; reg.negate = src.negate; @@ -2527,6 +2524,11 @@ vec4_visitor::apply_logical_swizzle(struct brw_reg *hw_reg, assert(brw_is_single_value_swizzle(reg.swizzle) || is_supported_64bit_region(inst, arg)); + /* Apply the region <2, 2, 1> for GRF or <0, 2, 1> for uniforms, as align16 + * HW can only do 32-bit swizzle channels. + */ + hw_reg->width = BRW_WIDTH_2; + if (is_supported_64bit_region(inst, arg) && !is_gen7_supported_64bit_swizzle(inst, arg)) { /* Supported 64-bit swizzles are those such that their first two |