[media] media: don't try to empty links list in media_entity_cleanup()
authorJavier Martinez Canillas <javier@osg.samsung.com>
Mon, 24 Aug 2015 17:57:53 +0000 (14:57 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Mon, 11 Jan 2016 14:18:56 +0000 (12:18 -0200)
The media_entity_cleanup() function only cleans up the entity links list
but this operation is already made in media_device_unregister_entity().

In most cases this should be harmless (besides having duplicated code)
since the links list would be empty so the iteration would not happen
but the links list is initialized in media_device_register_entity() so
if a driver fails to register an entity with a media device and clean up
the entity in the error path, a NULL deference pointer error will happen.

So don't try to empty the links list in media_entity_cleanup() since
is either done already or haven't been initialized yet.

Signed-off-by: Javier Martinez Canillas <javier@osg.samsung.com>
drivers/media/media-entity.c

index b1390d843909ba236d7093602d85fd0e380e8f56..d7243cb56c79d1ea7f4ae745abd884b91b350722 100644 (file)
@@ -242,13 +242,6 @@ EXPORT_SYMBOL_GPL(media_entity_init);
 void
 media_entity_cleanup(struct media_entity *entity)
 {
-       struct media_link *link, *tmp;
-
-       list_for_each_entry_safe(link, tmp, &entity->links, list) {
-               media_gobj_remove(&link->graph_obj);
-               list_del(&link->list);
-               kfree(link);
-       }
 }
 EXPORT_SYMBOL_GPL(media_entity_cleanup);