hc
2023-12-06 d38611ca164021d018c1b23eee65bbebc09c63e0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __MM_CMA_H__
#define __MM_CMA_H__
 
#include <linux/debugfs.h>
#include <linux/kobject.h>
#include <linux/android_vendor.h>
 
struct cma_kobject {
   struct kobject kobj;
   struct cma *cma;
};
 
struct cma {
   unsigned long   base_pfn;
   unsigned long   count;
   unsigned long   *bitmap;
   unsigned int order_per_bit; /* Order of pages represented by one bit */
   struct mutex    lock;
#ifdef CONFIG_CMA_DEBUGFS
   struct hlist_head mem_head;
   spinlock_t mem_head_lock;
   struct debugfs_u32_array dfs_bitmap;
#endif
   char name[CMA_MAX_NAME];
#ifdef CONFIG_CMA_SYSFS
   /* the number of CMA page successful allocations */
   atomic64_t nr_pages_succeeded;
   /* the number of CMA page allocation failures */
   atomic64_t nr_pages_failed;
   /* kobject requires dynamic object */
   struct cma_kobject *cma_kobj;
#endif
   ANDROID_OEM_DATA_ARRAY(1, 4);
};
 
extern struct cma cma_areas[MAX_CMA_AREAS];
extern unsigned cma_area_count;
 
static inline unsigned long cma_bitmap_maxno(struct cma *cma)
{
   return cma->count >> cma->order_per_bit;
}
 
#ifdef CONFIG_CMA_SYSFS
void cma_sysfs_account_success_pages(struct cma *cma, unsigned long nr_pages);
void cma_sysfs_account_fail_pages(struct cma *cma, unsigned long nr_pages);
#else
static inline void cma_sysfs_account_success_pages(struct cma *cma,
                          unsigned long nr_pages) {};
static inline void cma_sysfs_account_fail_pages(struct cma *cma,
                       unsigned long nr_pages) {};
#endif
#endif