amd/common: remove has_ds_bpermute argument from ac_build_ddxy
Reviewed-by: Marek Olšák <marek.olsak@amd.com>
This commit is contained in:
@@ -972,7 +972,6 @@ ac_get_thread_id(struct ac_llvm_context *ctx)
|
||||
*/
|
||||
LLVMValueRef
|
||||
ac_build_ddxy(struct ac_llvm_context *ctx,
|
||||
bool has_ds_bpermute,
|
||||
uint32_t mask,
|
||||
int idx,
|
||||
LLVMValueRef val)
|
||||
@@ -980,7 +979,7 @@ ac_build_ddxy(struct ac_llvm_context *ctx,
|
||||
LLVMValueRef tl, trbl, args[2];
|
||||
LLVMValueRef result;
|
||||
|
||||
if (has_ds_bpermute) {
|
||||
if (ctx->chip_class >= VI) {
|
||||
LLVMValueRef thread_id, tl_tid, trbl_tid;
|
||||
thread_id = ac_get_thread_id(ctx);
|
||||
|
||||
|
@@ -194,7 +194,6 @@ ac_get_thread_id(struct ac_llvm_context *ctx);
|
||||
|
||||
LLVMValueRef
|
||||
ac_build_ddxy(struct ac_llvm_context *ctx,
|
||||
bool has_ds_bpermute,
|
||||
uint32_t mask,
|
||||
int idx,
|
||||
LLVMValueRef val);
|
||||
|
@@ -1414,7 +1414,6 @@ static LLVMValueRef emit_ddxy(struct ac_nir_context *ctx,
|
||||
unsigned mask;
|
||||
int idx;
|
||||
LLVMValueRef result;
|
||||
bool has_ds_bpermute = ctx->abi->chip_class >= VI;
|
||||
|
||||
if (op == nir_op_fddx_fine || op == nir_op_fddx)
|
||||
mask = AC_TID_MASK_LEFT;
|
||||
@@ -1431,9 +1430,7 @@ static LLVMValueRef emit_ddxy(struct ac_nir_context *ctx,
|
||||
else
|
||||
idx = 2;
|
||||
|
||||
result = ac_build_ddxy(&ctx->ac, has_ds_bpermute,
|
||||
mask, idx,
|
||||
src0);
|
||||
result = ac_build_ddxy(&ctx->ac, mask, idx, src0);
|
||||
return result;
|
||||
}
|
||||
|
||||
|
@@ -1045,7 +1045,6 @@ struct pipe_screen *radeonsi_screen_create(struct radeon_winsys *ws,
|
||||
sscreen->b.info.pfp_fw_version >= 79 &&
|
||||
sscreen->b.info.me_fw_version >= 142);
|
||||
|
||||
sscreen->has_ds_bpermute = sscreen->b.chip_class >= VI;
|
||||
sscreen->has_msaa_sample_loc_bug = (sscreen->b.family >= CHIP_POLARIS10 &&
|
||||
sscreen->b.family <= CHIP_POLARIS12) ||
|
||||
sscreen->b.family == CHIP_VEGA10 ||
|
||||
|
@@ -94,7 +94,6 @@ struct si_screen {
|
||||
bool has_clear_state;
|
||||
bool has_distributed_tess;
|
||||
bool has_draw_indirect_multi;
|
||||
bool has_ds_bpermute;
|
||||
bool has_msaa_sample_loc_bug;
|
||||
bool dpbb_allowed;
|
||||
bool dfsm_allowed;
|
||||
|
@@ -3653,8 +3653,7 @@ static void si_llvm_emit_ddxy(
|
||||
idx = (opcode == TGSI_OPCODE_DDX || opcode == TGSI_OPCODE_DDX_FINE) ? 1 : 2;
|
||||
|
||||
val = LLVMBuildBitCast(gallivm->builder, emit_data->args[0], ctx->i32, "");
|
||||
val = ac_build_ddxy(&ctx->ac, ctx->screen->has_ds_bpermute,
|
||||
mask, idx, val);
|
||||
val = ac_build_ddxy(&ctx->ac, mask, idx, val);
|
||||
emit_data->output[emit_data->chan] = val;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user