Commit 9c6f1942 authored by Dan Carpenter's avatar Dan Carpenter Committed by Thomas Zimmermann

drm: simpledrm: fix a potential NULL dereference

The drm_format_info() function returns NULL if the format is
unsupported, but the simplefb_get_validated_format() is expected to
return error pointers.  If we propagate the NULL return then it will
lead to a NULL dereference in the callers.  Swap the NULL and trade it
in for an ERR_PTR(-EINVAL).

Fixes: 11e8f5fd ("drm: Add simpledrm driver")
Signed-off-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarThomas Zimmermann <tzimmermann@suse.de>
Link: https://patchwork.freedesktop.org/patch/msgid/YJ+aC47XX58ICXax@mwanda
parent 527a9471
...@@ -72,6 +72,7 @@ simplefb_get_validated_format(struct drm_device *dev, const char *format_name) ...@@ -72,6 +72,7 @@ simplefb_get_validated_format(struct drm_device *dev, const char *format_name)
static const struct simplefb_format formats[] = SIMPLEFB_FORMATS; static const struct simplefb_format formats[] = SIMPLEFB_FORMATS;
const struct simplefb_format *fmt = formats; const struct simplefb_format *fmt = formats;
const struct simplefb_format *end = fmt + ARRAY_SIZE(formats); const struct simplefb_format *end = fmt + ARRAY_SIZE(formats);
const struct drm_format_info *info;
if (!format_name) { if (!format_name) {
drm_err(dev, "simplefb: missing framebuffer format\n"); drm_err(dev, "simplefb: missing framebuffer format\n");
...@@ -79,8 +80,12 @@ simplefb_get_validated_format(struct drm_device *dev, const char *format_name) ...@@ -79,8 +80,12 @@ simplefb_get_validated_format(struct drm_device *dev, const char *format_name)
} }
while (fmt < end) { while (fmt < end) {
if (!strcmp(format_name, fmt->name)) if (!strcmp(format_name, fmt->name)) {
return drm_format_info(fmt->fourcc); info = drm_format_info(fmt->fourcc);
if (!info)
return ERR_PTR(-EINVAL);
return info;
}
++fmt; ++fmt;
} }
......
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