提交 705c8160 编写于 作者: D Dan Carpenter 提交者: Daniel Vetter

drm: Fix an error pointer dereference()

The drm_mode_create_tile_group() is only called from
drm_parse_tiled_block() and the caller expects it to return a NULL on
error.  In other words, this function should match
drm_mode_get_tile_group().
Signed-off-by: NDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20181217065733.GA12159@kadam
上级 706246c7
...@@ -1960,7 +1960,7 @@ EXPORT_SYMBOL(drm_mode_get_tile_group); ...@@ -1960,7 +1960,7 @@ EXPORT_SYMBOL(drm_mode_get_tile_group);
* identifier for the tile group. * identifier for the tile group.
* *
* RETURNS: * RETURNS:
* new tile group or error. * new tile group or NULL.
*/ */
struct drm_tile_group *drm_mode_create_tile_group(struct drm_device *dev, struct drm_tile_group *drm_mode_create_tile_group(struct drm_device *dev,
char topology[8]) char topology[8])
...@@ -1970,7 +1970,7 @@ struct drm_tile_group *drm_mode_create_tile_group(struct drm_device *dev, ...@@ -1970,7 +1970,7 @@ struct drm_tile_group *drm_mode_create_tile_group(struct drm_device *dev,
tg = kzalloc(sizeof(*tg), GFP_KERNEL); tg = kzalloc(sizeof(*tg), GFP_KERNEL);
if (!tg) if (!tg)
return ERR_PTR(-ENOMEM); return NULL;
kref_init(&tg->refcount); kref_init(&tg->refcount);
memcpy(tg->group_data, topology, 8); memcpy(tg->group_data, topology, 8);
...@@ -1982,7 +1982,7 @@ struct drm_tile_group *drm_mode_create_tile_group(struct drm_device *dev, ...@@ -1982,7 +1982,7 @@ struct drm_tile_group *drm_mode_create_tile_group(struct drm_device *dev,
tg->id = ret; tg->id = ret;
} else { } else {
kfree(tg); kfree(tg);
tg = ERR_PTR(ret); tg = NULL;
} }
mutex_unlock(&dev->mode_config.idr_mutex); mutex_unlock(&dev->mode_config.idr_mutex);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册