Convert array index from the loop bound to the loop index.
A simplified version of the semantic patch that fixes this problem is as
// <smpl>
@@
expression e1,e2,ar;
@@
for(e1 = 0; e1 < e2; e1++) { <...
  ar[
- e2
+ e1
  ]
  ...> }
// </smpl>
Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
                if (!stream->urb_list[i]) {
                        deb_mem("not enough memory for urb_alloc_urb!.\n");
                        for (j = 0; j < i; j++)
-                               usb_free_urb(stream->urb_list[i]);
+                               usb_free_urb(stream->urb_list[j]);
                        return -ENOMEM;
                }
                usb_fill_bulk_urb( stream->urb_list[i], stream->udev,
                if (!stream->urb_list[i]) {
                        deb_mem("not enough memory for urb_alloc_urb!\n");
                        for (j = 0; j < i; j++)
-                               usb_free_urb(stream->urb_list[i]);
+                               usb_free_urb(stream->urb_list[j]);
                        return -ENOMEM;
                }