[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20241023075302.27194-1-maarten.lankhorst@linux.intel.com>
Date: Wed, 23 Oct 2024 09:52:53 +0200
From: Maarten Lankhorst <maarten.lankhorst@...ux.intel.com>
To: intel-xe@...ts.freedesktop.org,
linux-kernel@...r.kernel.org,
dri-devel@...ts.freedesktop.org,
Tejun Heo <tj@...nel.org>,
Zefan Li <lizefan.x@...edance.com>,
Johannes Weiner <hannes@...xchg.org>,
Andrew Morton <akpm@...ux-foundation.org>
Cc: Friedrich Vock <friedrich.vock@....de>,
cgroups@...r.kernel.org,
linux-mm@...ck.org,
Maxime Ripard <mripard@...nel.org>,
Maarten Lankhorst <maarten.lankhorst@...ux.intel.com>
Subject: [PATCH 0/7] kernel/cgroups: Add "dev" memory accounting cgroup.
New submission!
I've added documentation for each call, and integrated the renaming from
drm cgroup to dev cgroup, based on maxime ripard's work.
Maxime has been testing this with dma-buf heaps and v4l2 too, and it seems to work.
In the initial submission, I've decided to only add the smallest enablement possible,
to have less chance of breaking things.
The API has been changed slightly, from "$name region.$regionname=$limit" in a file called
dev.min/low/max to "$subsystem/$name $regionname=$limit" in a file called dev.region.min/low/max.
This hopefully allows us to perhaps extend the API later on with the possibility to
set scheduler weights on the device, like in
https://blogs.igalia.com/tursulin/drm-scheduling-cgroup-controller/
Maarten Lankhorst (5):
kernel/cgroup: Add "dev" memory accounting cgroup
drm/ttm: Handle cgroup based eviction in TTM
drm/xe: Implement cgroup for vram
drm/amdgpu: Add cgroups implementation
[HACK] drm/xe: Hack to test with mapped pages instead of vram.
Maxime Ripard (2):
drm/drv: Add drmm cgroup registration for dev cgroups.
[DISCUSSION] drm/gem: Add cgroup memory accounting
Documentation/admin-guide/cgroup-v2.rst | 51 +
Documentation/core-api/cgroup.rst | 9 +
Documentation/core-api/index.rst | 1 +
Documentation/gpu/drm-compute.rst | 54 ++
drivers/gpu/drm/amd/amdgpu/amdgpu.h | 2 +
drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c | 6 +
drivers/gpu/drm/amd/amdgpu/amdgpu_vram_mgr.c | 6 +
drivers/gpu/drm/drm_drv.c | 32 +-
drivers/gpu/drm/drm_gem.c | 4 +
drivers/gpu/drm/drm_gem_dma_helper.c | 4 +
drivers/gpu/drm/ttm/tests/ttm_bo_test.c | 18 +-
.../gpu/drm/ttm/tests/ttm_bo_validate_test.c | 4 +-
drivers/gpu/drm/ttm/tests/ttm_resource_test.c | 2 +-
drivers/gpu/drm/ttm/ttm_bo.c | 57 +-
drivers/gpu/drm/ttm/ttm_resource.c | 24 +-
drivers/gpu/drm/xe/xe_device.c | 4 +
drivers/gpu/drm/xe/xe_device_types.h | 4 +
drivers/gpu/drm/xe/xe_ttm_sys_mgr.c | 14 +
drivers/gpu/drm/xe/xe_ttm_vram_mgr.c | 10 +
include/drm/drm_device.h | 4 +
include/drm/drm_drv.h | 4 +
include/drm/drm_gem.h | 2 +
include/drm/ttm/ttm_resource.h | 16 +-
include/linux/cgroup_dev.h | 91 ++
include/linux/cgroup_subsys.h | 4 +
include/linux/page_counter.h | 2 +-
init/Kconfig | 7 +
kernel/cgroup/Makefile | 1 +
kernel/cgroup/dev.c | 893 ++++++++++++++++++
mm/page_counter.c | 4 +-
30 files changed, 1307 insertions(+), 27 deletions(-)
create mode 100644 Documentation/core-api/cgroup.rst
create mode 100644 Documentation/gpu/drm-compute.rst
create mode 100644 include/linux/cgroup_dev.h
create mode 100644 kernel/cgroup/dev.c
--
2.45.2
Powered by blists - more mailing lists