/* Copyright (C) 2015 Broadcom * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice (including the next * paragraph) shall be included in all copies or substantial portions of the * Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS * IN THE SOFTWARE. */ #ifndef _NIR_BUILDER_OPCODES_ #define _NIR_BUILDER_OPCODES_ static inline nir_ssa_def * nir_amul(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_amul, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_fequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_fequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_fequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_fequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_fequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_fequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_fequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_fequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_fequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_fequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_iequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_iequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_iequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_iequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_iequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_iequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_iequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_iequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16all_iequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16all_iequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_fnequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_fnequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_fnequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_fnequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_fnequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_fnequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_fnequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_fnequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_fnequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_fnequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_inequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_inequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_inequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_inequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_inequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_inequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_inequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_inequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16any_inequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b16any_inequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b16csel(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_b16csel, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_b2b1(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2b1, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2b16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2b16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2b32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2b32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2b8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2b8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2f16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2f16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2f32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2f32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2f64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2f64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2i1(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2i1, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2i16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2i16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2i32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2i32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2i64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2i64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b2i8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_b2i8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_b32all_fequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_fequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_fequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_fequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_fequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_fequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_fequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_fequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_fequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_fequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_iequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_iequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_iequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_iequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_iequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_iequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_iequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_iequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32all_iequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32all_iequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_fnequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_fnequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_fnequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_fnequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_fnequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_fnequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_fnequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_fnequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_fnequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_fnequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_inequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_inequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_inequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_inequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_inequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_inequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_inequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_inequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32any_inequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b32any_inequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b32csel(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_b32csel, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_b8all_fequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_fequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_fequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_fequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_fequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_fequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_fequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_fequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_fequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_fequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_iequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_iequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_iequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_iequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_iequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_iequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_iequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_iequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8all_iequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8all_iequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_fnequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_fnequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_fnequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_fnequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_fnequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_fnequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_fnequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_fnequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_fnequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_fnequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_inequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_inequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_inequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_inequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_inequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_inequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_inequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_inequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8any_inequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_b8any_inequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_b8csel(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_b8csel, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_ball_fequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_fequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_fequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_fequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_fequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_fequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_fequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_fequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_fequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_fequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_iequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_iequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_iequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_iequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_iequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_iequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_iequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_iequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ball_iequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ball_iequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_fnequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_fnequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_fnequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_fnequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_fnequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_fnequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_fnequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_fnequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_fnequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_fnequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_inequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_inequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_inequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_inequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_inequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_inequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_inequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_inequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bany_inequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bany_inequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bcsel(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_bcsel, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_bfi(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_bfi, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_bfm(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_bfm, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_bit_count(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_bit_count, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_bitfield_insert(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2, nir_ssa_def *src3) { return nir_build_alu(build, nir_op_bitfield_insert, src0, src1, src2, src3); } static inline nir_ssa_def * nir_bitfield_reverse(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_bitfield_reverse, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_bitfield_select(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_bitfield_select, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_cube_face_coord(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_cube_face_coord, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_cube_face_index(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_cube_face_index, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_extract_i16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_extract_i16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_extract_i8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_extract_i8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_extract_u16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_extract_u16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_extract_u8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_extract_u8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_f2b1(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2b1, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2b16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2b16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2b32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2b32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2b8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2b8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2f16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2f16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2f16_rtne(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2f16_rtne, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2f16_rtz(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2f16_rtz, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2f32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2f32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2f64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2f64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2fmp(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2fmp, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2i1(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2i1, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2i16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2i16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2i32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2i32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2i64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2i64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2i8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2i8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2imp(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2imp, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2u1(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2u1, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2u16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2u16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2u32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2u32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2u64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2u64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2u8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2u8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_f2ump(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_f2ump, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fabs(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fabs, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fadd(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fadd, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fall_equal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fall_equal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fall_equal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fall_equal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fall_equal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fall_equal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fall_equal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fall_equal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fall_equal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fall_equal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fany_nequal16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fany_nequal16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fany_nequal2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fany_nequal2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fany_nequal3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fany_nequal3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fany_nequal4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fany_nequal4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fany_nequal8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fany_nequal8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fceil(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fceil, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fclamp_pos(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fclamp_pos, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fcos(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fcos, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fcsel(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_fcsel, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_fddx(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fddx, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fddx_coarse(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fddx_coarse, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fddx_fine(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fddx_fine, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fddy(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fddy, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fddy_coarse(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fddy_coarse, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fddy_fine(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fddy_fine, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fdiv(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdiv, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot16_replicated(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot16_replicated, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot2_replicated(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot2_replicated, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot3, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot3_replicated(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot3_replicated, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot4, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot4_replicated(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot4_replicated, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdot8_replicated(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdot8_replicated, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdph(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdph, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fdph_replicated(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fdph_replicated, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_feq(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_feq, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_feq16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_feq16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_feq32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_feq32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_feq8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_feq8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fexp2(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fexp2, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_ffloor(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_ffloor, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_ffma(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_ffma, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_ffract(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_ffract, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fge(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fge, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fge16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fge16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fge32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fge32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fge8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fge8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_find_lsb(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_find_lsb, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fisfinite(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fisfinite, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fisnormal(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fisnormal, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_flog2(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_flog2, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_flrp(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_flrp, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_flt(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_flt, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_flt16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_flt16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_flt32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_flt32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_flt8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_flt8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fmax(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fmax, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fmin(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fmin, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fmod(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fmod, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fmul(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fmul, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fneg(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fneg, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fneu(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fneu, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fneu16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fneu16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fneu32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fneu32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fneu8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fneu8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fpow(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fpow, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fquantize2f16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fquantize2f16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_frcp(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_frcp, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_frem(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_frem, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_frexp_exp(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_frexp_exp, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_frexp_sig(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_frexp_sig, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fround_even(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fround_even, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_frsq(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_frsq, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fsat(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fsat, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fsat_signed(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fsat_signed, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fsign(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fsign, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fsin(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fsin, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fsqrt(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fsqrt, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fsub(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_fsub, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_fsum2(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fsum2, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fsum3(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fsum3, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_fsum4(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_fsum4, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_ftrunc(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_ftrunc, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2b1(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2b1, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2b16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2b16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2b32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2b32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2b8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2b8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2f16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2f16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2f32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2f32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2f64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2f64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2fmp(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2fmp, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2i1(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2i1, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2i16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2i16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2i32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2i32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2i64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2i64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2i8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2i8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_i2imp(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_i2imp, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_iabs(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_iabs, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_iadd(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_iadd, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_iadd_sat(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_iadd_sat, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_iand(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_iand, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ibfe(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_ibfe, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_ibitfield_extract(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_ibitfield_extract, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_idiv(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_idiv, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ieq(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ieq, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ieq16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ieq16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ieq32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ieq32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ieq8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ieq8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ifind_msb(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_ifind_msb, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_ige(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ige, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ige16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ige16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ige32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ige32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ige8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ige8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ihadd(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ihadd, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ilt(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ilt, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ilt16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ilt16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ilt32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ilt32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ilt8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ilt8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_imad24_ir3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_imad24_ir3, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_imadsh_mix16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_imadsh_mix16, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_imax(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_imax, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_imin(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_imin, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_imod(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_imod, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_imul(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_imul, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_imul24(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_imul24, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_imul_2x32_64(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_imul_2x32_64, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_imul_32x16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_imul_32x16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_imul_high(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_imul_high, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ine(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ine, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ine16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ine16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ine32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ine32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ine8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ine8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ineg(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_ineg, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_inot(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_inot, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_ior(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ior, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_irem(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_irem, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_irhadd(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_irhadd, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ishl(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ishl, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ishr(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ishr, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_isign(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_isign, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_isub(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_isub, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_isub_sat(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_isub_sat, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ixor(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ixor, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ldexp(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ldexp, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_mov(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_mov, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_32_2x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_32_2x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_32_2x16_split(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_pack_32_2x16_split, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_pack_32_4x8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_32_4x8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_64_2x32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_64_2x32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_64_2x32_split(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_pack_64_2x32_split, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_pack_64_4x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_64_4x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_half_2x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_half_2x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_half_2x16_split(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_pack_half_2x16_split, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_pack_snorm_2x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_snorm_2x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_snorm_4x8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_snorm_4x8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_unorm_2x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_unorm_2x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_unorm_4x8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_unorm_4x8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_uvec2_to_uint(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_uvec2_to_uint, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_pack_uvec4_to_uint(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_pack_uvec4_to_uint, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_seq(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_seq, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_sge(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_sge, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_slt(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_slt, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_sne(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_sne, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_u2f16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2f16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_u2f32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2f32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_u2f64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2f64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_u2fmp(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2fmp, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_u2u1(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2u1, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_u2u16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2u16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_u2u32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2u32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_u2u64(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2u64, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_u2u8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_u2u8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_uabs_isub(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uabs_isub, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_uabs_usub(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uabs_usub, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_uadd_carry(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uadd_carry, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_uadd_sat(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uadd_sat, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ubfe(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_ubfe, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_ubitfield_extract(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_ubitfield_extract, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_uclz(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_uclz, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_udiv(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_udiv, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ufind_msb(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_ufind_msb, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_uge(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uge, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_uge16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uge16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_uge32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uge32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_uge8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uge8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_uhadd(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uhadd, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ult(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ult, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ult16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ult16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ult32(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ult32, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ult8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ult8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umad24(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_umad24, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_umax(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umax, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umax_4x8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umax_4x8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umin(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umin, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umin_4x8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umin_4x8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umod(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umod, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umul24(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umul24, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umul_2x32_64(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umul_2x32_64, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umul_32x16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umul_32x16, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umul_high(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umul_high, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umul_low(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umul_low, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_umul_unorm_4x8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_umul_unorm_4x8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_unpack_32_2x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_32_2x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_32_2x16_split_x(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_32_2x16_split_x, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_32_2x16_split_y(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_32_2x16_split_y, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_32_4x8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_32_4x8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_64_2x32(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_64_2x32, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_64_2x32_split_x(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_64_2x32_split_x, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_64_2x32_split_y(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_64_2x32_split_y, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_64_4x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_64_4x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_half_2x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_half_2x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_half_2x16_flush_to_zero(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_half_2x16_flush_to_zero, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_half_2x16_split_x(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_half_2x16_split_x, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_half_2x16_split_x_flush_to_zero(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_half_2x16_split_x_flush_to_zero, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_half_2x16_split_y(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_half_2x16_split_y, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_half_2x16_split_y_flush_to_zero(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_half_2x16_split_y_flush_to_zero, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_snorm_2x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_snorm_2x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_snorm_4x8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_snorm_4x8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_unorm_2x16(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_unorm_2x16, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_unpack_unorm_4x8(nir_builder *build, nir_ssa_def *src0) { return nir_build_alu(build, nir_op_unpack_unorm_4x8, src0, NULL, NULL, NULL); } static inline nir_ssa_def * nir_urhadd(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_urhadd, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_urol(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_urol, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_uror(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_uror, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_usadd_4x8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_usadd_4x8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ushr(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ushr, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_ussub_4x8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_ussub_4x8, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_usub_borrow(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_usub_borrow, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_usub_sat(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_usub_sat, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_vec16(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2, nir_ssa_def *src3, nir_ssa_def *src4, nir_ssa_def *src5, nir_ssa_def *src6, nir_ssa_def *src7, nir_ssa_def *src8, nir_ssa_def *src9, nir_ssa_def *src10, nir_ssa_def *src11, nir_ssa_def *src12, nir_ssa_def *src13, nir_ssa_def *src14, nir_ssa_def *src15) { nir_ssa_def *srcs[16] = {src0, src1, src2, src3, src4, src5, src6, src7, src8, src9, src10, src11, src12, src13, src14, src15}; return nir_build_alu_src_arr(build, nir_op_vec16, srcs); } static inline nir_ssa_def * nir_vec2(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1) { return nir_build_alu(build, nir_op_vec2, src0, src1, NULL, NULL); } static inline nir_ssa_def * nir_vec3(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2) { return nir_build_alu(build, nir_op_vec3, src0, src1, src2, NULL); } static inline nir_ssa_def * nir_vec4(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2, nir_ssa_def *src3) { return nir_build_alu(build, nir_op_vec4, src0, src1, src2, src3); } static inline nir_ssa_def * nir_vec8(nir_builder *build, nir_ssa_def *src0, nir_ssa_def *src1, nir_ssa_def *src2, nir_ssa_def *src3, nir_ssa_def *src4, nir_ssa_def *src5, nir_ssa_def *src6, nir_ssa_def *src7) { nir_ssa_def *srcs[8] = {src0, src1, src2, src3, src4, src5, src6, src7}; return nir_build_alu_src_arr(build, nir_op_vec8, srcs); } /* Generic builder for system values. */ static inline nir_ssa_def * nir_load_system_value(nir_builder *build, nir_intrinsic_op op, int index, unsigned num_components, unsigned bit_size) { nir_intrinsic_instr *load = nir_intrinsic_instr_create(build->shader, op); if (nir_intrinsic_infos[op].dest_components > 0) assert(num_components == nir_intrinsic_infos[op].dest_components); else load->num_components = num_components; load->const_index[0] = index; nir_ssa_dest_init(&load->instr, &load->dest, num_components, bit_size, NULL); nir_builder_instr_insert(build, &load->instr); return &load->dest.ssa; } static inline nir_ssa_def * nir_load_aa_line_width(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_aa_line_width, 0, 1, 32); } static inline nir_ssa_def * nir_load_base_global_invocation_id(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_base_global_invocation_id, 0, 3, bit_size); } static inline nir_ssa_def * nir_load_base_instance(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_base_instance, 0, 1, 32); } static inline nir_ssa_def * nir_load_base_vertex(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_base_vertex, 0, 1, 32); } static inline nir_ssa_def * nir_load_base_work_group_id(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_base_work_group_id, 0, 3, bit_size); } static inline nir_ssa_def * nir_load_blend_const_color_a_float(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_blend_const_color_a_float, 0, 1, 32); } static inline nir_ssa_def * nir_load_blend_const_color_aaaa8888_unorm(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_blend_const_color_aaaa8888_unorm, 0, 1, 32); } static inline nir_ssa_def * nir_load_blend_const_color_b_float(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_blend_const_color_b_float, 0, 1, 32); } static inline nir_ssa_def * nir_load_blend_const_color_g_float(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_blend_const_color_g_float, 0, 1, 32); } static inline nir_ssa_def * nir_load_blend_const_color_r_float(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_blend_const_color_r_float, 0, 1, 32); } static inline nir_ssa_def * nir_load_blend_const_color_rgba(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_blend_const_color_rgba, 0, 4, 32); } static inline nir_ssa_def * nir_load_blend_const_color_rgba8888_unorm(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_blend_const_color_rgba8888_unorm, 0, 1, 32); } static inline nir_ssa_def * nir_load_color0(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_color0, 0, 4, 32); } static inline nir_ssa_def * nir_load_color1(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_color1, 0, 4, 32); } static inline nir_ssa_def * nir_load_constant_base_ptr(nir_builder *build, unsigned num_components, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_constant_base_ptr, 0, num_components, bit_size); } static inline nir_ssa_def * nir_load_draw_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_draw_id, 0, 1, 32); } static inline nir_ssa_def * nir_load_first_vertex(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_first_vertex, 0, 1, 32); } static inline nir_ssa_def * nir_load_frag_coord(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_frag_coord, 0, 4, 32); } static inline nir_ssa_def * nir_load_front_face(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_front_face, 0, 1, bit_size); } static inline nir_ssa_def * nir_load_global_invocation_id(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_global_invocation_id, 0, 3, bit_size); } static inline nir_ssa_def * nir_load_global_invocation_id_zero_base(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_global_invocation_id_zero_base, 0, 3, bit_size); } static inline nir_ssa_def * nir_load_global_invocation_index(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_global_invocation_index, 0, 1, bit_size); } static inline nir_ssa_def * nir_load_gs_header_ir3(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_gs_header_ir3, 0, 1, 32); } static inline nir_ssa_def * nir_load_helper_invocation(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_helper_invocation, 0, 1, bit_size); } static inline nir_ssa_def * nir_load_hs_patch_stride_ir3(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_hs_patch_stride_ir3, 0, 1, 32); } static inline nir_ssa_def * nir_load_instance_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_instance_id, 0, 1, 32); } static inline nir_ssa_def * nir_load_invocation_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_invocation_id, 0, 1, 32); } static inline nir_ssa_def * nir_load_is_indexed_draw(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_is_indexed_draw, 0, 1, 32); } static inline nir_ssa_def * nir_load_layer_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_layer_id, 0, 1, 32); } static inline nir_ssa_def * nir_load_line_coord(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_line_coord, 0, 1, 32); } static inline nir_ssa_def * nir_load_line_width(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_line_width, 0, 1, 32); } static inline nir_ssa_def * nir_load_local_group_size(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_local_group_size, 0, 3, 32); } static inline nir_ssa_def * nir_load_local_invocation_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_local_invocation_id, 0, 3, 32); } static inline nir_ssa_def * nir_load_local_invocation_index(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_local_invocation_index, 0, 1, 32); } static inline nir_ssa_def * nir_load_num_subgroups(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_num_subgroups, 0, 1, 32); } static inline nir_ssa_def * nir_load_num_work_groups(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_num_work_groups, 0, 3, bit_size); } static inline nir_ssa_def * nir_load_patch_vertices_in(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_patch_vertices_in, 0, 1, 32); } static inline nir_ssa_def * nir_load_point_coord(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_point_coord, 0, 2, 32); } static inline nir_ssa_def * nir_load_primitive_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_primitive_id, 0, 1, 32); } static inline nir_ssa_def * nir_load_primitive_location_ir3(nir_builder *build, unsigned nir_intrinsic_driver_location) { return nir_load_system_value(build, nir_intrinsic_load_primitive_location_ir3, nir_intrinsic_driver_location, 1, 32); } static inline nir_ssa_def * nir_load_ray_flags(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_flags, 0, 1, 32); } static inline nir_ssa_def * nir_load_ray_geometry_index(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_geometry_index, 0, 1, 32); } static inline nir_ssa_def * nir_load_ray_hit_kind(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_hit_kind, 0, 1, 32); } static inline nir_ssa_def * nir_load_ray_instance_custom_index(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_instance_custom_index, 0, 1, 32); } static inline nir_ssa_def * nir_load_ray_launch_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_launch_id, 0, 3, 32); } static inline nir_ssa_def * nir_load_ray_launch_size(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_launch_size, 0, 3, 32); } static inline nir_ssa_def * nir_load_ray_object_direction(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_object_direction, 0, 3, 32); } static inline nir_ssa_def * nir_load_ray_object_origin(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_object_origin, 0, 3, 32); } static inline nir_ssa_def * nir_load_ray_object_to_world(nir_builder *build, unsigned nir_intrinsic_column) { return nir_load_system_value(build, nir_intrinsic_load_ray_object_to_world, nir_intrinsic_column, 3, 32); } static inline nir_ssa_def * nir_load_ray_t_max(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_t_max, 0, 1, 32); } static inline nir_ssa_def * nir_load_ray_t_min(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_t_min, 0, 1, 32); } static inline nir_ssa_def * nir_load_ray_world_direction(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_world_direction, 0, 3, 32); } static inline nir_ssa_def * nir_load_ray_world_origin(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_ray_world_origin, 0, 3, 32); } static inline nir_ssa_def * nir_load_ray_world_to_object(nir_builder *build, unsigned nir_intrinsic_column) { return nir_load_system_value(build, nir_intrinsic_load_ray_world_to_object, nir_intrinsic_column, 3, 32); } static inline nir_ssa_def * nir_load_sample_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_sample_id, 0, 1, 32); } static inline nir_ssa_def * nir_load_sample_id_no_per_sample(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_sample_id_no_per_sample, 0, 1, 32); } static inline nir_ssa_def * nir_load_sample_mask_in(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_sample_mask_in, 0, 1, 32); } static inline nir_ssa_def * nir_load_sample_pos(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_sample_pos, 0, 2, 32); } static inline nir_ssa_def * nir_load_scratch_base_ptr(nir_builder *build, unsigned nir_intrinsic_base, unsigned num_components, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_scratch_base_ptr, nir_intrinsic_base, num_components, bit_size); } static inline nir_ssa_def * nir_load_shader_record_ptr(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_shader_record_ptr, 0, 1, 64); } static inline nir_ssa_def * nir_load_shared_base_ptr(nir_builder *build, unsigned num_components, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_shared_base_ptr, 0, num_components, bit_size); } static inline nir_ssa_def * nir_load_simd_width_intel(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_simd_width_intel, 0, 1, 32); } static inline nir_ssa_def * nir_load_subgroup_eq_mask(nir_builder *build, unsigned num_components, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_subgroup_eq_mask, 0, num_components, bit_size); } static inline nir_ssa_def * nir_load_subgroup_ge_mask(nir_builder *build, unsigned num_components, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_subgroup_ge_mask, 0, num_components, bit_size); } static inline nir_ssa_def * nir_load_subgroup_gt_mask(nir_builder *build, unsigned num_components, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_subgroup_gt_mask, 0, num_components, bit_size); } static inline nir_ssa_def * nir_load_subgroup_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_subgroup_id, 0, 1, 32); } static inline nir_ssa_def * nir_load_subgroup_invocation(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_subgroup_invocation, 0, 1, 32); } static inline nir_ssa_def * nir_load_subgroup_le_mask(nir_builder *build, unsigned num_components, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_subgroup_le_mask, 0, num_components, bit_size); } static inline nir_ssa_def * nir_load_subgroup_lt_mask(nir_builder *build, unsigned num_components, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_subgroup_lt_mask, 0, num_components, bit_size); } static inline nir_ssa_def * nir_load_subgroup_size(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_subgroup_size, 0, 1, 32); } static inline nir_ssa_def * nir_load_tcs_header_ir3(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tcs_header_ir3, 0, 1, 32); } static inline nir_ssa_def * nir_load_tcs_in_param_base_r600(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tcs_in_param_base_r600, 0, 4, 32); } static inline nir_ssa_def * nir_load_tcs_out_param_base_r600(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tcs_out_param_base_r600, 0, 4, 32); } static inline nir_ssa_def * nir_load_tcs_rel_patch_id_r600(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tcs_rel_patch_id_r600, 0, 1, 32); } static inline nir_ssa_def * nir_load_tcs_tess_factor_base_r600(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tcs_tess_factor_base_r600, 0, 1, 32); } static inline nir_ssa_def * nir_load_tess_coord(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tess_coord, 0, 3, 32); } static inline nir_ssa_def * nir_load_tess_factor_base_ir3(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tess_factor_base_ir3, 0, 2, 32); } static inline nir_ssa_def * nir_load_tess_level_inner(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tess_level_inner, 0, 2, 32); } static inline nir_ssa_def * nir_load_tess_level_inner_default(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tess_level_inner_default, 0, 2, 32); } static inline nir_ssa_def * nir_load_tess_level_outer(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tess_level_outer, 0, 4, 32); } static inline nir_ssa_def * nir_load_tess_level_outer_default(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tess_level_outer_default, 0, 4, 32); } static inline nir_ssa_def * nir_load_tess_param_base_ir3(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_tess_param_base_ir3, 0, 2, 32); } static inline nir_ssa_def * nir_load_user_clip_plane(nir_builder *build, unsigned nir_intrinsic_ucp_id) { return nir_load_system_value(build, nir_intrinsic_load_user_clip_plane, nir_intrinsic_ucp_id, 4, 32); } static inline nir_ssa_def * nir_load_user_data_amd(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_user_data_amd, 0, 4, 32); } static inline nir_ssa_def * nir_load_vertex_id(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_vertex_id, 0, 1, 32); } static inline nir_ssa_def * nir_load_vertex_id_zero_base(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_vertex_id_zero_base, 0, 1, 32); } static inline nir_ssa_def * nir_load_view_index(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_view_index, 0, 1, 32); } static inline nir_ssa_def * nir_load_viewport_offset(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_viewport_offset, 0, 3, 32); } static inline nir_ssa_def * nir_load_viewport_scale(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_viewport_scale, 0, 3, 32); } static inline nir_ssa_def * nir_load_viewport_x_scale(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_viewport_x_scale, 0, 1, 32); } static inline nir_ssa_def * nir_load_viewport_y_scale(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_viewport_y_scale, 0, 1, 32); } static inline nir_ssa_def * nir_load_viewport_z_offset(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_viewport_z_offset, 0, 1, 32); } static inline nir_ssa_def * nir_load_viewport_z_scale(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_viewport_z_scale, 0, 1, 32); } static inline nir_ssa_def * nir_load_vs_primitive_stride_ir3(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_vs_primitive_stride_ir3, 0, 1, 32); } static inline nir_ssa_def * nir_load_vs_vertex_stride_ir3(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_vs_vertex_stride_ir3, 0, 1, 32); } static inline nir_ssa_def * nir_load_work_dim(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_work_dim, 0, 1, 32); } static inline nir_ssa_def * nir_load_work_group_id(nir_builder *build, unsigned bit_size) { return nir_load_system_value(build, nir_intrinsic_load_work_group_id, 0, 3, bit_size); } static inline nir_ssa_def * nir_load_work_group_id_zero_base(nir_builder *build) { return nir_load_system_value(build, nir_intrinsic_load_work_group_id_zero_base, 0, 3, 32); } #endif /* _NIR_BUILDER_OPCODES_ */