mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-06 19:08:57 +09:00
drm/atomic: Pass the full state to CRTC atomic enable/disable
If the CRTC driver ever needs to access the full DRM state, it can't do so
at atomic_enable / atomic_disable time since drm_atomic_helper_swap_state
will have cleared the pointer from the struct drm_crtc_state to the struct
drm_atomic_state before calling those hooks.
In order to allow that, let's pass the full DRM state to atomic_enable and
atomic_disable. The conversion was done using the coccinelle script below,
built tested on all the drivers and actually tested on vc4.
virtual report
@@
struct drm_crtc_helper_funcs *FUNCS;
identifier dev, state;
identifier crtc, crtc_state;
@@
disable_outputs(struct drm_device *dev, struct drm_atomic_state *state)
{
<...
- FUNCS->atomic_disable(crtc, crtc_state);
+ FUNCS->atomic_disable(crtc, state);
...>
}
@@
struct drm_crtc_helper_funcs *FUNCS;
identifier dev, state;
identifier crtc, crtc_state;
@@
drm_atomic_helper_commit_modeset_enables(struct drm_device *dev, struct drm_atomic_state *state)
{
<...
- FUNCS->atomic_enable(crtc, crtc_state);
+ FUNCS->atomic_enable(crtc, state);
...>
}
@@
identifier crtc, old_state;
@@
struct drm_crtc_helper_funcs {
...
- void (*atomic_enable)(struct drm_crtc *crtc, struct drm_crtc_state *old_state);
+ void (*atomic_enable)(struct drm_crtc *crtc, struct drm_atomic_state *state);
...
- void (*atomic_disable)(struct drm_crtc *crtc, struct drm_crtc_state *old_state);
+ void (*atomic_disable)(struct drm_crtc *crtc, struct drm_atomic_state *state);
...
}
@ crtc_atomic_func @
identifier helpers;
identifier func;
@@
(
static struct drm_crtc_helper_funcs helpers = {
...,
.atomic_enable = func,
...,
};
|
static struct drm_crtc_helper_funcs helpers = {
...,
.atomic_disable = func,
...,
};
)
@ ignores_old_state @
identifier crtc_atomic_func.func;
identifier crtc, old_state;
@@
void func(struct drm_crtc *crtc,
struct drm_crtc_state *old_state)
{
... when != old_state
}
@ adds_old_state depends on crtc_atomic_func && !ignores_old_state @
identifier crtc_atomic_func.func;
identifier crtc, old_state;
@@
void func(struct drm_crtc *crtc, struct drm_crtc_state *old_state)
{
+ struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state, crtc);
...
}
@ depends on crtc_atomic_func @
identifier crtc_atomic_func.func;
expression E;
type T;
@@
void func(...)
{
...
- T state = E;
+ T crtc_state = E;
<+...
- state
+ crtc_state
...+>
}
@ depends on crtc_atomic_func @
identifier crtc_atomic_func.func;
type T;
@@
void func(...)
{
...
- T state;
+ T crtc_state;
<+...
- state
+ crtc_state
...+>
}
@ depends on crtc_atomic_func @
identifier crtc_atomic_func.func;
identifier old_state;
identifier crtc;
@@
void func(struct drm_crtc *crtc,
- struct drm_crtc_state *old_state
+ struct drm_atomic_state *state
)
{ ... }
@ include depends on adds_old_state @
@@
#include <drm/drm_atomic.h>
@ no_include depends on !include && adds_old_state @
@@
+ #include <drm/drm_atomic.h>
#include <drm/...>
Signed-off-by: Maxime Ripard <maxime@cerno.tech>
Acked-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/845aa10ef171fc0ea060495efef142a0c13f7870.1602161031.git-series.maxime@cerno.tech
This commit is contained in:
@@ -116,7 +116,7 @@ static void arc_pgu_crtc_mode_set_nofb(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void arc_pgu_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void arc_pgu_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct arcpgu_drm_private *arcpgu = crtc_to_arcpgu_priv(crtc);
|
struct arcpgu_drm_private *arcpgu = crtc_to_arcpgu_priv(crtc);
|
||||||
|
|
||||||
@@ -127,7 +127,7 @@ static void arc_pgu_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void arc_pgu_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void arc_pgu_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct arcpgu_drm_private *arcpgu = crtc_to_arcpgu_priv(crtc);
|
struct arcpgu_drm_private *arcpgu = crtc_to_arcpgu_priv(crtc);
|
||||||
|
|
||||||
|
|||||||
@@ -273,8 +273,10 @@ komeda_crtc_do_flush(struct drm_crtc *crtc,
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
komeda_crtc_atomic_enable(struct drm_crtc *crtc,
|
komeda_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
pm_runtime_get_sync(crtc->dev->dev);
|
pm_runtime_get_sync(crtc->dev->dev);
|
||||||
komeda_crtc_prepare(to_kcrtc(crtc));
|
komeda_crtc_prepare(to_kcrtc(crtc));
|
||||||
drm_crtc_vblank_on(crtc);
|
drm_crtc_vblank_on(crtc);
|
||||||
@@ -319,8 +321,10 @@ komeda_crtc_flush_and_wait_for_flip_done(struct komeda_crtc *kcrtc,
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
komeda_crtc_atomic_disable(struct drm_crtc *crtc,
|
komeda_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct komeda_crtc *kcrtc = to_kcrtc(crtc);
|
struct komeda_crtc *kcrtc = to_kcrtc(crtc);
|
||||||
struct komeda_crtc_state *old_st = to_kcrtc_st(old);
|
struct komeda_crtc_state *old_st = to_kcrtc_st(old);
|
||||||
struct komeda_pipeline *master = kcrtc->master;
|
struct komeda_pipeline *master = kcrtc->master;
|
||||||
|
|||||||
@@ -168,7 +168,7 @@ static void hdlcd_crtc_mode_set_nofb(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void hdlcd_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void hdlcd_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct hdlcd_drm_private *hdlcd = crtc_to_hdlcd_priv(crtc);
|
struct hdlcd_drm_private *hdlcd = crtc_to_hdlcd_priv(crtc);
|
||||||
|
|
||||||
@@ -179,7 +179,7 @@ static void hdlcd_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void hdlcd_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void hdlcd_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct hdlcd_drm_private *hdlcd = crtc_to_hdlcd_priv(crtc);
|
struct hdlcd_drm_private *hdlcd = crtc_to_hdlcd_priv(crtc);
|
||||||
|
|
||||||
|
|||||||
@@ -46,7 +46,7 @@ static enum drm_mode_status malidp_crtc_mode_valid(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void malidp_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void malidp_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct malidp_drm *malidp = crtc_to_malidp_device(crtc);
|
struct malidp_drm *malidp = crtc_to_malidp_device(crtc);
|
||||||
struct malidp_hw_device *hwdev = malidp->dev;
|
struct malidp_hw_device *hwdev = malidp->dev;
|
||||||
@@ -70,8 +70,10 @@ static void malidp_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void malidp_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void malidp_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct malidp_drm *malidp = crtc_to_malidp_device(crtc);
|
struct malidp_drm *malidp = crtc_to_malidp_device(crtc);
|
||||||
struct malidp_hw_device *hwdev = malidp->dev;
|
struct malidp_hw_device *hwdev = malidp->dev;
|
||||||
int err;
|
int err;
|
||||||
|
|||||||
@@ -467,8 +467,10 @@ static void armada_drm_crtc_atomic_flush(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void armada_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void armada_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct armada_crtc *dcrtc = drm_to_armada_crtc(crtc);
|
struct armada_crtc *dcrtc = drm_to_armada_crtc(crtc);
|
||||||
struct drm_pending_vblank_event *event;
|
struct drm_pending_vblank_event *event;
|
||||||
|
|
||||||
@@ -503,8 +505,10 @@ static void armada_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void armada_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void armada_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct armada_crtc *dcrtc = drm_to_armada_crtc(crtc);
|
struct armada_crtc *dcrtc = drm_to_armada_crtc(crtc);
|
||||||
|
|
||||||
DRM_DEBUG_KMS("[CRTC:%d:%s]\n", crtc->base.id, crtc->name);
|
DRM_DEBUG_KMS("[CRTC:%d:%s]\n", crtc->base.id, crtc->name);
|
||||||
|
|||||||
@@ -793,7 +793,7 @@ ast_crtc_helper_atomic_flush(struct drm_crtc *crtc, struct drm_crtc_state *old_c
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
ast_crtc_helper_atomic_enable(struct drm_crtc *crtc,
|
ast_crtc_helper_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = crtc->dev;
|
struct drm_device *dev = crtc->dev;
|
||||||
struct ast_private *ast = to_ast_private(dev);
|
struct ast_private *ast = to_ast_private(dev);
|
||||||
@@ -816,8 +816,10 @@ ast_crtc_helper_atomic_enable(struct drm_crtc *crtc,
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
ast_crtc_helper_atomic_disable(struct drm_crtc *crtc,
|
ast_crtc_helper_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_crtc_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct drm_device *dev = crtc->dev;
|
struct drm_device *dev = crtc->dev;
|
||||||
struct ast_private *ast = to_ast_private(dev);
|
struct ast_private *ast = to_ast_private(dev);
|
||||||
|
|
||||||
|
|||||||
@@ -165,7 +165,7 @@ atmel_hlcdc_crtc_mode_valid(struct drm_crtc *c,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void atmel_hlcdc_crtc_atomic_disable(struct drm_crtc *c,
|
static void atmel_hlcdc_crtc_atomic_disable(struct drm_crtc *c,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = c->dev;
|
struct drm_device *dev = c->dev;
|
||||||
struct atmel_hlcdc_crtc *crtc = drm_crtc_to_atmel_hlcdc_crtc(c);
|
struct atmel_hlcdc_crtc *crtc = drm_crtc_to_atmel_hlcdc_crtc(c);
|
||||||
@@ -200,7 +200,7 @@ static void atmel_hlcdc_crtc_atomic_disable(struct drm_crtc *c,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void atmel_hlcdc_crtc_atomic_enable(struct drm_crtc *c,
|
static void atmel_hlcdc_crtc_atomic_enable(struct drm_crtc *c,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = c->dev;
|
struct drm_device *dev = c->dev;
|
||||||
struct atmel_hlcdc_crtc *crtc = drm_crtc_to_atmel_hlcdc_crtc(c);
|
struct atmel_hlcdc_crtc *crtc = drm_crtc_to_atmel_hlcdc_crtc(c);
|
||||||
|
|||||||
@@ -1093,7 +1093,7 @@ disable_outputs(struct drm_device *dev, struct drm_atomic_state *old_state)
|
|||||||
if (new_crtc_state->enable && funcs->prepare)
|
if (new_crtc_state->enable && funcs->prepare)
|
||||||
funcs->prepare(crtc);
|
funcs->prepare(crtc);
|
||||||
else if (funcs->atomic_disable)
|
else if (funcs->atomic_disable)
|
||||||
funcs->atomic_disable(crtc, old_crtc_state);
|
funcs->atomic_disable(crtc, old_state);
|
||||||
else if (funcs->disable)
|
else if (funcs->disable)
|
||||||
funcs->disable(crtc);
|
funcs->disable(crtc);
|
||||||
else if (funcs->dpms)
|
else if (funcs->dpms)
|
||||||
@@ -1358,7 +1358,7 @@ void drm_atomic_helper_commit_modeset_enables(struct drm_device *dev,
|
|||||||
DRM_DEBUG_ATOMIC("enabling [CRTC:%d:%s]\n",
|
DRM_DEBUG_ATOMIC("enabling [CRTC:%d:%s]\n",
|
||||||
crtc->base.id, crtc->name);
|
crtc->base.id, crtc->name);
|
||||||
if (funcs->atomic_enable)
|
if (funcs->atomic_enable)
|
||||||
funcs->atomic_enable(crtc, old_crtc_state);
|
funcs->atomic_enable(crtc, old_state);
|
||||||
else if (funcs->commit)
|
else if (funcs->commit)
|
||||||
funcs->commit(crtc);
|
funcs->commit(crtc);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -99,7 +99,7 @@ static int drm_simple_kms_crtc_check(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void drm_simple_kms_crtc_enable(struct drm_crtc *crtc,
|
static void drm_simple_kms_crtc_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_plane *plane;
|
struct drm_plane *plane;
|
||||||
struct drm_simple_display_pipe *pipe;
|
struct drm_simple_display_pipe *pipe;
|
||||||
@@ -113,7 +113,7 @@ static void drm_simple_kms_crtc_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void drm_simple_kms_crtc_disable(struct drm_crtc *crtc,
|
static void drm_simple_kms_crtc_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_simple_display_pipe *pipe;
|
struct drm_simple_display_pipe *pipe;
|
||||||
|
|
||||||
|
|||||||
@@ -19,7 +19,7 @@
|
|||||||
#include "exynos_drm_plane.h"
|
#include "exynos_drm_plane.h"
|
||||||
|
|
||||||
static void exynos_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void exynos_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct exynos_drm_crtc *exynos_crtc = to_exynos_crtc(crtc);
|
struct exynos_drm_crtc *exynos_crtc = to_exynos_crtc(crtc);
|
||||||
|
|
||||||
@@ -30,7 +30,7 @@ static void exynos_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void exynos_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void exynos_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct exynos_drm_crtc *exynos_crtc = to_exynos_crtc(crtc);
|
struct exynos_drm_crtc *exynos_crtc = to_exynos_crtc(crtc);
|
||||||
|
|
||||||
|
|||||||
@@ -43,8 +43,10 @@ static void fsl_dcu_drm_crtc_atomic_flush(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void fsl_dcu_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void fsl_dcu_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_crtc_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct drm_device *dev = crtc->dev;
|
struct drm_device *dev = crtc->dev;
|
||||||
struct fsl_dcu_drm_device *fsl_dev = dev->dev_private;
|
struct fsl_dcu_drm_device *fsl_dev = dev->dev_private;
|
||||||
|
|
||||||
@@ -62,7 +64,7 @@ static void fsl_dcu_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void fsl_dcu_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void fsl_dcu_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = crtc->dev;
|
struct drm_device *dev = crtc->dev;
|
||||||
struct fsl_dcu_drm_device *fsl_dev = dev->dev_private;
|
struct fsl_dcu_drm_device *fsl_dev = dev->dev_private;
|
||||||
|
|||||||
@@ -170,7 +170,7 @@ static void hibmc_crtc_dpms(struct drm_crtc *crtc, int dpms)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void hibmc_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void hibmc_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
unsigned int reg;
|
unsigned int reg;
|
||||||
struct hibmc_drm_private *priv = to_hibmc_drm_private(crtc->dev);
|
struct hibmc_drm_private *priv = to_hibmc_drm_private(crtc->dev);
|
||||||
@@ -189,7 +189,7 @@ static void hibmc_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void hibmc_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void hibmc_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
unsigned int reg;
|
unsigned int reg;
|
||||||
struct hibmc_drm_private *priv = to_hibmc_drm_private(crtc->dev);
|
struct hibmc_drm_private *priv = to_hibmc_drm_private(crtc->dev);
|
||||||
|
|||||||
@@ -436,7 +436,7 @@ static void ade_dump_regs(void __iomem *base) { }
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void ade_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void ade_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct kirin_crtc *kcrtc = to_kirin_crtc(crtc);
|
struct kirin_crtc *kcrtc = to_kirin_crtc(crtc);
|
||||||
struct ade_hw_ctx *ctx = kcrtc->hw_ctx;
|
struct ade_hw_ctx *ctx = kcrtc->hw_ctx;
|
||||||
@@ -459,7 +459,7 @@ static void ade_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void ade_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void ade_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct kirin_crtc *kcrtc = to_kirin_crtc(crtc);
|
struct kirin_crtc *kcrtc = to_kirin_crtc(crtc);
|
||||||
struct ade_hw_ctx *ctx = kcrtc->hw_ctx;
|
struct ade_hw_ctx *ctx = kcrtc->hw_ctx;
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
* Copyright 2019 NXP.
|
* Copyright 2019 NXP.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <drm/drm_atomic.h>
|
||||||
#include <drm/drm_atomic_helper.h>
|
#include <drm/drm_atomic_helper.h>
|
||||||
#include <drm/drm_vblank.h>
|
#include <drm/drm_vblank.h>
|
||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
@@ -77,8 +78,10 @@ static void dcss_crtc_atomic_flush(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void dcss_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void dcss_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_crtc_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct dcss_crtc *dcss_crtc = container_of(crtc, struct dcss_crtc,
|
struct dcss_crtc *dcss_crtc = container_of(crtc, struct dcss_crtc,
|
||||||
base);
|
base);
|
||||||
struct dcss_dev *dcss = dcss_crtc->base.dev->dev_private;
|
struct dcss_dev *dcss = dcss_crtc->base.dev->dev_private;
|
||||||
@@ -111,8 +114,10 @@ static void dcss_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void dcss_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void dcss_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_crtc_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct dcss_crtc *dcss_crtc = container_of(crtc, struct dcss_crtc,
|
struct dcss_crtc *dcss_crtc = container_of(crtc, struct dcss_crtc,
|
||||||
base);
|
base);
|
||||||
struct dcss_dev *dcss = dcss_crtc->base.dev->dev_private;
|
struct dcss_dev *dcss = dcss_crtc->base.dev->dev_private;
|
||||||
|
|||||||
@@ -47,7 +47,7 @@ static inline struct ipu_crtc *to_ipu_crtc(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void ipu_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void ipu_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct ipu_crtc *ipu_crtc = to_ipu_crtc(crtc);
|
struct ipu_crtc *ipu_crtc = to_ipu_crtc(crtc);
|
||||||
struct ipu_soc *ipu = dev_get_drvdata(ipu_crtc->dev->parent);
|
struct ipu_soc *ipu = dev_get_drvdata(ipu_crtc->dev->parent);
|
||||||
@@ -79,8 +79,10 @@ static void ipu_crtc_disable_planes(struct ipu_crtc *ipu_crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void ipu_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void ipu_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_crtc_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct ipu_crtc *ipu_crtc = to_ipu_crtc(crtc);
|
struct ipu_crtc *ipu_crtc = to_ipu_crtc(crtc);
|
||||||
struct ipu_soc *ipu = dev_get_drvdata(ipu_crtc->dev->parent);
|
struct ipu_soc *ipu = dev_get_drvdata(ipu_crtc->dev->parent);
|
||||||
|
|
||||||
|
|||||||
@@ -156,7 +156,7 @@ static int ingenic_drm_update_pixclk(struct notifier_block *nb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void ingenic_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void ingenic_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct ingenic_drm *priv = drm_crtc_get_priv(crtc);
|
struct ingenic_drm *priv = drm_crtc_get_priv(crtc);
|
||||||
|
|
||||||
@@ -170,7 +170,7 @@ static void ingenic_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void ingenic_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void ingenic_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct ingenic_drm *priv = drm_crtc_get_priv(crtc);
|
struct ingenic_drm *priv = drm_crtc_get_priv(crtc);
|
||||||
unsigned int var;
|
unsigned int var;
|
||||||
|
|||||||
@@ -517,7 +517,7 @@ void mtk_drm_crtc_async_update(struct drm_crtc *crtc, struct drm_plane *plane,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void mtk_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void mtk_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct mtk_drm_crtc *mtk_crtc = to_mtk_crtc(crtc);
|
struct mtk_drm_crtc *mtk_crtc = to_mtk_crtc(crtc);
|
||||||
struct mtk_ddp_comp *comp = mtk_crtc->ddp_comp[0];
|
struct mtk_ddp_comp *comp = mtk_crtc->ddp_comp[0];
|
||||||
@@ -542,7 +542,7 @@ static void mtk_drm_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void mtk_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void mtk_drm_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct mtk_drm_crtc *mtk_crtc = to_mtk_crtc(crtc);
|
struct mtk_drm_crtc *mtk_crtc = to_mtk_crtc(crtc);
|
||||||
struct mtk_ddp_comp *comp = mtk_crtc->ddp_comp[0];
|
struct mtk_ddp_comp *comp = mtk_crtc->ddp_comp[0];
|
||||||
|
|||||||
@@ -82,7 +82,7 @@ static const struct drm_crtc_funcs meson_crtc_funcs = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static void meson_g12a_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void meson_g12a_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct meson_crtc *meson_crtc = to_meson_crtc(crtc);
|
struct meson_crtc *meson_crtc = to_meson_crtc(crtc);
|
||||||
struct drm_crtc_state *crtc_state = crtc->state;
|
struct drm_crtc_state *crtc_state = crtc->state;
|
||||||
@@ -118,7 +118,7 @@ static void meson_g12a_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void meson_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void meson_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct meson_crtc *meson_crtc = to_meson_crtc(crtc);
|
struct meson_crtc *meson_crtc = to_meson_crtc(crtc);
|
||||||
struct drm_crtc_state *crtc_state = crtc->state;
|
struct drm_crtc_state *crtc_state = crtc->state;
|
||||||
@@ -146,7 +146,7 @@ static void meson_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void meson_g12a_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void meson_g12a_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct meson_crtc *meson_crtc = to_meson_crtc(crtc);
|
struct meson_crtc *meson_crtc = to_meson_crtc(crtc);
|
||||||
struct meson_drm *priv = meson_crtc->priv;
|
struct meson_drm *priv = meson_crtc->priv;
|
||||||
@@ -171,7 +171,7 @@ static void meson_g12a_crtc_atomic_disable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void meson_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void meson_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct meson_crtc *meson_crtc = to_meson_crtc(crtc);
|
struct meson_crtc *meson_crtc = to_meson_crtc(crtc);
|
||||||
struct meson_drm *priv = meson_crtc->priv;
|
struct meson_drm *priv = meson_crtc->priv;
|
||||||
|
|||||||
@@ -11,6 +11,7 @@
|
|||||||
#include <linux/ktime.h>
|
#include <linux/ktime.h>
|
||||||
#include <linux/bits.h>
|
#include <linux/bits.h>
|
||||||
|
|
||||||
|
#include <drm/drm_atomic.h>
|
||||||
#include <drm/drm_crtc.h>
|
#include <drm/drm_crtc.h>
|
||||||
#include <drm/drm_flip_work.h>
|
#include <drm/drm_flip_work.h>
|
||||||
#include <drm/drm_mode.h>
|
#include <drm/drm_mode.h>
|
||||||
@@ -752,8 +753,10 @@ static struct drm_crtc_state *dpu_crtc_duplicate_state(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void dpu_crtc_disable(struct drm_crtc *crtc,
|
static void dpu_crtc_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_crtc_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct dpu_crtc *dpu_crtc;
|
struct dpu_crtc *dpu_crtc;
|
||||||
struct dpu_crtc_state *cstate;
|
struct dpu_crtc_state *cstate;
|
||||||
struct drm_encoder *encoder;
|
struct drm_encoder *encoder;
|
||||||
@@ -823,7 +826,7 @@ static void dpu_crtc_disable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void dpu_crtc_enable(struct drm_crtc *crtc,
|
static void dpu_crtc_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct dpu_crtc *dpu_crtc;
|
struct dpu_crtc *dpu_crtc;
|
||||||
struct drm_encoder *encoder;
|
struct drm_encoder *encoder;
|
||||||
|
|||||||
@@ -264,7 +264,7 @@ static void mdp4_crtc_mode_set_nofb(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void mdp4_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void mdp4_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct mdp4_crtc *mdp4_crtc = to_mdp4_crtc(crtc);
|
struct mdp4_crtc *mdp4_crtc = to_mdp4_crtc(crtc);
|
||||||
struct mdp4_kms *mdp4_kms = get_kms(crtc);
|
struct mdp4_kms *mdp4_kms = get_kms(crtc);
|
||||||
@@ -284,7 +284,7 @@ static void mdp4_crtc_atomic_disable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void mdp4_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void mdp4_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct mdp4_crtc *mdp4_crtc = to_mdp4_crtc(crtc);
|
struct mdp4_crtc *mdp4_crtc = to_mdp4_crtc(crtc);
|
||||||
struct mdp4_kms *mdp4_kms = get_kms(crtc);
|
struct mdp4_kms *mdp4_kms = get_kms(crtc);
|
||||||
|
|||||||
@@ -483,7 +483,7 @@ static u32 mdp5_crtc_get_vblank_counter(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void mdp5_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void mdp5_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct mdp5_crtc *mdp5_crtc = to_mdp5_crtc(crtc);
|
struct mdp5_crtc *mdp5_crtc = to_mdp5_crtc(crtc);
|
||||||
struct mdp5_crtc_state *mdp5_cstate = to_mdp5_crtc_state(crtc->state);
|
struct mdp5_crtc_state *mdp5_cstate = to_mdp5_crtc_state(crtc->state);
|
||||||
@@ -529,7 +529,7 @@ static void mdp5_crtc_vblank_on(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void mdp5_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void mdp5_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct mdp5_crtc *mdp5_crtc = to_mdp5_crtc(crtc);
|
struct mdp5_crtc *mdp5_crtc = to_mdp5_crtc(crtc);
|
||||||
struct mdp5_crtc_state *mdp5_cstate = to_mdp5_crtc_state(crtc->state);
|
struct mdp5_crtc_state *mdp5_cstate = to_mdp5_crtc_state(crtc->state);
|
||||||
|
|||||||
@@ -302,7 +302,7 @@ static void mxsfb_crtc_atomic_flush(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void mxsfb_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void mxsfb_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct mxsfb_drm_private *mxsfb = to_mxsfb_drm_private(crtc->dev);
|
struct mxsfb_drm_private *mxsfb = to_mxsfb_drm_private(crtc->dev);
|
||||||
struct drm_device *drm = mxsfb->drm;
|
struct drm_device *drm = mxsfb->drm;
|
||||||
@@ -326,7 +326,7 @@ static void mxsfb_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void mxsfb_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void mxsfb_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct mxsfb_drm_private *mxsfb = to_mxsfb_drm_private(crtc->dev);
|
struct mxsfb_drm_private *mxsfb = to_mxsfb_drm_private(crtc->dev);
|
||||||
struct drm_device *drm = mxsfb->drm;
|
struct drm_device *drm = mxsfb->drm;
|
||||||
|
|||||||
@@ -436,7 +436,7 @@ static void omap_crtc_arm_event(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void omap_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void omap_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct omap_drm_private *priv = crtc->dev->dev_private;
|
struct omap_drm_private *priv = crtc->dev->dev_private;
|
||||||
struct omap_crtc *omap_crtc = to_omap_crtc(crtc);
|
struct omap_crtc *omap_crtc = to_omap_crtc(crtc);
|
||||||
@@ -462,7 +462,7 @@ static void omap_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void omap_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void omap_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct omap_drm_private *priv = crtc->dev->dev_private;
|
struct omap_drm_private *priv = crtc->dev->dev_private;
|
||||||
struct omap_crtc *omap_crtc = to_omap_crtc(crtc);
|
struct omap_crtc *omap_crtc = to_omap_crtc(crtc);
|
||||||
|
|||||||
@@ -444,13 +444,13 @@ static const struct drm_framebuffer_funcs qxl_fb_funcs = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static void qxl_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void qxl_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
qxl_crtc_update_monitors_config(crtc, "enable");
|
qxl_crtc_update_monitors_config(crtc, "enable");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qxl_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void qxl_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
qxl_crtc_update_monitors_config(crtc, "disable");
|
qxl_crtc_update_monitors_config(crtc, "disable");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -710,7 +710,7 @@ static int rcar_du_crtc_atomic_check(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void rcar_du_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void rcar_du_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct rcar_du_crtc *rcrtc = to_rcar_crtc(crtc);
|
struct rcar_du_crtc *rcrtc = to_rcar_crtc(crtc);
|
||||||
struct rcar_du_crtc_state *rstate = to_rcar_crtc_state(crtc->state);
|
struct rcar_du_crtc_state *rstate = to_rcar_crtc_state(crtc->state);
|
||||||
@@ -748,8 +748,10 @@ static void rcar_du_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void rcar_du_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void rcar_du_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct rcar_du_crtc *rcrtc = to_rcar_crtc(crtc);
|
struct rcar_du_crtc *rcrtc = to_rcar_crtc(crtc);
|
||||||
struct rcar_du_crtc_state *rstate = to_rcar_crtc_state(old_state);
|
struct rcar_du_crtc_state *rstate = to_rcar_crtc_state(old_state);
|
||||||
struct rcar_du_device *rcdu = rcrtc->dev;
|
struct rcar_du_device *rcdu = rcrtc->dev;
|
||||||
|
|||||||
@@ -693,7 +693,7 @@ static void rockchip_drm_set_win_enabled(struct drm_crtc *crtc, bool enabled)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void vop_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void vop_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct vop *vop = to_vop(crtc);
|
struct vop *vop = to_vop(crtc);
|
||||||
|
|
||||||
@@ -1260,8 +1260,10 @@ static void vop_crtc_atomic_begin(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void vop_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void vop_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct vop *vop = to_vop(crtc);
|
struct vop *vop = to_vop(crtc);
|
||||||
const struct vop_data *vop_data = vop->data;
|
const struct vop_data *vop_data = vop->data;
|
||||||
struct rockchip_crtc_state *s = to_rockchip_crtc_state(crtc->state);
|
struct rockchip_crtc_state *s = to_rockchip_crtc_state(crtc->state);
|
||||||
|
|||||||
@@ -23,7 +23,7 @@
|
|||||||
#include "sti_vtg.h"
|
#include "sti_vtg.h"
|
||||||
|
|
||||||
static void sti_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void sti_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct sti_mixer *mixer = to_sti_mixer(crtc);
|
struct sti_mixer *mixer = to_sti_mixer(crtc);
|
||||||
|
|
||||||
@@ -35,7 +35,7 @@ static void sti_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void sti_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void sti_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct sti_mixer *mixer = to_sti_mixer(crtc);
|
struct sti_mixer *mixer = to_sti_mixer(crtc);
|
||||||
|
|
||||||
|
|||||||
@@ -420,7 +420,7 @@ static void ltdc_crtc_update_clut(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void ltdc_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void ltdc_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct ltdc_device *ldev = crtc_to_ltdc(crtc);
|
struct ltdc_device *ldev = crtc_to_ltdc(crtc);
|
||||||
struct drm_device *ddev = crtc->dev;
|
struct drm_device *ddev = crtc->dev;
|
||||||
@@ -442,7 +442,7 @@ static void ltdc_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void ltdc_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void ltdc_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct ltdc_device *ldev = crtc_to_ltdc(crtc);
|
struct ltdc_device *ldev = crtc_to_ltdc(crtc);
|
||||||
struct drm_device *ddev = crtc->dev;
|
struct drm_device *ddev = crtc->dev;
|
||||||
|
|||||||
@@ -101,7 +101,7 @@ static void sun4i_crtc_atomic_flush(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void sun4i_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void sun4i_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_encoder *encoder = sun4i_crtc_get_encoder(crtc);
|
struct drm_encoder *encoder = sun4i_crtc_get_encoder(crtc);
|
||||||
struct sun4i_crtc *scrtc = drm_crtc_to_sun4i_crtc(crtc);
|
struct sun4i_crtc *scrtc = drm_crtc_to_sun4i_crtc(crtc);
|
||||||
@@ -122,7 +122,7 @@ static void sun4i_crtc_atomic_disable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void sun4i_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void sun4i_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_encoder *encoder = sun4i_crtc_get_encoder(crtc);
|
struct drm_encoder *encoder = sun4i_crtc_get_encoder(crtc);
|
||||||
struct sun4i_crtc *scrtc = drm_crtc_to_sun4i_crtc(crtc);
|
struct sun4i_crtc *scrtc = drm_crtc_to_sun4i_crtc(crtc);
|
||||||
|
|||||||
@@ -1742,7 +1742,7 @@ static int tegra_dc_wait_idle(struct tegra_dc *dc, unsigned long timeout)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void tegra_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void tegra_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct tegra_dc *dc = to_tegra_dc(crtc);
|
struct tegra_dc *dc = to_tegra_dc(crtc);
|
||||||
u32 value;
|
u32 value;
|
||||||
@@ -1799,10 +1799,10 @@ static void tegra_crtc_atomic_disable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void tegra_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void tegra_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_display_mode *mode = &crtc->state->adjusted_mode;
|
struct drm_display_mode *mode = &crtc->state->adjusted_mode;
|
||||||
struct tegra_dc_state *state = to_dc_state(crtc->state);
|
struct tegra_dc_state *crtc_state = to_dc_state(crtc->state);
|
||||||
struct tegra_dc *dc = to_tegra_dc(crtc);
|
struct tegra_dc *dc = to_tegra_dc(crtc);
|
||||||
u32 value;
|
u32 value;
|
||||||
int err;
|
int err;
|
||||||
@@ -1882,7 +1882,7 @@ static void tegra_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
tegra_dc_writel(dc, 0, DC_DISP_BORDER_COLOR);
|
tegra_dc_writel(dc, 0, DC_DISP_BORDER_COLOR);
|
||||||
|
|
||||||
/* apply PLL and pixel clock changes */
|
/* apply PLL and pixel clock changes */
|
||||||
tegra_dc_commit_state(dc, state);
|
tegra_dc_commit_state(dc, crtc_state);
|
||||||
|
|
||||||
/* program display mode */
|
/* program display mode */
|
||||||
tegra_dc_set_timings(dc, mode);
|
tegra_dc_set_timings(dc, mode);
|
||||||
|
|||||||
@@ -212,8 +212,10 @@ static void tidss_crtc_atomic_flush(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void tidss_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void tidss_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct tidss_crtc *tcrtc = to_tidss_crtc(crtc);
|
struct tidss_crtc *tcrtc = to_tidss_crtc(crtc);
|
||||||
struct drm_device *ddev = crtc->dev;
|
struct drm_device *ddev = crtc->dev;
|
||||||
struct tidss_device *tidss = to_tidss(ddev);
|
struct tidss_device *tidss = to_tidss(ddev);
|
||||||
@@ -255,7 +257,7 @@ static void tidss_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void tidss_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void tidss_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct tidss_crtc *tcrtc = to_tidss_crtc(crtc);
|
struct tidss_crtc *tcrtc = to_tidss_crtc(crtc);
|
||||||
struct drm_device *ddev = crtc->dev;
|
struct drm_device *ddev = crtc->dev;
|
||||||
|
|||||||
@@ -484,7 +484,7 @@ static void tilcdc_crtc_enable(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void tilcdc_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void tilcdc_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
tilcdc_crtc_enable(crtc);
|
tilcdc_crtc_enable(crtc);
|
||||||
}
|
}
|
||||||
@@ -532,7 +532,7 @@ static void tilcdc_crtc_disable(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void tilcdc_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void tilcdc_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
tilcdc_crtc_disable(crtc);
|
tilcdc_crtc_disable(crtc);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -213,12 +213,12 @@ static void vbox_crtc_set_base_and_mode(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void vbox_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void vbox_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vbox_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void vbox_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -472,8 +472,10 @@ int vc4_crtc_disable_at_boot(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void vc4_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void vc4_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct vc4_crtc_state *old_vc4_state = to_vc4_crtc_state(old_state);
|
struct vc4_crtc_state *old_vc4_state = to_vc4_crtc_state(old_state);
|
||||||
struct drm_device *dev = crtc->dev;
|
struct drm_device *dev = crtc->dev;
|
||||||
|
|
||||||
@@ -499,8 +501,10 @@ static void vc4_crtc_atomic_disable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void vc4_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void vc4_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct drm_device *dev = crtc->dev;
|
struct drm_device *dev = crtc->dev;
|
||||||
struct vc4_crtc *vc4_crtc = to_vc4_crtc(crtc);
|
struct vc4_crtc *vc4_crtc = to_vc4_crtc(crtc);
|
||||||
struct drm_encoder *encoder = vc4_get_crtc_encoder(crtc);
|
struct drm_encoder *encoder = vc4_get_crtc_encoder(crtc);
|
||||||
|
|||||||
@@ -13,6 +13,7 @@
|
|||||||
#include <linux/of_platform.h>
|
#include <linux/of_platform.h>
|
||||||
#include <linux/pm_runtime.h>
|
#include <linux/pm_runtime.h>
|
||||||
|
|
||||||
|
#include <drm/drm_atomic.h>
|
||||||
#include <drm/drm_atomic_helper.h>
|
#include <drm/drm_atomic_helper.h>
|
||||||
#include <drm/drm_edid.h>
|
#include <drm/drm_edid.h>
|
||||||
#include <drm/drm_fb_cma_helper.h>
|
#include <drm/drm_fb_cma_helper.h>
|
||||||
@@ -401,15 +402,19 @@ static int vc4_txp_atomic_check(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void vc4_txp_atomic_enable(struct drm_crtc *crtc,
|
static void vc4_txp_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
drm_crtc_vblank_on(crtc);
|
drm_crtc_vblank_on(crtc);
|
||||||
vc4_hvs_atomic_enable(crtc, old_state);
|
vc4_hvs_atomic_enable(crtc, old_state);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vc4_txp_atomic_disable(struct drm_crtc *crtc,
|
static void vc4_txp_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct drm_device *dev = crtc->dev;
|
struct drm_device *dev = crtc->dev;
|
||||||
|
|
||||||
/* Disable vblank irq handling before crtc is disabled. */
|
/* Disable vblank irq handling before crtc is disabled. */
|
||||||
|
|||||||
@@ -95,12 +95,12 @@ static void virtio_gpu_crtc_mode_set_nofb(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void virtio_gpu_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void virtio_gpu_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
static void virtio_gpu_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void virtio_gpu_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = crtc->dev;
|
struct drm_device *dev = crtc->dev;
|
||||||
struct virtio_gpu_device *vgdev = dev->dev_private;
|
struct virtio_gpu_device *vgdev = dev->dev_private;
|
||||||
|
|||||||
@@ -214,13 +214,13 @@ static int vkms_crtc_atomic_check(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void vkms_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void vkms_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
drm_crtc_vblank_on(crtc);
|
drm_crtc_vblank_on(crtc);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vkms_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void vkms_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
drm_crtc_vblank_off(crtc);
|
drm_crtc_vblank_off(crtc);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -214,7 +214,7 @@ static void vmw_ldu_crtc_mode_set_nofb(struct drm_crtc *crtc)
|
|||||||
* CRTC, it makes more sense to do those at plane update time.
|
* CRTC, it makes more sense to do those at plane update time.
|
||||||
*/
|
*/
|
||||||
static void vmw_ldu_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void vmw_ldu_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -224,7 +224,7 @@ static void vmw_ldu_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
* @crtc: CRTC to be turned off
|
* @crtc: CRTC to be turned off
|
||||||
*/
|
*/
|
||||||
static void vmw_ldu_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void vmw_ldu_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -279,7 +279,7 @@ static void vmw_sou_crtc_helper_prepare(struct drm_crtc *crtc)
|
|||||||
* This is called after a mode set has been completed.
|
* This is called after a mode set has been completed.
|
||||||
*/
|
*/
|
||||||
static void vmw_sou_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void vmw_sou_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -289,7 +289,7 @@ static void vmw_sou_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
* @crtc: CRTC to be turned off
|
* @crtc: CRTC to be turned off
|
||||||
*/
|
*/
|
||||||
static void vmw_sou_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void vmw_sou_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct vmw_private *dev_priv;
|
struct vmw_private *dev_priv;
|
||||||
struct vmw_screen_object_unit *sou;
|
struct vmw_screen_object_unit *sou;
|
||||||
|
|||||||
@@ -408,12 +408,12 @@ static void vmw_stdu_crtc_helper_prepare(struct drm_crtc *crtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void vmw_stdu_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void vmw_stdu_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vmw_stdu_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void vmw_stdu_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct vmw_private *dev_priv;
|
struct vmw_private *dev_priv;
|
||||||
struct vmw_screen_target_display_unit *stdu;
|
struct vmw_screen_target_display_unit *stdu;
|
||||||
|
|||||||
@@ -1449,7 +1449,7 @@ static int zynqmp_disp_crtc_setup_clock(struct drm_crtc *crtc,
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
zynqmp_disp_crtc_atomic_enable(struct drm_crtc *crtc,
|
zynqmp_disp_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct zynqmp_disp *disp = crtc_to_disp(crtc);
|
struct zynqmp_disp *disp = crtc_to_disp(crtc);
|
||||||
struct drm_display_mode *adjusted_mode = &crtc->state->adjusted_mode;
|
struct drm_display_mode *adjusted_mode = &crtc->state->adjusted_mode;
|
||||||
@@ -1480,8 +1480,10 @@ zynqmp_disp_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
zynqmp_disp_crtc_atomic_disable(struct drm_crtc *crtc,
|
zynqmp_disp_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
|
struct drm_crtc_state *old_crtc_state = drm_atomic_get_old_crtc_state(state,
|
||||||
|
crtc);
|
||||||
struct zynqmp_disp *disp = crtc_to_disp(crtc);
|
struct zynqmp_disp *disp = crtc_to_disp(crtc);
|
||||||
struct drm_plane_state *old_plane_state;
|
struct drm_plane_state *old_plane_state;
|
||||||
|
|
||||||
|
|||||||
@@ -350,7 +350,7 @@ static inline void vou_chn_set_update(struct zx_crtc *zcrtc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void zx_crtc_atomic_enable(struct drm_crtc *crtc,
|
static void zx_crtc_atomic_enable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct drm_display_mode *mode = &crtc->state->adjusted_mode;
|
struct drm_display_mode *mode = &crtc->state->adjusted_mode;
|
||||||
bool interlaced = mode->flags & DRM_MODE_FLAG_INTERLACE;
|
bool interlaced = mode->flags & DRM_MODE_FLAG_INTERLACE;
|
||||||
@@ -455,7 +455,7 @@ static void zx_crtc_atomic_enable(struct drm_crtc *crtc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void zx_crtc_atomic_disable(struct drm_crtc *crtc,
|
static void zx_crtc_atomic_disable(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_state)
|
struct drm_atomic_state *state)
|
||||||
{
|
{
|
||||||
struct zx_crtc *zcrtc = to_zx_crtc(crtc);
|
struct zx_crtc *zcrtc = to_zx_crtc(crtc);
|
||||||
const struct zx_crtc_bits *bits = zcrtc->bits;
|
const struct zx_crtc_bits *bits = zcrtc->bits;
|
||||||
|
|||||||
@@ -417,14 +417,10 @@ struct drm_crtc_helper_funcs {
|
|||||||
* @atomic_enable must be the inverse of @atomic_disable for atomic
|
* @atomic_enable must be the inverse of @atomic_disable for atomic
|
||||||
* drivers.
|
* drivers.
|
||||||
*
|
*
|
||||||
* Drivers can use the @old_crtc_state input parameter if the operations
|
|
||||||
* needed to enable the CRTC don't depend solely on the new state but
|
|
||||||
* also on the transition between the old state and the new state.
|
|
||||||
*
|
|
||||||
* This function is optional.
|
* This function is optional.
|
||||||
*/
|
*/
|
||||||
void (*atomic_enable)(struct drm_crtc *crtc,
|
void (*atomic_enable)(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state);
|
struct drm_atomic_state *state);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @atomic_disable:
|
* @atomic_disable:
|
||||||
@@ -441,15 +437,10 @@ struct drm_crtc_helper_funcs {
|
|||||||
* need to implement it if there's no need to disable anything at the
|
* need to implement it if there's no need to disable anything at the
|
||||||
* CRTC level.
|
* CRTC level.
|
||||||
*
|
*
|
||||||
* Comparing to @disable, this one provides the additional input
|
|
||||||
* parameter @old_crtc_state which could be used to access the old
|
|
||||||
* state. Atomic drivers should consider to use this one instead
|
|
||||||
* of @disable.
|
|
||||||
*
|
|
||||||
* This function is optional.
|
* This function is optional.
|
||||||
*/
|
*/
|
||||||
void (*atomic_disable)(struct drm_crtc *crtc,
|
void (*atomic_disable)(struct drm_crtc *crtc,
|
||||||
struct drm_crtc_state *old_crtc_state);
|
struct drm_atomic_state *state);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @get_scanout_position:
|
* @get_scanout_position:
|
||||||
|
|||||||
Reference in New Issue
Block a user