[Mesa-dev] [PATCH v2 19/53] intel/compiler: implement 16-bit fsign
Pohjolainen, Topi
topi.pohjolainen at gmail.com
Mon Dec 31 11:11:44 UTC 2018
On Wed, Dec 19, 2018 at 12:50:47PM +0100, Iago Toral Quiroga wrote:
> v2:
> - make 16-bit be its own separate case (Jason)
>
> Reviewed-by: Topi Pohjolainen <topi.pohjolainen at intel.com> (v1)
This version also.
> ---
> src/intel/compiler/brw_fs_nir.cpp | 18 +++++++++++++++++-
> 1 file changed, 17 insertions(+), 1 deletion(-)
>
> diff --git a/src/intel/compiler/brw_fs_nir.cpp b/src/intel/compiler/brw_fs_nir.cpp
> index 797050e8f02..6089c883c9a 100644
> --- a/src/intel/compiler/brw_fs_nir.cpp
> +++ b/src/intel/compiler/brw_fs_nir.cpp
> @@ -880,7 +880,22 @@ fs_visitor::nir_emit_alu(const fs_builder &bld, nir_alu_instr *instr)
> : bld.MOV(result, brw_imm_f(1.0f));
>
> set_predicate(BRW_PREDICATE_NORMAL, inst);
> - } else if (type_sz(op[0].type) < 8) {
> + } else if (type_sz(op[0].type) == 2) {
> + /* AND(val, 0x8000) gives the sign bit.
> + *
> + * Predicated OR ORs 1.0 (0x3c00) with the sign bit if val is not zero.
> + */
> + fs_reg zero = retype(brw_imm_uw(0), BRW_REGISTER_TYPE_HF);
> + bld.CMP(bld.null_reg_f(), op[0], zero, BRW_CONDITIONAL_NZ);
> +
> + fs_reg result_int = retype(result, BRW_REGISTER_TYPE_UW);
> + op[0].type = BRW_REGISTER_TYPE_UW;
> + result.type = BRW_REGISTER_TYPE_UW;
> + bld.AND(result_int, op[0], brw_imm_uw(0x8000u));
> +
> + inst = bld.OR(result_int, result_int, brw_imm_uw(0x3c00u));
> + inst->predicate = BRW_PREDICATE_NORMAL;
> + } else if (type_sz(op[0].type) == 4) {
> /* AND(val, 0x80000000) gives the sign bit.
> *
> * Predicated OR ORs 1.0 (0x3f800000) with the sign bit if val is not
> @@ -902,6 +917,7 @@ fs_visitor::nir_emit_alu(const fs_builder &bld, nir_alu_instr *instr)
> * - The sign is encoded in the high 32-bit of each DF
> * - We need to produce a DF result.
> */
> + assert(type_sz(op[0].type) == 8);
>
> fs_reg zero = vgrf(glsl_type::double_type);
> bld.MOV(zero, setup_imm_df(bld, 0.0));
> --
> 2.17.1
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev
More information about the mesa-dev
mailing list