提交 f318dd08 编写于 作者: L Laura Abbott 提交者: Greg Kroah-Hartman

cma: Store a name in the cma structure

Frameworks that may want to enumerate CMA heaps (e.g. Ion) will find it
useful to have an explicit name attached to each region. Store the name
in each CMA structure.
Signed-off-by: NLaura Abbott <labbott@redhat.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 df47c0a6
...@@ -100,7 +100,8 @@ void __init kvm_cma_reserve(void) ...@@ -100,7 +100,8 @@ void __init kvm_cma_reserve(void)
(unsigned long)selected_size / SZ_1M); (unsigned long)selected_size / SZ_1M);
align_size = HPT_ALIGN_PAGES << PAGE_SHIFT; align_size = HPT_ALIGN_PAGES << PAGE_SHIFT;
cma_declare_contiguous(0, selected_size, 0, align_size, cma_declare_contiguous(0, selected_size, 0, align_size,
KVM_CMA_CHUNK_ORDER - PAGE_SHIFT, false, &kvm_cma); KVM_CMA_CHUNK_ORDER - PAGE_SHIFT, false, "kvm_cma",
&kvm_cma);
} }
} }
......
...@@ -165,7 +165,8 @@ int __init dma_contiguous_reserve_area(phys_addr_t size, phys_addr_t base, ...@@ -165,7 +165,8 @@ int __init dma_contiguous_reserve_area(phys_addr_t size, phys_addr_t base,
{ {
int ret; int ret;
ret = cma_declare_contiguous(base, size, limit, 0, 0, fixed, res_cma); ret = cma_declare_contiguous(base, size, limit, 0, 0, fixed,
"reserved", res_cma);
if (ret) if (ret)
return ret; return ret;
...@@ -258,7 +259,7 @@ static int __init rmem_cma_setup(struct reserved_mem *rmem) ...@@ -258,7 +259,7 @@ static int __init rmem_cma_setup(struct reserved_mem *rmem)
return -EINVAL; return -EINVAL;
} }
err = cma_init_reserved_mem(rmem->base, rmem->size, 0, &cma); err = cma_init_reserved_mem(rmem->base, rmem->size, 0, rmem->name, &cma);
if (err) { if (err) {
pr_err("Reserved memory: unable to setup CMA region\n"); pr_err("Reserved memory: unable to setup CMA region\n");
return err; return err;
......
...@@ -21,13 +21,15 @@ struct cma; ...@@ -21,13 +21,15 @@ struct cma;
extern unsigned long totalcma_pages; extern unsigned long totalcma_pages;
extern phys_addr_t cma_get_base(const struct cma *cma); extern phys_addr_t cma_get_base(const struct cma *cma);
extern unsigned long cma_get_size(const struct cma *cma); extern unsigned long cma_get_size(const struct cma *cma);
extern const char *cma_get_name(const struct cma *cma);
extern int __init cma_declare_contiguous(phys_addr_t base, extern int __init cma_declare_contiguous(phys_addr_t base,
phys_addr_t size, phys_addr_t limit, phys_addr_t size, phys_addr_t limit,
phys_addr_t alignment, unsigned int order_per_bit, phys_addr_t alignment, unsigned int order_per_bit,
bool fixed, struct cma **res_cma); bool fixed, const char *name, struct cma **res_cma);
extern int cma_init_reserved_mem(phys_addr_t base, phys_addr_t size, extern int cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
unsigned int order_per_bit, unsigned int order_per_bit,
const char *name,
struct cma **res_cma); struct cma **res_cma);
extern struct page *cma_alloc(struct cma *cma, size_t count, unsigned int align, extern struct page *cma_alloc(struct cma *cma, size_t count, unsigned int align,
gfp_t gfp_mask); gfp_t gfp_mask);
......
...@@ -53,6 +53,11 @@ unsigned long cma_get_size(const struct cma *cma) ...@@ -53,6 +53,11 @@ unsigned long cma_get_size(const struct cma *cma)
return cma->count << PAGE_SHIFT; return cma->count << PAGE_SHIFT;
} }
const char *cma_get_name(const struct cma *cma)
{
return cma->name ? cma->name : "(undefined)";
}
static unsigned long cma_bitmap_aligned_mask(const struct cma *cma, static unsigned long cma_bitmap_aligned_mask(const struct cma *cma,
int align_order) int align_order)
{ {
...@@ -168,6 +173,7 @@ core_initcall(cma_init_reserved_areas); ...@@ -168,6 +173,7 @@ core_initcall(cma_init_reserved_areas);
*/ */
int __init cma_init_reserved_mem(phys_addr_t base, phys_addr_t size, int __init cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
unsigned int order_per_bit, unsigned int order_per_bit,
const char *name,
struct cma **res_cma) struct cma **res_cma)
{ {
struct cma *cma; struct cma *cma;
...@@ -198,6 +204,13 @@ int __init cma_init_reserved_mem(phys_addr_t base, phys_addr_t size, ...@@ -198,6 +204,13 @@ int __init cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
* subsystems (like slab allocator) are available. * subsystems (like slab allocator) are available.
*/ */
cma = &cma_areas[cma_area_count]; cma = &cma_areas[cma_area_count];
if (name) {
cma->name = name;
} else {
cma->name = kasprintf(GFP_KERNEL, "cma%d\n", cma_area_count);
if (!cma->name)
return -ENOMEM;
}
cma->base_pfn = PFN_DOWN(base); cma->base_pfn = PFN_DOWN(base);
cma->count = size >> PAGE_SHIFT; cma->count = size >> PAGE_SHIFT;
cma->order_per_bit = order_per_bit; cma->order_per_bit = order_per_bit;
...@@ -229,7 +242,7 @@ int __init cma_init_reserved_mem(phys_addr_t base, phys_addr_t size, ...@@ -229,7 +242,7 @@ int __init cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
int __init cma_declare_contiguous(phys_addr_t base, int __init cma_declare_contiguous(phys_addr_t base,
phys_addr_t size, phys_addr_t limit, phys_addr_t size, phys_addr_t limit,
phys_addr_t alignment, unsigned int order_per_bit, phys_addr_t alignment, unsigned int order_per_bit,
bool fixed, struct cma **res_cma) bool fixed, const char *name, struct cma **res_cma)
{ {
phys_addr_t memblock_end = memblock_end_of_DRAM(); phys_addr_t memblock_end = memblock_end_of_DRAM();
phys_addr_t highmem_start; phys_addr_t highmem_start;
...@@ -335,7 +348,7 @@ int __init cma_declare_contiguous(phys_addr_t base, ...@@ -335,7 +348,7 @@ int __init cma_declare_contiguous(phys_addr_t base,
base = addr; base = addr;
} }
ret = cma_init_reserved_mem(base, size, order_per_bit, res_cma); ret = cma_init_reserved_mem(base, size, order_per_bit, name, res_cma);
if (ret) if (ret)
goto err; goto err;
......
...@@ -11,6 +11,7 @@ struct cma { ...@@ -11,6 +11,7 @@ struct cma {
struct hlist_head mem_head; struct hlist_head mem_head;
spinlock_t mem_head_lock; spinlock_t mem_head_lock;
#endif #endif
const char *name;
}; };
extern struct cma cma_areas[MAX_CMA_AREAS]; extern struct cma cma_areas[MAX_CMA_AREAS];
......
...@@ -167,7 +167,7 @@ static void cma_debugfs_add_one(struct cma *cma, int idx) ...@@ -167,7 +167,7 @@ static void cma_debugfs_add_one(struct cma *cma, int idx)
char name[16]; char name[16];
int u32s; int u32s;
sprintf(name, "cma-%d", idx); sprintf(name, "cma-%s", cma->name);
tmp = debugfs_create_dir(name, cma_debugfs_root); tmp = debugfs_create_dir(name, cma_debugfs_root);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册