On Wed 05-09-18 18:59:35, Mike Rapoport wrote: > The conversion is done using the following semantic patch: > > @@ > expression e1, e2, e3; > @@ > - __alloc_bootmem(e1, e2, e3) > + memblock_alloc(e1, e2, e3) This is not that straightforward. memblock_virt_alloc with 0 alignment uses SMP_CACHE_BYTES implicitly. I do not see this being handled here. I do not expect this should cause any problems, it would be worse other way around, but it should be at least documented. > Signed-off-by: Mike Rapoport <rppt@xxxxxxxxxxxxxxxxxx> > --- > arch/alpha/kernel/core_cia.c | 2 +- > arch/alpha/kernel/pci_iommu.c | 4 ++-- > arch/alpha/kernel/setup.c | 2 +- > arch/ia64/kernel/mca.c | 4 ++-- > arch/ia64/mm/contig.c | 5 +++-- > arch/mips/kernel/traps.c | 2 +- > arch/sparc/kernel/prom_32.c | 2 +- > arch/sparc/kernel/smp_64.c | 10 +++++----- > arch/sparc/mm/init_32.c | 2 +- > arch/sparc/mm/init_64.c | 9 ++++++--- > arch/sparc/mm/srmmu.c | 10 +++++----- > include/linux/bootmem.h | 8 ++++++++ > 12 files changed, 36 insertions(+), 24 deletions(-) > > diff --git a/arch/alpha/kernel/core_cia.c b/arch/alpha/kernel/core_cia.c > index 4b38386..026ee95 100644 > --- a/arch/alpha/kernel/core_cia.c > +++ b/arch/alpha/kernel/core_cia.c > @@ -331,7 +331,7 @@ cia_prepare_tbia_workaround(int window) > long i; > > /* Use minimal 1K map. */ > - ppte = __alloc_bootmem(CIA_BROKEN_TBIA_SIZE, 32768, 0); > + ppte = memblock_alloc_from(CIA_BROKEN_TBIA_SIZE, 32768, 0); > pte = (virt_to_phys(ppte) >> (PAGE_SHIFT - 1)) | 1; > > for (i = 0; i < CIA_BROKEN_TBIA_SIZE / sizeof(unsigned long); ++i) > diff --git a/arch/alpha/kernel/pci_iommu.c b/arch/alpha/kernel/pci_iommu.c > index b52d76f..0c05493 100644 > --- a/arch/alpha/kernel/pci_iommu.c > +++ b/arch/alpha/kernel/pci_iommu.c > @@ -87,13 +87,13 @@ iommu_arena_new_node(int nid, struct pci_controller *hose, dma_addr_t base, > printk("%s: couldn't allocate arena ptes from node %d\n" > " falling back to system-wide allocation\n", > __func__, nid); > - arena->ptes = __alloc_bootmem(mem_size, align, 0); > + arena->ptes = memblock_alloc_from(mem_size, align, 0); > } > > #else /* CONFIG_DISCONTIGMEM */ > > arena = alloc_bootmem(sizeof(*arena)); > - arena->ptes = __alloc_bootmem(mem_size, align, 0); > + arena->ptes = memblock_alloc_from(mem_size, align, 0); > > #endif /* CONFIG_DISCONTIGMEM */ > > diff --git a/arch/alpha/kernel/setup.c b/arch/alpha/kernel/setup.c > index 4f0d944..64c06a0 100644 > --- a/arch/alpha/kernel/setup.c > +++ b/arch/alpha/kernel/setup.c > @@ -294,7 +294,7 @@ move_initrd(unsigned long mem_limit) > unsigned long size; > > size = initrd_end - initrd_start; > - start = __alloc_bootmem(PAGE_ALIGN(size), PAGE_SIZE, 0); > + start = memblock_alloc_from(PAGE_ALIGN(size), PAGE_SIZE, 0); > if (!start || __pa(start) + size > mem_limit) { > initrd_start = initrd_end = 0; > return NULL; > diff --git a/arch/ia64/kernel/mca.c b/arch/ia64/kernel/mca.c > index 6115464..5586926 100644 > --- a/arch/ia64/kernel/mca.c > +++ b/arch/ia64/kernel/mca.c > @@ -1835,8 +1835,8 @@ format_mca_init_stack(void *mca_data, unsigned long offset, > /* Caller prevents this from being called after init */ > static void * __ref mca_bootmem(void) > { > - return __alloc_bootmem(sizeof(struct ia64_mca_cpu), > - KERNEL_STACK_SIZE, 0); > + return memblock_alloc_from(sizeof(struct ia64_mca_cpu), > + KERNEL_STACK_SIZE, 0); > } > > /* Do per-CPU MCA-related initialization. */ > diff --git a/arch/ia64/mm/contig.c b/arch/ia64/mm/contig.c > index e2e40bb..9e5c23a 100644 > --- a/arch/ia64/mm/contig.c > +++ b/arch/ia64/mm/contig.c > @@ -85,8 +85,9 @@ void *per_cpu_init(void) > static inline void > alloc_per_cpu_data(void) > { > - cpu_data = __alloc_bootmem(PERCPU_PAGE_SIZE * num_possible_cpus(), > - PERCPU_PAGE_SIZE, __pa(MAX_DMA_ADDRESS)); > + cpu_data = memblock_alloc_from(PERCPU_PAGE_SIZE * num_possible_cpus(), > + PERCPU_PAGE_SIZE, > + __pa(MAX_DMA_ADDRESS)); > } > > /** > diff --git a/arch/mips/kernel/traps.c b/arch/mips/kernel/traps.c > index 576aeef..31566d5 100644 > --- a/arch/mips/kernel/traps.c > +++ b/arch/mips/kernel/traps.c > @@ -2261,7 +2261,7 @@ void __init trap_init(void) > phys_addr_t ebase_pa; > > ebase = (unsigned long) > - __alloc_bootmem(size, 1 << fls(size), 0); > + memblock_alloc_from(size, 1 << fls(size), 0); > > /* > * Try to ensure ebase resides in KSeg0 if possible. > diff --git a/arch/sparc/kernel/prom_32.c b/arch/sparc/kernel/prom_32.c > index b51cbb9..4389944 100644 > --- a/arch/sparc/kernel/prom_32.c > +++ b/arch/sparc/kernel/prom_32.c > @@ -32,7 +32,7 @@ void * __init prom_early_alloc(unsigned long size) > { > void *ret; > > - ret = __alloc_bootmem(size, SMP_CACHE_BYTES, 0UL); > + ret = memblock_alloc_from(size, SMP_CACHE_BYTES, 0UL); > if (ret != NULL) > memset(ret, 0, size); > > diff --git a/arch/sparc/kernel/smp_64.c b/arch/sparc/kernel/smp_64.c > index 83ff88d..337febd 100644 > --- a/arch/sparc/kernel/smp_64.c > +++ b/arch/sparc/kernel/smp_64.c > @@ -1588,7 +1588,7 @@ static void * __init pcpu_alloc_bootmem(unsigned int cpu, size_t size, > void *ptr; > > if (!node_online(node) || !NODE_DATA(node)) { > - ptr = __alloc_bootmem(size, align, goal); > + ptr = memblock_alloc_from(size, align, goal); > pr_info("cpu %d has no node %d or node-local memory\n", > cpu, node); > pr_debug("per cpu data for cpu%d %lu bytes at %016lx\n", > @@ -1601,7 +1601,7 @@ static void * __init pcpu_alloc_bootmem(unsigned int cpu, size_t size, > } > return ptr; > #else > - return __alloc_bootmem(size, align, goal); > + return memblock_alloc_from(size, align, goal); > #endif > } > > @@ -1627,7 +1627,7 @@ static void __init pcpu_populate_pte(unsigned long addr) > if (pgd_none(*pgd)) { > pud_t *new; > > - new = __alloc_bootmem(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > + new = memblock_alloc_from(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > pgd_populate(&init_mm, pgd, new); > } > > @@ -1635,7 +1635,7 @@ static void __init pcpu_populate_pte(unsigned long addr) > if (pud_none(*pud)) { > pmd_t *new; > > - new = __alloc_bootmem(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > + new = memblock_alloc_from(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > pud_populate(&init_mm, pud, new); > } > > @@ -1643,7 +1643,7 @@ static void __init pcpu_populate_pte(unsigned long addr) > if (!pmd_present(*pmd)) { > pte_t *new; > > - new = __alloc_bootmem(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > + new = memblock_alloc_from(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > pmd_populate_kernel(&init_mm, pmd, new); > } > } > diff --git a/arch/sparc/mm/init_32.c b/arch/sparc/mm/init_32.c > index 92634d4..885dd38 100644 > --- a/arch/sparc/mm/init_32.c > +++ b/arch/sparc/mm/init_32.c > @@ -265,7 +265,7 @@ void __init mem_init(void) > i = last_valid_pfn >> ((20 - PAGE_SHIFT) + 5); > i += 1; > sparc_valid_addr_bitmap = (unsigned long *) > - __alloc_bootmem(i << 2, SMP_CACHE_BYTES, 0UL); > + memblock_alloc_from(i << 2, SMP_CACHE_BYTES, 0UL); > > if (sparc_valid_addr_bitmap == NULL) { > prom_printf("mem_init: Cannot alloc valid_addr_bitmap.\n"); > diff --git a/arch/sparc/mm/init_64.c b/arch/sparc/mm/init_64.c > index 578ec3d..51cd583 100644 > --- a/arch/sparc/mm/init_64.c > +++ b/arch/sparc/mm/init_64.c > @@ -1810,7 +1810,8 @@ static unsigned long __ref kernel_map_range(unsigned long pstart, > if (pgd_none(*pgd)) { > pud_t *new; > > - new = __alloc_bootmem(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > + new = memblock_alloc_from(PAGE_SIZE, PAGE_SIZE, > + PAGE_SIZE); > alloc_bytes += PAGE_SIZE; > pgd_populate(&init_mm, pgd, new); > } > @@ -1822,7 +1823,8 @@ static unsigned long __ref kernel_map_range(unsigned long pstart, > vstart = kernel_map_hugepud(vstart, vend, pud); > continue; > } > - new = __alloc_bootmem(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > + new = memblock_alloc_from(PAGE_SIZE, PAGE_SIZE, > + PAGE_SIZE); > alloc_bytes += PAGE_SIZE; > pud_populate(&init_mm, pud, new); > } > @@ -1835,7 +1837,8 @@ static unsigned long __ref kernel_map_range(unsigned long pstart, > vstart = kernel_map_hugepmd(vstart, vend, pmd); > continue; > } > - new = __alloc_bootmem(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE); > + new = memblock_alloc_from(PAGE_SIZE, PAGE_SIZE, > + PAGE_SIZE); > alloc_bytes += PAGE_SIZE; > pmd_populate_kernel(&init_mm, pmd, new); > } > diff --git a/arch/sparc/mm/srmmu.c b/arch/sparc/mm/srmmu.c > index be9cb00..b48fea5 100644 > --- a/arch/sparc/mm/srmmu.c > +++ b/arch/sparc/mm/srmmu.c > @@ -303,13 +303,13 @@ static void __init srmmu_nocache_init(void) > > bitmap_bits = srmmu_nocache_size >> SRMMU_NOCACHE_BITMAP_SHIFT; > > - srmmu_nocache_pool = __alloc_bootmem(srmmu_nocache_size, > - SRMMU_NOCACHE_ALIGN_MAX, 0UL); > + srmmu_nocache_pool = memblock_alloc_from(srmmu_nocache_size, > + SRMMU_NOCACHE_ALIGN_MAX, 0UL); > memset(srmmu_nocache_pool, 0, srmmu_nocache_size); > > srmmu_nocache_bitmap = > - __alloc_bootmem(BITS_TO_LONGS(bitmap_bits) * sizeof(long), > - SMP_CACHE_BYTES, 0UL); > + memblock_alloc_from(BITS_TO_LONGS(bitmap_bits) * sizeof(long), > + SMP_CACHE_BYTES, 0UL); > bit_map_init(&srmmu_nocache_map, srmmu_nocache_bitmap, bitmap_bits); > > srmmu_swapper_pg_dir = __srmmu_get_nocache(SRMMU_PGD_TABLE_SIZE, SRMMU_PGD_TABLE_SIZE); > @@ -467,7 +467,7 @@ static void __init sparc_context_init(int numctx) > unsigned long size; > > size = numctx * sizeof(struct ctx_list); > - ctx_list_pool = __alloc_bootmem(size, SMP_CACHE_BYTES, 0UL); > + ctx_list_pool = memblock_alloc_from(size, SMP_CACHE_BYTES, 0UL); > > for (ctx = 0; ctx < numctx; ctx++) { > struct ctx_list *clist; > diff --git a/include/linux/bootmem.h b/include/linux/bootmem.h > index 3896af2..c97c105 100644 > --- a/include/linux/bootmem.h > +++ b/include/linux/bootmem.h > @@ -122,6 +122,14 @@ static inline void * __init memblock_alloc_raw( > NUMA_NO_NODE); > } > > +static inline void * __init memblock_alloc_from( > + phys_addr_t size, phys_addr_t align, phys_addr_t min_addr) > +{ > + return memblock_alloc_try_nid(size, align, min_addr, > + BOOTMEM_ALLOC_ACCESSIBLE, > + NUMA_NO_NODE); > +} > + > static inline void * __init memblock_alloc_nopanic( > phys_addr_t size, phys_addr_t align) > { > -- > 2.7.4 > -- Michal Hocko SUSE Labs