Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1290425pxb; Wed, 10 Feb 2021 05:10:01 -0800 (PST) X-Google-Smtp-Source: ABdhPJyATmLD19EaxDHmuOmiZfcuVsbtWGDJh5vMbfFvbidZIiU9WHHWu2mIx10TsPfR2BW86ywM X-Received: by 2002:a17:906:8292:: with SMTP id h18mr2885237ejx.342.1612962601522; Wed, 10 Feb 2021 05:10:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612962601; cv=none; d=google.com; s=arc-20160816; b=NiAeFrk5qLxM4rh6YgDCZKK4F5s4y5pbVSUJSUI7JjeNQHVVxuzoB26XKsiNgGiBb9 pZD8jbZgyHL+kLiP4VK6LaXzTWNczrZz41FiQiuZjlBYKzwny8OiYclgs70cHOIHrskD A+I97g3POEsxDTXfAk8jqBZCmRLdhxJ01ynNTpqZ/f9a1wEU0nB7Tip9Jpfs18CWbk0f gYYUfm8Sf/XqcDM933Pk3gxMvBju0AmHQn0IDSjX/vU9+3CV29REZjd4rBobIyecErB/ GLPHuYWw4uyENpQc6ChqCy2s4zvDF15Krn2CpHZsm0+3sLcBvWjrZUrXBSfq7faYG0t1 U4qQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:mail-followup-to :message-id:subject:cc:to:from:date:dkim-signature; bh=vWjBWvQGye13+7MEOsW3WY2wA0+N3oWZdpjvZSe2p7s=; b=QU1AOqh7JfwqfDSl9CTLhu0cuuWCKvELPFYmqd5Rxp/wpX/N4cVdYmH8TLGu4ucWEs 3xa1sW8kDocpnGuI+aI7yBPAysHffm4GeWgiHpRo6dOW9fhSZgALY9oxJFp8LQzILNkt RBtX3xAK+8Vu/+BDa6U6EN/pOytDbrBNOQSj8FdIafEhQ5L1PfRTYH4Y8aHuG0XBTeCV E3IHW9S50xFXRORD7fVdctJJs86aMn+kS3epV5TgILsdZG6EDvp9vQXmxoeotSpwU3PK SEyjCxHIPbBEI14B9DLhTr3YllBQaznol3tBKocap67pUECF8lOGSNyYbFn0f/X6T7TK BZpg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ffwll.ch header.s=google header.b=UX+PcbmG; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f8si1339909edw.351.2021.02.10.05.09.37; Wed, 10 Feb 2021 05:10:01 -0800 (PST) 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=@ffwll.ch header.s=google header.b=UX+PcbmG; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229853AbhBJNIl (ORCPT + 99 others); Wed, 10 Feb 2021 08:08:41 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52104 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231451AbhBJNHb (ORCPT ); Wed, 10 Feb 2021 08:07:31 -0500 Received: from mail-wm1-x332.google.com (mail-wm1-x332.google.com [IPv6:2a00:1450:4864:20::332]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4DB70C0613D6 for ; Wed, 10 Feb 2021 05:06:50 -0800 (PST) Received: by mail-wm1-x332.google.com with SMTP id j21so1801682wmj.0 for ; Wed, 10 Feb 2021 05:06:50 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=date:from:to:cc:subject:message-id:mail-followup-to:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to; bh=vWjBWvQGye13+7MEOsW3WY2wA0+N3oWZdpjvZSe2p7s=; b=UX+PcbmGXshC1SgIRJQjOu9U2SVaDM3DTuqb/lPCGbOnrC8AugwDoo1YFbbNb7oKvO SeR6Ed5M7bWiJfZnpidco12k1pU6EyW+bg8VMX3IvUezzmTCfI5dZBra4ArywFO4e3TM YFK26V3E7LwMWIg1+bm9MzIXUfzZIbdEmZNAM= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :content-transfer-encoding:in-reply-to; bh=vWjBWvQGye13+7MEOsW3WY2wA0+N3oWZdpjvZSe2p7s=; b=YvBZ7WWZUxHRpH8E+E9MU4yr2+XDh8MGHbDc3uCidxFk2QzmnL+T/qtdJDFq2VmM8P jNAERPrT+rphdSoXE/XxVA8ZPULMp/pGlzpbOsP/dnVEboJtxiqdtevEkBZqrd0A+vEd 4fQapZT21Aa1n9sefvtPxlwTdHdXOLOGnCsviUswi3JJRSAQ+AkQjkQZZdoyQ08F1O83 ZlFyan8HUXGyhTbnm+09DS0fnA02ywI3lkuJ2cpEumTPxFnIRyVBnY4G2whEe46AlCcF HTmH1yXJb/59n2r3DR99L342+G3EUveIgd/PXb56aVVwClI7QkTbpqAqNnMcaiNLjkBl b8Xw== X-Gm-Message-State: AOAM533T7toBhoWYCgtfYEOFzisR4710/NOK8yHFEAZUxa4axEVXjZ/Z yKZzYWrqiF1aSekr8+vemceSCg== X-Received: by 2002:a1c:cc14:: with SMTP id h20mr2889601wmb.14.1612962408981; Wed, 10 Feb 2021 05:06:48 -0800 (PST) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id r16sm2680646wrt.68.2021.02.10.05.06.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 10 Feb 2021 05:06:47 -0800 (PST) Date: Wed, 10 Feb 2021 14:06:45 +0100 From: Daniel Vetter To: Suren Baghdasaryan Cc: Daniel Vetter , Christian =?iso-8859-1?Q?K=F6nig?= , John Stultz , lkml , Sumit Semwal , Liam Mark , Chris Goldsworthy , Laura Abbott , Brian Starkey , Hridya Valsaraju , Sandeep Patil , Daniel Mentz , =?iso-8859-1?Q?=D8rjan?= Eide , Robin Murphy , Ezequiel Garcia , Simon Ser , James Jones , linux-media , dri-devel Subject: Re: [RFC][PATCH v6 1/7] drm: Add a sharable drm page-pool implementation Message-ID: Mail-Followup-To: Suren Baghdasaryan , Christian =?iso-8859-1?Q?K=F6nig?= , John Stultz , lkml , Sumit Semwal , Liam Mark , Chris Goldsworthy , Laura Abbott , Brian Starkey , Hridya Valsaraju , Sandeep Patil , Daniel Mentz , =?iso-8859-1?Q?=D8rjan?= Eide , Robin Murphy , Ezequiel Garcia , Simon Ser , James Jones , linux-media , dri-devel References: <20210205080621.3102035-1-john.stultz@linaro.org> <20210205080621.3102035-2-john.stultz@linaro.org> <4471b3b0-603e-6dbb-8064-ff4a95afbba9@amd.com> <48225879-2fe1-22ac-daae-c61d52465aea@amd.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Operating-System: Linux phenom 5.7.0-1-amd64 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Feb 09, 2021 at 12:16:51PM -0800, Suren Baghdasaryan wrote: > On Tue, Feb 9, 2021 at 12:03 PM Daniel Vetter wrote: > > > > On Tue, Feb 9, 2021 at 6:46 PM Christian K?nig wrote: > > > > > > > > > > > > Am 09.02.21 um 18:33 schrieb Suren Baghdasaryan: > > > > On Tue, Feb 9, 2021 at 4:57 AM Christian K?nig wrote: > > > >> Am 09.02.21 um 13:11 schrieb Christian K?nig: > > > >>> [SNIP] > > > >>>>>> +void drm_page_pool_add(struct drm_page_pool *pool, struct page *page) > > > >>>>>> +{ > > > >>>>>> + spin_lock(&pool->lock); > > > >>>>>> + list_add_tail(&page->lru, &pool->items); > > > >>>>>> + pool->count++; > > > >>>>>> + atomic_long_add(1 << pool->order, &total_pages); > > > >>>>>> + spin_unlock(&pool->lock); > > > >>>>>> + > > > >>>>>> + mod_node_page_state(page_pgdat(page), > > > >>>>>> NR_KERNEL_MISC_RECLAIMABLE, > > > >>>>>> + 1 << pool->order); > > > >>>>> Hui what? What should that be good for? > > > >>>> This is a carryover from the ION page pool implementation: > > > >>>> https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgit.kernel.org%2Fpub%2Fscm%2Flinux%2Fkernel%2Fgit%2Ftorvalds%2Flinux.git%2Ftree%2Fdrivers%2Fstaging%2Fandroid%2Fion%2Fion_page_pool.c%3Fh%3Dv5.10%23n28&data=04%7C01%7Cchristian.koenig%40amd.com%7Cdccccff8edcd4d147a5b08d8cd20cff2%7C3dd8961fe4884e608e11a82d994e183d%7C0%7C0%7C637484888114923580%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=9%2BIBC0tezSV6Ci4S3kWfW%2BQvJm4mdunn3dF6C0kyfCw%3D&reserved=0 > > > >>>> > > > >>>> > > > >>>> My sense is it helps with the vmstat/meminfo accounting so folks can > > > >>>> see the cached pages are shrinkable/freeable. This maybe falls under > > > >>>> other dmabuf accounting/stats discussions, so I'm happy to remove it > > > >>>> for now, or let the drivers using the shared page pool logic handle > > > >>>> the accounting themselves? > > > >> Intentionally separated the discussion for that here. > > > >> > > > >> As far as I can see this is just bluntly incorrect. > > > >> > > > >> Either the page is reclaimable or it is part of our pool and freeable > > > >> through the shrinker, but never ever both. > > > > IIRC the original motivation for counting ION pooled pages as > > > > reclaimable was to include them into /proc/meminfo's MemAvailable > > > > calculations. NR_KERNEL_MISC_RECLAIMABLE defined as "reclaimable > > > > non-slab kernel pages" seems like a good place to account for them but > > > > I might be wrong. > > > > > > Yeah, that's what I see here as well. But exactly that is utterly nonsense. > > > > > > Those pages are not "free" in the sense that get_free_page could return > > > them directly. > > > > Well on Android that is kinda true, because Android has it's > > oom-killer (way back it was just a shrinker callback, not sure how it > > works now), which just shot down all the background apps. So at least > > some of that (everything used by background apps) is indeed > > reclaimable on Android. > > > > But that doesn't hold on Linux in general, so we can't really do this > > for common code. > > > > Also I had a long meeting with Suren, John and other googles > > yesterday, and the aim is now to try and support all the Android gpu > > memory accounting needs with cgroups. That should work, and it will > > allow Android to handle all the Android-ism in a clean way in upstream > > code. Or that's at least the plan. > > > > I think the only thing we identified that Android still needs on top > > is the dma-buf sysfs stuff, so that shared buffers (which on Android > > are always dma-buf, and always stay around as dma-buf fd throughout > > their lifetime) can be listed/analyzed with full detail. > > > > But aside from this the plan for all the per-process or per-heap > > account, oom-killer integration and everything else is planned to be > > done with cgroups. > > Until cgroups are ready we probably will need to add a sysfs node to > report the total dmabuf pool size and I think that would cover our > current accounting need here. > As I mentioned, not including dmabuf pools into MemAvailable would > affect that stat and I'm wondering if pools should be considered as > part of MemAvailable or not. Since MemAvailable includes SReclaimable > I think it makes sense to include them but maybe there are other > considerations that I'm missing? On Android, yes, on upstream, not so much. Because upstream doesn't have the android low memory killer cleanup up all the apps, so effectively we can't reclaim that memory, and we shouldn't report it as such. -Daniel > > > Android (for now) only needs to account overall gpu > > memory since none of it is swappable on android drivers anyway, plus > > no vram, so not much needed. > > > > Cheers, Daniel > > > > > > > > Regards, > > > Christian. > > > > > > > > > > >> In the best case this just messes up the accounting, in the worst case > > > >> it can cause memory corruption. > > > >> > > > >> Christian. > > > > > > > > > -- > > Daniel Vetter > > Software Engineer, Intel Corporation > > http://blog.ffwll.ch -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch