[Mesa-dev] [PATCH 1/2] radeonsi: move si_nir_load_input_gs() to si_shader.c
Dave Airlie
airlied at gmail.com
Tue Mar 6 00:04:08 UTC 2018
For 1,1.5,2
Reviewed-by: Dave Airlie <airlied at redhat.com>
On 1 March 2018 at 14:24, Timothy Arceri <tarceri at itsqueeze.com> wrote:
> All the tess shader and tgsi equivalents are here and it allows
> use to use llvm_type_is_64bit() in the following patch without
> exposing it externally.
> ---
> src/gallium/drivers/radeonsi/si_shader.c | 20 ++++++++++++++++++++
> src/gallium/drivers/radeonsi/si_shader_internal.h | 9 ---------
> src/gallium/drivers/radeonsi/si_shader_nir.c | 20 --------------------
> 3 files changed, 20 insertions(+), 29 deletions(-)
>
> diff --git a/src/gallium/drivers/radeonsi/si_shader.c b/src/gallium/drivers/radeonsi/si_shader.c
> index 2a50b266f6..f3a37d71a0 100644
> --- a/src/gallium/drivers/radeonsi/si_shader.c
> +++ b/src/gallium/drivers/radeonsi/si_shader.c
> @@ -1682,6 +1682,26 @@ LLVMValueRef si_llvm_load_input_gs(struct ac_shader_abi *abi,
> return LLVMBuildBitCast(ctx->ac.builder, value, type, "");
> }
>
> +static LLVMValueRef si_nir_load_input_gs(struct ac_shader_abi *abi,
> + unsigned location,
> + unsigned driver_location,
> + unsigned component,
> + unsigned num_components,
> + unsigned vertex_index,
> + unsigned const_index,
> + LLVMTypeRef type)
> +{
> + struct si_shader_context *ctx = si_shader_context_from_abi(abi);
> +
> + LLVMValueRef value[8];
> + for (unsigned i = component; i < num_components + component; i++) {
> + value[i] = si_llvm_load_input_gs(&ctx->abi, driver_location / 4,
> + vertex_index, type, i);
> + }
> +
> + return ac_build_varying_gather_values(&ctx->ac, value, num_components, component);
> +}
> +
> static LLVMValueRef fetch_input_gs(
> struct lp_build_tgsi_context *bld_base,
> const struct tgsi_full_src_register *reg,
> diff --git a/src/gallium/drivers/radeonsi/si_shader_internal.h b/src/gallium/drivers/radeonsi/si_shader_internal.h
> index dbe4f2e969..dc73517018 100644
> --- a/src/gallium/drivers/radeonsi/si_shader_internal.h
> +++ b/src/gallium/drivers/radeonsi/si_shader_internal.h
> @@ -337,13 +337,4 @@ void si_llvm_load_input_fs(
>
> bool si_nir_build_llvm(struct si_shader_context *ctx, struct nir_shader *nir);
>
> -LLVMValueRef si_nir_load_input_gs(struct ac_shader_abi *abi,
> - unsigned location,
> - unsigned driver_location,
> - unsigned component,
> - unsigned num_components,
> - unsigned vertex_index,
> - unsigned const_index,
> - LLVMTypeRef type);
> -
> #endif
> diff --git a/src/gallium/drivers/radeonsi/si_shader_nir.c b/src/gallium/drivers/radeonsi/si_shader_nir.c
> index 2ca093e237..fc709d8546 100644
> --- a/src/gallium/drivers/radeonsi/si_shader_nir.c
> +++ b/src/gallium/drivers/radeonsi/si_shader_nir.c
> @@ -771,26 +771,6 @@ static void declare_nir_input_fs(struct si_shader_context *ctx,
> si_llvm_load_input_fs(ctx, input_index, out);
> }
>
> -LLVMValueRef si_nir_load_input_gs(struct ac_shader_abi *abi,
> - unsigned location,
> - unsigned driver_location,
> - unsigned component,
> - unsigned num_components,
> - unsigned vertex_index,
> - unsigned const_index,
> - LLVMTypeRef type)
> -{
> - struct si_shader_context *ctx = si_shader_context_from_abi(abi);
> -
> - LLVMValueRef value[8];
> - for (unsigned i = component; i < num_components + component; i++) {
> - value[i] = si_llvm_load_input_gs(&ctx->abi, driver_location / 4,
> - vertex_index, type, i);
> - }
> -
> - return ac_build_varying_gather_values(&ctx->ac, value, num_components, component);
> -}
> -
> LLVMValueRef
> si_nir_lookup_interp_param(struct ac_shader_abi *abi,
> enum glsl_interp_mode interp, unsigned location)
> --
> 2.14.3
>
> _______________________________________________
> 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