~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/linux/cma.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/linux/cma.h (Version linux-6.12-rc7) and /include/linux/cma.h (Version linux-6.9.12)


  1 /* SPDX-License-Identifier: GPL-2.0 */              1 /* SPDX-License-Identifier: GPL-2.0 */
  2 #ifndef __CMA_H__                                   2 #ifndef __CMA_H__
  3 #define __CMA_H__                                   3 #define __CMA_H__
  4                                                     4 
  5 #include <linux/init.h>                             5 #include <linux/init.h>
  6 #include <linux/types.h>                            6 #include <linux/types.h>
  7 #include <linux/numa.h>                             7 #include <linux/numa.h>
  8                                                     8 
  9 #ifdef CONFIG_CMA_AREAS                             9 #ifdef CONFIG_CMA_AREAS
 10 #define MAX_CMA_AREAS   CONFIG_CMA_AREAS           10 #define MAX_CMA_AREAS   CONFIG_CMA_AREAS
 11 #endif                                             11 #endif
 12                                                    12 
 13 #define CMA_MAX_NAME 64                            13 #define CMA_MAX_NAME 64
 14                                                    14 
 15 /*                                                 15 /*
 16  *  the buddy -- especially pageblock merging      16  *  the buddy -- especially pageblock merging and alloc_contig_range()
 17  * -- can deal with only some pageblocks of a      17  * -- can deal with only some pageblocks of a higher-order page being
 18  *  MIGRATE_CMA, we can use pageblock_nr_pages     18  *  MIGRATE_CMA, we can use pageblock_nr_pages.
 19  */                                                19  */
 20 #define CMA_MIN_ALIGNMENT_PAGES pageblock_nr_p     20 #define CMA_MIN_ALIGNMENT_PAGES pageblock_nr_pages
 21 #define CMA_MIN_ALIGNMENT_BYTES (PAGE_SIZE * C     21 #define CMA_MIN_ALIGNMENT_BYTES (PAGE_SIZE * CMA_MIN_ALIGNMENT_PAGES)
 22                                                    22 
 23 struct cma;                                        23 struct cma;
 24                                                    24 
 25 extern unsigned long totalcma_pages;               25 extern unsigned long totalcma_pages;
 26 extern phys_addr_t cma_get_base(const struct c     26 extern phys_addr_t cma_get_base(const struct cma *cma);
 27 extern unsigned long cma_get_size(const struct     27 extern unsigned long cma_get_size(const struct cma *cma);
 28 extern const char *cma_get_name(const struct c     28 extern const char *cma_get_name(const struct cma *cma);
 29                                                    29 
 30 extern int __init cma_declare_contiguous_nid(p     30 extern int __init cma_declare_contiguous_nid(phys_addr_t base,
 31                         phys_addr_t size, phys     31                         phys_addr_t size, phys_addr_t limit,
 32                         phys_addr_t alignment,     32                         phys_addr_t alignment, unsigned int order_per_bit,
 33                         bool fixed, const char     33                         bool fixed, const char *name, struct cma **res_cma,
 34                         int nid);                  34                         int nid);
 35 static inline int __init cma_declare_contiguou     35 static inline int __init cma_declare_contiguous(phys_addr_t base,
 36                         phys_addr_t size, phys     36                         phys_addr_t size, phys_addr_t limit,
 37                         phys_addr_t alignment,     37                         phys_addr_t alignment, unsigned int order_per_bit,
 38                         bool fixed, const char     38                         bool fixed, const char *name, struct cma **res_cma)
 39 {                                                  39 {
 40         return cma_declare_contiguous_nid(base     40         return cma_declare_contiguous_nid(base, size, limit, alignment,
 41                         order_per_bit, fixed,      41                         order_per_bit, fixed, name, res_cma, NUMA_NO_NODE);
 42 }                                                  42 }
 43 extern int cma_init_reserved_mem(phys_addr_t b     43 extern int cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
 44                                         unsign     44                                         unsigned int order_per_bit,
 45                                         const      45                                         const char *name,
 46                                         struct     46                                         struct cma **res_cma);
 47 extern struct page *cma_alloc(struct cma *cma,     47 extern struct page *cma_alloc(struct cma *cma, unsigned long count, unsigned int align,
 48                               bool no_warn);       48                               bool no_warn);
 49 extern bool cma_pages_valid(struct cma *cma, c     49 extern bool cma_pages_valid(struct cma *cma, const struct page *pages, unsigned long count);
 50 extern bool cma_release(struct cma *cma, const     50 extern bool cma_release(struct cma *cma, const struct page *pages, unsigned long count);
 51                                                    51 
 52 extern int cma_for_each_area(int (*it)(struct      52 extern int cma_for_each_area(int (*it)(struct cma *cma, void *data), void *data);
 53                                                    53 
 54 extern void cma_reserve_pages_on_error(struct      54 extern void cma_reserve_pages_on_error(struct cma *cma);
 55                                                << 
 56 #ifdef CONFIG_CMA                              << 
 57 struct folio *cma_alloc_folio(struct cma *cma, << 
 58 bool cma_free_folio(struct cma *cma, const str << 
 59 #else                                          << 
 60 static inline struct folio *cma_alloc_folio(st << 
 61 {                                              << 
 62         return NULL;                           << 
 63 }                                              << 
 64                                                << 
 65 static inline bool cma_free_folio(struct cma * << 
 66 {                                              << 
 67         return false;                          << 
 68 }                                              << 
 69 #endif                                         << 
 70                                                << 
 71 #endif                                             55 #endif
 72                                                    56 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php