summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShrenuj Bansal <shrenujb@codeaurora.org>2015-07-08 17:10:02 -0700
committerDavid Keitel <dkeitel@codeaurora.org>2016-03-22 11:04:36 -0700
commitaeb2abd83d93d3b7c6192d1cc3cf0dbcd9388085 (patch)
tree11acb050eea76a56f6d359588fbc64ed09cb9ea1
parente6051f3f4123f23196a27e38b5b8f7c00f2f2aff (diff)
ion: Set the page private bit on secure buffers
Set the private page bit on each sg of secure buffers to inform other entities, which import these buffers as an fd, that this memory is secure. Change-Id: I767c26fa1feca7505bbb3293cfdb4e09520496a6 Signed-off-by: Shrenuj Bansal <shrenujb@codeaurora.org>
-rw-r--r--drivers/staging/android/ion/ion_system_secure_heap.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/drivers/staging/android/ion/ion_system_secure_heap.c b/drivers/staging/android/ion/ion_system_secure_heap.c
index ab681c9418a2..62974c79fe63 100644
--- a/drivers/staging/android/ion/ion_system_secure_heap.c
+++ b/drivers/staging/android/ion/ion_system_secure_heap.c
@@ -52,9 +52,12 @@ static int get_secure_vmid(unsigned long flags)
static void ion_system_secure_heap_free(struct ion_buffer *buffer)
{
int ret = 0;
+ int i;
u32 source_vm;
int dest_vmid;
int dest_perms;
+ struct sg_table *sgt;
+ struct scatterlist *sg;
struct ion_heap *heap = buffer->heap;
struct ion_system_secure_heap *secure_heap = container_of(heap,
struct ion_system_secure_heap,
@@ -76,6 +79,10 @@ static void ion_system_secure_heap_free(struct ion_buffer *buffer)
return;
}
+ sgt = buffer->priv_virt;
+ for_each_sg(sgt->sgl, sg, sgt->nents, i)
+ ClearPagePrivate(sg_page(sg));
+
buffer->heap = secure_heap->sys_heap;
secure_heap->sys_heap->ops->free(buffer);
}
@@ -86,9 +93,12 @@ static int ion_system_secure_heap_allocate(struct ion_heap *heap,
unsigned long flags)
{
int ret = 0;
+ int i;
u32 source_vm;
int dest_vmid;
int dest_perms;
+ struct sg_table *sgt;
+ struct scatterlist *sg;
struct ion_system_secure_heap *secure_heap = container_of(heap,
struct ion_system_secure_heap,
heap);
@@ -123,6 +133,11 @@ static int ion_system_secure_heap_allocate(struct ion_heap *heap,
pr_err("%s: Assign call failed\n", __func__);
goto err;
}
+
+ sgt = buffer->priv_virt;
+ for_each_sg(sgt->sgl, sg, sgt->nents, i)
+ SetPagePrivate(sg_page(sg));
+
return ret;
err: