media: intel-ipu3: cio2: fix a crash with out-of-bounds access
authorYong Zhi <[email protected]>
Thu, 4 Jan 2018 02:57:16 +0000 (21:57 -0500)
committerMauro Carvalho Chehab <[email protected]>
Fri, 5 Jan 2018 17:43:20 +0000 (12:43 -0500)
When dmabuf is used for BLOB type frame, the frame
buffers allocated by gralloc will hold more pages
than the valid frame data due to height alignment.

In this case, the page numbers in sg list could exceed the
FBPT upper limit value - max_lops(8)*1024 to cause crash.

Limit the LOP access to the valid data length
to avoid FBPT sub-entries overflow.

Signed-off-by: Yong Zhi <[email protected]>
Signed-off-by: Cao Bing Bu <[email protected]>
Signed-off-by: Sakari Ailus <[email protected]>
Signed-off-by: Mauro Carvalho Chehab <[email protected]>
drivers/media/pci/intel/ipu3/ipu3-cio2.c

index 9b9ad7771dda12d9c8f6059f1ce57bfd53012618..9377f880b8f6d202a5d48784630d6cf20fd0c851 100644 (file)
@@ -838,8 +838,9 @@ static int cio2_vb2_buf_init(struct vb2_buffer *vb)
                container_of(vb, struct cio2_buffer, vbb.vb2_buf);
        static const unsigned int entries_per_page =
                CIO2_PAGE_SIZE / sizeof(u32);
-       unsigned int pages = DIV_ROUND_UP(vb->planes[0].length, CIO2_PAGE_SIZE);
-       unsigned int lops = DIV_ROUND_UP(pages + 1, entries_per_page);
+       unsigned int pages = DIV_ROUND_UP(vb->planes[0].length,
+                                         CIO2_PAGE_SIZE) + 1;
+       unsigned int lops = DIV_ROUND_UP(pages, entries_per_page);
        struct sg_table *sg;
        struct sg_page_iter sg_iter;
        int i, j;
@@ -869,6 +870,8 @@ static int cio2_vb2_buf_init(struct vb2_buffer *vb)
 
        i = j = 0;
        for_each_sg_page(sg->sgl, &sg_iter, sg->nents, 0) {
+               if (!pages--)
+                       break;
                b->lop[i][j] = sg_page_iter_dma_address(&sg_iter) >> PAGE_SHIFT;
                j++;
                if (j == entries_per_page) {