]> git.proxmox.com Git - mirror_ubuntu-zesty-kernel.git/commitdiff
bcm2835-v4l2: Fix buffer overflow problem
authorDave Stevenson <dave.stevenson@raspberrypi.org>
Fri, 10 Mar 2017 14:43:15 +0000 (14:43 +0000)
committerKleber Sacilotto de Souza <kleber.souza@canonical.com>
Tue, 19 Sep 2017 10:07:53 +0000 (12:07 +0200)
https://github.com/raspberrypi/linux/issues/1447
port_parameter_get() failed to account for the header
(u32 id and u32 size) in the size before memcpying
the response into the response buffer, so overrunning
the provided buffer by 8 bytes.

Account for those bytes, and also a belt-and-braces
check to ensure we never copy more than *value_size
bytes into value.

Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.org>
Signed-off-by: Tim Gardner <tim.gardner@canonical.com>
drivers/media/platform/bcm2835/mmal-vchiq.c

index 781322542d5a8295f3d7d5a3eaaf0cac29930c30..e4b243b33f58913f3d2952c97d2a2e3fbbbd0ae8 100644 (file)
@@ -1315,7 +1315,12 @@ static int port_parameter_get(struct vchiq_mmal_instance *instance,
        }
 
        ret = -rmsg->u.port_parameter_get_reply.status;
-       if (ret) {
+       /* port_parameter_get_reply.size includes the header,
+        * whilst *value_size doesn't.
+        */
+       rmsg->u.port_parameter_get_reply.size -= (2 * sizeof(u32));
+
+       if (ret || rmsg->u.port_parameter_get_reply.size > *value_size) {
                /* Copy only as much as we have space for
                 * but report true size of parameter
                 */