Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1126271pxb; Wed, 10 Feb 2021 00:11:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJyVzvwigPGr0sFgK208a2ThTek+7d7c51aPUUrT/WEnPPPFOcCNdQWCERNmjK+7n0wEUVRe X-Received: by 2002:a17:906:c04f:: with SMTP id bm15mr1836323ejb.364.1612944710570; Wed, 10 Feb 2021 00:11:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612944710; cv=none; d=google.com; s=arc-20160816; b=oSzPWdSg6gtffq2GRqHO2z+/GrUTKXOqpvkqm8fQI3zpb07jF2sb4k09o42bb2ESFh wjqudYpoSVG/i3a9jAXhQlv+11bZhLOAlk39gJ7Xrx0zOaqu3aqXADZ4Mo2ieF1+oI6m oti9rTuTjTaWXQ+NJ5+f2ZIlunxF8XruF42hw0fG0qmVBDvQ8mand6mOXgKQM3b/VRTb 40vupQrsvDdvbFsXKqVzsK9WufBc9I8ynqqpmoERvG9896vpasAl/FMyqTtaEx/7T3BT eL9nZJeahUDRdpAGd8aFdbH17UMHS/V6itLv5iSrX4hMKXQd8Jb6Fv+KkMxg2i1PbkjK /f+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=WSIKXYPYAgR9bcpSSCcdKf1jjEFLRGvSegQRcPSmIHk=; b=LZns3mHl3DFHUcvSd7vmPT0z0dCIlThJVEcDSb+RQf31pvhIQA8MhPIW2UOXIUiaz2 77bDcr6ukEl29KbLSFq8uMdQpI/7W/U/88Y9NZHV40QTpFA5xOh3LWqmZDXF19KeXLPz 9U/EDpPq/O/6BVbEsZ+uL0qiu1IZpcaxBsYdsnaeKjOOC/kHdJIjASvM3mAGChjeVCts eoPaSwYfHYfbmGW1PNBF0SEdABn4V3VKAmLAnHi2soWCEG/1mupcHXutRScIxvTJX80X c8JyRwTPRb2CWaJwYz/KpNh9VNA6j8ezZMEeg6FXaEiALR02SuYNbHw1h0W/3mFBq8sc fFKg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=TpWVcq0c; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a7si873778ejj.40.2021.02.10.00.11.26; Wed, 10 Feb 2021 00:11:50 -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=@google.com header.s=20161025 header.b=TpWVcq0c; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234209AbhBIXoh (ORCPT + 99 others); Tue, 9 Feb 2021 18:44:37 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35468 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233681AbhBIUd6 (ORCPT ); Tue, 9 Feb 2021 15:33:58 -0500 Received: from mail-wr1-x434.google.com (mail-wr1-x434.google.com [IPv6:2a00:1450:4864:20::434]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B24E9C0698C7 for ; Tue, 9 Feb 2021 12:17:04 -0800 (PST) Received: by mail-wr1-x434.google.com with SMTP id u14so23652919wri.3 for ; Tue, 09 Feb 2021 12:17:04 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=WSIKXYPYAgR9bcpSSCcdKf1jjEFLRGvSegQRcPSmIHk=; b=TpWVcq0cAHCjTMjUTaZgT1rftmkIZpeK/w+9IeAIZ71VrVi/eZqrSZAKHw0g3FpFjZ vhhP4TAJeK4H72vQJngmfiTh0QNKw33RQeOcNqTM7j5L8ANMd4FulgcZOwFpskNLdrVU W9NVwjLqcAiuIBfGCLYmtGwfUcEJ/2I3/aee3J9ypcoxx/5mZt/jkfvhc2ha7tjrVqYH MC0Zy1pZHBqFVPyjuy2i2cnC5JiZpUdgR/LjCwm2P8BOLgPrsEwxo1rPvdrC50ruK7KS IXaNhLs1QuEUHfVAvV0NJN3y7pc8mYTciKnRuF5CVUP2f1ct6tEu1sGbxt4iE8o/kgfq 5wMQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=WSIKXYPYAgR9bcpSSCcdKf1jjEFLRGvSegQRcPSmIHk=; b=BV/lZtl/shaGWdBuRKhOfrt1tkMLmf7OBI0lR4CGCS+DzDfQpK6xAg4fWUIcmSdBwS h+Iesy5IyXDfTFxhRR9venxf1Mp7V4pnwkCG3or6qhiqF1ghP9tSYTSCNyDEJcBEAvDi C0XG/2uaS+NpyomtjcgsRGb21IJduN3n9tDIhkstSLaUGfZCYM/gqy0mObQhqlqdeNJ1 M9ZOvRMNJmKqvrZUK//YUrePXE2ZnlcBnw/bQefh1FY2GRxUyjCtWXs4IHshQRxbl9QS dA45wP5DCk/iLXXKexz0w/VQdoaCDsDbJqXXl25l3wEZDxsHzBqrU3fceveBwFs6JGlE 5XSA== X-Gm-Message-State: AOAM533d77rV20f/0jA1Vn948c199Q/7t9tkK/S1jOZ27VoW2xK4bjxs XI4H/0W4GmnR35Vdy3Zc+5pKsQ8hYWmJ90GLSuSu5A== X-Received: by 2002:adf:ed45:: with SMTP id u5mr27326708wro.358.1612901823243; Tue, 09 Feb 2021 12:17:03 -0800 (PST) MIME-Version: 1.0 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> In-Reply-To: From: Suren Baghdasaryan Date: Tue, 9 Feb 2021 12:16:51 -0800 Message-ID: Subject: Re: [RFC][PATCH v6 1/7] drm: Add a sharable drm page-pool implementation To: Daniel Vetter Cc: =?UTF-8?Q?Christian_K=C3=B6nig?= , John Stultz , lkml , Sumit Semwal , Liam Mark , Chris Goldsworthy , Laura Abbott , Brian Starkey , Hridya Valsaraju , Sandeep Patil , Daniel Mentz , =?UTF-8?Q?=C3=98rjan_Eide?= , Robin Murphy , Ezequiel Garcia , Simon Ser , James Jones , linux-media , dri-devel Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Feb 9, 2021 at 12:03 PM Daniel Vetter wrote: > > On Tue, Feb 9, 2021 at 6:46 PM Christian K=C3=B6nig wrote: > > > > > > > > Am 09.02.21 um 18:33 schrieb Suren Baghdasaryan: > > > On Tue, Feb 9, 2021 at 4:57 AM Christian K=C3=B6nig wrote: > > >> Am 09.02.21 um 13:11 schrieb Christian K=C3=B6nig: > > >>> [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=3Dhttps%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%23= n28&data=3D04%7C01%7Cchristian.koenig%40amd.com%7Cdccccff8edcd4d147a5b0= 8d8cd20cff2%7C3dd8961fe4884e608e11a82d994e183d%7C0%7C0%7C637484888114923580= %7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haW= wiLCJXVCI6Mn0%3D%7C1000&sdata=3D9%2BIBC0tezSV6Ci4S3kWfW%2BQvJm4mdunn3dF= 6C0kyfCw%3D&reserved=3D0 > > >>>> > > >>>> > > >>>> My sense is it helps with the vmstat/meminfo accounting so folks c= an > > >>>> see the cached pages are shrinkable/freeable. This maybe falls und= er > > >>>> other dmabuf accounting/stats discussions, so I'm happy to remove = it > > >>>> for now, or let the drivers using the shared page pool logic handl= e > > >>>> 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 freeabl= e > > >> 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 bu= t > > > I might be wrong. > > > > Yeah, that's what I see here as well. But exactly that is utterly nonse= nse. > > > > 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? > 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 ca= se > > >> it can cause memory corruption. > > >> > > >> Christian. > > > > > -- > Daniel Vetter > Software Engineer, Intel Corporation > http://blog.ffwll.ch