Merge tag 'drm-misc-fixes-2023-05-11' of git://anongit.freedesktop.org/drm/drm-misc into drm-fixes

drm-misc-fixes for v6.4-rc2:
- More DSC macro fixes.
- Small mipi-dsi fix.
- Scheduler timeout handling fix.

---

drm-misc-fixes for v6.4-rc1:
- Fix DSC macros.
- Fix VESA format for simplefb.
- Prohibit potential out-of-bounds access in generic fbdev emulation.
- Improve AST2500+ compat on ARM.

Signed-off-by: Dave Airlie <airlied@redhat.com>
From: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/b34135e3-2651-4e0a-a776-9b047882b1b2@linux.intel.com
This commit is contained in:
Dave Airlie 2023-05-12 05:32:36 +10:00
commit dc49c3b1d4
10 changed files with 32 additions and 20 deletions

View File

@ -51,7 +51,8 @@ __init bool sysfb_parse_mode(const struct screen_info *si,
* *
* It's not easily possible to fix this in struct screen_info, * It's not easily possible to fix this in struct screen_info,
* as this could break UAPI. The best solution is to compute * as this could break UAPI. The best solution is to compute
* bits_per_pixel here and ignore lfb_depth. In the loop below, * bits_per_pixel from the color bits, reserved bits and
* reported lfb_depth, whichever is highest. In the loop below,
* ignore simplefb formats with alpha bits, as EFI and VESA * ignore simplefb formats with alpha bits, as EFI and VESA
* don't specify alpha channels. * don't specify alpha channels.
*/ */
@ -60,6 +61,7 @@ __init bool sysfb_parse_mode(const struct screen_info *si,
si->green_size + si->green_pos, si->green_size + si->green_pos,
si->blue_size + si->blue_pos), si->blue_size + si->blue_pos),
si->rsvd_size + si->rsvd_pos); si->rsvd_size + si->rsvd_pos);
bits_per_pixel = max_t(u32, bits_per_pixel, si->lfb_depth);
} else { } else {
bits_per_pixel = si->lfb_depth; bits_per_pixel = si->lfb_depth;
} }

View File

@ -425,11 +425,12 @@ struct ast_device *ast_device_create(const struct drm_driver *drv,
return ERR_PTR(-EIO); return ERR_PTR(-EIO);
/* /*
* If we don't have IO space at all, use MMIO now and * After AST2500, MMIO is enabled by default, and it should be adopted
* assume the chip has MMIO enabled by default (rev 0x20 * to be compatible with Arm.
* and higher).
*/ */
if (!(pci_resource_flags(pdev, 2) & IORESOURCE_IO)) { if (pdev->revision >= 0x40) {
ast->ioregs = ast->regs + AST_IO_MM_OFFSET;
} else if (!(pci_resource_flags(pdev, 2) & IORESOURCE_IO)) {
drm_info(dev, "platform has no IO space, trying MMIO\n"); drm_info(dev, "platform has no IO space, trying MMIO\n");
ast->ioregs = ast->regs + AST_IO_MM_OFFSET; ast->ioregs = ast->regs + AST_IO_MM_OFFSET;
} }

View File

@ -641,19 +641,27 @@ static void drm_fb_helper_damage(struct drm_fb_helper *helper, u32 x, u32 y,
static void drm_fb_helper_memory_range_to_clip(struct fb_info *info, off_t off, size_t len, static void drm_fb_helper_memory_range_to_clip(struct fb_info *info, off_t off, size_t len,
struct drm_rect *clip) struct drm_rect *clip)
{ {
u32 line_length = info->fix.line_length;
u32 fb_height = info->var.yres;
off_t end = off + len; off_t end = off + len;
u32 x1 = 0; u32 x1 = 0;
u32 y1 = off / info->fix.line_length; u32 y1 = off / line_length;
u32 x2 = info->var.xres; u32 x2 = info->var.xres;
u32 y2 = DIV_ROUND_UP(end, info->fix.line_length); u32 y2 = DIV_ROUND_UP(end, line_length);
/* Don't allow any of them beyond the bottom bound of display area */
if (y1 > fb_height)
y1 = fb_height;
if (y2 > fb_height)
y2 = fb_height;
if ((y2 - y1) == 1) { if ((y2 - y1) == 1) {
/* /*
* We've only written to a single scanline. Try to reduce * We've only written to a single scanline. Try to reduce
* the number of horizontal pixels that need an update. * the number of horizontal pixels that need an update.
*/ */
off_t bit_off = (off % info->fix.line_length) * 8; off_t bit_off = (off % line_length) * 8;
off_t bit_end = (end % info->fix.line_length) * 8; off_t bit_end = (end % line_length) * 8;
x1 = bit_off / info->var.bits_per_pixel; x1 = bit_off / info->var.bits_per_pixel;
x2 = DIV_ROUND_UP(bit_end, info->var.bits_per_pixel); x2 = DIV_ROUND_UP(bit_end, info->var.bits_per_pixel);

View File

@ -221,7 +221,7 @@ mipi_dsi_device_register_full(struct mipi_dsi_host *host,
return dsi; return dsi;
} }
dsi->dev.of_node = info->node; device_set_node(&dsi->dev, of_fwnode_handle(info->node));
dsi->channel = info->channel; dsi->channel = info->channel;
strlcpy(dsi->name, info->type, sizeof(dsi->name)); strlcpy(dsi->name, info->type, sizeof(dsi->name));

View File

@ -2,6 +2,8 @@
#ifndef __NVIF_IF0012_H__ #ifndef __NVIF_IF0012_H__
#define __NVIF_IF0012_H__ #define __NVIF_IF0012_H__
#include <drm/display/drm_dp.h>
union nvif_outp_args { union nvif_outp_args {
struct nvif_outp_v0 { struct nvif_outp_v0 {
__u8 version; __u8 version;
@ -63,7 +65,7 @@ union nvif_outp_acquire_args {
__u8 hda; __u8 hda;
__u8 mst; __u8 mst;
__u8 pad04[4]; __u8 pad04[4];
__u8 dpcd[16]; __u8 dpcd[DP_RECEIVER_CAP_SIZE];
} dp; } dp;
}; };
} v0; } v0;

View File

@ -3,6 +3,7 @@
#define __NVKM_DISP_OUTP_H__ #define __NVKM_DISP_OUTP_H__
#include "priv.h" #include "priv.h"
#include <drm/display/drm_dp.h>
#include <subdev/bios.h> #include <subdev/bios.h>
#include <subdev/bios/dcb.h> #include <subdev/bios/dcb.h>
#include <subdev/bios/dp.h> #include <subdev/bios/dp.h>
@ -42,7 +43,7 @@ struct nvkm_outp {
bool aux_pwr_pu; bool aux_pwr_pu;
u8 lttpr[6]; u8 lttpr[6];
u8 lttprs; u8 lttprs;
u8 dpcd[16]; u8 dpcd[DP_RECEIVER_CAP_SIZE];
struct { struct {
int dpcd; /* -1, or index into SUPPORTED_LINK_RATES table */ int dpcd; /* -1, or index into SUPPORTED_LINK_RATES table */

View File

@ -146,7 +146,7 @@ nvkm_uoutp_mthd_release(struct nvkm_outp *outp, void *argv, u32 argc)
} }
static int static int
nvkm_uoutp_mthd_acquire_dp(struct nvkm_outp *outp, u8 dpcd[16], nvkm_uoutp_mthd_acquire_dp(struct nvkm_outp *outp, u8 dpcd[DP_RECEIVER_CAP_SIZE],
u8 link_nr, u8 link_bw, bool hda, bool mst) u8 link_nr, u8 link_bw, bool hda, bool mst)
{ {
int ret; int ret;

View File

@ -309,7 +309,7 @@ static void drm_sched_start_timeout(struct drm_gpu_scheduler *sched)
*/ */
void drm_sched_fault(struct drm_gpu_scheduler *sched) void drm_sched_fault(struct drm_gpu_scheduler *sched)
{ {
if (sched->ready) if (sched->timeout_wq)
mod_delayed_work(sched->timeout_wq, &sched->work_tdr, 0); mod_delayed_work(sched->timeout_wq, &sched->work_tdr, 0);
} }
EXPORT_SYMBOL(drm_sched_fault); EXPORT_SYMBOL(drm_sched_fault);

View File

@ -286,9 +286,8 @@
#define DP_DSC_MAX_BITS_PER_PIXEL_HI 0x068 /* eDP 1.4 */ #define DP_DSC_MAX_BITS_PER_PIXEL_HI 0x068 /* eDP 1.4 */
# define DP_DSC_MAX_BITS_PER_PIXEL_HI_MASK (0x3 << 0) # define DP_DSC_MAX_BITS_PER_PIXEL_HI_MASK (0x3 << 0)
# define DP_DSC_MAX_BITS_PER_PIXEL_HI_SHIFT 8 # define DP_DSC_MAX_BPP_DELTA_VERSION_MASK (0x3 << 5) /* eDP 1.5 & DP 2.0 */
# define DP_DSC_MAX_BPP_DELTA_VERSION_MASK 0x06 # define DP_DSC_MAX_BPP_DELTA_AVAILABILITY (1 << 7) /* eDP 1.5 & DP 2.0 */
# define DP_DSC_MAX_BPP_DELTA_AVAILABILITY 0x08
#define DP_DSC_DEC_COLOR_FORMAT_CAP 0x069 #define DP_DSC_DEC_COLOR_FORMAT_CAP 0x069
# define DP_DSC_RGB (1 << 0) # define DP_DSC_RGB (1 << 0)

View File

@ -181,9 +181,8 @@ static inline u16
drm_edp_dsc_sink_output_bpp(const u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE]) drm_edp_dsc_sink_output_bpp(const u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE])
{ {
return dsc_dpcd[DP_DSC_MAX_BITS_PER_PIXEL_LOW - DP_DSC_SUPPORT] | return dsc_dpcd[DP_DSC_MAX_BITS_PER_PIXEL_LOW - DP_DSC_SUPPORT] |
(dsc_dpcd[DP_DSC_MAX_BITS_PER_PIXEL_HI - DP_DSC_SUPPORT] & ((dsc_dpcd[DP_DSC_MAX_BITS_PER_PIXEL_HI - DP_DSC_SUPPORT] &
DP_DSC_MAX_BITS_PER_PIXEL_HI_MASK << DP_DSC_MAX_BITS_PER_PIXEL_HI_MASK) << 8);
DP_DSC_MAX_BITS_PER_PIXEL_HI_SHIFT);
} }
static inline u32 static inline u32