Lines Matching +full:mem +full:- +full:base

20 	phys_addr_t base;  member
25 static struct region __initdata mem[MPU_MAX_REGIONS]; variable
52 /* Data-side / unified region attributes */
66 /* Region base address register */
76 /* Optional instruction-side region attributes */
78 /* I-side Region access control register */
84 /* I-side Region size register */
90 /* I-side Region base address register */
108 /* Data-side / unified region attributes */
126 /* Region base address register */
137 /* ARMv7-M only supports a unified MPU, so I-side operations are nop */
146 static bool __init try_split_region(phys_addr_t base, phys_addr_t size, struct region *region) in try_split_region() argument
149 phys_addr_t abase = base & ~(size - 1); in try_split_region()
150 phys_addr_t asize = base + size - abase; in try_split_region()
157 bdiff = base - abase; in try_split_region()
158 sdiff = p2size - asize; in try_split_region()
177 _set_bit(i, &region->subreg); in try_split_region()
180 _set_bit(PMSAv7_NR_SUBREGS - i, &region->subreg); in try_split_region()
183 region->base = abase; in try_split_region()
184 region->size = p2size; in try_split_region()
189 static int __init allocate_region(phys_addr_t base, phys_addr_t size, in allocate_region() argument
198 if (try_split_region(base, size, &regions[count])) { in allocate_region()
200 base += size; in allocate_region()
201 diff -= size; in allocate_region()
206 * if "base" is 0. Hence we keep everything below 4G in allocate_region()
212 phys_addr_t asize = (base - 1) ^ base; in allocate_region()
213 phys_addr_t p2size = (1 << __fls(diff)) - 1; in allocate_region()
224 attempts--; in allocate_region()
242 /* Free-up PMSAv7_PROBE_REGION */ in pmsav7_adjust_lowmem_bounds()
251 mem_max_regions--; in pmsav7_adjust_lowmem_bounds()
255 mem_max_regions--; in pmsav7_adjust_lowmem_bounds()
260 num = allocate_region(CONFIG_XIP_PHYS_ADDR, __pa(_exiprom) - CONFIG_XIP_PHYS_ADDR, in pmsav7_adjust_lowmem_bounds()
263 mem_max_regions -= num; in pmsav7_adjust_lowmem_bounds()
278 specified_mem_size = mem_end - mem_start; in pmsav7_adjust_lowmem_bounds()
288 memblock_remove(reg_start, 0 - reg_start); in pmsav7_adjust_lowmem_bounds()
293 memset(mem, 0, sizeof(mem)); in pmsav7_adjust_lowmem_bounds()
294 num = allocate_region(mem_start, specified_mem_size, mem_max_regions, mem); in pmsav7_adjust_lowmem_bounds()
297 unsigned long subreg = mem[i].size / PMSAv7_NR_SUBREGS; in pmsav7_adjust_lowmem_bounds()
299 total_mem_size += mem[i].size - subreg * hweight_long(mem[i].subreg); in pmsav7_adjust_lowmem_bounds()
301 pr_debug("MPU: base %pa size %pa disable subregions: %*pbl\n", in pmsav7_adjust_lowmem_bounds()
302 &mem[i].base, &mem[i].size, PMSAv7_NR_SUBREGS, &mem[i].subreg); in pmsav7_adjust_lowmem_bounds()
309 specified_mem_size - total_mem_size); in pmsav7_adjust_lowmem_bounds()
326 /* Check for separate d-side and i-side memory maps */ in __mpu_max_regions()
354 /* If the MPU is non-unified, we use the larger of the two minima*/ in __mpu_min_region_order()
375 return -ENOENT; in mpu_setup_region()
378 return -ENOMEM; in mpu_setup_region()
381 return -ENOMEM; in mpu_setup_region()
384 size_data = ((size_order - 1) << PMSAv7_RSR_SZ) | 1 << PMSAv7_RSR_EN; in mpu_setup_region()
398 /* Check for independent I-side registers */ in mpu_setup_region()
436 * head-nommu.S (which is cachable) all subsequent in pmsav7_setup()
446 err |= mpu_setup_region(region++, xip[i].base, ilog2(xip[i].size), in pmsav7_setup()
453 for (i = 0; i < ARRAY_SIZE(mem); i++) { in pmsav7_setup()
454 if (!mem[i].size) in pmsav7_setup()
457 err |= mpu_setup_region(region++, mem[i].base, ilog2(mem[i].size), in pmsav7_setup()
459 mem[i].subreg, false); in pmsav7_setup()