Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp260095imm; Thu, 6 Sep 2018 01:54:03 -0700 (PDT) X-Google-Smtp-Source: ANB0VdaOHguqFmol4y6P7f+neWLHOZ7Ne+7KNKxY085trRHIu8sOBpNmKtzUXKETEgUXNCL4kxhx X-Received: by 2002:a17:902:26c:: with SMTP id 99-v6mr1627124plc.341.1536224043721; Thu, 06 Sep 2018 01:54:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536224043; cv=none; d=google.com; s=arc-20160816; b=SELLFhCejr+7x/jWUM6rN5VfAFICzFaZYlw0nz1HUieLaVV4pncjBvTWOFdZp9yBQG kO2AyYH5Re89DhQS8rjWnBmy/uk+dDoSticq6WPFRcwrGedCW34RdIw9HJ6Tkm1V6pul dldCr+qUngueCb1JI90eYrx+vpDk/0GyvEPqG4IWINSdrCAeYTulq8F3g8TpgbG2wCM7 AAs2mic9wvSFJW6vHpZT7aOX2qodT5N9cU+5+GiwEU7Ds0B684KFK8wRlFYUbHkaosPH GRKAYsATNPzUHbBjgayzDFp9PDaGFWp89NpfCaFym9j6iQEBAHIx0CwEUy6qXJUTzI6M KUqQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=/cdv9IS6ER3xsGub8SlE8MmpNVgMl/C2T/W4nRKJYWU=; b=vd5yM/TgCJS1sYPqH6p8q5EDZn8wjHEOOrkrv05zW3UPimUEbTsQA/nHqiSQsr71F+ +a0qtYe6LV9Wm9YkK9blgTMYUhw2pkwtiR7Hz1Minxt26XVZicbdzKlIR3NjnPMXuYaM 42dlCYGX+rob0bLLNMhR31Sm0pEoPAnixKgWOq9FEdK43uSvm0Kf/dCX1V3L+5Lg77qZ 2SWhwpDsNSkJ36U60ikPGaiaQ2ykUJoy3XagGocTj0kFWAoVGN1DSLjqZVOcPtuq9bHL lZKVusK9cl6hEGJ/uiX7EF/8+IlQxlA9zEbqFkFfXaNcXpm9r55pPbCAcKB+bTe+SV2b TyIg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 94-v6si4711417plb.59.2018.09.06.01.53.47; Thu, 06 Sep 2018 01:54:03 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727962AbeIFN0j (ORCPT + 99 others); Thu, 6 Sep 2018 09:26:39 -0400 Received: from mx2.suse.de ([195.135.220.15]:41448 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725894AbeIFN0j (ORCPT ); Thu, 6 Sep 2018 09:26:39 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id BB666AF60; Thu, 6 Sep 2018 08:52:06 +0000 (UTC) Date: Thu, 6 Sep 2018 10:52:05 +0200 From: Michal Hocko To: Mike Rapoport Cc: linux-mm@kvack.org, Andrew Morton , "David S. Miller" , Greg Kroah-Hartman , Ingo Molnar , Michael Ellerman , Paul Burton , Thomas Gleixner , Tony Luck , linux-ia64@vger.kernel.org, linux-mips@linux-mips.org, linuxppc-dev@lists.ozlabs.org, sparclinux@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [RFC PATCH 20/29] memblock: replace __alloc_bootmem with memblock_alloc_from Message-ID: <20180906085205.GE14951@dhcp22.suse.cz> References: <1536163184-26356-1-git-send-email-rppt@linux.vnet.ibm.com> <1536163184-26356-21-git-send-email-rppt@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1536163184-26356-21-git-send-email-rppt@linux.vnet.ibm.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 > --- > 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