mirror of
https://github.com/hardkernel/linux.git
synced 2026-04-05 12:43:09 +09:00
PD#172483 Problem: Add reserved & cma support for 4.9. Solution: 1. add tvp padding, for test. 2. add no-cma-tvp,to force not used cma for tvp. 3. add nomap for reserved memroy detective. 4. add res & cma two mem region on same board. 5. add clear-map property for codec_mm_cma. Verify: Test this function with Android_O-MR1(GTVS) & ExoPlayer. Change-Id: Ib20e0e9bc4725afb271de97543ce5ebf3bfcfb29 Signed-off-by: Zhi Zhou <zhi.zhou@amlogic.com>
38 lines
1.1 KiB
C
38 lines
1.1 KiB
C
#ifndef __CMA_H__
|
|
#define __CMA_H__
|
|
|
|
/*
|
|
* 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;
|
|
|
|
extern unsigned long totalcma_pages;
|
|
extern phys_addr_t cma_get_base(const struct cma *cma);
|
|
extern unsigned long cma_get_size(const struct cma *cma);
|
|
|
|
extern int __init cma_declare_contiguous(phys_addr_t base,
|
|
phys_addr_t size, phys_addr_t limit,
|
|
phys_addr_t alignment, unsigned int order_per_bit,
|
|
bool fixed, struct cma **res_cma);
|
|
extern int cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
|
|
unsigned int order_per_bit,
|
|
struct cma **res_cma);
|
|
extern struct page *cma_alloc(struct cma *cma, size_t count, unsigned int align);
|
|
extern bool cma_release(struct cma *cma, const struct page *pages, unsigned int count);
|
|
#ifdef CONFIG_AMLOGIC_CMA
|
|
extern void cma_init_clear(struct cma *cma, bool clear);
|
|
extern int setup_cma_full_pagemap(struct cma *cma);
|
|
extern int cma_mmu_op(struct page *page, int count, bool set);
|
|
#endif
|
|
|
|
#endif
|