diff --git a/drivers/staging/android/ion/ion.c b/drivers/staging/android/ion/ion.c index aa5dcce45b764b43c8c3b5fd7dd7978a296ce283..623622e295dd8ca1e2151783ac2a5210b603a08a 100755 --- a/drivers/staging/android/ion/ion.c +++ b/drivers/staging/android/ion/ion.c @@ -1480,11 +1480,6 @@ static int ion_sync_for_device(struct ion_client *client, int fd) } buffer = dmabuf->priv; - if (buffer->flags & ION_FLAG_SECURE) { - pr_err("%s: cannot sync a secure dmabuf\n", __func__); - dma_buf_put(dmabuf); - return -EINVAL; - } dma_sync_sg_for_device(NULL, buffer->sg_table->sgl, buffer->sg_table->nents, DMA_BIDIRECTIONAL); dma_buf_put(dmabuf); diff --git a/drivers/staging/android/ion/msm/msm_ion.c b/drivers/staging/android/ion/msm/msm_ion.c index 82882625465720177ccd155b31a4fe4ed988af5f..8e10e0cddd74fb1a54ce9e8804eeeb4a684d140f 100644 --- a/drivers/staging/android/ion/msm/msm_ion.c +++ b/drivers/staging/android/ion/msm/msm_ion.c @@ -1,4 +1,4 @@ -/* Copyright (c) 2011-2014,2016,2018 The Linux Foundation. All rights reserved. +/* Copyright (c) 2011-2014, The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and @@ -722,11 +722,11 @@ long msm_ion_custom_ioctl(struct ion_client *client, down_read(&mm->mmap_sem); - start = (unsigned long)data.flush_data.vaddr + - data.flush_data.offset; - end = start + data.flush_data.length; + start = (unsigned long) data.flush_data.vaddr; + end = (unsigned long) data.flush_data.vaddr + + data.flush_data.length; - if (check_vaddr_bounds(start, end)) { + if (start && check_vaddr_bounds(start, end)) { pr_err("%s: virtual address %p is out of bounds\n", __func__, data.flush_data.vaddr); ret = -EINVAL;