|
@@ -699,7 +699,6 @@ EXPORT_SYMBOL(drm_atomic_helper_check_modeset);
|
|
|
* drm_atomic_helper_check_plane_state() - Check plane state for validity
|
|
|
* @plane_state: plane state to check
|
|
|
* @crtc_state: crtc state to check
|
|
|
- * @clip: integer clipping coordinates
|
|
|
* @min_scale: minimum @src:@dest scaling factor in 16.16 fixed point
|
|
|
* @max_scale: maximum @src:@dest scaling factor in 16.16 fixed point
|
|
|
* @can_position: is it legal to position the plane such that it
|
|
@@ -719,7 +718,6 @@ EXPORT_SYMBOL(drm_atomic_helper_check_modeset);
|
|
|
*/
|
|
|
int drm_atomic_helper_check_plane_state(struct drm_plane_state *plane_state,
|
|
|
const struct drm_crtc_state *crtc_state,
|
|
|
- const struct drm_rect *clip,
|
|
|
int min_scale,
|
|
|
int max_scale,
|
|
|
bool can_position,
|
|
@@ -729,6 +727,7 @@ int drm_atomic_helper_check_plane_state(struct drm_plane_state *plane_state,
|
|
|
struct drm_rect *src = &plane_state->src;
|
|
|
struct drm_rect *dst = &plane_state->dst;
|
|
|
unsigned int rotation = plane_state->rotation;
|
|
|
+ struct drm_rect clip = {};
|
|
|
int hscale, vscale;
|
|
|
|
|
|
WARN_ON(plane_state->crtc && plane_state->crtc != crtc_state->crtc);
|
|
@@ -764,7 +763,10 @@ int drm_atomic_helper_check_plane_state(struct drm_plane_state *plane_state,
|
|
|
return -ERANGE;
|
|
|
}
|
|
|
|
|
|
- plane_state->visible = drm_rect_clip_scaled(src, dst, clip, hscale, vscale);
|
|
|
+ if (crtc_state->enable)
|
|
|
+ drm_mode_get_hv_timing(&crtc_state->mode, &clip.x2, &clip.y2);
|
|
|
+
|
|
|
+ plane_state->visible = drm_rect_clip_scaled(src, dst, &clip, hscale, vscale);
|
|
|
|
|
|
drm_rect_rotate_inv(src, fb->width << 16, fb->height << 16, rotation);
|
|
|
|
|
@@ -778,10 +780,10 @@ int drm_atomic_helper_check_plane_state(struct drm_plane_state *plane_state,
|
|
|
*/
|
|
|
return 0;
|
|
|
|
|
|
- if (!can_position && !drm_rect_equals(dst, clip)) {
|
|
|
+ if (!can_position && !drm_rect_equals(dst, &clip)) {
|
|
|
DRM_DEBUG_KMS("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;
|
|
|
}
|
|
|
|