Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3119039pxk; Tue, 15 Sep 2020 10:29:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz04u4DOyv2+k/NmcbnPS7qW7BFuwpb0VhdxwnwBOyMnMIRJps9OfpooNy6G95pOzmf/46Y X-Received: by 2002:aa7:cc8d:: with SMTP id p13mr24403975edt.136.1600190967463; Tue, 15 Sep 2020 10:29:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600190967; cv=none; d=google.com; s=arc-20160816; b=ei22rRMwHCCbD+Rde67T5BRagQ4vhnyASZSfYdTIvLCzltTmQkjELJyfZchTfNdord Cu5GV3pfeIPf0EppyrPtmJ/VRCsqwPnfoepDKtcFrQlxN7yIgPDL7JNox66wDM4NmIAK HPJKAx8lk2cEKd2G3jNdV+hPRABg7UcqP1von0afN044OPa5i49aNOeZ7SUH+pjIJg1j 690SxVnpTDTq12LKYA51OAujxdb/1g+/gAG+floZ0KOsKM5JeZ0uuH5LacDtOFcSd5HB VJRJavVUv1h6IuhGAR/I3QI9oWDYq3yzX6/oDL8Lpu1sNY1KzNqrt16dLxx7Xj66ZPbu oC8g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=C1s92L4x7f4rIF6lqQWyaq+r/2kk7tSSBG+aULp1tK0=; b=U8XYqVKSfZ2ItfgUufp36b6eLXVHPH5zaQPkJCFTrbFSAGLC51XH82LJliCGRLe89d Oa84WJ1zc5BV5xwV1GEcrpHASnhWw31e5e/PwrniIglUqA/eqlVdo0/B+3d4eToFFW47 2S27nhTgp0ctyEwTbY/cGfNQ3HcCVVwDwTV5rU5jEm9bq4cdug3b082H4DL6fnhjSvxG pPF2nb/c04uawv62tUnEoDmWMlCsdkFgL2DFappRvREBh3elKlH/+ZtISxYmBwrtWizf l+CPsMGqmJ8Uh3GtPXry8rBepAY5h7kIf0wfaNWFk4ACI7fHnF8M3BsKO33WPUl+U3Tz tT6w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=MjyrTGfI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q24si8429842edi.78.2020.09.15.10.29.05; Tue, 15 Sep 2020 10:29:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=MjyrTGfI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727899AbgIOR1m (ORCPT + 99 others); Tue, 15 Sep 2020 13:27:42 -0400 Received: from hqnvemgate26.nvidia.com ([216.228.121.65]:15003 "EHLO hqnvemgate26.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727758AbgIOQkD (ORCPT ); Tue, 15 Sep 2020 12:40:03 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate26.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Tue, 15 Sep 2020 09:39:35 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Tue, 15 Sep 2020 09:39:48 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Tue, 15 Sep 2020 09:39:48 -0700 Received: from rcampbell-dev.nvidia.com (172.20.13.39) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Tue, 15 Sep 2020 16:39:47 +0000 Subject: Re: [PATCH] mm: remove extra ZONE_DEVICE struct page refcount To: Christoph Hellwig CC: Dan Williams , Linux MM , , , "Linux Kernel Mailing List" , Ira Weiny , Matthew Wilcox , Jerome Glisse , John Hubbard , Alistair Popple , Christoph Hellwig , Jason Gunthorpe , Bharata B Rao , Zi Yan , "Kirill A . Shutemov" , Yang Shi , Paul Mackerras , Ben Skeggs , Andrew Morton References: <20200914224509.17699-1-rcampbell@nvidia.com> <10b4b85c-f1e9-b6b5-74cd-6190ee0aca5d@nvidia.com> <20200915162956.GA21990@infradead.org> X-Nvconfidentiality: public From: Ralph Campbell Message-ID: <6dff5231-26d5-1aec-0c05-6880cf747642@nvidia.com> Date: Tue, 15 Sep 2020 09:39:47 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.2 MIME-Version: 1.0 In-Reply-To: <20200915162956.GA21990@infradead.org> X-Originating-IP: [172.20.13.39] X-ClientProxiedBy: HQMAIL107.nvidia.com (172.20.187.13) To HQMAIL107.nvidia.com (172.20.187.13) Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1600187975; bh=C1s92L4x7f4rIF6lqQWyaq+r/2kk7tSSBG+aULp1tK0=; h=X-PGP-Universal:Subject:To:CC:References:X-Nvconfidentiality:From: Message-ID:Date:User-Agent:MIME-Version:In-Reply-To: X-Originating-IP:X-ClientProxiedBy:Content-Type:Content-Language: Content-Transfer-Encoding; b=MjyrTGfIene7vVu5hucCl8X7jJJtGy4gEfp8s9S8BvUOqlyhVR/Jr/cF4kdzJc0Sy LCNccr/EB6s9AbvrN0g1vzjM0eTf5Ecb0AFIePVFELVPA01dU+slLbzDLM67GL26Ek hRD/99TeqMFmNTw8ILvsCZqgAHPunVc0BJXMZXgbWMvQ3LinUrL1J2/FZJuuGPurhp l2c3JDfB5skX8McyhBI3hpbKwAXU/D1yYeLTxWXKEYDXLR2Cc+bMRYvFmtgboy2agT 8cLHw3JEIT9+4E0SQHnvIvwomdfJGbjdgwupYbPF07ykO5rH/LOpLA8eYXXUPqITk7 Je7vqmrwPefZQ== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 9/15/20 9:29 AM, Christoph Hellwig wrote: > On Mon, Sep 14, 2020 at 04:53:25PM -0700, Ralph Campbell wrote: >> Since set_page_refcounted() is defined in mm_interal.h I would have to >> move the definition to someplace like page_ref.h or have the drivers >> cal init_page_count() or set_page_count() since get_page() calls >> VM_BUG_ON_PAGE() if refcount == 0. >> I'll move set_page_refcounted() since that is what the page allocator >> uses and seems named for the purpose. > > I don't think any of the three ->page_free instances even cares about > the page refcount. > Not true. The page_free() callback records the page is free by setting a bit or putting the page on a free list but when it allocates a free device private struct page to be used with migrate_vma_setup(), it needs to increment the refcount. For the ZONE_DEVICE MEMORY_DEVICE_GENERIC and MEMORY_DEVICE_PCI_P2PDMA struct pages, I think you are correct because they don't define page_free() and from what I can see, don't decrement the page refcount to zero.