Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp769415imm; Wed, 17 Oct 2018 08:04:34 -0700 (PDT) X-Google-Smtp-Source: ACcGV62ctNPnmCYmTzbmOASoZa0RRAs2Pp9VTO/kG4N9whymXtnUW/GZIKYp/Lk+bAnBstyDdLKm X-Received: by 2002:a62:55c3:: with SMTP id j186-v6mr17649842pfb.161.1539788674191; Wed, 17 Oct 2018 08:04:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539788674; cv=none; d=google.com; s=arc-20160816; b=yMd4Em3zTT/I1gdvMSlrF31RMB8Rwo+PJJumgOzrxaLnPva/RRoooLXkq2EyneTQgB f0OE8FeJ828XqqDluQbQjGqWFPbg4ou20s3FJthP1mtYbZSW+1OZMffLNGWbJXU6lEwM VXwcLC9h3x/Sc8stoo21Wdp+PKWJvk+J30wTWte5mGugCrKsLuCYr/mqSpw7KZxjzspI zmG0a1HVJMZpphB4xml6RGz8RKGjqHOk2/xxCo1GeJhJoEffzME1AYVdYPJzVbB3ze5R xqCLOYpHzfAv4nCVgUtcpjdg+zvclN5mv/lpSKgAfKea3nHoKAbAljnMJpkYP0LchsSF tfGA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=8uLR5QJI7gHeb25z2LF8S6pdtJK4I7iviC5MtrkGX/I=; b=gZ9jnU+l5uMAx/2Rr63W6mJfGKBhvJNCwtjUd0kLkjudC2gJVfdEMRBRZZYlyNolf7 hMt908FAIyhNun0vdcU6ghHLx3lZPiU84at70Jh1P/IeAz3ZofKSc72+z5OC8D1p+jhw K7nDvAsiPQrk1UZN3z3rFHf00/9xqUBe4kKuP7dBPHn9sHq24TPBqpr4Y0Sj9nj3q6us MUC1ezvpyq9KvzX2SuOL2RRLImOLGMDhZiwa+biyR7eZtYmBWbgu8acWezwc+gTU4nM3 fNfklan3TEpIz112nlCK/QO6efUi575Bi5YCBvE/TX+kIBWuEnLaeRj7XeL44xoFRP8V B6Ng== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i84-v6si18848023pfi.17.2018.10.17.08.04.17; Wed, 17 Oct 2018 08:04:34 -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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727761AbeJQW61 (ORCPT + 99 others); Wed, 17 Oct 2018 18:58:27 -0400 Received: from mga12.intel.com ([192.55.52.136]:11480 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727016AbeJQW60 (ORCPT ); Wed, 17 Oct 2018 18:58:26 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga106.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 17 Oct 2018 08:02:20 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.54,392,1534834800"; d="scan'208";a="83359835" Received: from ahduyck-mobl.amr.corp.intel.com (HELO [10.7.198.154]) ([10.7.198.154]) by orsmga006.jf.intel.com with ESMTP; 17 Oct 2018 08:02:20 -0700 Subject: Re: [PATCH v5 4/4] mm: Defer ZONE_DEVICE page initialization to the point where we init pgmap To: Michal Hocko Cc: Dan Williams , Linux MM , Andrew Morton , Linux Kernel Mailing List , linux-nvdimm , Pasha Tatashin , Dave Hansen , =?UTF-8?B?SsOpcsO0bWUgR2xpc3Nl?= , rppt@linux.vnet.ibm.com, Ingo Molnar , "Kirill A. Shutemov" , yi.z.zhang@linux.intel.com References: <20181009170051.GA40606@tiger-server> <25092df0-b7b4-d456-8409-9c004cb6e422@linux.intel.com> <20181010095838.GG5873@dhcp22.suse.cz> <20181010172451.GK5873@dhcp22.suse.cz> <98c35e19-13b9-0913-87d9-b3f1ab738b61@linux.intel.com> <20181010185242.GP5873@dhcp22.suse.cz> <20181011085509.GS5873@dhcp22.suse.cz> <6f32f23c-c21c-9d42-7dda-a1d18613cd3c@linux.intel.com> <20181017075257.GF18839@dhcp22.suse.cz> From: Alexander Duyck Message-ID: <971729e6-bcfe-a386-361b-d662951e69a7@linux.intel.com> Date: Wed, 17 Oct 2018 08:02:20 -0700 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <20181017075257.GF18839@dhcp22.suse.cz> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/17/2018 12:52 AM, Michal Hocko wrote: > On Thu 11-10-18 10:38:39, Alexander Duyck wrote: >> On 10/11/2018 1:55 AM, Michal Hocko wrote: >>> On Wed 10-10-18 20:52:42, Michal Hocko wrote: >>> [...] >>>> My recollection was that we do clear the reserved bit in >>>> move_pfn_range_to_zone and we indeed do in __init_single_page. But then >>>> we set the bit back right afterwards. This seems to be the case since >>>> d0dc12e86b319 which reorganized the code. I have to study this some more >>>> obviously. >>> >>> so my recollection was wrong and d0dc12e86b319 hasn't really changed >>> much because __init_single_page wouldn't zero out the struct page for >>> the hotplug contex. A comment in move_pfn_range_to_zone explains that we >>> want the reserved bit because pfn walkers already do see the pfn range >>> and the page is not fully associated with the zone until it is onlined. >>> >>> I am thinking that we might be overzealous here. With the full state >>> initialized we shouldn't actually care. pfn_to_online_page should return >>> NULL regardless of the reserved bit and normal pfn walkers shouldn't >>> touch pages they do not recognize and a plain page with ref. count 1 >>> doesn't tell much to anybody. So I _suspect_ that we can simply drop the >>> reserved bit setting here. >> >> So this has me a bit hesitant to want to just drop the bit entirely. If >> nothing else I think I may wan to make that a patch onto itself so that if >> we aren't going to set it we just drop it there. That way if it does cause >> issues we can bisect it to that patch and pinpoint the cause. > > Yes a patch on its own make sense for bisectability. For now I think I am going to back off of this. There is a bunch of other changes that need to happen in order for us to make this work. As far as I can tell there are several places that are relying on this reserved bit. >>> Regarding the post initialization required by devm_memremap_pages and >>> potentially others. Can we update the altmap which is already a way how >>> to get alternative struct pages by a constructor which we could call >>> from memmap_init_zone and do the post initialization? This would reduce >>> the additional loop in the caller while it would still fit the overall >>> design of the altmap and the core hotplug doesn't have to know anything >>> about DAX or whatever needs a special treatment. >>> >>> Does that make any sense? >> >> I think the only thing that is currently using the altmap is the ZONE_DEVICE >> memory init. Specifically I think it is only really used by the >> devm_memremap_pages version of things, and then only under certain >> circumstances. Also the HMM driver doesn't pass an altmap. What we would >> really need is a non-ZONE_DEVICE users of the altmap to really justify >> sticking with that as the preferred argument to pass. > > I am not aware of any upstream HMM user so I am not sure what are the > expectations there. But I thought that ZONE_DEVICE users use altmap. If > that is not generally true then we certainly have to think about a > better interface. I'm just basing my statement on the use of the move_pfn_range_to_zone call. The only caller that is actually passing the altmap is devm_memremap_pages and if I understand things correctly that is only used when we want to stare the vmmemmap on the same memory that we just hotplugged. That is why it made more sense to me to just create a ZONE_DEVICE specific function for handling the page initialization because the one value I do have to pass is the dev_pagemap in both HMM and memremap case, and that has the altmap already embedded inside of it. >> For those two functions it currently makes much more sense to pass the >> dev_pagemap pointer and then reference the altmap from there. Otherwise we >> are likely starting to look at something that would be more of a dirty hack >> where we are passing a unused altmap in order to get to the dev_pagemap so >> that we could populate the page. > > If dev_pagemap is a general abstraction then I agree. Well so far HMM and the memremap code have both agreed to use that structure to store the metadata for ZONE_DEVICE mappings, and at this point we are already looking at 3 different memory types being stored within that zone as we already have the private, public, and DAX memory types all using this structure.