diff --git a/.pick_status.json b/.pick_status.json index dad9294c0a6..095c26567f7 100644 --- a/.pick_status.json +++ b/.pick_status.json @@ -2227,7 +2227,7 @@ "description": "zink: implement i2b1", "nominated": true, "nomination_type": 1, - "resolution": 0, + "resolution": 1, "master_sha": null, "because_sha": "7f6a491eec02d6c141e2b4849a3ba924926a482a" }, diff --git a/src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c b/src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c index aaf722ad394..e609a08caf6 100644 --- a/src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c +++ b/src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c @@ -1020,6 +1020,13 @@ emit_alu(struct ntv_context *ctx, nir_alu_instr *alu) nir_src_bit_size(alu->src[0].src), num_components, 0)); break; + case nir_op_i2b1: + assert(nir_op_infos[alu->op].num_inputs == 1); + result = emit_binop(ctx, SpvOpINotEqual, dest_type, src[0], + get_ivec_constant(ctx, + nir_src_bit_size(alu->src[0].src), + num_components, 0)); + break; #define BINOP(nir_op, spirv_op) \