Re: [PATCH 1/1] staging: ion: Fix error handling in ion_buffer_create

From: Gioh Kim
Date: Thu Oct 01 2015 - 02:36:41 EST




2015-10-01 ìí 2:31ì PINTU KUMAR ì(ê) ì ê:

-----Original Message-----
From: Laura Abbott [mailto:labbott@xxxxxxxxxx]
Sent: Wednesday, September 30, 2015 11:42 PM
To: Rohit kumar; gregkh@xxxxxxxxxxxxxxxxxxx; arve@xxxxxxxxxxx;
riandrews@xxxxxxxxxxx; dan.carpenter@xxxxxxxxxx;
sumit.semwal@xxxxxxxxxx; mitchelh@xxxxxxxxxxxxxx; akpm@linux-
foundation.org; linux@xxxxxxxxxxxxxxxxxx; dmitry.kalinkin@xxxxxxxxx;
elfring@xxxxxxxxxxxxxxxxxxxxx; gioh.kim@xxxxxxx; devel@xxxxxxxxxxxxxxxxxxxx;
linux-kernel@xxxxxxxxxxxxxxx
Cc: pintu.k@xxxxxxxxxxx; me.rohit@xxxxxxxx; pintu_agarwal@xxxxxxxxx;
c.rajkumar@xxxxxxxxxxx; sreenathd@xxxxxxxxxxx; cpgs@xxxxxxxxxxx;
vishnu.ps@xxxxxxxxxxx
Subject: Re: [PATCH 1/1] staging: ion: Fix error handling in ion_buffer_create

On 09/29/2015 10:37 PM, Rohit kumar wrote:
This patch fixes error handling case when buffer->pages allocation
fails. Also, it removes unreachable code of checking ret variable
although it is not updated.


Reviewed-by: Laura Abbott <labbott@xxxxxxxxxx>

Signed-off-by: Rohit kumar <rohit.kr@xxxxxxxxxxx>
---
drivers/staging/android/ion/ion.c | 14 +++++---------
1 file changed, 5 insertions(+), 9 deletions(-)

diff --git a/drivers/staging/android/ion/ion.c
b/drivers/staging/android/ion/ion.c
index 217aa53..af59e4a 100644
--- a/drivers/staging/android/ion/ion.c
+++ b/drivers/staging/android/ion/ion.c
@@ -213,10 +213,10 @@ static struct ion_buffer *ion_buffer_create(struct
ion_heap *heap,
"heap->ops->map_dma should return ERR_PTR on
error"))
table = ERR_PTR(-EINVAL);
if (IS_ERR(table)) {
- heap->ops->free(buffer);
- kfree(buffer);
- return ERR_CAST(table);
+ ret = -EINVAL;
+ goto err1;
}
+
buffer->sg_table = table;
if (ion_buffer_fault_user_mappings(buffer)) {
int num_pages = PAGE_ALIGN(buffer->size) / PAGE_SIZE; @@ -
226,7
+226,7 @@ static struct ion_buffer *ion_buffer_create(struct ion_heap *heap,
buffer->pages = vmalloc(sizeof(struct page *) * num_pages);
if (!buffer->pages) {
ret = -ENOMEM;
- goto err1;
+ goto err;
}

for_each_sg(table->sgl, sg, table->nents, i) { @@ -235,9 +235,6
@@
static struct ion_buffer *ion_buffer_create(struct ion_heap *heap,
for (j = 0; j < sg->length / PAGE_SIZE; j++)
buffer->pages[k++] = page++;
}
-
- if (ret)
- goto err;
}

buffer->dev = dev;
@@ -261,9 +258,8 @@ static struct ion_buffer *ion_buffer_create(struct
ion_heap *heap,

err:
heap->ops->unmap_dma(heap, buffer);
- heap->ops->free(buffer);
err1:
- vfree(buffer->pages);
+ heap->ops->free(buffer);
err2:
kfree(buffer);
return ERR_PTR(ret);


Suggested-by: Pintu Kumar <pintu.k@xxxxxxxxxxx>
Reviewed-by: Pintu Kumar <pintu.k@xxxxxxxxxxx>




It's nice!
Reviewed-by: Gioh Kim <gioh.kim@xxxxxxx>

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/