Lines Matching full:level
13 #define MAX_CACHE_LEVEL 7 /* Max 7 level supported */
15 #define CLIDR_CTYPE_SHIFT(level) (3 * (level - 1)) argument
16 #define CLIDR_CTYPE_MASK(level) (7 << CLIDR_CTYPE_SHIFT(level)) argument
17 #define CLIDR_CTYPE(clidr, level) \ argument
18 (((clidr) & CLIDR_CTYPE_MASK(level)) >> CLIDR_CTYPE_SHIFT(level))
29 static inline enum cache_type get_cache_type(int level) in get_cache_type() argument
33 if (level > MAX_CACHE_LEVEL) in get_cache_type()
36 return CLIDR_CTYPE(clidr, level); in get_cache_type()
40 enum cache_type type, unsigned int level) in ci_leaf_init() argument
42 this_leaf->level = level; in ci_leaf_init()
48 unsigned int ctype, level, leaves, fw_level; in __init_cache_level() local
51 for (level = 1, leaves = 0; level <= MAX_CACHE_LEVEL; level++) { in __init_cache_level()
52 ctype = get_cache_type(level); in __init_cache_level()
54 level--; in __init_cache_level()
66 if (level < fw_level) { in __init_cache_level()
72 leaves += (fw_level - level); in __init_cache_level()
73 level = fw_level; in __init_cache_level()
76 this_cpu_ci->num_levels = level; in __init_cache_level()
83 unsigned int level, idx; in __populate_cache_leaves() local
88 for (idx = 0, level = 1; level <= this_cpu_ci->num_levels && in __populate_cache_leaves()
89 idx < this_cpu_ci->num_leaves; idx++, level++) { in __populate_cache_leaves()
90 type = get_cache_type(level); in __populate_cache_leaves()
92 ci_leaf_init(this_leaf++, CACHE_TYPE_DATA, level); in __populate_cache_leaves()
93 ci_leaf_init(this_leaf++, CACHE_TYPE_INST, level); in __populate_cache_leaves()
95 ci_leaf_init(this_leaf++, type, level); in __populate_cache_leaves()