Server IP : 13.213.54.232 / Your IP : 216.73.216.30 Web Server : Apache/2.4.52 (Ubuntu) System : Linux ip-172-31-17-110 6.8.0-1029-aws #31~22.04.1-Ubuntu SMP Thu Apr 24 21:16:18 UTC 2025 x86_64 User : www-data ( 33) PHP Version : 7.1.33-67+ubuntu22.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /lib/modules/6.8.0-1029-aws/build/include/linux/ |
Upload File : |
/* SPDX-License-Identifier: GPL-2.0 */ #ifndef _LINUX_MEMORY_TIERS_H #define _LINUX_MEMORY_TIERS_H #include <linux/types.h> #include <linux/nodemask.h> #include <linux/kref.h> #include <linux/mmzone.h> #include <linux/notifier.h> /* * Each tier cover a abstrace distance chunk size of 128 */ #define MEMTIER_CHUNK_BITS 7 #define MEMTIER_CHUNK_SIZE (1 << MEMTIER_CHUNK_BITS) /* * Smaller abstract distance values imply faster (higher) memory tiers. Offset * the DRAM adistance so that we can accommodate devices with a slightly lower * adistance value (slightly faster) than default DRAM adistance to be part of * the same memory tier. */ #define MEMTIER_ADISTANCE_DRAM ((4 * MEMTIER_CHUNK_SIZE) + (MEMTIER_CHUNK_SIZE >> 1)) struct memory_tier; struct memory_dev_type { /* list of memory types that are part of same tier as this type */ struct list_head tier_sibling; /* list of memory types that are managed by one driver */ struct list_head list; /* abstract distance for this specific memory type */ int adistance; /* Nodes of same abstract distance */ nodemask_t nodes; struct kref kref; }; struct access_coordinate; #ifdef CONFIG_NUMA extern bool numa_demotion_enabled; extern struct memory_dev_type *default_dram_type; struct memory_dev_type *alloc_memory_type(int adistance); void put_memory_type(struct memory_dev_type *memtype); void init_node_memory_type(int node, struct memory_dev_type *default_type); void clear_node_memory_type(int node, struct memory_dev_type *memtype); int register_mt_adistance_algorithm(struct notifier_block *nb); int unregister_mt_adistance_algorithm(struct notifier_block *nb); int mt_calc_adistance(int node, int *adist); int mt_set_default_dram_perf(int nid, struct access_coordinate *perf, const char *source); int mt_perf_to_adistance(struct access_coordinate *perf, int *adist); #ifdef CONFIG_MIGRATION int next_demotion_node(int node); void node_get_allowed_targets(pg_data_t *pgdat, nodemask_t *targets); bool node_is_toptier(int node); #else static inline int next_demotion_node(int node) { return NUMA_NO_NODE; } static inline void node_get_allowed_targets(pg_data_t *pgdat, nodemask_t *targets) { *targets = NODE_MASK_NONE; } static inline bool node_is_toptier(int node) { return true; } #endif #else #define numa_demotion_enabled false #define default_dram_type NULL /* * CONFIG_NUMA implementation returns non NULL error. */ static inline struct memory_dev_type *alloc_memory_type(int adistance) { return NULL; } static inline void put_memory_type(struct memory_dev_type *memtype) { } static inline void init_node_memory_type(int node, struct memory_dev_type *default_type) { } static inline void clear_node_memory_type(int node, struct memory_dev_type *memtype) { } static inline int next_demotion_node(int node) { return NUMA_NO_NODE; } static inline void node_get_allowed_targets(pg_data_t *pgdat, nodemask_t *targets) { *targets = NODE_MASK_NONE; } static inline bool node_is_toptier(int node) { return true; } static inline int register_mt_adistance_algorithm(struct notifier_block *nb) { return 0; } static inline int unregister_mt_adistance_algorithm(struct notifier_block *nb) { return 0; } static inline int mt_calc_adistance(int node, int *adist) { return NOTIFY_DONE; } static inline int mt_set_default_dram_perf(int nid, struct access_coordinate *perf, const char *source) { return -EIO; } static inline int mt_perf_to_adistance(struct access_coordinate *perf, int *adist) { return -EIO; } #endif /* CONFIG_NUMA */ #endif /* _LINUX_MEMORY_TIERS_H */