From: Matt Turner Date: Mon, 30 Nov 2015 20:18:27 +0000 (-0800) Subject: glsl: Implement all(v) as all_equal(v, true). X-Git-Tag: upstream/17.1.0~13617 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=21cd298aec1c6cb1d6853ccd3de53e45c617fd0a;p=platform%2Fupstream%2Fmesa.git glsl: Implement all(v) as all_equal(v, true). Reviewed-by: Ian Romanick --- diff --git a/src/glsl/builtin_functions.cpp b/src/glsl/builtin_functions.cpp index 2487a2b..602852a 100644 --- a/src/glsl/builtin_functions.cpp +++ b/src/glsl/builtin_functions.cpp @@ -4392,20 +4392,8 @@ builtin_builder::_all(const glsl_type *type) ir_variable *v = in_var(type, "v"); MAKE_SIG(glsl_type::bool_type, always_available, 1, v); - switch (type->vector_elements) { - case 2: - body.emit(ret(logic_and(swizzle_x(v), swizzle_y(v)))); - break; - case 3: - body.emit(ret(logic_and(logic_and(swizzle_x(v), swizzle_y(v)), - swizzle_z(v)))); - break; - case 4: - body.emit(ret(logic_and(logic_and(logic_and(swizzle_x(v), swizzle_y(v)), - swizzle_z(v)), - swizzle_w(v)))); - break; - } + const unsigned vec_elem = v->type->vector_elements; + body.emit(ret(expr(ir_binop_all_equal, v, imm(true, vec_elem)))); return sig; }