2014-08-07 07:05:25 +08:00
|
|
|
#ifndef __CMA_H__
|
|
|
|
#define __CMA_H__
|
|
|
|
|
2016-12-13 08:43:15 +08:00
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
2014-08-07 07:05:25 +08:00
|
|
|
/*
|
|
|
|
* There is always at least global CMA area and a few optional
|
|
|
|
* areas configured in kernel .config.
|
|
|
|
*/
|
|
|
|
#ifdef CONFIG_CMA_AREAS
|
|
|
|
#define MAX_CMA_AREAS (1 + CONFIG_CMA_AREAS)
|
|
|
|
|
|
|
|
#else
|
|
|
|
#define MAX_CMA_AREAS (0)
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
struct cma;
|
|
|
|
|
mm: cma: split cma-reserved in dmesg log
When the system boots up, in the dmesg logs we can see the memory
statistics along with total reserved as below. Memory: 458840k/458840k
available, 65448k reserved, 0K highmem
When CMA is enabled, still the total reserved memory remains the same.
However, the CMA memory is not considered as reserved. But, when we see
/proc/meminfo, the CMA memory is part of free memory. This creates
confusion. This patch corrects the problem by properly subtracting the
CMA reserved memory from the total reserved memory in dmesg logs.
Below is the dmesg snapshot from an arm based device with 512MB RAM and
12MB single CMA region.
Before this change:
Memory: 458840k/458840k available, 65448k reserved, 0K highmem
After this change:
Memory: 458840k/458840k available, 53160k reserved, 12288k cma-reserved, 0K highmem
Signed-off-by: Pintu Kumar <pintu.k@samsung.com>
Signed-off-by: Vishnu Pratap Singh <vishnu.ps@samsung.com>
Acked-by: Michal Nazarewicz <mina86@mina86.com>
Cc: Rafael Aquini <aquini@redhat.com>
Cc: Jerome Marchand <jmarchan@redhat.com>
Cc: Marek Szyprowski <m.szyprowski@samsung.com>
Cc: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2014-12-19 08:17:15 +08:00
|
|
|
extern unsigned long totalcma_pages;
|
2015-04-15 06:47:04 +08:00
|
|
|
extern phys_addr_t cma_get_base(const struct cma *cma);
|
|
|
|
extern unsigned long cma_get_size(const struct cma *cma);
|
2017-04-19 02:27:03 +08:00
|
|
|
extern const char *cma_get_name(const struct cma *cma);
|
2014-08-07 07:05:25 +08:00
|
|
|
|
2014-10-24 17:47:57 +08:00
|
|
|
extern int __init cma_declare_contiguous(phys_addr_t base,
|
|
|
|
phys_addr_t size, phys_addr_t limit,
|
2014-08-07 07:05:25 +08:00
|
|
|
phys_addr_t alignment, unsigned int order_per_bit,
|
2017-04-19 02:27:03 +08:00
|
|
|
bool fixed, const char *name, struct cma **res_cma);
|
2015-04-15 06:47:04 +08:00
|
|
|
extern int cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
|
|
|
|
unsigned int order_per_bit,
|
2017-04-19 02:27:03 +08:00
|
|
|
const char *name,
|
2014-10-14 06:51:09 +08:00
|
|
|
struct cma **res_cma);
|
2017-02-25 06:58:41 +08:00
|
|
|
extern struct page *cma_alloc(struct cma *cma, size_t count, unsigned int align,
|
|
|
|
gfp_t gfp_mask);
|
2015-04-15 06:47:04 +08:00
|
|
|
extern bool cma_release(struct cma *cma, const struct page *pages, unsigned int count);
|
2017-04-19 02:27:04 +08:00
|
|
|
|
|
|
|
extern int cma_for_each_area(int (*it)(struct cma *cma, void *data), void *data);
|
2014-08-07 07:05:25 +08:00
|
|
|
#endif
|