4a2ff73177
Changelog: https://cdn.kernel.org/pub/linux/kernel/v6.x/ChangeLog-6.1.69 Removed upstreamed: generic/backport-6.1/795-v6.3-01-r8152-add-USB-device-driver-for-config-selection.patch[1] generic/backport-6.1/795-v6.3-03-r8152-avoid-to-change-cfg-for-all-devices.patch[2] generic/backport-6.1/795-v6.3-04-r8152-remove-rtl_vendor_mode-function.patch[3] generic/backport-6.1/795-v6.4-07-r8152-fix-the-autosuspend-doesn-t-work.patch[4] generic/backport-6.1/795-v6.6-11-r8152-add-vendor-device-ID-pair-for-D-Link-DUB-E250.patch[5] All other patches automatically rebased. 1. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.1.69&id=893597cbabfbc00ee51fd5f73e2028994f49ded6 2. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.1.69&id=1d82735f4bae954d5ba004994b96baec791f874f 3. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.1.69&id=4c2ad8e39c62c5288ca31ebf5c30e34f3bd9d044 4. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.1.69&id=325556d46bfd13a2fa0d304d0625be86821fd683 5. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.1.69&id=cac1218b32d7b56832dd36f7baf82f123f305a2a Build system: x86/64 Build-tested: x86/64/AMD Cezanne Run-tested: x86/64/AMD Cezanne Signed-off-by: John Audia <therealgraysky@proton.me>
130 lines
4.7 KiB
Diff
130 lines
4.7 KiB
Diff
From 9ca4e437a24dfc4ec6c362f319eb9850b9eca497 Mon Sep 17 00:00:00 2001
|
|
From: Yu Zhao <yuzhao@google.com>
|
|
Date: Fri, 30 Dec 2022 14:52:52 -0700
|
|
Subject: [PATCH 11/19] UPSTREAM: mm: support POSIX_FADV_NOREUSE
|
|
|
|
This patch adds POSIX_FADV_NOREUSE to vma_has_recency() so that the LRU
|
|
algorithm can ignore access to mapped files marked by this flag.
|
|
|
|
The advantages of POSIX_FADV_NOREUSE are:
|
|
1. Unlike MADV_SEQUENTIAL and MADV_RANDOM, it does not alter the
|
|
default readahead behavior.
|
|
2. Unlike MADV_SEQUENTIAL and MADV_RANDOM, it does not split VMAs and
|
|
therefore does not take mmap_lock.
|
|
3. Unlike MADV_COLD, setting it has a negligible cost, regardless of
|
|
how many pages it affects.
|
|
|
|
Its limitations are:
|
|
1. Like POSIX_FADV_RANDOM and POSIX_FADV_SEQUENTIAL, it currently does
|
|
not support range. IOW, its scope is the entire file.
|
|
2. It currently does not ignore access through file descriptors.
|
|
Specifically, for the active/inactive LRU, given a file page shared
|
|
by two users and one of them having set POSIX_FADV_NOREUSE on the
|
|
file, this page will be activated upon the second user accessing
|
|
it. This corner case can be covered by checking POSIX_FADV_NOREUSE
|
|
before calling folio_mark_accessed() on the read path. But it is
|
|
considered not worth the effort.
|
|
|
|
There have been a few attempts to support POSIX_FADV_NOREUSE, e.g., [1].
|
|
This time the goal is to fill a niche: a few desktop applications, e.g.,
|
|
large file transferring and video encoding/decoding, want fast file
|
|
streaming with mmap() rather than direct IO. Among those applications, an
|
|
SVT-AV1 regression was reported when running with MGLRU [2]. The
|
|
following test can reproduce that regression.
|
|
|
|
kb=$(awk '/MemTotal/ { print $2 }' /proc/meminfo)
|
|
kb=$((kb - 8*1024*1024))
|
|
|
|
modprobe brd rd_nr=1 rd_size=$kb
|
|
dd if=/dev/zero of=/dev/ram0 bs=1M
|
|
|
|
mkfs.ext4 /dev/ram0
|
|
mount /dev/ram0 /mnt/
|
|
swapoff -a
|
|
|
|
fallocate -l 8G /mnt/swapfile
|
|
mkswap /mnt/swapfile
|
|
swapon /mnt/swapfile
|
|
|
|
wget http://ultravideo.cs.tut.fi/video/Bosphorus_3840x2160_120fps_420_8bit_YUV_Y4M.7z
|
|
7z e -o/mnt/ Bosphorus_3840x2160_120fps_420_8bit_YUV_Y4M.7z
|
|
SvtAv1EncApp --preset 12 -w 3840 -h 2160 \
|
|
-i /mnt/Bosphorus_3840x2160.y4m
|
|
|
|
For MGLRU, the following change showed a [9-11]% increase in FPS,
|
|
which makes it on par with the active/inactive LRU.
|
|
|
|
patch Source/App/EncApp/EbAppMain.c <<EOF
|
|
31a32
|
|
> #include <fcntl.h>
|
|
35d35
|
|
< #include <fcntl.h> /* _O_BINARY */
|
|
117a118
|
|
> posix_fadvise(config->mmap.fd, 0, 0, POSIX_FADV_NOREUSE);
|
|
EOF
|
|
|
|
[1] https://lore.kernel.org/r/1308923350-7932-1-git-send-email-andrea@betterlinux.com/
|
|
[2] https://openbenchmarking.org/result/2209259-PTS-MGLRU8GB57
|
|
|
|
Link: https://lkml.kernel.org/r/20221230215252.2628425-2-yuzhao@google.com
|
|
Change-Id: I0b7f5f971d78014ea1ba44cee6a8ec902a4330d0
|
|
Signed-off-by: Yu Zhao <yuzhao@google.com>
|
|
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
|
|
Cc: Andrea Righi <andrea.righi@canonical.com>
|
|
Cc: Johannes Weiner <hannes@cmpxchg.org>
|
|
Cc: Michael Larabel <Michael@MichaelLarabel.com>
|
|
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
|
|
(cherry picked from commit 17e810229cb3068b692fa078bd9b3a6527e0866a)
|
|
Bug: 274865848
|
|
Signed-off-by: T.J. Mercier <tjmercier@google.com>
|
|
---
|
|
include/linux/fs.h | 2 ++
|
|
include/linux/mm_inline.h | 3 +++
|
|
mm/fadvise.c | 5 ++++-
|
|
3 files changed, 9 insertions(+), 1 deletion(-)
|
|
|
|
--- a/include/linux/fs.h
|
|
+++ b/include/linux/fs.h
|
|
@@ -166,6 +166,8 @@ typedef int (dio_iodone_t)(struct kiocb
|
|
/* File supports DIRECT IO */
|
|
#define FMODE_CAN_ODIRECT ((__force fmode_t)0x400000)
|
|
|
|
+#define FMODE_NOREUSE ((__force fmode_t)0x800000)
|
|
+
|
|
/* File was opened by fanotify and shouldn't generate fanotify events */
|
|
#define FMODE_NONOTIFY ((__force fmode_t)0x4000000)
|
|
|
|
--- a/include/linux/mm_inline.h
|
|
+++ b/include/linux/mm_inline.h
|
|
@@ -605,6 +605,9 @@ static inline bool vma_has_recency(struc
|
|
if (vma->vm_flags & (VM_SEQ_READ | VM_RAND_READ))
|
|
return false;
|
|
|
|
+ if (vma->vm_file && (vma->vm_file->f_mode & FMODE_NOREUSE))
|
|
+ return false;
|
|
+
|
|
return true;
|
|
}
|
|
|
|
--- a/mm/fadvise.c
|
|
+++ b/mm/fadvise.c
|
|
@@ -80,7 +80,7 @@ int generic_fadvise(struct file *file, l
|
|
case POSIX_FADV_NORMAL:
|
|
file->f_ra.ra_pages = bdi->ra_pages;
|
|
spin_lock(&file->f_lock);
|
|
- file->f_mode &= ~FMODE_RANDOM;
|
|
+ file->f_mode &= ~(FMODE_RANDOM | FMODE_NOREUSE);
|
|
spin_unlock(&file->f_lock);
|
|
break;
|
|
case POSIX_FADV_RANDOM:
|
|
@@ -107,6 +107,9 @@ int generic_fadvise(struct file *file, l
|
|
force_page_cache_readahead(mapping, file, start_index, nrpages);
|
|
break;
|
|
case POSIX_FADV_NOREUSE:
|
|
+ spin_lock(&file->f_lock);
|
|
+ file->f_mode |= FMODE_NOREUSE;
|
|
+ spin_unlock(&file->f_lock);
|
|
break;
|
|
case POSIX_FADV_DONTNEED:
|
|
__filemap_fdatawrite_range(mapping, offset, endbyte,
|