提交 b39d53f6 编写于 作者: V Ville Syrjälä 提交者: Daniel Vetter

drm/i915: Pass crtc to our update/disable_plane hooks

We're going to want to know which CRTC we're dealing with, so pass it
down to the update/disable_plane hooks.
Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
上级 c35426d2
...@@ -359,13 +359,15 @@ struct intel_plane { ...@@ -359,13 +359,15 @@ struct intel_plane {
struct intel_plane_wm_parameters wm; struct intel_plane_wm_parameters wm;
void (*update_plane)(struct drm_plane *plane, void (*update_plane)(struct drm_plane *plane,
struct drm_crtc *crtc,
struct drm_framebuffer *fb, struct drm_framebuffer *fb,
struct drm_i915_gem_object *obj, struct drm_i915_gem_object *obj,
int crtc_x, int crtc_y, int crtc_x, int crtc_y,
unsigned int crtc_w, unsigned int crtc_h, unsigned int crtc_w, unsigned int crtc_h,
uint32_t x, uint32_t y, uint32_t x, uint32_t y,
uint32_t src_w, uint32_t src_h); uint32_t src_w, uint32_t src_h);
void (*disable_plane)(struct drm_plane *plane); void (*disable_plane)(struct drm_plane *plane,
struct drm_crtc *crtc);
int (*update_colorkey)(struct drm_plane *plane, int (*update_colorkey)(struct drm_plane *plane,
struct drm_intel_sprite_colorkey *key); struct drm_intel_sprite_colorkey *key);
void (*get_colorkey)(struct drm_plane *plane, void (*get_colorkey)(struct drm_plane *plane,
......
...@@ -38,7 +38,8 @@ ...@@ -38,7 +38,8 @@
#include "i915_drv.h" #include "i915_drv.h"
static void static void
vlv_update_plane(struct drm_plane *dplane, struct drm_framebuffer *fb, vlv_update_plane(struct drm_plane *dplane, struct drm_crtc *crtc,
struct drm_framebuffer *fb,
struct drm_i915_gem_object *obj, int crtc_x, int crtc_y, struct drm_i915_gem_object *obj, int crtc_x, int crtc_y,
unsigned int crtc_w, unsigned int crtc_h, unsigned int crtc_w, unsigned int crtc_h,
uint32_t x, uint32_t y, uint32_t x, uint32_t y,
...@@ -140,7 +141,7 @@ vlv_update_plane(struct drm_plane *dplane, struct drm_framebuffer *fb, ...@@ -140,7 +141,7 @@ vlv_update_plane(struct drm_plane *dplane, struct drm_framebuffer *fb,
} }
static void static void
vlv_disable_plane(struct drm_plane *dplane) vlv_disable_plane(struct drm_plane *dplane, struct drm_crtc *crtc)
{ {
struct drm_device *dev = dplane->dev; struct drm_device *dev = dplane->dev;
struct drm_i915_private *dev_priv = dev->dev_private; struct drm_i915_private *dev_priv = dev->dev_private;
...@@ -207,7 +208,8 @@ vlv_get_colorkey(struct drm_plane *dplane, ...@@ -207,7 +208,8 @@ vlv_get_colorkey(struct drm_plane *dplane,
} }
static void static void
ivb_update_plane(struct drm_plane *plane, struct drm_framebuffer *fb, ivb_update_plane(struct drm_plane *plane, struct drm_crtc *crtc,
struct drm_framebuffer *fb,
struct drm_i915_gem_object *obj, int crtc_x, int crtc_y, struct drm_i915_gem_object *obj, int crtc_x, int crtc_y,
unsigned int crtc_w, unsigned int crtc_h, unsigned int crtc_w, unsigned int crtc_h,
uint32_t x, uint32_t y, uint32_t x, uint32_t y,
...@@ -320,7 +322,7 @@ ivb_update_plane(struct drm_plane *plane, struct drm_framebuffer *fb, ...@@ -320,7 +322,7 @@ ivb_update_plane(struct drm_plane *plane, struct drm_framebuffer *fb,
} }
static void static void
ivb_disable_plane(struct drm_plane *plane) ivb_disable_plane(struct drm_plane *plane, struct drm_crtc *crtc)
{ {
struct drm_device *dev = plane->dev; struct drm_device *dev = plane->dev;
struct drm_i915_private *dev_priv = dev->dev_private; struct drm_i915_private *dev_priv = dev->dev_private;
...@@ -400,7 +402,8 @@ ivb_get_colorkey(struct drm_plane *plane, struct drm_intel_sprite_colorkey *key) ...@@ -400,7 +402,8 @@ ivb_get_colorkey(struct drm_plane *plane, struct drm_intel_sprite_colorkey *key)
} }
static void static void
ilk_update_plane(struct drm_plane *plane, struct drm_framebuffer *fb, ilk_update_plane(struct drm_plane *plane, struct drm_crtc *crtc,
struct drm_framebuffer *fb,
struct drm_i915_gem_object *obj, int crtc_x, int crtc_y, struct drm_i915_gem_object *obj, int crtc_x, int crtc_y,
unsigned int crtc_w, unsigned int crtc_h, unsigned int crtc_w, unsigned int crtc_h,
uint32_t x, uint32_t y, uint32_t x, uint32_t y,
...@@ -488,7 +491,7 @@ ilk_update_plane(struct drm_plane *plane, struct drm_framebuffer *fb, ...@@ -488,7 +491,7 @@ ilk_update_plane(struct drm_plane *plane, struct drm_framebuffer *fb,
} }
static void static void
ilk_disable_plane(struct drm_plane *plane) ilk_disable_plane(struct drm_plane *plane, struct drm_crtc *crtc)
{ {
struct drm_device *dev = plane->dev; struct drm_device *dev = plane->dev;
struct drm_i915_private *dev_priv = dev->dev_private; struct drm_i915_private *dev_priv = dev->dev_private;
...@@ -823,11 +826,11 @@ intel_update_plane(struct drm_plane *plane, struct drm_crtc *crtc, ...@@ -823,11 +826,11 @@ intel_update_plane(struct drm_plane *plane, struct drm_crtc *crtc,
intel_enable_primary(crtc); intel_enable_primary(crtc);
if (visible) if (visible)
intel_plane->update_plane(plane, fb, obj, intel_plane->update_plane(plane, crtc, fb, obj,
crtc_x, crtc_y, crtc_w, crtc_h, crtc_x, crtc_y, crtc_w, crtc_h,
src_x, src_y, src_w, src_h); src_x, src_y, src_w, src_h);
else else
intel_plane->disable_plane(plane); intel_plane->disable_plane(plane, crtc);
if (disable_primary) if (disable_primary)
intel_disable_primary(crtc); intel_disable_primary(crtc);
...@@ -862,7 +865,7 @@ intel_disable_plane(struct drm_plane *plane) ...@@ -862,7 +865,7 @@ intel_disable_plane(struct drm_plane *plane)
if (plane->crtc) if (plane->crtc)
intel_enable_primary(plane->crtc); intel_enable_primary(plane->crtc);
intel_plane->disable_plane(plane); intel_plane->disable_plane(plane, plane->crtc);
if (!intel_plane->obj) if (!intel_plane->obj)
goto out; goto out;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册