Merge "ion: msm: Add support for addition/removal of memory to ION heaps"

This commit is contained in:
qctecmdr 2020-02-09 14:36:36 -08:00 committed by Gerrit - the friendly Code Review server
commit c5d20367bc
3 changed files with 78 additions and 2 deletions

View File

@ -1,6 +1,6 @@
// SPDX-License-Identifier: GPL-2.0-only
/*
* Copyright (c) 2017-2019, The Linux Foundation. All rights reserved.
* Copyright (c) 2017-2020, The Linux Foundation. All rights reserved.
*/
#include <linux/err.h>
@ -229,6 +229,19 @@ struct device *msm_ion_heap_device_by_id(int heap_id)
}
EXPORT_SYMBOL(msm_ion_heap_device_by_id);
bool msm_ion_heap_is_secure(int heap_id)
{
struct ion_heap *heap = ion_heap_by_id(heap_id);
if (IS_ERR(heap) || !(heap->type == ION_HEAP_TYPE_SECURE_CARVEOUT ||
heap->type == ION_HEAP_TYPE_SYSTEM_SECURE ||
heap->type == ION_HEAP_TYPE_HYP_CMA))
return false;
return true;
}
EXPORT_SYMBOL(msm_ion_heap_is_secure);
int msm_ion_heap_prefetch(int heap_id, struct ion_prefetch_region *regions,
int nr_regions)
{
@ -267,6 +280,40 @@ int msm_ion_heap_drain(int heap_id, struct ion_prefetch_region *regions,
}
EXPORT_SYMBOL(msm_ion_heap_drain);
int msm_ion_heap_add_memory(int heap_id, struct sg_table *sgt)
{
struct ion_heap *heap = ion_heap_by_id(heap_id);
struct msm_ion_heap *msm_heap;
if (IS_ERR(heap))
return PTR_ERR(heap);
msm_heap = to_msm_ion_heap(heap);
if (msm_heap->msm_heap_ops && msm_heap->msm_heap_ops->add_memory)
return msm_heap->msm_heap_ops->add_memory(heap, sgt);
return -ENOTSUPP;
}
EXPORT_SYMBOL(msm_ion_heap_add_memory);
int msm_ion_heap_remove_memory(int heap_id, struct sg_table *sgt)
{
struct ion_heap *heap = ion_heap_by_id(heap_id);
struct msm_ion_heap *msm_heap;
if (IS_ERR(heap))
return PTR_ERR(heap);
msm_heap = to_msm_ion_heap(heap);
if (msm_heap->msm_heap_ops && msm_heap->msm_heap_ops->remove_memory)
return msm_heap->msm_heap_ops->remove_memory(heap, sgt);
return -ENOTSUPP;
}
EXPORT_SYMBOL(msm_ion_heap_remove_memory);
static int msm_ion_get_heap_type_from_dt_node(struct device_node *node,
int *heap_type)
{

View File

@ -1,7 +1,7 @@
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* Copyright (C) 2011 Google, Inc.
* Copyright (c) 2011-2019, The Linux Foundation. All rights reserved.
* Copyright (c) 2011-2020, The Linux Foundation. All rights reserved.
*/
#ifndef _MSM_ION_PRIV_H
@ -87,6 +87,11 @@ struct ion_platform_heap {
* @heap_drain: called to asynchronously drain a certain amount of
* memory that was prefetched for the heap at an earlier
* point in time.
* @add_memory: called to add memory to an ION heap. Subsequent
* allocations may be satisfied utilizing newly added
* memory.
* @remove_memory: called to remove memory from an ION heap. Subsequent
* allocations will fail if the heap no longer has memory.
* @debug_show: called when the heap debug file is read to add any heap
* specific debug info to output
*/
@ -97,6 +102,8 @@ struct msm_ion_heap_ops {
int (*heap_drain)(struct ion_heap *heap,
struct ion_prefetch_region *regions,
int nr_regions);
int (*add_memory)(struct ion_heap *heap, struct sg_table *sgt);
int (*remove_memory)(struct ion_heap *heap, struct sg_table *sgt);
int (*debug_show)(struct ion_heap *heap, struct seq_file *s,
void *unused);
};

View File

@ -8,6 +8,7 @@
#include <linux/bitmap.h>
#include <linux/device.h>
#include <linux/scatterlist.h>
#include <uapi/linux/msm_ion.h>
struct ion_prefetch_region {
@ -37,6 +38,12 @@ int msm_ion_heap_drain(int heap_id, struct ion_prefetch_region *regions,
int get_ion_flags(u32 vmid);
bool msm_ion_heap_is_secure(int heap_id);
int msm_ion_heap_add_memory(int heap_id, struct sg_table *sgt);
int msm_ion_heap_remove_memory(int heap_id, struct sg_table *sgt);
#else
static inline struct device *msm_ion_heap_device_by_id(int heap_id)
@ -74,5 +81,20 @@ static inline int get_ion_flags(u32 vmid)
return -EINVAL;
}
static inline bool msm_ion_heap_is_secure(int heap_id)
{
return false;
}
static inline int msm_ion_heap_add_memory(int heap_id, struct sg_table *sgt)
{
return -ENODEV;
}
static inline int msm_ion_heap_remove_memory(int heap_id, struct sg_table *sgt)
{
return -ENODEV;
}
#endif /* CONFIG_ION_MSM_HEAPS */
#endif /* _MSM_ION_H */