~ [ 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-4.16.18)


  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>                        << 
  8                                                     7 
                                                   >>   8 /*
                                                   >>   9  * There is always at least global CMA area and a few optional
                                                   >>  10  * areas configured in kernel .config.
                                                   >>  11  */
  9 #ifdef CONFIG_CMA_AREAS                            12 #ifdef CONFIG_CMA_AREAS
 10 #define MAX_CMA_AREAS   CONFIG_CMA_AREAS       !!  13 #define MAX_CMA_AREAS   (1 + CONFIG_CMA_AREAS)
 11 #endif                                         << 
 12                                                    14 
 13 #define CMA_MAX_NAME 64                        !!  15 #else
                                                   >>  16 #define MAX_CMA_AREAS   (0)
 14                                                    17 
 15 /*                                             !!  18 #endif
 16  *  the buddy -- especially pageblock merging  << 
 17  * -- can deal with only some pageblocks of a  << 
 18  *  MIGRATE_CMA, we can use pageblock_nr_pages << 
 19  */                                            << 
 20 #define CMA_MIN_ALIGNMENT_PAGES pageblock_nr_p << 
 21 #define CMA_MIN_ALIGNMENT_BYTES (PAGE_SIZE * C << 
 22                                                    19 
 23 struct cma;                                        20 struct cma;
 24                                                    21 
 25 extern unsigned long totalcma_pages;               22 extern unsigned long totalcma_pages;
 26 extern phys_addr_t cma_get_base(const struct c     23 extern phys_addr_t cma_get_base(const struct cma *cma);
 27 extern unsigned long cma_get_size(const struct     24 extern unsigned long cma_get_size(const struct cma *cma);
 28 extern const char *cma_get_name(const struct c     25 extern const char *cma_get_name(const struct cma *cma);
 29                                                    26 
 30 extern int __init cma_declare_contiguous_nid(p !!  27 extern int __init cma_declare_contiguous(phys_addr_t base,
 31                         phys_addr_t size, phys     28                         phys_addr_t size, phys_addr_t limit,
 32                         phys_addr_t alignment,     29                         phys_addr_t alignment, unsigned int order_per_bit,
 33                         bool fixed, const char !!  30                         bool fixed, const char *name, struct cma **res_cma);
 34                         int nid);              << 
 35 static inline int __init cma_declare_contiguou << 
 36                         phys_addr_t size, phys << 
 37                         phys_addr_t alignment, << 
 38                         bool fixed, const char << 
 39 {                                              << 
 40         return cma_declare_contiguous_nid(base << 
 41                         order_per_bit, fixed,  << 
 42 }                                              << 
 43 extern int cma_init_reserved_mem(phys_addr_t b     31 extern int cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
 44                                         unsign     32                                         unsigned int order_per_bit,
 45                                         const      33                                         const char *name,
 46                                         struct     34                                         struct cma **res_cma);
 47 extern struct page *cma_alloc(struct cma *cma, !!  35 extern struct page *cma_alloc(struct cma *cma, size_t count, unsigned int align,
 48                               bool no_warn);   !!  36                               gfp_t gfp_mask);
 49 extern bool cma_pages_valid(struct cma *cma, c !!  37 extern bool cma_release(struct cma *cma, const struct page *pages, unsigned int count);
 50 extern bool cma_release(struct cma *cma, const << 
 51                                                    38 
 52 extern int cma_for_each_area(int (*it)(struct      39 extern int cma_for_each_area(int (*it)(struct cma *cma, void *data), void *data);
 53                                                << 
 54 extern void cma_reserve_pages_on_error(struct  << 
 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                                             40 #endif
 72                                                    41 

~ [ 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