usb: gadget: uvc: configfs: Prevent format changes after linking header
authorJoel Pepper <joel.pepper@rwth-aachen.de>
Tue, 29 May 2018 19:02:12 +0000 (21:02 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 25 Nov 2019 08:52:50 +0000 (09:52 +0100)
[ Upstream commit cb2200f7af8341aaf0c6abd7ba37e4c667c41639 ]

While checks are in place to avoid attributes and children of a format
being manipulated after the format is linked into the streaming header,
the linked flag was never actually set, invalidating the protections.
Update the flag as appropriate in the header link calls.

Signed-off-by: Joel Pepper <joel.pepper@rwth-aachen.de>
Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/usb/gadget/function/uvc_configfs.c

index 3803dda54666b9d4c57856a17d533299187e0841..3d843e14447bb768052aa01b6478a7d4052b1881 100644 (file)
@@ -772,6 +772,7 @@ static int uvcg_streaming_header_allow_link(struct config_item *src,
        format_ptr->fmt = target_fmt;
        list_add_tail(&format_ptr->entry, &src_hdr->formats);
        ++src_hdr->num_fmt;
+       ++target_fmt->linked;
 
 out:
        mutex_unlock(&opts->lock);
@@ -810,6 +811,8 @@ static int uvcg_streaming_header_drop_link(struct config_item *src,
                        break;
                }
 
+       --target_fmt->linked;
+
 out:
        mutex_unlock(&opts->lock);
        mutex_unlock(su_mutex);