mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-17 22:05:08 +00:00
Merge tag 'drm-fixes-5.4-2019-10-30' of git://people.freedesktop.org/~agd5f/linux into drm-fixes
drm-fixes-5.4-2019-10-30: amdgpu: - clang fixes - Updated golden settings - GPUVM fixes for navi - Navi sdma fix - Navi display fixes - Freesync fix - Gamma fix for DCN - DP dongle detection fix - Fix for undervolting on vega10 radeon: - enable kexec fix for PPC scheduler: - set an error on fence if hw job failed Signed-off-by: Dave Airlie <airlied@redhat.com> From: Alex Deucher <alexdeucher@gmail.com> Link: https://patchwork.freedesktop.org/patch/msgid/20191030162339.44366-1-alexander.deucher@amd.com
This commit is contained in:
commit
e54de91a24
@ -218,7 +218,7 @@ static struct dma_fence *amdgpu_job_run(struct drm_sched_job *sched_job)
|
|||||||
struct amdgpu_ring *ring = to_amdgpu_ring(sched_job->sched);
|
struct amdgpu_ring *ring = to_amdgpu_ring(sched_job->sched);
|
||||||
struct dma_fence *fence = NULL, *finished;
|
struct dma_fence *fence = NULL, *finished;
|
||||||
struct amdgpu_job *job;
|
struct amdgpu_job *job;
|
||||||
int r;
|
int r = 0;
|
||||||
|
|
||||||
job = to_amdgpu_job(sched_job);
|
job = to_amdgpu_job(sched_job);
|
||||||
finished = &job->base.s_fence->finished;
|
finished = &job->base.s_fence->finished;
|
||||||
@ -243,6 +243,8 @@ static struct dma_fence *amdgpu_job_run(struct drm_sched_job *sched_job)
|
|||||||
job->fence = dma_fence_get(fence);
|
job->fence = dma_fence_get(fence);
|
||||||
|
|
||||||
amdgpu_job_free_resources(job);
|
amdgpu_job_free_resources(job);
|
||||||
|
|
||||||
|
fence = r ? ERR_PTR(r) : fence;
|
||||||
return fence;
|
return fence;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,7 +93,7 @@ static const struct soc15_reg_golden golden_settings_gc_10_1[] =
|
|||||||
{
|
{
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCB_HW_CONTROL_4, 0xffffffff, 0x00400014),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCB_HW_CONTROL_4, 0xffffffff, 0x00400014),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_CPF_CLK_CTRL, 0xfcff8fff, 0xf8000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_CPF_CLK_CTRL, 0xfcff8fff, 0xf8000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SPI_CLK_CTRL, 0xc0000000, 0xc0000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SPI_CLK_CTRL, 0xcd000000, 0x0d000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQ_CLK_CTRL, 0x60000ff0, 0x60000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQ_CLK_CTRL, 0x60000ff0, 0x60000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQG_CLK_CTRL, 0x40000000, 0x40000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQG_CLK_CTRL, 0x40000000, 0x40000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_VGT_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_VGT_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
||||||
@ -140,7 +140,7 @@ static const struct soc15_reg_golden golden_settings_gc_10_1_1[] =
|
|||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCB_HW_CONTROL_4, 0xffffffff, 0x003c0014),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCB_HW_CONTROL_4, 0xffffffff, 0x003c0014),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_GS_NGG_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_GS_NGG_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_IA_CLK_CTRL, 0xffff0fff, 0xffff0100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_IA_CLK_CTRL, 0xffff0fff, 0xffff0100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SPI_CLK_CTRL, 0xc0000000, 0xc0000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SPI_CLK_CTRL, 0xcd000000, 0x0d000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQ_CLK_CTRL, 0xf8ff0fff, 0x60000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQ_CLK_CTRL, 0xf8ff0fff, 0x60000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQG_CLK_CTRL, 0x40000ff0, 0x40000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQG_CLK_CTRL, 0x40000ff0, 0x40000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_VGT_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_VGT_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
||||||
@ -179,7 +179,7 @@ static const struct soc15_reg_golden golden_settings_gc_10_1_2[] =
|
|||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCB_HW_CONTROL_4, 0x003e001f, 0x003c0014),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCB_HW_CONTROL_4, 0x003e001f, 0x003c0014),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_GS_NGG_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_GS_NGG_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_IA_CLK_CTRL, 0xffff0fff, 0xffff0100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_IA_CLK_CTRL, 0xffff0fff, 0xffff0100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SPI_CLK_CTRL, 0xff7f0fff, 0xc0000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SPI_CLK_CTRL, 0xff7f0fff, 0x0d000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQ_CLK_CTRL, 0xffffcfff, 0x60000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQ_CLK_CTRL, 0xffffcfff, 0x60000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQG_CLK_CTRL, 0xffff0fff, 0x40000100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_SQG_CLK_CTRL, 0xffff0fff, 0x40000100),
|
||||||
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_VGT_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
SOC15_REG_GOLDEN_VALUE(GC, 0, mmCGTT_VGT_CLK_CTRL, 0xffff8fff, 0xffff8100),
|
||||||
|
@ -151,6 +151,15 @@ static void gfxhub_v2_0_init_cache_regs(struct amdgpu_device *adev)
|
|||||||
WREG32_SOC15(GC, 0, mmGCVM_L2_CNTL2, tmp);
|
WREG32_SOC15(GC, 0, mmGCVM_L2_CNTL2, tmp);
|
||||||
|
|
||||||
tmp = mmGCVM_L2_CNTL3_DEFAULT;
|
tmp = mmGCVM_L2_CNTL3_DEFAULT;
|
||||||
|
if (adev->gmc.translate_further) {
|
||||||
|
tmp = REG_SET_FIELD(tmp, GCVM_L2_CNTL3, BANK_SELECT, 12);
|
||||||
|
tmp = REG_SET_FIELD(tmp, GCVM_L2_CNTL3,
|
||||||
|
L2_CACHE_BIGK_FRAGMENT_SIZE, 9);
|
||||||
|
} else {
|
||||||
|
tmp = REG_SET_FIELD(tmp, GCVM_L2_CNTL3, BANK_SELECT, 9);
|
||||||
|
tmp = REG_SET_FIELD(tmp, GCVM_L2_CNTL3,
|
||||||
|
L2_CACHE_BIGK_FRAGMENT_SIZE, 6);
|
||||||
|
}
|
||||||
WREG32_SOC15(GC, 0, mmGCVM_L2_CNTL3, tmp);
|
WREG32_SOC15(GC, 0, mmGCVM_L2_CNTL3, tmp);
|
||||||
|
|
||||||
tmp = mmGCVM_L2_CNTL4_DEFAULT;
|
tmp = mmGCVM_L2_CNTL4_DEFAULT;
|
||||||
|
@ -309,6 +309,7 @@ static void gmc_v10_0_flush_gpu_tlb(struct amdgpu_device *adev, uint32_t vmid,
|
|||||||
|
|
||||||
job->vm_pd_addr = amdgpu_gmc_pd_addr(adev->gart.bo);
|
job->vm_pd_addr = amdgpu_gmc_pd_addr(adev->gart.bo);
|
||||||
job->vm_needs_flush = true;
|
job->vm_needs_flush = true;
|
||||||
|
job->ibs->ptr[job->ibs->length_dw++] = ring->funcs->nop;
|
||||||
amdgpu_ring_pad_ib(ring, &job->ibs[0]);
|
amdgpu_ring_pad_ib(ring, &job->ibs[0]);
|
||||||
r = amdgpu_job_submit(job, &adev->mman.entity,
|
r = amdgpu_job_submit(job, &adev->mman.entity,
|
||||||
AMDGPU_FENCE_OWNER_UNDEFINED, &fence);
|
AMDGPU_FENCE_OWNER_UNDEFINED, &fence);
|
||||||
|
@ -137,6 +137,15 @@ static void mmhub_v2_0_init_cache_regs(struct amdgpu_device *adev)
|
|||||||
WREG32_SOC15(MMHUB, 0, mmMMVM_L2_CNTL2, tmp);
|
WREG32_SOC15(MMHUB, 0, mmMMVM_L2_CNTL2, tmp);
|
||||||
|
|
||||||
tmp = mmMMVM_L2_CNTL3_DEFAULT;
|
tmp = mmMMVM_L2_CNTL3_DEFAULT;
|
||||||
|
if (adev->gmc.translate_further) {
|
||||||
|
tmp = REG_SET_FIELD(tmp, MMVM_L2_CNTL3, BANK_SELECT, 12);
|
||||||
|
tmp = REG_SET_FIELD(tmp, MMVM_L2_CNTL3,
|
||||||
|
L2_CACHE_BIGK_FRAGMENT_SIZE, 9);
|
||||||
|
} else {
|
||||||
|
tmp = REG_SET_FIELD(tmp, MMVM_L2_CNTL3, BANK_SELECT, 9);
|
||||||
|
tmp = REG_SET_FIELD(tmp, MMVM_L2_CNTL3,
|
||||||
|
L2_CACHE_BIGK_FRAGMENT_SIZE, 6);
|
||||||
|
}
|
||||||
WREG32_SOC15(MMHUB, 0, mmMMVM_L2_CNTL3, tmp);
|
WREG32_SOC15(MMHUB, 0, mmMMVM_L2_CNTL3, tmp);
|
||||||
|
|
||||||
tmp = mmMMVM_L2_CNTL4_DEFAULT;
|
tmp = mmMMVM_L2_CNTL4_DEFAULT;
|
||||||
|
@ -254,6 +254,7 @@ static const struct soc15_reg_golden golden_settings_sdma_4_3[] = {
|
|||||||
SOC15_REG_GOLDEN_VALUE(SDMA0, 0, mmSDMA0_RLC0_RB_WPTR_POLL_CNTL, 0xfffffff7, 0x00403000),
|
SOC15_REG_GOLDEN_VALUE(SDMA0, 0, mmSDMA0_RLC0_RB_WPTR_POLL_CNTL, 0xfffffff7, 0x00403000),
|
||||||
SOC15_REG_GOLDEN_VALUE(SDMA0, 0, mmSDMA0_RLC1_RB_WPTR_POLL_CNTL, 0xfffffff7, 0x00403000),
|
SOC15_REG_GOLDEN_VALUE(SDMA0, 0, mmSDMA0_RLC1_RB_WPTR_POLL_CNTL, 0xfffffff7, 0x00403000),
|
||||||
SOC15_REG_GOLDEN_VALUE(SDMA0, 0, mmSDMA0_UTCL1_PAGE, 0x000003ff, 0x000003c0),
|
SOC15_REG_GOLDEN_VALUE(SDMA0, 0, mmSDMA0_UTCL1_PAGE, 0x000003ff, 0x000003c0),
|
||||||
|
SOC15_REG_GOLDEN_VALUE(SDMA0, 0, mmSDMA0_UTCL1_WATERMK, 0xfc000000, 0x00000000)
|
||||||
};
|
};
|
||||||
|
|
||||||
static u32 sdma_v4_0_get_reg_offset(struct amdgpu_device *adev,
|
static u32 sdma_v4_0_get_reg_offset(struct amdgpu_device *adev,
|
||||||
|
@ -24,15 +24,20 @@
|
|||||||
# It calculates Bandwidth and Watermarks values for HW programming
|
# It calculates Bandwidth and Watermarks values for HW programming
|
||||||
#
|
#
|
||||||
|
|
||||||
ifneq ($(call cc-option, -mpreferred-stack-boundary=4),)
|
calcs_ccflags := -mhard-float -msse
|
||||||
cc_stack_align := -mpreferred-stack-boundary=4
|
|
||||||
else ifneq ($(call cc-option, -mstack-alignment=16),)
|
ifdef CONFIG_CC_IS_GCC
|
||||||
cc_stack_align := -mstack-alignment=16
|
ifeq ($(call cc-ifversion, -lt, 0701, y), y)
|
||||||
|
IS_OLD_GCC = 1
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
calcs_ccflags := -mhard-float -msse $(cc_stack_align)
|
ifdef IS_OLD_GCC
|
||||||
|
# Stack alignment mismatch, proceed with caution.
|
||||||
ifdef CONFIG_CC_IS_CLANG
|
# GCC < 7.1 cannot compile code using `double` and -mpreferred-stack-boundary=3
|
||||||
|
# (8B stack alignment).
|
||||||
|
calcs_ccflags += -mpreferred-stack-boundary=4
|
||||||
|
else
|
||||||
calcs_ccflags += -msse2
|
calcs_ccflags += -msse2
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -580,6 +580,10 @@ static bool construct(struct dc *dc,
|
|||||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||||
// Allocate memory for the vm_helper
|
// Allocate memory for the vm_helper
|
||||||
dc->vm_helper = kzalloc(sizeof(struct vm_helper), GFP_KERNEL);
|
dc->vm_helper = kzalloc(sizeof(struct vm_helper), GFP_KERNEL);
|
||||||
|
if (!dc->vm_helper) {
|
||||||
|
dm_error("%s: failed to create dc->vm_helper\n", __func__);
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
memcpy(&dc->bb_overrides, &init_params->bb_overrides, sizeof(dc->bb_overrides));
|
memcpy(&dc->bb_overrides, &init_params->bb_overrides, sizeof(dc->bb_overrides));
|
||||||
|
@ -2767,6 +2767,15 @@ void core_link_enable_stream(
|
|||||||
CONTROLLER_DP_TEST_PATTERN_VIDEOMODE,
|
CONTROLLER_DP_TEST_PATTERN_VIDEOMODE,
|
||||||
COLOR_DEPTH_UNDEFINED);
|
COLOR_DEPTH_UNDEFINED);
|
||||||
|
|
||||||
|
/* This second call is needed to reconfigure the DIG
|
||||||
|
* as a workaround for the incorrect value being applied
|
||||||
|
* from transmitter control.
|
||||||
|
*/
|
||||||
|
if (!dc_is_virtual_signal(pipe_ctx->stream->signal))
|
||||||
|
stream->link->link_enc->funcs->setup(
|
||||||
|
stream->link->link_enc,
|
||||||
|
pipe_ctx->stream->signal);
|
||||||
|
|
||||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||||
if (pipe_ctx->stream->timing.flags.DSC) {
|
if (pipe_ctx->stream->timing.flags.DSC) {
|
||||||
if (dc_is_dp_signal(pipe_ctx->stream->signal) ||
|
if (dc_is_dp_signal(pipe_ctx->stream->signal) ||
|
||||||
|
@ -374,6 +374,7 @@ void dal_ddc_service_i2c_query_dp_dual_mode_adaptor(
|
|||||||
enum display_dongle_type *dongle = &sink_cap->dongle_type;
|
enum display_dongle_type *dongle = &sink_cap->dongle_type;
|
||||||
uint8_t type2_dongle_buf[DP_ADAPTOR_TYPE2_SIZE];
|
uint8_t type2_dongle_buf[DP_ADAPTOR_TYPE2_SIZE];
|
||||||
bool is_type2_dongle = false;
|
bool is_type2_dongle = false;
|
||||||
|
int retry_count = 2;
|
||||||
struct dp_hdmi_dongle_signature_data *dongle_signature;
|
struct dp_hdmi_dongle_signature_data *dongle_signature;
|
||||||
|
|
||||||
/* Assume we have no valid DP passive dongle connected */
|
/* Assume we have no valid DP passive dongle connected */
|
||||||
@ -386,13 +387,24 @@ void dal_ddc_service_i2c_query_dp_dual_mode_adaptor(
|
|||||||
DP_HDMI_DONGLE_ADDRESS,
|
DP_HDMI_DONGLE_ADDRESS,
|
||||||
type2_dongle_buf,
|
type2_dongle_buf,
|
||||||
sizeof(type2_dongle_buf))) {
|
sizeof(type2_dongle_buf))) {
|
||||||
*dongle = DISPLAY_DONGLE_DP_DVI_DONGLE;
|
/* Passive HDMI dongles can sometimes fail here without retrying*/
|
||||||
sink_cap->max_hdmi_pixel_clock = DP_ADAPTOR_DVI_MAX_TMDS_CLK;
|
while (retry_count > 0) {
|
||||||
|
if (i2c_read(ddc,
|
||||||
|
DP_HDMI_DONGLE_ADDRESS,
|
||||||
|
type2_dongle_buf,
|
||||||
|
sizeof(type2_dongle_buf)))
|
||||||
|
break;
|
||||||
|
retry_count--;
|
||||||
|
}
|
||||||
|
if (retry_count == 0) {
|
||||||
|
*dongle = DISPLAY_DONGLE_DP_DVI_DONGLE;
|
||||||
|
sink_cap->max_hdmi_pixel_clock = DP_ADAPTOR_DVI_MAX_TMDS_CLK;
|
||||||
|
|
||||||
CONN_DATA_DETECT(ddc->link, type2_dongle_buf, sizeof(type2_dongle_buf),
|
CONN_DATA_DETECT(ddc->link, type2_dongle_buf, sizeof(type2_dongle_buf),
|
||||||
"DP-DVI passive dongle %dMhz: ",
|
"DP-DVI passive dongle %dMhz: ",
|
||||||
DP_ADAPTOR_DVI_MAX_TMDS_CLK / 1000);
|
DP_ADAPTOR_DVI_MAX_TMDS_CLK / 1000);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check if Type 2 dongle.*/
|
/* Check if Type 2 dongle.*/
|
||||||
|
@ -404,6 +404,9 @@ bool resource_are_streams_timing_synchronizable(
|
|||||||
if (stream1->view_format != stream2->view_format)
|
if (stream1->view_format != stream2->view_format)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
if (stream1->ignore_msa_timing_param || stream2->ignore_msa_timing_param)
|
||||||
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
static bool is_dp_and_hdmi_sharable(
|
static bool is_dp_and_hdmi_sharable(
|
||||||
@ -1540,6 +1543,9 @@ bool dc_is_stream_unchanged(
|
|||||||
if (!are_stream_backends_same(old_stream, stream))
|
if (!are_stream_backends_same(old_stream, stream))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
if (old_stream->ignore_msa_timing_param != stream->ignore_msa_timing_param)
|
||||||
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -393,6 +393,10 @@ bool cm_helper_translate_curve_to_hw_format(
|
|||||||
rgb_resulted[hw_points - 1].green = output_tf->tf_pts.green[start_index];
|
rgb_resulted[hw_points - 1].green = output_tf->tf_pts.green[start_index];
|
||||||
rgb_resulted[hw_points - 1].blue = output_tf->tf_pts.blue[start_index];
|
rgb_resulted[hw_points - 1].blue = output_tf->tf_pts.blue[start_index];
|
||||||
|
|
||||||
|
rgb_resulted[hw_points].red = rgb_resulted[hw_points - 1].red;
|
||||||
|
rgb_resulted[hw_points].green = rgb_resulted[hw_points - 1].green;
|
||||||
|
rgb_resulted[hw_points].blue = rgb_resulted[hw_points - 1].blue;
|
||||||
|
|
||||||
// All 3 color channels have same x
|
// All 3 color channels have same x
|
||||||
corner_points[0].red.x = dc_fixpt_pow(dc_fixpt_from_int(2),
|
corner_points[0].red.x = dc_fixpt_pow(dc_fixpt_from_int(2),
|
||||||
dc_fixpt_from_int(region_start));
|
dc_fixpt_from_int(region_start));
|
||||||
@ -464,13 +468,6 @@ bool cm_helper_translate_curve_to_hw_format(
|
|||||||
|
|
||||||
i = 1;
|
i = 1;
|
||||||
while (i != hw_points + 1) {
|
while (i != hw_points + 1) {
|
||||||
if (dc_fixpt_lt(rgb_plus_1->red, rgb->red))
|
|
||||||
rgb_plus_1->red = rgb->red;
|
|
||||||
if (dc_fixpt_lt(rgb_plus_1->green, rgb->green))
|
|
||||||
rgb_plus_1->green = rgb->green;
|
|
||||||
if (dc_fixpt_lt(rgb_plus_1->blue, rgb->blue))
|
|
||||||
rgb_plus_1->blue = rgb->blue;
|
|
||||||
|
|
||||||
rgb->delta_red = dc_fixpt_sub(rgb_plus_1->red, rgb->red);
|
rgb->delta_red = dc_fixpt_sub(rgb_plus_1->red, rgb->red);
|
||||||
rgb->delta_green = dc_fixpt_sub(rgb_plus_1->green, rgb->green);
|
rgb->delta_green = dc_fixpt_sub(rgb_plus_1->green, rgb->green);
|
||||||
rgb->delta_blue = dc_fixpt_sub(rgb_plus_1->blue, rgb->blue);
|
rgb->delta_blue = dc_fixpt_sub(rgb_plus_1->blue, rgb->blue);
|
||||||
@ -562,6 +559,10 @@ bool cm_helper_translate_curve_to_degamma_hw_format(
|
|||||||
rgb_resulted[hw_points - 1].green = output_tf->tf_pts.green[start_index];
|
rgb_resulted[hw_points - 1].green = output_tf->tf_pts.green[start_index];
|
||||||
rgb_resulted[hw_points - 1].blue = output_tf->tf_pts.blue[start_index];
|
rgb_resulted[hw_points - 1].blue = output_tf->tf_pts.blue[start_index];
|
||||||
|
|
||||||
|
rgb_resulted[hw_points].red = rgb_resulted[hw_points - 1].red;
|
||||||
|
rgb_resulted[hw_points].green = rgb_resulted[hw_points - 1].green;
|
||||||
|
rgb_resulted[hw_points].blue = rgb_resulted[hw_points - 1].blue;
|
||||||
|
|
||||||
corner_points[0].red.x = dc_fixpt_pow(dc_fixpt_from_int(2),
|
corner_points[0].red.x = dc_fixpt_pow(dc_fixpt_from_int(2),
|
||||||
dc_fixpt_from_int(region_start));
|
dc_fixpt_from_int(region_start));
|
||||||
corner_points[0].green.x = corner_points[0].red.x;
|
corner_points[0].green.x = corner_points[0].red.x;
|
||||||
@ -624,13 +625,6 @@ bool cm_helper_translate_curve_to_degamma_hw_format(
|
|||||||
|
|
||||||
i = 1;
|
i = 1;
|
||||||
while (i != hw_points + 1) {
|
while (i != hw_points + 1) {
|
||||||
if (dc_fixpt_lt(rgb_plus_1->red, rgb->red))
|
|
||||||
rgb_plus_1->red = rgb->red;
|
|
||||||
if (dc_fixpt_lt(rgb_plus_1->green, rgb->green))
|
|
||||||
rgb_plus_1->green = rgb->green;
|
|
||||||
if (dc_fixpt_lt(rgb_plus_1->blue, rgb->blue))
|
|
||||||
rgb_plus_1->blue = rgb->blue;
|
|
||||||
|
|
||||||
rgb->delta_red = dc_fixpt_sub(rgb_plus_1->red, rgb->red);
|
rgb->delta_red = dc_fixpt_sub(rgb_plus_1->red, rgb->red);
|
||||||
rgb->delta_green = dc_fixpt_sub(rgb_plus_1->green, rgb->green);
|
rgb->delta_green = dc_fixpt_sub(rgb_plus_1->green, rgb->green);
|
||||||
rgb->delta_blue = dc_fixpt_sub(rgb_plus_1->blue, rgb->blue);
|
rgb->delta_blue = dc_fixpt_sub(rgb_plus_1->blue, rgb->blue);
|
||||||
|
@ -10,15 +10,20 @@ ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
|||||||
DCN20 += dcn20_dsc.o
|
DCN20 += dcn20_dsc.o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq ($(call cc-option, -mpreferred-stack-boundary=4),)
|
CFLAGS_$(AMDDALPATH)/dc/dcn20/dcn20_resource.o := -mhard-float -msse
|
||||||
cc_stack_align := -mpreferred-stack-boundary=4
|
|
||||||
else ifneq ($(call cc-option, -mstack-alignment=16),)
|
ifdef CONFIG_CC_IS_GCC
|
||||||
cc_stack_align := -mstack-alignment=16
|
ifeq ($(call cc-ifversion, -lt, 0701, y), y)
|
||||||
|
IS_OLD_GCC = 1
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CFLAGS_$(AMDDALPATH)/dc/dcn20/dcn20_resource.o := -mhard-float -msse $(cc_stack_align)
|
ifdef IS_OLD_GCC
|
||||||
|
# Stack alignment mismatch, proceed with caution.
|
||||||
ifdef CONFIG_CC_IS_CLANG
|
# GCC < 7.1 cannot compile code using `double` and -mpreferred-stack-boundary=3
|
||||||
|
# (8B stack alignment).
|
||||||
|
CFLAGS_$(AMDDALPATH)/dc/dcn20/dcn20_resource.o += -mpreferred-stack-boundary=4
|
||||||
|
else
|
||||||
CFLAGS_$(AMDDALPATH)/dc/dcn20/dcn20_resource.o += -msse2
|
CFLAGS_$(AMDDALPATH)/dc/dcn20/dcn20_resource.o += -msse2
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -814,7 +814,7 @@ static const struct resource_caps res_cap_nv14 = {
|
|||||||
.num_audio = 6,
|
.num_audio = 6,
|
||||||
.num_stream_encoder = 5,
|
.num_stream_encoder = 5,
|
||||||
.num_pll = 5,
|
.num_pll = 5,
|
||||||
.num_dwb = 0,
|
.num_dwb = 1,
|
||||||
.num_ddc = 5,
|
.num_ddc = 5,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3,15 +3,20 @@
|
|||||||
|
|
||||||
DCN21 = dcn21_hubp.o dcn21_hubbub.o dcn21_resource.o
|
DCN21 = dcn21_hubp.o dcn21_hubbub.o dcn21_resource.o
|
||||||
|
|
||||||
ifneq ($(call cc-option, -mpreferred-stack-boundary=4),)
|
CFLAGS_$(AMDDALPATH)/dc/dcn21/dcn21_resource.o := -mhard-float -msse
|
||||||
cc_stack_align := -mpreferred-stack-boundary=4
|
|
||||||
else ifneq ($(call cc-option, -mstack-alignment=16),)
|
ifdef CONFIG_CC_IS_GCC
|
||||||
cc_stack_align := -mstack-alignment=16
|
ifeq ($(call cc-ifversion, -lt, 0701, y), y)
|
||||||
|
IS_OLD_GCC = 1
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CFLAGS_$(AMDDALPATH)/dc/dcn21/dcn21_resource.o := -mhard-float -msse $(cc_stack_align)
|
ifdef IS_OLD_GCC
|
||||||
|
# Stack alignment mismatch, proceed with caution.
|
||||||
ifdef CONFIG_CC_IS_CLANG
|
# GCC < 7.1 cannot compile code using `double` and -mpreferred-stack-boundary=3
|
||||||
|
# (8B stack alignment).
|
||||||
|
CFLAGS_$(AMDDALPATH)/dc/dcn21/dcn21_resource.o += -mpreferred-stack-boundary=4
|
||||||
|
else
|
||||||
CFLAGS_$(AMDDALPATH)/dc/dcn21/dcn21_resource.o += -msse2
|
CFLAGS_$(AMDDALPATH)/dc/dcn21/dcn21_resource.o += -msse2
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -24,15 +24,20 @@
|
|||||||
# It provides the general basic services required by other DAL
|
# It provides the general basic services required by other DAL
|
||||||
# subcomponents.
|
# subcomponents.
|
||||||
|
|
||||||
ifneq ($(call cc-option, -mpreferred-stack-boundary=4),)
|
dml_ccflags := -mhard-float -msse
|
||||||
cc_stack_align := -mpreferred-stack-boundary=4
|
|
||||||
else ifneq ($(call cc-option, -mstack-alignment=16),)
|
ifdef CONFIG_CC_IS_GCC
|
||||||
cc_stack_align := -mstack-alignment=16
|
ifeq ($(call cc-ifversion, -lt, 0701, y), y)
|
||||||
|
IS_OLD_GCC = 1
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
dml_ccflags := -mhard-float -msse $(cc_stack_align)
|
ifdef IS_OLD_GCC
|
||||||
|
# Stack alignment mismatch, proceed with caution.
|
||||||
ifdef CONFIG_CC_IS_CLANG
|
# GCC < 7.1 cannot compile code using `double` and -mpreferred-stack-boundary=3
|
||||||
|
# (8B stack alignment).
|
||||||
|
dml_ccflags += -mpreferred-stack-boundary=4
|
||||||
|
else
|
||||||
dml_ccflags += -msse2
|
dml_ccflags += -msse2
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -2577,7 +2577,8 @@ static void dml20_DISPCLKDPPCLKDCFCLKDeepSleepPrefetchParametersWatermarksAndPer
|
|||||||
mode_lib->vba.MinActiveDRAMClockChangeMargin
|
mode_lib->vba.MinActiveDRAMClockChangeMargin
|
||||||
+ mode_lib->vba.DRAMClockChangeLatency;
|
+ mode_lib->vba.DRAMClockChangeLatency;
|
||||||
|
|
||||||
if (mode_lib->vba.MinActiveDRAMClockChangeMargin > 0) {
|
if (mode_lib->vba.MinActiveDRAMClockChangeMargin > 50) {
|
||||||
|
mode_lib->vba.DRAMClockChangeWatermark += 25;
|
||||||
mode_lib->vba.DRAMClockChangeSupport[0][0] = dm_dram_clock_change_vactive;
|
mode_lib->vba.DRAMClockChangeSupport[0][0] = dm_dram_clock_change_vactive;
|
||||||
} else {
|
} else {
|
||||||
if (mode_lib->vba.SynchronizedVBlank || mode_lib->vba.NumberOfActivePlanes == 1) {
|
if (mode_lib->vba.SynchronizedVBlank || mode_lib->vba.NumberOfActivePlanes == 1) {
|
||||||
|
@ -1,15 +1,20 @@
|
|||||||
#
|
#
|
||||||
# Makefile for the 'dsc' sub-component of DAL.
|
# Makefile for the 'dsc' sub-component of DAL.
|
||||||
|
|
||||||
ifneq ($(call cc-option, -mpreferred-stack-boundary=4),)
|
dsc_ccflags := -mhard-float -msse
|
||||||
cc_stack_align := -mpreferred-stack-boundary=4
|
|
||||||
else ifneq ($(call cc-option, -mstack-alignment=16),)
|
ifdef CONFIG_CC_IS_GCC
|
||||||
cc_stack_align := -mstack-alignment=16
|
ifeq ($(call cc-ifversion, -lt, 0701, y), y)
|
||||||
|
IS_OLD_GCC = 1
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
dsc_ccflags := -mhard-float -msse $(cc_stack_align)
|
ifdef IS_OLD_GCC
|
||||||
|
# Stack alignment mismatch, proceed with caution.
|
||||||
ifdef CONFIG_CC_IS_CLANG
|
# GCC < 7.1 cannot compile code using `double` and -mpreferred-stack-boundary=3
|
||||||
|
# (8B stack alignment).
|
||||||
|
dsc_ccflags += -mpreferred-stack-boundary=4
|
||||||
|
else
|
||||||
dsc_ccflags += -msse2
|
dsc_ccflags += -msse2
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -5098,9 +5098,7 @@ static void vega10_odn_update_soc_table(struct pp_hwmgr *hwmgr,
|
|||||||
|
|
||||||
if (type == PP_OD_EDIT_SCLK_VDDC_TABLE) {
|
if (type == PP_OD_EDIT_SCLK_VDDC_TABLE) {
|
||||||
podn_vdd_dep = &data->odn_dpm_table.vdd_dep_on_sclk;
|
podn_vdd_dep = &data->odn_dpm_table.vdd_dep_on_sclk;
|
||||||
for (i = 0; i < podn_vdd_dep->count - 1; i++)
|
for (i = 0; i < podn_vdd_dep->count; i++)
|
||||||
od_vddc_lookup_table->entries[i].us_vdd = podn_vdd_dep->entries[i].vddc;
|
|
||||||
if (od_vddc_lookup_table->entries[i].us_vdd < podn_vdd_dep->entries[i].vddc)
|
|
||||||
od_vddc_lookup_table->entries[i].us_vdd = podn_vdd_dep->entries[i].vddc;
|
od_vddc_lookup_table->entries[i].us_vdd = podn_vdd_dep->entries[i].vddc;
|
||||||
} else if (type == PP_OD_EDIT_MCLK_VDDC_TABLE) {
|
} else if (type == PP_OD_EDIT_MCLK_VDDC_TABLE) {
|
||||||
podn_vdd_dep = &data->odn_dpm_table.vdd_dep_on_mclk;
|
podn_vdd_dep = &data->odn_dpm_table.vdd_dep_on_mclk;
|
||||||
|
@ -379,11 +379,25 @@ radeon_pci_remove(struct pci_dev *pdev)
|
|||||||
static void
|
static void
|
||||||
radeon_pci_shutdown(struct pci_dev *pdev)
|
radeon_pci_shutdown(struct pci_dev *pdev)
|
||||||
{
|
{
|
||||||
|
#ifdef CONFIG_PPC64
|
||||||
|
struct drm_device *ddev = pci_get_drvdata(pdev);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* if we are running in a VM, make sure the device
|
/* if we are running in a VM, make sure the device
|
||||||
* torn down properly on reboot/shutdown
|
* torn down properly on reboot/shutdown
|
||||||
*/
|
*/
|
||||||
if (radeon_device_is_virtual())
|
if (radeon_device_is_virtual())
|
||||||
radeon_pci_remove(pdev);
|
radeon_pci_remove(pdev);
|
||||||
|
|
||||||
|
#ifdef CONFIG_PPC64
|
||||||
|
/* Some adapters need to be suspended before a
|
||||||
|
* shutdown occurs in order to prevent an error
|
||||||
|
* during kexec.
|
||||||
|
* Make this power specific becauase it breaks
|
||||||
|
* some non-power boards.
|
||||||
|
*/
|
||||||
|
radeon_suspend_kms(ddev, true, true, false);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static int radeon_pmops_suspend(struct device *dev)
|
static int radeon_pmops_suspend(struct device *dev)
|
||||||
|
@ -479,6 +479,7 @@ void drm_sched_resubmit_jobs(struct drm_gpu_scheduler *sched)
|
|||||||
struct drm_sched_job *s_job, *tmp;
|
struct drm_sched_job *s_job, *tmp;
|
||||||
uint64_t guilty_context;
|
uint64_t guilty_context;
|
||||||
bool found_guilty = false;
|
bool found_guilty = false;
|
||||||
|
struct dma_fence *fence;
|
||||||
|
|
||||||
list_for_each_entry_safe(s_job, tmp, &sched->ring_mirror_list, node) {
|
list_for_each_entry_safe(s_job, tmp, &sched->ring_mirror_list, node) {
|
||||||
struct drm_sched_fence *s_fence = s_job->s_fence;
|
struct drm_sched_fence *s_fence = s_job->s_fence;
|
||||||
@ -492,7 +493,16 @@ void drm_sched_resubmit_jobs(struct drm_gpu_scheduler *sched)
|
|||||||
dma_fence_set_error(&s_fence->finished, -ECANCELED);
|
dma_fence_set_error(&s_fence->finished, -ECANCELED);
|
||||||
|
|
||||||
dma_fence_put(s_job->s_fence->parent);
|
dma_fence_put(s_job->s_fence->parent);
|
||||||
s_job->s_fence->parent = sched->ops->run_job(s_job);
|
fence = sched->ops->run_job(s_job);
|
||||||
|
|
||||||
|
if (IS_ERR_OR_NULL(fence)) {
|
||||||
|
s_job->s_fence->parent = NULL;
|
||||||
|
dma_fence_set_error(&s_fence->finished, PTR_ERR(fence));
|
||||||
|
} else {
|
||||||
|
s_job->s_fence->parent = fence;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_sched_resubmit_jobs);
|
EXPORT_SYMBOL(drm_sched_resubmit_jobs);
|
||||||
@ -720,7 +730,7 @@ static int drm_sched_main(void *param)
|
|||||||
fence = sched->ops->run_job(sched_job);
|
fence = sched->ops->run_job(sched_job);
|
||||||
drm_sched_fence_scheduled(s_fence);
|
drm_sched_fence_scheduled(s_fence);
|
||||||
|
|
||||||
if (fence) {
|
if (!IS_ERR_OR_NULL(fence)) {
|
||||||
s_fence->parent = dma_fence_get(fence);
|
s_fence->parent = dma_fence_get(fence);
|
||||||
r = dma_fence_add_callback(fence, &sched_job->cb,
|
r = dma_fence_add_callback(fence, &sched_job->cb,
|
||||||
drm_sched_process_job);
|
drm_sched_process_job);
|
||||||
@ -730,8 +740,11 @@ static int drm_sched_main(void *param)
|
|||||||
DRM_ERROR("fence add callback failed (%d)\n",
|
DRM_ERROR("fence add callback failed (%d)\n",
|
||||||
r);
|
r);
|
||||||
dma_fence_put(fence);
|
dma_fence_put(fence);
|
||||||
} else
|
} else {
|
||||||
|
|
||||||
|
dma_fence_set_error(&s_fence->finished, PTR_ERR(fence));
|
||||||
drm_sched_process_job(NULL, &sched_job->cb);
|
drm_sched_process_job(NULL, &sched_job->cb);
|
||||||
|
}
|
||||||
|
|
||||||
wake_up(&sched->job_scheduled);
|
wake_up(&sched->job_scheduled);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user