drm/i915: Extract intel_adjusted_rate()
Extract a small helper to calculate the downscaling adjusted pixel rate/data rate/etc. v2: Drop the plane visibility check and add a comment explaining why Reviewed-by: Jani Nikula <jani.nikula@intel.com> Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20210401154043.19466-1-ville.syrjala@linux.intel.com
This commit is contained in:
parent
1884b579c0
commit
b876e79d7b
|
@ -133,25 +133,45 @@ intel_plane_destroy_state(struct drm_plane *plane,
|
||||||
kfree(plane_state);
|
kfree(plane_state);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int intel_plane_pixel_rate(const struct intel_crtc_state *crtc_state,
|
static unsigned int intel_adjusted_rate(const struct drm_rect *src,
|
||||||
const struct intel_plane_state *plane_state)
|
const struct drm_rect *dst,
|
||||||
|
unsigned int rate)
|
||||||
{
|
{
|
||||||
unsigned int src_w, src_h, dst_w, dst_h;
|
unsigned int src_w, src_h, dst_w, dst_h;
|
||||||
unsigned int pixel_rate = crtc_state->pixel_rate;
|
|
||||||
|
|
||||||
src_w = drm_rect_width(&plane_state->uapi.src) >> 16;
|
src_w = drm_rect_width(src) >> 16;
|
||||||
src_h = drm_rect_height(&plane_state->uapi.src) >> 16;
|
src_h = drm_rect_height(src) >> 16;
|
||||||
dst_w = drm_rect_width(&plane_state->uapi.dst);
|
dst_w = drm_rect_width(dst);
|
||||||
dst_h = drm_rect_height(&plane_state->uapi.dst);
|
dst_h = drm_rect_height(dst);
|
||||||
|
|
||||||
/* Downscaling limits the maximum pixel rate */
|
/* Downscaling limits the maximum pixel rate */
|
||||||
dst_w = min(src_w, dst_w);
|
dst_w = min(src_w, dst_w);
|
||||||
dst_h = min(src_h, dst_h);
|
dst_h = min(src_h, dst_h);
|
||||||
|
|
||||||
return DIV_ROUND_UP_ULL(mul_u32_u32(pixel_rate, src_w * src_h),
|
return DIV_ROUND_UP_ULL(mul_u32_u32(rate, src_w * src_h),
|
||||||
dst_w * dst_h);
|
dst_w * dst_h);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned int intel_plane_pixel_rate(const struct intel_crtc_state *crtc_state,
|
||||||
|
const struct intel_plane_state *plane_state)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Note we don't check for plane visibility here as
|
||||||
|
* we want to use this when calculating the cursor
|
||||||
|
* watermarks even if the cursor is fully offscreen.
|
||||||
|
* That depends on the src/dst rectangles being
|
||||||
|
* correctly populated whenever the watermark code
|
||||||
|
* considers the cursor to be visible, whether or not
|
||||||
|
* it is actually visible.
|
||||||
|
*
|
||||||
|
* See: intel_wm_plane_visible() and intel_check_cursor()
|
||||||
|
*/
|
||||||
|
|
||||||
|
return intel_adjusted_rate(&plane_state->uapi.src,
|
||||||
|
&plane_state->uapi.dst,
|
||||||
|
crtc_state->pixel_rate);
|
||||||
|
}
|
||||||
|
|
||||||
unsigned int intel_plane_data_rate(const struct intel_crtc_state *crtc_state,
|
unsigned int intel_plane_data_rate(const struct intel_crtc_state *crtc_state,
|
||||||
const struct intel_plane_state *plane_state)
|
const struct intel_plane_state *plane_state)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue