ping

On 2019/8/19 9:51, zhengbin wrote:
> In media_device_register_entity, if media_graph_walk_init fails,
> need to free the previously memory.
>
> Reported-by: Hulk Robot <hul...@huawei.com>
> Signed-off-by: zhengbin <zhengbi...@huawei.com>
> ---
>  drivers/media/mc/mc-device.c | 65 
> ++++++++++++++++++++++----------------------
>  1 file changed, 33 insertions(+), 32 deletions(-)
>
> diff --git a/drivers/media/mc/mc-device.c b/drivers/media/mc/mc-device.c
> index e19df51..da80883 100644
> --- a/drivers/media/mc/mc-device.c
> +++ b/drivers/media/mc/mc-device.c
> @@ -575,6 +575,38 @@ static void media_device_release(struct media_devnode 
> *devnode)
>       dev_dbg(devnode->parent, "Media device released\n");
>  }
>
> +static void __media_device_unregister_entity(struct media_entity *entity)
> +{
> +     struct media_device *mdev = entity->graph_obj.mdev;
> +     struct media_link *link, *tmp;
> +     struct media_interface *intf;
> +     unsigned int i;
> +
> +     ida_free(&mdev->entity_internal_idx, entity->internal_idx);
> +
> +     /* Remove all interface links pointing to this entity */
> +     list_for_each_entry(intf, &mdev->interfaces, graph_obj.list) {
> +             list_for_each_entry_safe(link, tmp, &intf->links, list) {
> +                     if (link->entity == entity)
> +                             __media_remove_intf_link(link);
> +             }
> +     }
> +
> +     /* Remove all data links that belong to this entity */
> +     __media_entity_remove_links(entity);
> +
> +     /* Remove all pads that belong to this entity */
> +     for (i = 0; i < entity->num_pads; i++)
> +             media_gobj_destroy(&entity->pads[i].graph_obj);
> +
> +     /* Remove the entity */
> +     media_gobj_destroy(&entity->graph_obj);
> +
> +     /* invoke entity_notify callbacks to handle entity removal?? */
> +
> +     entity->graph_obj.mdev = NULL;
> +}
> +
>  /**
>   * media_device_register_entity - Register an entity with a media device
>   * @mdev:    The media device
> @@ -632,6 +664,7 @@ int __must_check media_device_register_entity(struct 
> media_device *mdev,
>                */
>               ret = media_graph_walk_init(&new, mdev);
>               if (ret) {
> +                     __media_device_unregister_entity(entity);
>                       mutex_unlock(&mdev->graph_mutex);
>                       return ret;
>               }
> @@ -644,38 +677,6 @@ int __must_check media_device_register_entity(struct 
> media_device *mdev,
>  }
>  EXPORT_SYMBOL_GPL(media_device_register_entity);
>
> -static void __media_device_unregister_entity(struct media_entity *entity)
> -{
> -     struct media_device *mdev = entity->graph_obj.mdev;
> -     struct media_link *link, *tmp;
> -     struct media_interface *intf;
> -     unsigned int i;
> -
> -     ida_free(&mdev->entity_internal_idx, entity->internal_idx);
> -
> -     /* Remove all interface links pointing to this entity */
> -     list_for_each_entry(intf, &mdev->interfaces, graph_obj.list) {
> -             list_for_each_entry_safe(link, tmp, &intf->links, list) {
> -                     if (link->entity == entity)
> -                             __media_remove_intf_link(link);
> -             }
> -     }
> -
> -     /* Remove all data links that belong to this entity */
> -     __media_entity_remove_links(entity);
> -
> -     /* Remove all pads that belong to this entity */
> -     for (i = 0; i < entity->num_pads; i++)
> -             media_gobj_destroy(&entity->pads[i].graph_obj);
> -
> -     /* Remove the entity */
> -     media_gobj_destroy(&entity->graph_obj);
> -
> -     /* invoke entity_notify callbacks to handle entity removal?? */
> -
> -     entity->graph_obj.mdev = NULL;
> -}
> -
>  void media_device_unregister_entity(struct media_entity *entity)
>  {
>       struct media_device *mdev = entity->graph_obj.mdev;
> --
> 2.7.4
>
>
> .
>

Reply via email to