Skip to content

Commit 0d1409e

Browse files
committed
Merge tag 'drm-fixes-2022-12-09' of git://anongit.freedesktop.org/drm/drm
Pull drm fixes from Dave Airlie: "Last set of fixes for final, scattered bunch of fixes, two amdgpu, one vmwgfx, and some misc others. amdgpu: - S0ix fix - DCN 3.2 array out of bounds fix shmem: - Fixes to shmem-helper error paths bridge: - Fix polarity bug in bridge/ti-sn65dsi86 dw-hdmi: - Prefer 8-bit RGB fallback before any YUV mode in dw-hdmi, since some panels lie about YUV support vmwgfx: - Stop using screen objects when SEV is active" * tag 'drm-fixes-2022-12-09' of git://anongit.freedesktop.org/drm/drm: drm/amd/display: fix array index out of bound error in DCN32 DML drm/amdgpu/sdma_v4_0: turn off SDMA ring buffer in the s2idle suspend drm/vmwgfx: Don't use screen objects when SEV is active drm/shmem-helper: Avoid vm_open error paths drm/shmem-helper: Remove errant put in error path drm: bridge: dw_hdmi: fix preference of RGB modes over YUV420 drm/bridge: ti-sn65dsi86: Fix output polarity setting bug drm/vmwgfx: Fix race issue calling pin_user_pages
2 parents 859c73d + c425265 commit 0d1409e

File tree

7 files changed

+40
-24
lines changed

7 files changed

+40
-24
lines changed

drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c

Lines changed: 15 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -907,13 +907,13 @@ static void sdma_v4_0_ring_emit_fence(struct amdgpu_ring *ring, u64 addr, u64 se
907907

908908

909909
/**
910-
* sdma_v4_0_gfx_stop - stop the gfx async dma engines
910+
* sdma_v4_0_gfx_enable - enable the gfx async dma engines
911911
*
912912
* @adev: amdgpu_device pointer
913-
*
914-
* Stop the gfx async dma ring buffers (VEGA10).
913+
* @enable: enable SDMA RB/IB
914+
* control the gfx async dma ring buffers (VEGA10).
915915
*/
916-
static void sdma_v4_0_gfx_stop(struct amdgpu_device *adev)
916+
static void sdma_v4_0_gfx_enable(struct amdgpu_device *adev, bool enable)
917917
{
918918
u32 rb_cntl, ib_cntl;
919919
int i;
@@ -922,10 +922,10 @@ static void sdma_v4_0_gfx_stop(struct amdgpu_device *adev)
922922

923923
for (i = 0; i < adev->sdma.num_instances; i++) {
924924
rb_cntl = RREG32_SDMA(i, mmSDMA0_GFX_RB_CNTL);
925-
rb_cntl = REG_SET_FIELD(rb_cntl, SDMA0_GFX_RB_CNTL, RB_ENABLE, 0);
925+
rb_cntl = REG_SET_FIELD(rb_cntl, SDMA0_GFX_RB_CNTL, RB_ENABLE, enable ? 1 : 0);
926926
WREG32_SDMA(i, mmSDMA0_GFX_RB_CNTL, rb_cntl);
927927
ib_cntl = RREG32_SDMA(i, mmSDMA0_GFX_IB_CNTL);
928-
ib_cntl = REG_SET_FIELD(ib_cntl, SDMA0_GFX_IB_CNTL, IB_ENABLE, 0);
928+
ib_cntl = REG_SET_FIELD(ib_cntl, SDMA0_GFX_IB_CNTL, IB_ENABLE, enable ? 1 : 0);
929929
WREG32_SDMA(i, mmSDMA0_GFX_IB_CNTL, ib_cntl);
930930
}
931931
}
@@ -1044,7 +1044,7 @@ static void sdma_v4_0_enable(struct amdgpu_device *adev, bool enable)
10441044
int i;
10451045

10461046
if (!enable) {
1047-
sdma_v4_0_gfx_stop(adev);
1047+
sdma_v4_0_gfx_enable(adev, enable);
10481048
sdma_v4_0_rlc_stop(adev);
10491049
if (adev->sdma.has_page_queue)
10501050
sdma_v4_0_page_stop(adev);
@@ -1960,8 +1960,10 @@ static int sdma_v4_0_suspend(void *handle)
19601960
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
19611961

19621962
/* SMU saves SDMA state for us */
1963-
if (adev->in_s0ix)
1963+
if (adev->in_s0ix) {
1964+
sdma_v4_0_gfx_enable(adev, false);
19641965
return 0;
1966+
}
19651967

19661968
return sdma_v4_0_hw_fini(adev);
19671969
}
@@ -1971,8 +1973,12 @@ static int sdma_v4_0_resume(void *handle)
19711973
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
19721974

19731975
/* SMU restores SDMA state for us */
1974-
if (adev->in_s0ix)
1976+
if (adev->in_s0ix) {
1977+
sdma_v4_0_enable(adev, true);
1978+
sdma_v4_0_gfx_enable(adev, true);
1979+
amdgpu_ttm_set_buffer_funcs_status(adev, true);
19751980
return 0;
1981+
}
19761982

19771983
return sdma_v4_0_hw_init(adev);
19781984
}

drivers/gpu/drm/amd/display/dc/dml/display_mode_vba.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1153,7 +1153,7 @@ struct vba_vars_st {
11531153
double UrgBurstFactorLumaPre[DC__NUM_DPP__MAX];
11541154
double UrgBurstFactorChromaPre[DC__NUM_DPP__MAX];
11551155
bool NotUrgentLatencyHidingPre[DC__NUM_DPP__MAX];
1156-
bool LinkCapacitySupport[DC__NUM_DPP__MAX];
1156+
bool LinkCapacitySupport[DC__VOLTAGE_STATES];
11571157
bool VREADY_AT_OR_AFTER_VSYNC[DC__NUM_DPP__MAX];
11581158
unsigned int MIN_DST_Y_NEXT_START[DC__NUM_DPP__MAX];
11591159
unsigned int VFrontPorch[DC__NUM_DPP__MAX];

drivers/gpu/drm/bridge/synopsys/dw-hdmi.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2720,6 +2720,9 @@ static u32 *dw_hdmi_bridge_atomic_get_output_bus_fmts(struct drm_bridge *bridge,
27202720
* if supported. In any case the default RGB888 format is added
27212721
*/
27222722

2723+
/* Default 8bit RGB fallback */
2724+
output_fmts[i++] = MEDIA_BUS_FMT_RGB888_1X24;
2725+
27232726
if (max_bpc >= 16 && info->bpc == 16) {
27242727
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR444)
27252728
output_fmts[i++] = MEDIA_BUS_FMT_YUV16_1X48;
@@ -2753,9 +2756,6 @@ static u32 *dw_hdmi_bridge_atomic_get_output_bus_fmts(struct drm_bridge *bridge,
27532756
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR444)
27542757
output_fmts[i++] = MEDIA_BUS_FMT_YUV8_1X24;
27552758

2756-
/* Default 8bit RGB fallback */
2757-
output_fmts[i++] = MEDIA_BUS_FMT_RGB888_1X24;
2758-
27592759
*num_output_fmts = i;
27602760

27612761
return output_fmts;

drivers/gpu/drm/bridge/ti-sn65dsi86.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -931,9 +931,9 @@ static void ti_sn_bridge_set_video_timings(struct ti_sn65dsi86 *pdata)
931931
&pdata->bridge.encoder->crtc->state->adjusted_mode;
932932
u8 hsync_polarity = 0, vsync_polarity = 0;
933933

934-
if (mode->flags & DRM_MODE_FLAG_PHSYNC)
934+
if (mode->flags & DRM_MODE_FLAG_NHSYNC)
935935
hsync_polarity = CHA_HSYNC_POLARITY;
936-
if (mode->flags & DRM_MODE_FLAG_PVSYNC)
936+
if (mode->flags & DRM_MODE_FLAG_NVSYNC)
937937
vsync_polarity = CHA_VSYNC_POLARITY;
938938

939939
ti_sn65dsi86_write_u16(pdata, SN_CHA_ACTIVE_LINE_LENGTH_LOW_REG,

drivers/gpu/drm/drm_gem_shmem_helper.c

Lines changed: 12 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -571,12 +571,20 @@ static void drm_gem_shmem_vm_open(struct vm_area_struct *vma)
571571
{
572572
struct drm_gem_object *obj = vma->vm_private_data;
573573
struct drm_gem_shmem_object *shmem = to_drm_gem_shmem_obj(obj);
574-
int ret;
575574

576575
WARN_ON(shmem->base.import_attach);
577576

578-
ret = drm_gem_shmem_get_pages(shmem);
579-
WARN_ON_ONCE(ret != 0);
577+
mutex_lock(&shmem->pages_lock);
578+
579+
/*
580+
* We should have already pinned the pages when the buffer was first
581+
* mmap'd, vm_open() just grabs an additional reference for the new
582+
* mm the vma is getting copied into (ie. on fork()).
583+
*/
584+
if (!WARN_ON_ONCE(!shmem->pages_use_count))
585+
shmem->pages_use_count++;
586+
587+
mutex_unlock(&shmem->pages_lock);
580588

581589
drm_gem_vm_open(vma);
582590
}
@@ -622,10 +630,8 @@ int drm_gem_shmem_mmap(struct drm_gem_shmem_object *shmem, struct vm_area_struct
622630
}
623631

624632
ret = drm_gem_shmem_get_pages(shmem);
625-
if (ret) {
626-
drm_gem_vm_close(vma);
633+
if (ret)
627634
return ret;
628-
}
629635

630636
vma->vm_flags |= VM_PFNMAP | VM_DONTEXPAND | VM_DONTDUMP;
631637
vma->vm_page_prot = vm_get_page_prot(vma->vm_flags);

drivers/gpu/drm/vmwgfx/vmwgfx_msg.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1085,21 +1085,21 @@ int vmw_mksstat_add_ioctl(struct drm_device *dev, void *data,
10851085
reset_ppn_array(pdesc->strsPPNs, ARRAY_SIZE(pdesc->strsPPNs));
10861086

10871087
/* Pin mksGuestStat user pages and store those in the instance descriptor */
1088-
nr_pinned_stat = pin_user_pages(arg->stat, num_pages_stat, FOLL_LONGTERM, pages_stat, NULL);
1088+
nr_pinned_stat = pin_user_pages_fast(arg->stat, num_pages_stat, FOLL_LONGTERM, pages_stat);
10891089
if (num_pages_stat != nr_pinned_stat)
10901090
goto err_pin_stat;
10911091

10921092
for (i = 0; i < num_pages_stat; ++i)
10931093
pdesc->statPPNs[i] = page_to_pfn(pages_stat[i]);
10941094

1095-
nr_pinned_info = pin_user_pages(arg->info, num_pages_info, FOLL_LONGTERM, pages_info, NULL);
1095+
nr_pinned_info = pin_user_pages_fast(arg->info, num_pages_info, FOLL_LONGTERM, pages_info);
10961096
if (num_pages_info != nr_pinned_info)
10971097
goto err_pin_info;
10981098

10991099
for (i = 0; i < num_pages_info; ++i)
11001100
pdesc->infoPPNs[i] = page_to_pfn(pages_info[i]);
11011101

1102-
nr_pinned_strs = pin_user_pages(arg->strs, num_pages_strs, FOLL_LONGTERM, pages_strs, NULL);
1102+
nr_pinned_strs = pin_user_pages_fast(arg->strs, num_pages_strs, FOLL_LONGTERM, pages_strs);
11031103
if (num_pages_strs != nr_pinned_strs)
11041104
goto err_pin_strs;
11051105

drivers/gpu/drm/vmwgfx/vmwgfx_scrn.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -949,6 +949,10 @@ int vmw_kms_sou_init_display(struct vmw_private *dev_priv)
949949
struct drm_device *dev = &dev_priv->drm;
950950
int i, ret;
951951

952+
/* Screen objects won't work if GMR's aren't available */
953+
if (!dev_priv->has_gmr)
954+
return -ENOSYS;
955+
952956
if (!(dev_priv->capabilities & SVGA_CAP_SCREEN_OBJECT_2)) {
953957
return -ENOSYS;
954958
}

0 commit comments

Comments
 (0)