mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-05 21:35:04 +08:00
drm/exynos: add global macro for the default primary plane
Define DEFAULT_WIN as zero to help set the primary plane on all CRTCs. Some CRTCs were defining a variable to store the default window, but that is not necessary as the default (primary) window is always the window zero. Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.co.uk> Signed-off-by: Inki Dae <inki.dae@samsung.com>
This commit is contained in:
parent
c691349ca4
commit
5d3d099574
@ -33,7 +33,6 @@ struct decon_context {
|
|||||||
struct exynos_drm_plane planes[WINDOWS_NR];
|
struct exynos_drm_plane planes[WINDOWS_NR];
|
||||||
void __iomem *addr;
|
void __iomem *addr;
|
||||||
struct clk *clks[6];
|
struct clk *clks[6];
|
||||||
unsigned int default_win;
|
|
||||||
unsigned long irq_flags;
|
unsigned long irq_flags;
|
||||||
int pipe;
|
int pipe;
|
||||||
bool suspended;
|
bool suspended;
|
||||||
@ -501,7 +500,7 @@ static int decon_bind(struct device *dev, struct device *master, void *data)
|
|||||||
ctx->pipe = priv->pipe++;
|
ctx->pipe = priv->pipe++;
|
||||||
|
|
||||||
for (zpos = 0; zpos < WINDOWS_NR; zpos++) {
|
for (zpos = 0; zpos < WINDOWS_NR; zpos++) {
|
||||||
type = (zpos == ctx->default_win) ? DRM_PLANE_TYPE_PRIMARY :
|
type = (zpos == DEFAULT_WIN) ? DRM_PLANE_TYPE_PRIMARY :
|
||||||
DRM_PLANE_TYPE_OVERLAY;
|
DRM_PLANE_TYPE_OVERLAY;
|
||||||
ret = exynos_plane_init(drm_dev, &ctx->planes[zpos],
|
ret = exynos_plane_init(drm_dev, &ctx->planes[zpos],
|
||||||
1 << ctx->pipe, type, decon_formats,
|
1 << ctx->pipe, type, decon_formats,
|
||||||
@ -510,7 +509,7 @@ static int decon_bind(struct device *dev, struct device *master, void *data)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
exynos_plane = &ctx->planes[ctx->default_win];
|
exynos_plane = &ctx->planes[DEFAULT_WIN];
|
||||||
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
||||||
ctx->pipe, EXYNOS_DISPLAY_TYPE_LCD,
|
ctx->pipe, EXYNOS_DISPLAY_TYPE_LCD,
|
||||||
&decon_crtc_ops, ctx);
|
&decon_crtc_ops, ctx);
|
||||||
@ -607,7 +606,6 @@ static int exynos5433_decon_probe(struct platform_device *pdev)
|
|||||||
if (!ctx)
|
if (!ctx)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
ctx->default_win = 0;
|
|
||||||
ctx->suspended = true;
|
ctx->suspended = true;
|
||||||
ctx->dev = dev;
|
ctx->dev = dev;
|
||||||
if (of_get_child_by_name(dev->of_node, "i80-if-timings"))
|
if (of_get_child_by_name(dev->of_node, "i80-if-timings"))
|
||||||
|
@ -51,7 +51,6 @@ struct decon_context {
|
|||||||
struct clk *eclk;
|
struct clk *eclk;
|
||||||
struct clk *vclk;
|
struct clk *vclk;
|
||||||
void __iomem *regs;
|
void __iomem *regs;
|
||||||
unsigned int default_win;
|
|
||||||
unsigned long irq_flags;
|
unsigned long irq_flags;
|
||||||
bool i80_if;
|
bool i80_if;
|
||||||
bool suspended;
|
bool suspended;
|
||||||
@ -690,7 +689,7 @@ static int decon_bind(struct device *dev, struct device *master, void *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (zpos = 0; zpos < WINDOWS_NR; zpos++) {
|
for (zpos = 0; zpos < WINDOWS_NR; zpos++) {
|
||||||
type = (zpos == ctx->default_win) ? DRM_PLANE_TYPE_PRIMARY :
|
type = (zpos == DEFAULT_WIN) ? DRM_PLANE_TYPE_PRIMARY :
|
||||||
DRM_PLANE_TYPE_OVERLAY;
|
DRM_PLANE_TYPE_OVERLAY;
|
||||||
ret = exynos_plane_init(drm_dev, &ctx->planes[zpos],
|
ret = exynos_plane_init(drm_dev, &ctx->planes[zpos],
|
||||||
1 << ctx->pipe, type, decon_formats,
|
1 << ctx->pipe, type, decon_formats,
|
||||||
@ -699,7 +698,7 @@ static int decon_bind(struct device *dev, struct device *master, void *data)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
exynos_plane = &ctx->planes[ctx->default_win];
|
exynos_plane = &ctx->planes[DEFAULT_WIN];
|
||||||
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
||||||
ctx->pipe, EXYNOS_DISPLAY_TYPE_LCD,
|
ctx->pipe, EXYNOS_DISPLAY_TYPE_LCD,
|
||||||
&decon_crtc_ops, ctx);
|
&decon_crtc_ops, ctx);
|
||||||
|
@ -22,6 +22,8 @@
|
|||||||
#define MAX_PLANE 5
|
#define MAX_PLANE 5
|
||||||
#define MAX_FB_BUFFER 4
|
#define MAX_FB_BUFFER 4
|
||||||
|
|
||||||
|
#define DEFAULT_WIN 0
|
||||||
|
|
||||||
#define to_exynos_crtc(x) container_of(x, struct exynos_drm_crtc, base)
|
#define to_exynos_crtc(x) container_of(x, struct exynos_drm_crtc, base)
|
||||||
#define to_exynos_plane(x) container_of(x, struct exynos_drm_plane, base)
|
#define to_exynos_plane(x) container_of(x, struct exynos_drm_plane, base)
|
||||||
|
|
||||||
|
@ -153,7 +153,6 @@ struct fimd_context {
|
|||||||
struct clk *lcd_clk;
|
struct clk *lcd_clk;
|
||||||
void __iomem *regs;
|
void __iomem *regs;
|
||||||
struct regmap *sysreg;
|
struct regmap *sysreg;
|
||||||
unsigned int default_win;
|
|
||||||
unsigned long irq_flags;
|
unsigned long irq_flags;
|
||||||
u32 vidcon0;
|
u32 vidcon0;
|
||||||
u32 vidcon1;
|
u32 vidcon1;
|
||||||
@ -949,7 +948,7 @@ static int fimd_bind(struct device *dev, struct device *master, void *data)
|
|||||||
ctx->pipe = priv->pipe++;
|
ctx->pipe = priv->pipe++;
|
||||||
|
|
||||||
for (zpos = 0; zpos < WINDOWS_NR; zpos++) {
|
for (zpos = 0; zpos < WINDOWS_NR; zpos++) {
|
||||||
type = (zpos == ctx->default_win) ? DRM_PLANE_TYPE_PRIMARY :
|
type = (zpos == DEFAULT_WIN) ? DRM_PLANE_TYPE_PRIMARY :
|
||||||
DRM_PLANE_TYPE_OVERLAY;
|
DRM_PLANE_TYPE_OVERLAY;
|
||||||
ret = exynos_plane_init(drm_dev, &ctx->planes[zpos],
|
ret = exynos_plane_init(drm_dev, &ctx->planes[zpos],
|
||||||
1 << ctx->pipe, type, fimd_formats,
|
1 << ctx->pipe, type, fimd_formats,
|
||||||
@ -958,7 +957,7 @@ static int fimd_bind(struct device *dev, struct device *master, void *data)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
exynos_plane = &ctx->planes[ctx->default_win];
|
exynos_plane = &ctx->planes[DEFAULT_WIN];
|
||||||
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
||||||
ctx->pipe, EXYNOS_DISPLAY_TYPE_LCD,
|
ctx->pipe, EXYNOS_DISPLAY_TYPE_LCD,
|
||||||
&fimd_crtc_ops, ctx);
|
&fimd_crtc_ops, ctx);
|
||||||
|
@ -42,7 +42,6 @@ struct vidi_context {
|
|||||||
struct exynos_drm_plane planes[WINDOWS_NR];
|
struct exynos_drm_plane planes[WINDOWS_NR];
|
||||||
struct edid *raw_edid;
|
struct edid *raw_edid;
|
||||||
unsigned int clkdiv;
|
unsigned int clkdiv;
|
||||||
unsigned int default_win;
|
|
||||||
unsigned long irq_flags;
|
unsigned long irq_flags;
|
||||||
unsigned int connected;
|
unsigned int connected;
|
||||||
bool vblank_on;
|
bool vblank_on;
|
||||||
@ -446,7 +445,7 @@ static int vidi_bind(struct device *dev, struct device *master, void *data)
|
|||||||
vidi_ctx_initialize(ctx, drm_dev);
|
vidi_ctx_initialize(ctx, drm_dev);
|
||||||
|
|
||||||
for (zpos = 0; zpos < WINDOWS_NR; zpos++) {
|
for (zpos = 0; zpos < WINDOWS_NR; zpos++) {
|
||||||
type = (zpos == ctx->default_win) ? DRM_PLANE_TYPE_PRIMARY :
|
type = (zpos == DEFAULT_WIN) ? DRM_PLANE_TYPE_PRIMARY :
|
||||||
DRM_PLANE_TYPE_OVERLAY;
|
DRM_PLANE_TYPE_OVERLAY;
|
||||||
ret = exynos_plane_init(drm_dev, &ctx->planes[zpos],
|
ret = exynos_plane_init(drm_dev, &ctx->planes[zpos],
|
||||||
1 << ctx->pipe, type, formats,
|
1 << ctx->pipe, type, formats,
|
||||||
@ -455,7 +454,7 @@ static int vidi_bind(struct device *dev, struct device *master, void *data)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
exynos_plane = &ctx->planes[ctx->default_win];
|
exynos_plane = &ctx->planes[DEFAULT_WIN];
|
||||||
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
||||||
ctx->pipe, EXYNOS_DISPLAY_TYPE_VIDI,
|
ctx->pipe, EXYNOS_DISPLAY_TYPE_VIDI,
|
||||||
&vidi_crtc_ops, ctx);
|
&vidi_crtc_ops, ctx);
|
||||||
@ -507,7 +506,6 @@ static int vidi_probe(struct platform_device *pdev)
|
|||||||
if (!ctx)
|
if (!ctx)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
ctx->default_win = 0;
|
|
||||||
ctx->pdev = pdev;
|
ctx->pdev = pdev;
|
||||||
|
|
||||||
INIT_WORK(&ctx->work, vidi_fake_vblank_handler);
|
INIT_WORK(&ctx->work, vidi_fake_vblank_handler);
|
||||||
|
@ -42,7 +42,6 @@
|
|||||||
#include "exynos_mixer.h"
|
#include "exynos_mixer.h"
|
||||||
|
|
||||||
#define MIXER_WIN_NR 3
|
#define MIXER_WIN_NR 3
|
||||||
#define MIXER_DEFAULT_WIN 0
|
|
||||||
#define VP_DEFAULT_WIN 2
|
#define VP_DEFAULT_WIN 2
|
||||||
|
|
||||||
/* The pixelformats that are natively supported by the mixer. */
|
/* The pixelformats that are natively supported by the mixer. */
|
||||||
@ -600,7 +599,7 @@ static void mixer_graph_buffer(struct mixer_context *ctx,
|
|||||||
|
|
||||||
/* setup display size */
|
/* setup display size */
|
||||||
if (ctx->mxr_ver == MXR_VER_128_0_0_184 &&
|
if (ctx->mxr_ver == MXR_VER_128_0_0_184 &&
|
||||||
win == MIXER_DEFAULT_WIN) {
|
win == DEFAULT_WIN) {
|
||||||
val = MXR_MXR_RES_HEIGHT(mode->vdisplay);
|
val = MXR_MXR_RES_HEIGHT(mode->vdisplay);
|
||||||
val |= MXR_MXR_RES_WIDTH(mode->hdisplay);
|
val |= MXR_MXR_RES_WIDTH(mode->hdisplay);
|
||||||
mixer_reg_write(res, MXR_RESOLUTION, val);
|
mixer_reg_write(res, MXR_RESOLUTION, val);
|
||||||
@ -1197,7 +1196,7 @@ static int mixer_bind(struct device *dev, struct device *manager, void *data)
|
|||||||
const uint32_t *formats;
|
const uint32_t *formats;
|
||||||
unsigned int fcount;
|
unsigned int fcount;
|
||||||
|
|
||||||
type = (zpos == MIXER_DEFAULT_WIN) ? DRM_PLANE_TYPE_PRIMARY :
|
type = (zpos == DEFAULT_WIN) ? DRM_PLANE_TYPE_PRIMARY :
|
||||||
DRM_PLANE_TYPE_OVERLAY;
|
DRM_PLANE_TYPE_OVERLAY;
|
||||||
if (zpos < VP_DEFAULT_WIN) {
|
if (zpos < VP_DEFAULT_WIN) {
|
||||||
formats = mixer_formats;
|
formats = mixer_formats;
|
||||||
@ -1214,7 +1213,7 @@ static int mixer_bind(struct device *dev, struct device *manager, void *data)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
exynos_plane = &ctx->planes[MIXER_DEFAULT_WIN];
|
exynos_plane = &ctx->planes[DEFAULT_WIN];
|
||||||
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base,
|
||||||
ctx->pipe, EXYNOS_DISPLAY_TYPE_HDMI,
|
ctx->pipe, EXYNOS_DISPLAY_TYPE_HDMI,
|
||||||
&mixer_crtc_ops, ctx);
|
&mixer_crtc_ops, ctx);
|
||||||
|
Loading…
Reference in New Issue
Block a user