提交 7a2b8924 编写于 作者: J Jernej Skrabec 提交者: Maxime Ripard

drm/sun4i: Add multi plane support to DE2 driver

Support for multiple UI planes can now be easily enabled just by adding
more planes with different index.

For now, add immutable zpos property.
Signed-off-by: NJernej Skrabec <jernej.skrabec@siol.net>
Signed-off-by: NMaxime Ripard <maxime.ripard@free-electrons.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171201060550.10392-17-jernej.skrabec@siol.net
上级 165d24df
...@@ -22,12 +22,6 @@ ...@@ -22,12 +22,6 @@
#include "sun8i_layer.h" #include "sun8i_layer.h"
#include "sun8i_mixer.h" #include "sun8i_mixer.h"
struct sun8i_plane_desc {
enum drm_plane_type type;
const uint32_t *formats;
uint32_t nformats;
};
static int sun8i_mixer_layer_atomic_check(struct drm_plane *plane, static int sun8i_mixer_layer_atomic_check(struct drm_plane *plane,
struct drm_plane_state *state) struct drm_plane_state *state)
{ {
...@@ -106,35 +100,38 @@ static const uint32_t sun8i_mixer_layer_formats[] = { ...@@ -106,35 +100,38 @@ static const uint32_t sun8i_mixer_layer_formats[] = {
DRM_FORMAT_XRGB8888, DRM_FORMAT_XRGB8888,
}; };
static const struct sun8i_plane_desc sun8i_mixer_planes[] = {
{
.type = DRM_PLANE_TYPE_PRIMARY,
.formats = sun8i_mixer_layer_formats,
.nformats = ARRAY_SIZE(sun8i_mixer_layer_formats),
},
};
static struct sun8i_layer *sun8i_layer_init_one(struct drm_device *drm, static struct sun8i_layer *sun8i_layer_init_one(struct drm_device *drm,
struct sun8i_mixer *mixer, struct sun8i_mixer *mixer,
const struct sun8i_plane_desc *plane) int index)
{ {
struct sun8i_layer *layer; struct sun8i_layer *layer;
enum drm_plane_type type;
int ret; int ret;
layer = devm_kzalloc(drm->dev, sizeof(*layer), GFP_KERNEL); layer = devm_kzalloc(drm->dev, sizeof(*layer), GFP_KERNEL);
if (!layer) if (!layer)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
type = index == 0 ? DRM_PLANE_TYPE_PRIMARY : DRM_PLANE_TYPE_OVERLAY;
/* possible crtcs are set later */ /* possible crtcs are set later */
ret = drm_universal_plane_init(drm, &layer->plane, 0, ret = drm_universal_plane_init(drm, &layer->plane, 0,
&sun8i_mixer_layer_funcs, &sun8i_mixer_layer_funcs,
plane->formats, plane->nformats, sun8i_mixer_layer_formats,
NULL, plane->type, NULL); ARRAY_SIZE(sun8i_mixer_layer_formats),
NULL, type, NULL);
if (ret) { if (ret) {
dev_err(drm->dev, "Couldn't initialize layer\n"); dev_err(drm->dev, "Couldn't initialize layer\n");
return ERR_PTR(ret); return ERR_PTR(ret);
} }
/* fixed zpos for now */
ret = drm_plane_create_zpos_immutable_property(&layer->plane, index);
if (ret) {
dev_err(drm->dev, "Couldn't add zpos property\n");
return ERR_PTR(ret);
}
drm_plane_helper_add(&layer->plane, drm_plane_helper_add(&layer->plane,
&sun8i_mixer_layer_helper_funcs); &sun8i_mixer_layer_helper_funcs);
layer->mixer = mixer; layer->mixer = mixer;
...@@ -149,16 +146,15 @@ struct drm_plane **sun8i_layers_init(struct drm_device *drm, ...@@ -149,16 +146,15 @@ struct drm_plane **sun8i_layers_init(struct drm_device *drm,
struct sun8i_mixer *mixer = engine_to_sun8i_mixer(engine); struct sun8i_mixer *mixer = engine_to_sun8i_mixer(engine);
int i; int i;
planes = devm_kcalloc(drm->dev, ARRAY_SIZE(sun8i_mixer_planes) + 1, planes = devm_kcalloc(drm->dev, mixer->cfg->ui_num + 1,
sizeof(*planes), GFP_KERNEL); sizeof(*planes), GFP_KERNEL);
if (!planes) if (!planes)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
for (i = 0; i < ARRAY_SIZE(sun8i_mixer_planes); i++) { for (i = 0; i < mixer->cfg->ui_num; i++) {
const struct sun8i_plane_desc *plane = &sun8i_mixer_planes[i];
struct sun8i_layer *layer; struct sun8i_layer *layer;
layer = sun8i_layer_init_one(drm, mixer, plane); layer = sun8i_layer_init_one(drm, mixer, i);
if (IS_ERR(layer)) { if (IS_ERR(layer)) {
dev_err(drm->dev, "Couldn't initialize %s plane\n", dev_err(drm->dev, "Couldn't initialize %s plane\n",
i ? "overlay" : "primary"); i ? "overlay" : "primary");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册