drm/i915: Start tracking PIPESRC as a drm_rect
Instead of just having the pipe_src_{w,h} let's use a full drm_rect for it. This will be particularly useful to astract away some bigjoiner details. v2: No hweight() stuff yet Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20220223131315.18016-11-ville.syrjala@linux.intel.com Reviewed-by: Manasi Navare <manasi.d.navare@intel.com>
This commit is contained in:
parent
0fa1d65e7d
commit
26111a161a
@ -802,8 +802,8 @@ int intel_atomic_plane_check_clipping(struct intel_plane_state *plane_state,
|
||||
struct drm_framebuffer *fb = plane_state->hw.fb;
|
||||
struct drm_rect *src = &plane_state->uapi.src;
|
||||
struct drm_rect *dst = &plane_state->uapi.dst;
|
||||
const struct drm_rect *clip = &crtc_state->pipe_src;
|
||||
unsigned int rotation = plane_state->hw.rotation;
|
||||
struct drm_rect clip = {};
|
||||
int hscale, vscale;
|
||||
|
||||
if (!fb) {
|
||||
@ -823,28 +823,23 @@ int intel_atomic_plane_check_clipping(struct intel_plane_state *plane_state,
|
||||
return -ERANGE;
|
||||
}
|
||||
|
||||
if (crtc_state->hw.enable) {
|
||||
clip.x2 = crtc_state->pipe_src_w;
|
||||
clip.y2 = crtc_state->pipe_src_h;
|
||||
}
|
||||
|
||||
/* right side of the image is on the slave crtc, adjust dst to match */
|
||||
if (intel_crtc_is_bigjoiner_slave(crtc_state))
|
||||
drm_rect_translate(dst, -crtc_state->pipe_src_w, 0);
|
||||
drm_rect_translate(dst, -drm_rect_width(&crtc_state->pipe_src), 0);
|
||||
|
||||
/*
|
||||
* FIXME: This might need further adjustment for seamless scaling
|
||||
* with phase information, for the 2p2 and 2p1 scenarios.
|
||||
*/
|
||||
plane_state->uapi.visible = drm_rect_clip_scaled(src, dst, &clip);
|
||||
plane_state->uapi.visible = drm_rect_clip_scaled(src, dst, clip);
|
||||
|
||||
drm_rect_rotate_inv(src, fb->width << 16, fb->height << 16, rotation);
|
||||
|
||||
if (!can_position && plane_state->uapi.visible &&
|
||||
!drm_rect_equals(dst, &clip)) {
|
||||
!drm_rect_equals(dst, clip)) {
|
||||
drm_dbg_kms(&i915->drm, "Plane must cover entire CRTC\n");
|
||||
drm_rect_debug_print("dst: ", dst, false);
|
||||
drm_rect_debug_print("clip: ", &clip, false);
|
||||
drm_rect_debug_print("clip: ", clip, false);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
|
@ -154,7 +154,7 @@ static int intel_check_cursor(struct intel_crtc_state *crtc_state,
|
||||
plane_state->uapi.dst = dst;
|
||||
if (intel_crtc_is_bigjoiner_slave(crtc_state))
|
||||
drm_rect_translate(&plane_state->uapi.dst,
|
||||
-crtc_state->pipe_src_w, 0);
|
||||
-drm_rect_width(&crtc_state->pipe_src), 0);
|
||||
|
||||
ret = intel_cursor_check_surface(plane_state);
|
||||
if (ret)
|
||||
|
@ -2675,8 +2675,8 @@ static u32 ilk_pipe_pixel_rate(const struct intel_crtc_state *crtc_state)
|
||||
return pixel_rate;
|
||||
|
||||
drm_rect_init(&src, 0, 0,
|
||||
crtc_state->pipe_src_w << 16,
|
||||
crtc_state->pipe_src_h << 16);
|
||||
drm_rect_width(&crtc_state->pipe_src) << 16,
|
||||
drm_rect_height(&crtc_state->pipe_src) << 16);
|
||||
|
||||
return intel_adjusted_rate(&src, &crtc_state->pch_pfit.dst,
|
||||
pixel_rate);
|
||||
@ -2780,8 +2780,8 @@ static void intel_crtc_readout_derived_state(struct intel_crtc_state *crtc_state
|
||||
/* Populate the "user" mode with full numbers */
|
||||
drm_mode_copy(mode, pipe_mode);
|
||||
intel_mode_from_crtc_timings(mode, mode);
|
||||
mode->hdisplay = crtc_state->pipe_src_w << crtc_state->bigjoiner;
|
||||
mode->vdisplay = crtc_state->pipe_src_h;
|
||||
mode->hdisplay = drm_rect_width(&crtc_state->pipe_src) << crtc_state->bigjoiner;
|
||||
mode->vdisplay = drm_rect_height(&crtc_state->pipe_src);
|
||||
|
||||
/* Derive per-pipe timings in case bigjoiner is used */
|
||||
intel_bigjoiner_adjust_timings(crtc_state, pipe_mode);
|
||||
@ -2798,13 +2798,26 @@ static void intel_encoder_get_config(struct intel_encoder *encoder,
|
||||
intel_crtc_readout_derived_state(crtc_state);
|
||||
}
|
||||
|
||||
static void intel_bigjoiner_compute_pipe_src(struct intel_crtc_state *crtc_state)
|
||||
{
|
||||
int width, height;
|
||||
|
||||
if (!crtc_state->bigjoiner)
|
||||
return;
|
||||
|
||||
width = drm_rect_width(&crtc_state->pipe_src);
|
||||
height = drm_rect_height(&crtc_state->pipe_src);
|
||||
|
||||
drm_rect_init(&crtc_state->pipe_src, 0, 0,
|
||||
width / 2, height);
|
||||
}
|
||||
|
||||
static int intel_crtc_compute_pipe_src(struct intel_crtc_state *crtc_state)
|
||||
{
|
||||
struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
|
||||
struct drm_i915_private *i915 = to_i915(crtc->base.dev);
|
||||
|
||||
if (crtc_state->bigjoiner)
|
||||
crtc_state->pipe_src_w /= 2;
|
||||
intel_bigjoiner_compute_pipe_src(crtc_state);
|
||||
|
||||
/*
|
||||
* Pipe horizontal size must be even in:
|
||||
@ -2812,7 +2825,7 @@ static int intel_crtc_compute_pipe_src(struct intel_crtc_state *crtc_state)
|
||||
* - LVDS dual channel mode
|
||||
* - Double wide pipe
|
||||
*/
|
||||
if (crtc_state->pipe_src_w & 1) {
|
||||
if (drm_rect_width(&crtc_state->pipe_src) & 1) {
|
||||
if (crtc_state->double_wide) {
|
||||
drm_dbg_kms(&i915->drm,
|
||||
"[CRTC:%d:%s] Odd pipe source width not supported with double wide pipe\n",
|
||||
@ -3099,14 +3112,15 @@ static void intel_set_pipe_src_size(const struct intel_crtc_state *crtc_state)
|
||||
{
|
||||
struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
|
||||
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
|
||||
int width = drm_rect_width(&crtc_state->pipe_src);
|
||||
int height = drm_rect_height(&crtc_state->pipe_src);
|
||||
enum pipe pipe = crtc->pipe;
|
||||
|
||||
/* pipesrc controls the size that is scaled from, which should
|
||||
* always be the user's requested size.
|
||||
*/
|
||||
intel_de_write(dev_priv, PIPESRC(pipe),
|
||||
PIPESRC_WIDTH(crtc_state->pipe_src_w - 1) |
|
||||
PIPESRC_HEIGHT(crtc_state->pipe_src_h - 1));
|
||||
PIPESRC_WIDTH(width - 1) | PIPESRC_HEIGHT(height - 1));
|
||||
}
|
||||
|
||||
static bool intel_pipe_is_interlaced(const struct intel_crtc_state *crtc_state)
|
||||
@ -3177,8 +3191,10 @@ static void intel_get_pipe_src_size(struct intel_crtc *crtc,
|
||||
u32 tmp;
|
||||
|
||||
tmp = intel_de_read(dev_priv, PIPESRC(crtc->pipe));
|
||||
pipe_config->pipe_src_w = REG_FIELD_GET(PIPESRC_WIDTH_MASK, tmp) + 1;
|
||||
pipe_config->pipe_src_h = REG_FIELD_GET(PIPESRC_HEIGHT_MASK, tmp) + 1;
|
||||
|
||||
drm_rect_init(&pipe_config->pipe_src, 0, 0,
|
||||
REG_FIELD_GET(PIPESRC_WIDTH_MASK, tmp) + 1,
|
||||
REG_FIELD_GET(PIPESRC_HEIGHT_MASK, tmp) + 1);
|
||||
}
|
||||
|
||||
static void i9xx_set_pipeconf(const struct intel_crtc_state *crtc_state)
|
||||
@ -5369,9 +5385,8 @@ static void intel_dump_pipe_config(const struct intel_crtc_state *pipe_config,
|
||||
drm_mode_debug_printmodeline(&pipe_config->hw.pipe_mode);
|
||||
intel_dump_crtc_timings(dev_priv, &pipe_config->hw.pipe_mode);
|
||||
drm_dbg_kms(&dev_priv->drm,
|
||||
"port clock: %d, pipe src size: %dx%d, pixel rate %d\n",
|
||||
pipe_config->port_clock,
|
||||
pipe_config->pipe_src_w, pipe_config->pipe_src_h,
|
||||
"port clock: %d, pipe src: " DRM_RECT_FMT ", pixel rate %d\n",
|
||||
pipe_config->port_clock, DRM_RECT_ARG(&pipe_config->pipe_src),
|
||||
pipe_config->pixel_rate);
|
||||
|
||||
drm_dbg_kms(&dev_priv->drm, "linetime: %d, ips linetime: %d\n",
|
||||
@ -5666,6 +5681,7 @@ intel_modeset_pipe_config(struct intel_atomic_state *state,
|
||||
struct drm_i915_private *i915 = to_i915(pipe_config->uapi.crtc->dev);
|
||||
struct drm_connector *connector;
|
||||
struct drm_connector_state *connector_state;
|
||||
int pipe_src_w, pipe_src_h;
|
||||
int base_bpp, ret, i;
|
||||
bool retry = true;
|
||||
|
||||
@ -5703,8 +5719,9 @@ intel_modeset_pipe_config(struct intel_atomic_state *state,
|
||||
* can be changed by the connectors in the below retry loop.
|
||||
*/
|
||||
drm_mode_get_hv_timing(&pipe_config->hw.mode,
|
||||
&pipe_config->pipe_src_w,
|
||||
&pipe_config->pipe_src_h);
|
||||
&pipe_src_w, &pipe_src_h);
|
||||
drm_rect_init(&pipe_config->pipe_src, 0, 0,
|
||||
pipe_src_w, pipe_src_h);
|
||||
|
||||
for_each_new_connector_in_state(&state->base, connector, connector_state, i) {
|
||||
struct intel_encoder *encoder =
|
||||
@ -6283,8 +6300,10 @@ intel_pipe_config_compare(const struct intel_crtc_state *current_config,
|
||||
PIPE_CONF_CHECK_BOOL(pch_pfit.force_thru);
|
||||
|
||||
if (!fastset) {
|
||||
PIPE_CONF_CHECK_I(pipe_src_w);
|
||||
PIPE_CONF_CHECK_I(pipe_src_h);
|
||||
PIPE_CONF_CHECK_I(pipe_src.x1);
|
||||
PIPE_CONF_CHECK_I(pipe_src.y1);
|
||||
PIPE_CONF_CHECK_I(pipe_src.x2);
|
||||
PIPE_CONF_CHECK_I(pipe_src.y2);
|
||||
|
||||
PIPE_CONF_CHECK_BOOL(pch_pfit.enabled);
|
||||
if (current_config->pch_pfit.enabled) {
|
||||
|
@ -939,8 +939,8 @@ static void intel_crtc_info(struct seq_file *m, struct intel_crtc *crtc)
|
||||
seq_printf(m, "\tpipe__mode=" DRM_MODE_FMT "\n",
|
||||
DRM_MODE_ARG(&crtc_state->hw.pipe_mode));
|
||||
|
||||
seq_printf(m, "\tpipe src size=%dx%d, dither=%s, bpp=%d\n",
|
||||
crtc_state->pipe_src_w, crtc_state->pipe_src_h,
|
||||
seq_printf(m, "\tpipe src=" DRM_RECT_FMT ", dither=%s, bpp=%d\n",
|
||||
DRM_RECT_ARG(&crtc_state->pipe_src),
|
||||
str_yes_no(crtc_state->dither), crtc_state->pipe_bpp);
|
||||
|
||||
intel_scaler_info(m, crtc);
|
||||
|
@ -954,7 +954,7 @@ struct intel_crtc_state {
|
||||
/* Pipe source size (ie. panel fitter input size)
|
||||
* All planes will be positioned inside this space,
|
||||
* and get clipped at the edges. */
|
||||
int pipe_src_w, pipe_src_h;
|
||||
struct drm_rect pipe_src;
|
||||
|
||||
/*
|
||||
* Pipe pixel rate, adjusted for
|
||||
|
@ -960,14 +960,16 @@ static int check_overlay_dst(struct intel_overlay *overlay,
|
||||
{
|
||||
const struct intel_crtc_state *pipe_config =
|
||||
overlay->crtc->config;
|
||||
int pipe_src_w = drm_rect_width(&pipe_config->pipe_src);
|
||||
int pipe_src_h = drm_rect_height(&pipe_config->pipe_src);
|
||||
|
||||
if (rec->dst_height == 0 || rec->dst_width == 0)
|
||||
return -EINVAL;
|
||||
|
||||
if (rec->dst_x < pipe_config->pipe_src_w &&
|
||||
rec->dst_x + rec->dst_width <= pipe_config->pipe_src_w &&
|
||||
rec->dst_y < pipe_config->pipe_src_h &&
|
||||
rec->dst_y + rec->dst_height <= pipe_config->pipe_src_h)
|
||||
if (rec->dst_x < pipe_src_w &&
|
||||
rec->dst_x + rec->dst_width <= pipe_src_w &&
|
||||
rec->dst_y < pipe_src_h &&
|
||||
rec->dst_y + rec->dst_height <= pipe_src_h)
|
||||
return 0;
|
||||
else
|
||||
return -EINVAL;
|
||||
@ -1160,7 +1162,7 @@ int intel_overlay_put_image_ioctl(struct drm_device *dev, void *data,
|
||||
crtc->overlay = overlay;
|
||||
|
||||
/* line too wide, i.e. one-line-mode */
|
||||
if (crtc->config->pipe_src_w > 1024 &&
|
||||
if (drm_rect_width(&crtc->config->pipe_src) > 1024 &&
|
||||
crtc->config->gmch_pfit.control & PFIT_ENABLE) {
|
||||
overlay->pfit_active = true;
|
||||
update_pfit_vscale_ratio(overlay);
|
||||
|
@ -205,18 +205,20 @@ static int pch_panel_fitting(struct intel_crtc_state *crtc_state,
|
||||
{
|
||||
const struct drm_display_mode *adjusted_mode =
|
||||
&crtc_state->hw.adjusted_mode;
|
||||
int pipe_src_w = drm_rect_width(&crtc_state->pipe_src);
|
||||
int pipe_src_h = drm_rect_height(&crtc_state->pipe_src);
|
||||
int x, y, width, height;
|
||||
|
||||
/* Native modes don't need fitting */
|
||||
if (adjusted_mode->crtc_hdisplay == crtc_state->pipe_src_w &&
|
||||
adjusted_mode->crtc_vdisplay == crtc_state->pipe_src_h &&
|
||||
if (adjusted_mode->crtc_hdisplay == pipe_src_w &&
|
||||
adjusted_mode->crtc_vdisplay == pipe_src_h &&
|
||||
crtc_state->output_format != INTEL_OUTPUT_FORMAT_YCBCR420)
|
||||
return 0;
|
||||
|
||||
switch (conn_state->scaling_mode) {
|
||||
case DRM_MODE_SCALE_CENTER:
|
||||
width = crtc_state->pipe_src_w;
|
||||
height = crtc_state->pipe_src_h;
|
||||
width = pipe_src_w;
|
||||
height = pipe_src_h;
|
||||
x = (adjusted_mode->crtc_hdisplay - width + 1)/2;
|
||||
y = (adjusted_mode->crtc_vdisplay - height + 1)/2;
|
||||
break;
|
||||
@ -224,19 +226,17 @@ static int pch_panel_fitting(struct intel_crtc_state *crtc_state,
|
||||
case DRM_MODE_SCALE_ASPECT:
|
||||
/* Scale but preserve the aspect ratio */
|
||||
{
|
||||
u32 scaled_width = adjusted_mode->crtc_hdisplay
|
||||
* crtc_state->pipe_src_h;
|
||||
u32 scaled_height = crtc_state->pipe_src_w
|
||||
* adjusted_mode->crtc_vdisplay;
|
||||
u32 scaled_width = adjusted_mode->crtc_hdisplay * pipe_src_h;
|
||||
u32 scaled_height = pipe_src_w * adjusted_mode->crtc_vdisplay;
|
||||
if (scaled_width > scaled_height) { /* pillar */
|
||||
width = scaled_height / crtc_state->pipe_src_h;
|
||||
width = scaled_height / pipe_src_h;
|
||||
if (width & 1)
|
||||
width++;
|
||||
x = (adjusted_mode->crtc_hdisplay - width + 1) / 2;
|
||||
y = 0;
|
||||
height = adjusted_mode->crtc_vdisplay;
|
||||
} else if (scaled_width < scaled_height) { /* letter */
|
||||
height = scaled_width / crtc_state->pipe_src_w;
|
||||
height = scaled_width / pipe_src_w;
|
||||
if (height & 1)
|
||||
height++;
|
||||
y = (adjusted_mode->crtc_vdisplay - height + 1) / 2;
|
||||
@ -251,8 +251,8 @@ static int pch_panel_fitting(struct intel_crtc_state *crtc_state,
|
||||
break;
|
||||
|
||||
case DRM_MODE_SCALE_NONE:
|
||||
WARN_ON(adjusted_mode->crtc_hdisplay != crtc_state->pipe_src_w);
|
||||
WARN_ON(adjusted_mode->crtc_vdisplay != crtc_state->pipe_src_h);
|
||||
WARN_ON(adjusted_mode->crtc_hdisplay != pipe_src_w);
|
||||
WARN_ON(adjusted_mode->crtc_vdisplay != pipe_src_h);
|
||||
fallthrough;
|
||||
case DRM_MODE_SCALE_FULLSCREEN:
|
||||
x = y = 0;
|
||||
@ -333,10 +333,10 @@ static void i965_scale_aspect(struct intel_crtc_state *crtc_state,
|
||||
{
|
||||
const struct drm_display_mode *adjusted_mode =
|
||||
&crtc_state->hw.adjusted_mode;
|
||||
u32 scaled_width = adjusted_mode->crtc_hdisplay *
|
||||
crtc_state->pipe_src_h;
|
||||
u32 scaled_height = crtc_state->pipe_src_w *
|
||||
adjusted_mode->crtc_vdisplay;
|
||||
int pipe_src_w = drm_rect_width(&crtc_state->pipe_src);
|
||||
int pipe_src_h = drm_rect_height(&crtc_state->pipe_src);
|
||||
u32 scaled_width = adjusted_mode->crtc_hdisplay * pipe_src_h;
|
||||
u32 scaled_height = pipe_src_w * adjusted_mode->crtc_vdisplay;
|
||||
|
||||
/* 965+ is easy, it does everything in hw */
|
||||
if (scaled_width > scaled_height)
|
||||
@ -345,7 +345,7 @@ static void i965_scale_aspect(struct intel_crtc_state *crtc_state,
|
||||
else if (scaled_width < scaled_height)
|
||||
*pfit_control |= PFIT_ENABLE |
|
||||
PFIT_SCALING_LETTER;
|
||||
else if (adjusted_mode->crtc_hdisplay != crtc_state->pipe_src_w)
|
||||
else if (adjusted_mode->crtc_hdisplay != pipe_src_w)
|
||||
*pfit_control |= PFIT_ENABLE | PFIT_SCALING_AUTO;
|
||||
}
|
||||
|
||||
@ -354,10 +354,10 @@ static void i9xx_scale_aspect(struct intel_crtc_state *crtc_state,
|
||||
u32 *border)
|
||||
{
|
||||
struct drm_display_mode *adjusted_mode = &crtc_state->hw.adjusted_mode;
|
||||
u32 scaled_width = adjusted_mode->crtc_hdisplay *
|
||||
crtc_state->pipe_src_h;
|
||||
u32 scaled_height = crtc_state->pipe_src_w *
|
||||
adjusted_mode->crtc_vdisplay;
|
||||
int pipe_src_w = drm_rect_width(&crtc_state->pipe_src);
|
||||
int pipe_src_h = drm_rect_height(&crtc_state->pipe_src);
|
||||
u32 scaled_width = adjusted_mode->crtc_hdisplay * pipe_src_h;
|
||||
u32 scaled_height = pipe_src_w * adjusted_mode->crtc_vdisplay;
|
||||
u32 bits;
|
||||
|
||||
/*
|
||||
@ -367,12 +367,11 @@ static void i9xx_scale_aspect(struct intel_crtc_state *crtc_state,
|
||||
*/
|
||||
if (scaled_width > scaled_height) { /* pillar */
|
||||
centre_horizontally(adjusted_mode,
|
||||
scaled_height /
|
||||
crtc_state->pipe_src_h);
|
||||
scaled_height / pipe_src_h);
|
||||
|
||||
*border = LVDS_BORDER_ENABLE;
|
||||
if (crtc_state->pipe_src_h != adjusted_mode->crtc_vdisplay) {
|
||||
bits = panel_fitter_scaling(crtc_state->pipe_src_h,
|
||||
if (pipe_src_h != adjusted_mode->crtc_vdisplay) {
|
||||
bits = panel_fitter_scaling(pipe_src_h,
|
||||
adjusted_mode->crtc_vdisplay);
|
||||
|
||||
*pfit_pgm_ratios |= (bits << PFIT_HORIZ_SCALE_SHIFT |
|
||||
@ -383,12 +382,11 @@ static void i9xx_scale_aspect(struct intel_crtc_state *crtc_state,
|
||||
}
|
||||
} else if (scaled_width < scaled_height) { /* letter */
|
||||
centre_vertically(adjusted_mode,
|
||||
scaled_width /
|
||||
crtc_state->pipe_src_w);
|
||||
scaled_width / pipe_src_w);
|
||||
|
||||
*border = LVDS_BORDER_ENABLE;
|
||||
if (crtc_state->pipe_src_w != adjusted_mode->crtc_hdisplay) {
|
||||
bits = panel_fitter_scaling(crtc_state->pipe_src_w,
|
||||
if (pipe_src_w != adjusted_mode->crtc_hdisplay) {
|
||||
bits = panel_fitter_scaling(pipe_src_w,
|
||||
adjusted_mode->crtc_hdisplay);
|
||||
|
||||
*pfit_pgm_ratios |= (bits << PFIT_HORIZ_SCALE_SHIFT |
|
||||
@ -413,10 +411,12 @@ static int gmch_panel_fitting(struct intel_crtc_state *crtc_state,
|
||||
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
|
||||
u32 pfit_control = 0, pfit_pgm_ratios = 0, border = 0;
|
||||
struct drm_display_mode *adjusted_mode = &crtc_state->hw.adjusted_mode;
|
||||
int pipe_src_w = drm_rect_width(&crtc_state->pipe_src);
|
||||
int pipe_src_h = drm_rect_height(&crtc_state->pipe_src);
|
||||
|
||||
/* Native modes don't need fitting */
|
||||
if (adjusted_mode->crtc_hdisplay == crtc_state->pipe_src_w &&
|
||||
adjusted_mode->crtc_vdisplay == crtc_state->pipe_src_h)
|
||||
if (adjusted_mode->crtc_hdisplay == pipe_src_w &&
|
||||
adjusted_mode->crtc_vdisplay == pipe_src_h)
|
||||
goto out;
|
||||
|
||||
switch (conn_state->scaling_mode) {
|
||||
@ -425,8 +425,8 @@ static int gmch_panel_fitting(struct intel_crtc_state *crtc_state,
|
||||
* For centered modes, we have to calculate border widths &
|
||||
* heights and modify the values programmed into the CRTC.
|
||||
*/
|
||||
centre_horizontally(adjusted_mode, crtc_state->pipe_src_w);
|
||||
centre_vertically(adjusted_mode, crtc_state->pipe_src_h);
|
||||
centre_horizontally(adjusted_mode, pipe_src_w);
|
||||
centre_vertically(adjusted_mode, pipe_src_h);
|
||||
border = LVDS_BORDER_ENABLE;
|
||||
break;
|
||||
case DRM_MODE_SCALE_ASPECT:
|
||||
@ -442,8 +442,8 @@ static int gmch_panel_fitting(struct intel_crtc_state *crtc_state,
|
||||
* Full scaling, even if it changes the aspect ratio.
|
||||
* Fortunately this is all done for us in hw.
|
||||
*/
|
||||
if (crtc_state->pipe_src_h != adjusted_mode->crtc_vdisplay ||
|
||||
crtc_state->pipe_src_w != adjusted_mode->crtc_hdisplay) {
|
||||
if (pipe_src_h != adjusted_mode->crtc_vdisplay ||
|
||||
pipe_src_w != adjusted_mode->crtc_hdisplay) {
|
||||
pfit_control |= PFIT_ENABLE;
|
||||
if (DISPLAY_VER(dev_priv) >= 4)
|
||||
pfit_control |= PFIT_SCALING_AUTO;
|
||||
|
@ -197,7 +197,8 @@ int skl_update_scaler_crtc(struct intel_crtc_state *crtc_state)
|
||||
return skl_update_scaler(crtc_state, !crtc_state->hw.active,
|
||||
SKL_CRTC_INDEX,
|
||||
&crtc_state->scaler_state.scaler_id,
|
||||
crtc_state->pipe_src_w, crtc_state->pipe_src_h,
|
||||
drm_rect_width(&crtc_state->pipe_src),
|
||||
drm_rect_height(&crtc_state->pipe_src),
|
||||
width, height, NULL, 0,
|
||||
crtc_state->pch_pfit.enabled);
|
||||
}
|
||||
@ -400,10 +401,6 @@ void skl_pfit_enable(const struct intel_crtc_state *crtc_state)
|
||||
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
|
||||
const struct intel_crtc_scaler_state *scaler_state =
|
||||
&crtc_state->scaler_state;
|
||||
struct drm_rect src = {
|
||||
.x2 = crtc_state->pipe_src_w << 16,
|
||||
.y2 = crtc_state->pipe_src_h << 16,
|
||||
};
|
||||
const struct drm_rect *dst = &crtc_state->pch_pfit.dst;
|
||||
u16 uv_rgb_hphase, uv_rgb_vphase;
|
||||
enum pipe pipe = crtc->pipe;
|
||||
@ -413,6 +410,7 @@ void skl_pfit_enable(const struct intel_crtc_state *crtc_state)
|
||||
int y = dst->y1;
|
||||
int hscale, vscale;
|
||||
unsigned long irqflags;
|
||||
struct drm_rect src;
|
||||
int id;
|
||||
u32 ps_ctrl;
|
||||
|
||||
@ -423,6 +421,10 @@ void skl_pfit_enable(const struct intel_crtc_state *crtc_state)
|
||||
crtc_state->scaler_state.scaler_id < 0))
|
||||
return;
|
||||
|
||||
drm_rect_init(&src, 0, 0,
|
||||
drm_rect_width(&crtc_state->pipe_src) << 16,
|
||||
drm_rect_height(&crtc_state->pipe_src) << 16);
|
||||
|
||||
hscale = drm_rect_calc_hscale(&src, dst, 0, INT_MAX);
|
||||
vscale = drm_rect_calc_vscale(&src, dst, 0, INT_MAX);
|
||||
|
||||
|
@ -1401,7 +1401,7 @@ static int skl_plane_check_dst_coordinates(const struct intel_crtc_state *crtc_s
|
||||
to_i915(plane_state->uapi.plane->dev);
|
||||
int crtc_x = plane_state->uapi.dst.x1;
|
||||
int crtc_w = drm_rect_width(&plane_state->uapi.dst);
|
||||
int pipe_src_w = crtc_state->pipe_src_w;
|
||||
int pipe_src_w = drm_rect_width(&crtc_state->pipe_src);
|
||||
|
||||
/*
|
||||
* Display WA #1175: glk
|
||||
|
Loading…
Reference in New Issue
Block a user