[Mesa-dev] [PATCH 1/3] gallivm: Emit vector selects.
Roland Scheidegger
sroland at vmware.com
Mon Apr 22 03:49:12 PDT 2013
Am 20.04.2013 10:57, schrieb jfonseca at vmware.com:
> From: José Fonseca <jfonseca at vmware.com>
>
> They are supported on LLVM 3.1, at least on x86. (I haven't tested on PPC
> though.)
>
> Actually lp_build_linear_mip_levels() already has been emitting them for
> some time.
>
> This avoids intrinsics, which tend to be an obstacle for certain
> optimization passes.
> ---
> src/gallium/auxiliary/gallivm/lp_bld_logic.c | 14 ++------------
> 1 file changed, 2 insertions(+), 12 deletions(-)
>
> diff --git a/src/gallium/auxiliary/gallivm/lp_bld_logic.c b/src/gallium/auxiliary/gallivm/lp_bld_logic.c
> index f56b61b..cdb7e0a 100644
> --- a/src/gallium/auxiliary/gallivm/lp_bld_logic.c
> +++ b/src/gallium/auxiliary/gallivm/lp_bld_logic.c
> @@ -458,20 +458,10 @@ lp_build_select(struct lp_build_context *bld,
> mask = LLVMBuildTrunc(builder, mask, LLVMInt1TypeInContext(lc), "");
> res = LLVMBuildSelect(builder, mask, a, b, "");
> }
> - else if (0) {
> + else if (HAVE_LLVM >= 0x301) {
> /* Generate a vector select.
> *
> - * XXX: Using vector selects would avoid emitting intrinsics, but they aren't
> - * properly supported yet.
> - *
> - * LLVM 3.0 includes experimental support provided the -promote-elements
> - * options is passed to LLVM's command line (e.g., via
> - * llvm::cl::ParseCommandLineOptions), but resulting code quality is much
> - * worse, probably because some optimization passes don't know how to
> - * handle vector selects.
> - *
> - * See also:
> - * - http://lists.cs.uiuc.edu/pipermail/llvmdev/2011-October/043659.html
> + * Only supported on LLVM 3.1 onwards
> */
>
> /* Convert the mask to a vector of booleans.
>
Series looks good to me.
Roland
More information about the mesa-dev
mailing list