[Mesa-dev] [PATCH 06/22] nir/format_convert: Add vec mask and sign-extend helpers
Kenneth Graunke
kenneth at whitecape.org
Mon Aug 20 07:42:15 UTC 2018
On Friday, August 17, 2018 1:06:12 PM PDT Jason Ekstrand wrote:
> ---
> src/compiler/nir/nir_format_convert.h | 35 +++++++++++++++++++++------
> 1 file changed, 27 insertions(+), 8 deletions(-)
>
> diff --git a/src/compiler/nir/nir_format_convert.h b/src/compiler/nir/nir_format_convert.h
> index b1345f7263b..305273cdfdd 100644
> --- a/src/compiler/nir/nir_format_convert.h
> +++ b/src/compiler/nir/nir_format_convert.h
> @@ -50,6 +50,32 @@ nir_mask_shift_or(struct nir_builder *b, nir_ssa_def *dst, nir_ssa_def *src,
> return nir_ior(b, nir_mask_shift(b, src, src_mask, src_left_shift), dst);
> }
>
> +static inline nir_ssa_def *
> +nir_format_mask_uvec(nir_builder *b, nir_ssa_def *src,
> + const unsigned *bits)
> +{
> + nir_const_value mask;
> + for (unsigned i = 0; i < src->num_components; i++) {
> + assert(bits[i] < 32);
> + mask.u32[i] = (1u << bits[i]) - 1;
> + }
> + return nir_iand(b, src, nir_build_imm(b, src->num_components, 32, mask));
> +}
> +
> +static inline nir_ssa_def *
> +nir_format_sign_extend_ivec(nir_builder *b, nir_ssa_def *src,
> + const unsigned *bits)
> +{
> + assert(src->num_components <= 4);
> + nir_ssa_def *comps[4];
> + for (unsigned i = 0; i < src->num_components; i++) {
> + nir_ssa_def *shift = nir_imm_int(b, src->bit_size - bits[i]);
> + comps[i] = nir_ishr(b, nir_ishl(b, nir_channel(b, src, i), shift), shift);
> + }
> + return nir_vec(b, comps, src->num_components);
> +}
> +
> +
> static inline nir_ssa_def *
> nir_format_unpack_int(nir_builder *b, nir_ssa_def *packed,
> const unsigned *bits, unsigned num_components,
> @@ -117,14 +143,7 @@ static inline nir_ssa_def *
> nir_format_pack_uint(nir_builder *b, nir_ssa_def *color,
> const unsigned *bits, unsigned num_components)
> {
> - nir_const_value mask;
> - for (unsigned i = 0; i < num_components; i++) {
This used to operate on the num_components parameter to
nir_format_pack_uint, but now it operates on color->num_components
instead. That's probably OK...do we even need the parameter?
Nothing actually uses this function in master today AFAICT...
Patches 1-3 (with Bas's fixes) and 5-7 are:
Reviewed-by: Kenneth Graunke <kenneth at whitecape.org>
> - assert(bits[i] < 32);
> - mask.u32[i] = (1u << bits[i]) - 1;
> - }
> - nir_ssa_def *mask_imm = nir_build_imm(b, num_components, 32, mask);
> -
> - return nir_format_pack_uint_unmasked(b, nir_iand(b, color, mask_imm),
> + return nir_format_pack_uint_unmasked(b, nir_format_mask_uvec(b, color, bits),
> bits, num_components);
> }
>
>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: This is a digitally signed message part.
URL: <https://lists.freedesktop.org/archives/mesa-dev/attachments/20180820/9a92bffd/attachment.sig>
More information about the mesa-dev
mailing list