mirror of
https://github.com/coolsnowwolf/lede.git
synced 2025-07-30 22:36:58 +08:00

These patches were generated from: https://github.com/raspberrypi/linux/commits/rpi-6.12.y With the following command: git format-patch -N v6.12.27..HEAD (HEAD -> 8d3206ee456a5ecdf9ddbfd8e5e231e4f0cd716e) Exceptions: - (def)configs patches - github workflows patches - applied & reverted patches - readme patches - wireless patches Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com>
133 lines
3.6 KiB
Diff
133 lines
3.6 KiB
Diff
From ffc4d519dd892375d66d0214445c74fc1d3a001b Mon Sep 17 00:00:00 2001
|
|
From: =?UTF-8?q?Ma=C3=ADra=20Canal?= <mcanal@igalia.com>
|
|
Date: Mon, 23 Sep 2024 10:55:09 -0300
|
|
Subject: [PATCH] drm/v3d: Introduce gemfs
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
Commit eb8d395f68421449c6201d3019f51011d034f00e upstream
|
|
|
|
Create a separate "tmpfs" kernel mount for V3D. This will allow us to
|
|
move away from the shmemfs `shm_mnt` and gives the flexibility to do
|
|
things like set our own mount options. Here, the interest is to use
|
|
"huge=", which should allow us to enable the use of THP for our
|
|
shmem-backed objects.
|
|
|
|
Signed-off-by: Maíra Canal <mcanal@igalia.com>
|
|
Reviewed-by: Iago Toral Quiroga <itoral@igalia.com>
|
|
Link: https://patchwork.freedesktop.org/patch/msgid/20240923141348.2422499-6-mcanal@igalia.com
|
|
---
|
|
drivers/gpu/drm/v3d/Makefile | 3 ++-
|
|
drivers/gpu/drm/v3d/v3d_drv.h | 9 +++++++
|
|
drivers/gpu/drm/v3d/v3d_gem.c | 3 +++
|
|
drivers/gpu/drm/v3d/v3d_gemfs.c | 46 +++++++++++++++++++++++++++++++++
|
|
4 files changed, 60 insertions(+), 1 deletion(-)
|
|
create mode 100644 drivers/gpu/drm/v3d/v3d_gemfs.c
|
|
|
|
--- a/drivers/gpu/drm/v3d/Makefile
|
|
+++ b/drivers/gpu/drm/v3d/Makefile
|
|
@@ -13,7 +13,8 @@ v3d-y := \
|
|
v3d_trace_points.o \
|
|
v3d_sched.o \
|
|
v3d_sysfs.o \
|
|
- v3d_submit.o
|
|
+ v3d_submit.o \
|
|
+ v3d_gemfs.o
|
|
|
|
v3d-$(CONFIG_DEBUG_FS) += v3d_debugfs.o
|
|
|
|
--- a/drivers/gpu/drm/v3d/v3d_drv.h
|
|
+++ b/drivers/gpu/drm/v3d/v3d_drv.h
|
|
@@ -143,6 +143,11 @@ struct v3d_dev {
|
|
struct drm_mm mm;
|
|
spinlock_t mm_lock;
|
|
|
|
+ /*
|
|
+ * tmpfs instance used for shmem backed objects
|
|
+ */
|
|
+ struct vfsmount *gemfs;
|
|
+
|
|
struct work_struct overflow_mem_work;
|
|
|
|
struct v3d_bin_job *bin_job;
|
|
@@ -540,6 +545,10 @@ void v3d_reset(struct v3d_dev *v3d);
|
|
void v3d_invalidate_caches(struct v3d_dev *v3d);
|
|
void v3d_clean_caches(struct v3d_dev *v3d);
|
|
|
|
+/* v3d_gemfs.c */
|
|
+void v3d_gemfs_init(struct v3d_dev *v3d);
|
|
+void v3d_gemfs_fini(struct v3d_dev *v3d);
|
|
+
|
|
/* v3d_submit.c */
|
|
void v3d_job_cleanup(struct v3d_job *job);
|
|
void v3d_job_put(struct v3d_job *job);
|
|
--- a/drivers/gpu/drm/v3d/v3d_gem.c
|
|
+++ b/drivers/gpu/drm/v3d/v3d_gem.c
|
|
@@ -291,6 +291,8 @@ v3d_gem_init(struct drm_device *dev)
|
|
v3d_init_hw_state(v3d);
|
|
v3d_mmu_set_page_table(v3d);
|
|
|
|
+ v3d_gemfs_init(v3d);
|
|
+
|
|
ret = v3d_sched_init(v3d);
|
|
if (ret) {
|
|
drm_mm_takedown(&v3d->mm);
|
|
@@ -308,6 +310,7 @@ v3d_gem_destroy(struct drm_device *dev)
|
|
struct v3d_dev *v3d = to_v3d_dev(dev);
|
|
|
|
v3d_sched_fini(v3d);
|
|
+ v3d_gemfs_fini(v3d);
|
|
|
|
/* Waiting for jobs to finish would need to be done before
|
|
* unregistering V3D.
|
|
--- /dev/null
|
|
+++ b/drivers/gpu/drm/v3d/v3d_gemfs.c
|
|
@@ -0,0 +1,46 @@
|
|
+// SPDX-License-Identifier: GPL-2.0+
|
|
+/* Copyright (C) 2024 Raspberry Pi */
|
|
+
|
|
+#include <linux/fs.h>
|
|
+#include <linux/mount.h>
|
|
+
|
|
+#include "v3d_drv.h"
|
|
+
|
|
+void v3d_gemfs_init(struct v3d_dev *v3d)
|
|
+{
|
|
+ char huge_opt[] = "huge=within_size";
|
|
+ struct file_system_type *type;
|
|
+ struct vfsmount *gemfs;
|
|
+
|
|
+ /*
|
|
+ * By creating our own shmemfs mountpoint, we can pass in
|
|
+ * mount flags that better match our usecase. However, we
|
|
+ * only do so on platforms which benefit from it.
|
|
+ */
|
|
+ if (!IS_ENABLED(CONFIG_TRANSPARENT_HUGEPAGE))
|
|
+ goto err;
|
|
+
|
|
+ type = get_fs_type("tmpfs");
|
|
+ if (!type)
|
|
+ goto err;
|
|
+
|
|
+ gemfs = vfs_kern_mount(type, SB_KERNMOUNT, type->name, huge_opt);
|
|
+ if (IS_ERR(gemfs))
|
|
+ goto err;
|
|
+
|
|
+ v3d->gemfs = gemfs;
|
|
+ drm_info(&v3d->drm, "Using Transparent Hugepages\n");
|
|
+
|
|
+ return;
|
|
+
|
|
+err:
|
|
+ v3d->gemfs = NULL;
|
|
+ drm_notice(&v3d->drm,
|
|
+ "Transparent Hugepage support is recommended for optimal performance on this platform!\n");
|
|
+}
|
|
+
|
|
+void v3d_gemfs_fini(struct v3d_dev *v3d)
|
|
+{
|
|
+ if (v3d->gemfs)
|
|
+ kern_unmount(v3d->gemfs);
|
|
+}
|