Commit 6941e3d1 authored by Laurent Pinchart's avatar Laurent Pinchart

drm: omapdrm: fb: Simplify mode command checks when creating framebuffer

The hardware requires all planes to have an identical pitch in number of
pixels. Given that all supported formats use the same number of bytes
per pixel in all planes, framebuffer creation checks can be simplified.
The implementations assumes that no format use more than two planes
which is true with the existing hardware.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent a39c94e8
...@@ -387,6 +387,7 @@ struct drm_framebuffer *omap_framebuffer_init(struct drm_device *dev, ...@@ -387,6 +387,7 @@ struct drm_framebuffer *omap_framebuffer_init(struct drm_device *dev,
struct omap_framebuffer *omap_fb = NULL; struct omap_framebuffer *omap_fb = NULL;
struct drm_framebuffer *fb = NULL; struct drm_framebuffer *fb = NULL;
enum omap_color_mode dss_format = 0; enum omap_color_mode dss_format = 0;
unsigned int pitch = mode_cmd->pitches[0];
int ret, i; int ret, i;
DBG("create framebuffer: dev=%p, mode_cmd=%p (%dx%d@%4.4s)", DBG("create framebuffer: dev=%p, mode_cmd=%p (%dx%d@%4.4s)",
...@@ -420,41 +421,36 @@ struct drm_framebuffer *omap_framebuffer_init(struct drm_device *dev, ...@@ -420,41 +421,36 @@ struct drm_framebuffer *omap_framebuffer_init(struct drm_device *dev,
omap_fb->dss_format = dss_format; omap_fb->dss_format = dss_format;
mutex_init(&omap_fb->lock); mutex_init(&omap_fb->lock);
for (i = 0; i < format->num_planes; i++) { /*
struct plane *plane = &omap_fb->planes[i]; * The code below assumes that no format use more than two planes, and
unsigned int pitch = mode_cmd->pitches[i]; * that the two planes of multiplane formats need the same number of
unsigned int hsub = i == 0 ? 1 : format->hsub; * bytes per pixel.
unsigned int vsub = i == 0 ? 1 : format->vsub; */
unsigned int size; if (format->num_planes == 2 && pitch != mode_cmd->pitches[1]) {
dev_err(dev->dev, "pitches differ between planes 0 and 1\n");
if (pitch < mode_cmd->width * format->cpp[i] / hsub) {
dev_err(dev->dev, "provided buffer pitch is too small! %d < %d\n",
pitch, mode_cmd->width * format->cpp[i] / hsub);
ret = -EINVAL; ret = -EINVAL;
goto fail; goto fail;
} }
if (pitch % format->cpp[i] != 0) { if (pitch % format->cpp[0]) {
dev_err(dev->dev, dev_err(dev->dev,
"buffer pitch (%d bytes) is not a multiple of pixel size (%d bytes)\n", "buffer pitch (%u bytes) is not a multiple of pixel size (%u bytes)\n",
pitch, format->cpp[i]); pitch, format->cpp[0]);
ret = -EINVAL; ret = -EINVAL;
goto fail; goto fail;
} }
size = pitch * mode_cmd->height / vsub; for (i = 0; i < format->num_planes; i++) {
struct plane *plane = &omap_fb->planes[i];
unsigned int vsub = i == 0 ? 1 : format->vsub;
unsigned int size;
if (size > (omap_gem_mmap_size(bos[i]) - mode_cmd->offsets[i])) { size = pitch * mode_cmd->height / vsub;
dev_err(dev->dev, "provided buffer object is too small! %d < %d\n",
bos[i]->size - mode_cmd->offsets[i], size);
ret = -EINVAL;
goto fail;
}
if (i > 0 && pitch != mode_cmd->pitches[i - 1]) { if (size > omap_gem_mmap_size(bos[i]) - mode_cmd->offsets[i]) {
dev_err(dev->dev, dev_err(dev->dev,
"pitches are not the same between framebuffer planes %d != %d\n", "provided buffer object is too small! %d < %d\n",
pitch, mode_cmd->pitches[i - 1]); bos[i]->size - mode_cmd->offsets[i], size);
ret = -EINVAL; ret = -EINVAL;
goto fail; goto fail;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment