drm/amdgpu/dce11: fix vertical bars appear on monitor
Fixed mc stop and resume hardware programming sequence. Signed-off-by: Vitaly Prosyak <vitaly.prosyak@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
e686941a32
commit
01c02a8b19
1 changed files with 5 additions and 60 deletions
|
@ -565,35 +565,14 @@ static void dce_v11_0_stop_mc_access(struct amdgpu_device *adev,
|
||||||
crtc_enabled = REG_GET_FIELD(RREG32(mmCRTC_CONTROL + crtc_offsets[i]),
|
crtc_enabled = REG_GET_FIELD(RREG32(mmCRTC_CONTROL + crtc_offsets[i]),
|
||||||
CRTC_CONTROL, CRTC_MASTER_EN);
|
CRTC_CONTROL, CRTC_MASTER_EN);
|
||||||
if (crtc_enabled) {
|
if (crtc_enabled) {
|
||||||
#if 0
|
#if 1
|
||||||
u32 frame_count;
|
|
||||||
int j;
|
|
||||||
|
|
||||||
save->crtc_enabled[i] = true;
|
save->crtc_enabled[i] = true;
|
||||||
tmp = RREG32(mmCRTC_BLANK_CONTROL + crtc_offsets[i]);
|
tmp = RREG32(mmCRTC_BLANK_CONTROL + crtc_offsets[i]);
|
||||||
if (REG_GET_FIELD(tmp, CRTC_BLANK_CONTROL, CRTC_BLANK_DATA_EN) == 0) {
|
if (REG_GET_FIELD(tmp, CRTC_BLANK_CONTROL, CRTC_BLANK_DATA_EN) == 0) {
|
||||||
amdgpu_display_vblank_wait(adev, i);
|
/*it is correct only for RGB ; black is 0*/
|
||||||
WREG32(mmCRTC_UPDATE_LOCK + crtc_offsets[i], 1);
|
WREG32(mmCRTC_BLANK_DATA_COLOR + crtc_offsets[i], 0);
|
||||||
tmp = REG_SET_FIELD(tmp, CRTC_BLANK_CONTROL, CRTC_BLANK_DATA_EN, 1);
|
tmp = REG_SET_FIELD(tmp, CRTC_BLANK_CONTROL, CRTC_BLANK_DATA_EN, 1);
|
||||||
WREG32(mmCRTC_BLANK_CONTROL + crtc_offsets[i], tmp);
|
WREG32(mmCRTC_BLANK_CONTROL + crtc_offsets[i], tmp);
|
||||||
WREG32(mmCRTC_UPDATE_LOCK + crtc_offsets[i], 0);
|
|
||||||
}
|
|
||||||
/* wait for the next frame */
|
|
||||||
frame_count = amdgpu_display_vblank_get_counter(adev, i);
|
|
||||||
for (j = 0; j < adev->usec_timeout; j++) {
|
|
||||||
if (amdgpu_display_vblank_get_counter(adev, i) != frame_count)
|
|
||||||
break;
|
|
||||||
udelay(1);
|
|
||||||
}
|
|
||||||
tmp = RREG32(mmGRPH_UPDATE + crtc_offsets[i]);
|
|
||||||
if (REG_GET_FIELD(tmp, GRPH_UPDATE, GRPH_UPDATE_LOCK) == 0) {
|
|
||||||
tmp = REG_SET_FIELD(tmp, GRPH_UPDATE, GRPH_UPDATE_LOCK, 1);
|
|
||||||
WREG32(mmGRPH_UPDATE + crtc_offsets[i], tmp);
|
|
||||||
}
|
|
||||||
tmp = RREG32(mmCRTC_MASTER_UPDATE_LOCK + crtc_offsets[i]);
|
|
||||||
if (REG_GET_FIELD(tmp, CRTC_MASTER_UPDATE_LOCK, MASTER_UPDATE_LOCK) == 0) {
|
|
||||||
tmp = REG_SET_FIELD(tmp, CRTC_MASTER_UPDATE_LOCK, MASTER_UPDATE_LOCK, 1);
|
|
||||||
WREG32(mmCRTC_MASTER_UPDATE_LOCK + crtc_offsets[i], tmp);
|
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
/* XXX this is a hack to avoid strange behavior with EFI on certain systems */
|
/* XXX this is a hack to avoid strange behavior with EFI on certain systems */
|
||||||
|
@ -614,54 +593,20 @@ static void dce_v11_0_stop_mc_access(struct amdgpu_device *adev,
|
||||||
static void dce_v11_0_resume_mc_access(struct amdgpu_device *adev,
|
static void dce_v11_0_resume_mc_access(struct amdgpu_device *adev,
|
||||||
struct amdgpu_mode_mc_save *save)
|
struct amdgpu_mode_mc_save *save)
|
||||||
{
|
{
|
||||||
u32 tmp, frame_count;
|
u32 tmp;
|
||||||
int i, j;
|
int i;
|
||||||
|
|
||||||
/* update crtc base addresses */
|
/* update crtc base addresses */
|
||||||
for (i = 0; i < adev->mode_info.num_crtc; i++) {
|
for (i = 0; i < adev->mode_info.num_crtc; i++) {
|
||||||
WREG32(mmGRPH_PRIMARY_SURFACE_ADDRESS_HIGH + crtc_offsets[i],
|
WREG32(mmGRPH_PRIMARY_SURFACE_ADDRESS_HIGH + crtc_offsets[i],
|
||||||
upper_32_bits(adev->mc.vram_start));
|
upper_32_bits(adev->mc.vram_start));
|
||||||
WREG32(mmGRPH_SECONDARY_SURFACE_ADDRESS_HIGH + crtc_offsets[i],
|
|
||||||
upper_32_bits(adev->mc.vram_start));
|
|
||||||
WREG32(mmGRPH_PRIMARY_SURFACE_ADDRESS + crtc_offsets[i],
|
WREG32(mmGRPH_PRIMARY_SURFACE_ADDRESS + crtc_offsets[i],
|
||||||
(u32)adev->mc.vram_start);
|
(u32)adev->mc.vram_start);
|
||||||
WREG32(mmGRPH_SECONDARY_SURFACE_ADDRESS + crtc_offsets[i],
|
|
||||||
(u32)adev->mc.vram_start);
|
|
||||||
|
|
||||||
if (save->crtc_enabled[i]) {
|
if (save->crtc_enabled[i]) {
|
||||||
tmp = RREG32(mmCRTC_MASTER_UPDATE_MODE + crtc_offsets[i]);
|
|
||||||
if (REG_GET_FIELD(tmp, CRTC_MASTER_UPDATE_MODE, MASTER_UPDATE_MODE) != 3) {
|
|
||||||
tmp = REG_SET_FIELD(tmp, CRTC_MASTER_UPDATE_MODE, MASTER_UPDATE_MODE, 3);
|
|
||||||
WREG32(mmCRTC_MASTER_UPDATE_MODE + crtc_offsets[i], tmp);
|
|
||||||
}
|
|
||||||
tmp = RREG32(mmGRPH_UPDATE + crtc_offsets[i]);
|
|
||||||
if (REG_GET_FIELD(tmp, GRPH_UPDATE, GRPH_UPDATE_LOCK)) {
|
|
||||||
tmp = REG_SET_FIELD(tmp, GRPH_UPDATE, GRPH_UPDATE_LOCK, 0);
|
|
||||||
WREG32(mmGRPH_UPDATE + crtc_offsets[i], tmp);
|
|
||||||
}
|
|
||||||
tmp = RREG32(mmCRTC_MASTER_UPDATE_LOCK + crtc_offsets[i]);
|
|
||||||
if (REG_GET_FIELD(tmp, CRTC_MASTER_UPDATE_LOCK, MASTER_UPDATE_LOCK)) {
|
|
||||||
tmp = REG_SET_FIELD(tmp, CRTC_MASTER_UPDATE_LOCK, MASTER_UPDATE_LOCK, 0);
|
|
||||||
WREG32(mmCRTC_MASTER_UPDATE_LOCK + crtc_offsets[i], tmp);
|
|
||||||
}
|
|
||||||
for (j = 0; j < adev->usec_timeout; j++) {
|
|
||||||
tmp = RREG32(mmGRPH_UPDATE + crtc_offsets[i]);
|
|
||||||
if (REG_GET_FIELD(tmp, GRPH_UPDATE, GRPH_SURFACE_UPDATE_PENDING) == 0)
|
|
||||||
break;
|
|
||||||
udelay(1);
|
|
||||||
}
|
|
||||||
tmp = RREG32(mmCRTC_BLANK_CONTROL + crtc_offsets[i]);
|
tmp = RREG32(mmCRTC_BLANK_CONTROL + crtc_offsets[i]);
|
||||||
tmp = REG_SET_FIELD(tmp, CRTC_BLANK_CONTROL, CRTC_BLANK_DATA_EN, 0);
|
tmp = REG_SET_FIELD(tmp, CRTC_BLANK_CONTROL, CRTC_BLANK_DATA_EN, 0);
|
||||||
WREG32(mmCRTC_UPDATE_LOCK + crtc_offsets[i], 1);
|
|
||||||
WREG32(mmCRTC_BLANK_CONTROL + crtc_offsets[i], tmp);
|
WREG32(mmCRTC_BLANK_CONTROL + crtc_offsets[i], tmp);
|
||||||
WREG32(mmCRTC_UPDATE_LOCK + crtc_offsets[i], 0);
|
|
||||||
/* wait for the next frame */
|
|
||||||
frame_count = amdgpu_display_vblank_get_counter(adev, i);
|
|
||||||
for (j = 0; j < adev->usec_timeout; j++) {
|
|
||||||
if (amdgpu_display_vblank_get_counter(adev, i) != frame_count)
|
|
||||||
break;
|
|
||||||
udelay(1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue