Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp7228602imm; Wed, 27 Jun 2018 23:30:41 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdyjO5q1iXo//ksdG42s16vbapMp/WgXlf/iq/2WYV+Mcs6pRUtuZyEHeHoKF2qPCzwJhyt X-Received: by 2002:a63:9702:: with SMTP id n2-v6mr4653798pge.88.1530167441243; Wed, 27 Jun 2018 23:30:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530167441; cv=none; d=google.com; s=arc-20160816; b=0paSD5l58XNLQTLztsKmhCRV0XgMWOifilHe7Bw8wtPUTfvQ9ayouU0m7TgtNsB9xh cUPtpnbRKAzuVbZGoFkNigcrFiecDlaWbIS82M5FIbcehcKZQT5kMHoJAtCLWIQbA0bz L8c2L1MVgf4CQ0z7/sY8jO8IZJBIXNJcwaU9KG0IpR9lHqTAd17yT2nUC5oJTcR5PPdz 3IwABqIO6J3Zr/9IIv3S6K2tDf4gN5KCP8NXah0+TdMAwevUPuTxGpAsvRvqpiCYJ+uf pqJ6OwAQ1Kk3AePKvtHkbs6pQGnCN59P/fDGByzMewfXaWGpjhmUJdMKoO0GTjuAFsvL SMqw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=0wgH1vdCIr1xYdl6AvWHVC7w60xQ7DVrqM88bcHH/eo=; b=A7LGYUHMFxNLz4aT5j9TBbE/QvVj0EiXrk3QTG88bZtn8BZmtoCiWLiWKMl5Hj3Gee glMJCQBCCuOp/Qcb4M5fMmKUE24694Zww2S+HWJiDIPt4xaQl4a1waoxnJgue5me0MGz t96ZRgZBZ52tz6c+ouIIEa0/H6THCTMwRbNLlWAffcs4yJNEcp3su9SszkH/+Kc4zf/D 5R+xwyrGNDpaEM7jypZUwiS2H/TnBxc6yVgy0+sehUXt4NwBBZ2o5tJuC/uuw1R+7J2g i71wJ3cxqDfW7DaLKtbOOhVds+75+OGVm0F7jAt/NiemSXtsq9rHMMjAvkPfJQxIG0v4 0EKw== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o5-v6si5318792pgs.303.2018.06.27.23.30.27; Wed, 27 Jun 2018 23:30:41 -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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933346AbeF1G3X (ORCPT + 99 others); Thu, 28 Jun 2018 02:29:23 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:35816 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S932350AbeF1G3V (ORCPT ); Thu, 28 Jun 2018 02:29:21 -0400 Received: from smtp.corp.redhat.com (int-mx06.intmail.prod.int.rdu2.redhat.com [10.11.54.6]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id B5509A5002; Thu, 28 Jun 2018 06:29:20 +0000 (UTC) Received: from MiWiFi-R3L-srv.redhat.com (ovpn-8-16.pek2.redhat.com [10.72.8.16]) by smtp.corp.redhat.com (Postfix) with ESMTP id 40A412156880; Thu, 28 Jun 2018 06:29:15 +0000 (UTC) From: Baoquan He To: linux-kernel@vger.kernel.org, akpm@linux-foundation.org, dave.hansen@intel.com, pagupta@redhat.com, Pavel Tatashin , Oscar Salvador Cc: linux-mm@kvack.org, kirill.shutemov@linux.intel.com, Baoquan He Subject: [PATCH v6 3/5] mm/sparse: Add a new parameter 'data_unit_size' for alloc_usemap_and_memmap Date: Thu, 28 Jun 2018 14:28:55 +0800 Message-Id: <20180628062857.29658-4-bhe@redhat.com> In-Reply-To: <20180628062857.29658-1-bhe@redhat.com> References: <20180628062857.29658-1-bhe@redhat.com> X-Scanned-By: MIMEDefang 2.78 on 10.11.54.6 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.2]); Thu, 28 Jun 2018 06:29:20 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.2]); Thu, 28 Jun 2018 06:29:20 +0000 (UTC) for IP:'10.11.54.6' DOMAIN:'int-mx06.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'bhe@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org alloc_usemap_and_memmap() is passing in a "void *" that points to usemap_map or memmap_map. In next patch we will change both of the map allocation from taking 'NR_MEM_SECTIONS' as the length to taking 'nr_present_sections' as the length. After that, the passed in 'void*' needs to update as things get consumed. But, it knows only the quantity of objects consumed and not the type. This effectively tells it enough about the type to let it update the pointer as objects are consumed. Signed-off-by: Baoquan He Reviewed-by: Pavel Tatashin --- mm/sparse.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/mm/sparse.c b/mm/sparse.c index 6a706093307d..4458a23e5293 100644 --- a/mm/sparse.c +++ b/mm/sparse.c @@ -486,10 +486,12 @@ void __weak __meminit vmemmap_populate_print_last(void) /** * alloc_usemap_and_memmap - memory alloction for pageblock flags and vmemmap * @map: usemap_map for pageblock flags or mmap_map for vmemmap + * @unit_size: size of map unit */ static void __init alloc_usemap_and_memmap(void (*alloc_func) (void *, unsigned long, unsigned long, - unsigned long, int), void *data) + unsigned long, int), void *data, + int data_unit_size) { unsigned long pnum; unsigned long map_count; @@ -566,7 +568,8 @@ void __init sparse_init(void) if (!usemap_map) panic("can not allocate usemap_map\n"); alloc_usemap_and_memmap(sparse_early_usemaps_alloc_node, - (void *)usemap_map); + (void *)usemap_map, + sizeof(usemap_map[0])); #ifdef CONFIG_SPARSEMEM_ALLOC_MEM_MAP_TOGETHER size2 = sizeof(struct page *) * NR_MEM_SECTIONS; @@ -574,7 +577,8 @@ void __init sparse_init(void) if (!map_map) panic("can not allocate map_map\n"); alloc_usemap_and_memmap(sparse_early_mem_maps_alloc_node, - (void *)map_map); + (void *)map_map, + sizeof(map_map[0])); #endif for_each_present_section_nr(0, pnum) { -- 2.13.6