]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
5.15-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 22 Aug 2024 22:42:27 +0000 (06:42 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 22 Aug 2024 22:42:27 +0000 (06:42 +0800)
added patches:
media-solo6x10-replace-max-a-min-b-c-by-clamp-b-a-c.patch

queue-5.15/media-solo6x10-replace-max-a-min-b-c-by-clamp-b-a-c.patch [new file with mode: 0644]
queue-5.15/series

diff --git a/queue-5.15/media-solo6x10-replace-max-a-min-b-c-by-clamp-b-a-c.patch b/queue-5.15/media-solo6x10-replace-max-a-min-b-c-by-clamp-b-a-c.patch
new file mode 100644 (file)
index 0000000..79144cb
--- /dev/null
@@ -0,0 +1,59 @@
+From 31e97d7c9ae3de072d7b424b2cf706a03ec10720 Mon Sep 17 00:00:00 2001
+From: Aurelien Jarno <aurelien@aurel32.net>
+Date: Sat, 13 Jan 2024 19:33:31 +0100
+Subject: media: solo6x10: replace max(a, min(b, c)) by clamp(b, a, c)
+
+From: Aurelien Jarno <aurelien@aurel32.net>
+
+commit 31e97d7c9ae3de072d7b424b2cf706a03ec10720 upstream.
+
+This patch replaces max(a, min(b, c)) by clamp(b, a, c) in the solo6x10
+driver.  This improves the readability and more importantly, for the
+solo6x10-p2m.c file, this reduces on my system (x86-64, gcc 13):
+
+ - the preprocessed size from 121 MiB to 4.5 MiB;
+
+ - the build CPU time from 46.8 s to 1.6 s;
+
+ - the build memory from 2786 MiB to 98MiB.
+
+In fine, this allows this relatively simple C file to be built on a
+32-bit system.
+
+Reported-by: Jiri Slaby <jirislaby@gmail.com>
+Closes: https://lore.kernel.org/lkml/18c6df0d-45ed-450c-9eda-95160a2bbb8e@gmail.com/
+Cc:  <stable@vger.kernel.org> # v6.7+
+Suggested-by: David Laight <David.Laight@ACULAB.COM>
+Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
+Reviewed-by: David Laight <David.Laight@ACULAB.COM>
+Reviewed-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
+Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/media/pci/solo6x10/solo6x10-offsets.h |   10 +++++-----
+ 1 file changed, 5 insertions(+), 5 deletions(-)
+
+--- a/drivers/media/pci/solo6x10/solo6x10-offsets.h
++++ b/drivers/media/pci/solo6x10/solo6x10-offsets.h
+@@ -57,16 +57,16 @@
+ #define SOLO_MP4E_EXT_ADDR(__solo) \
+       (SOLO_EREF_EXT_ADDR(__solo) + SOLO_EREF_EXT_AREA(__solo))
+ #define SOLO_MP4E_EXT_SIZE(__solo) \
+-      max((__solo->nr_chans * 0x00080000),                            \
+-          min(((__solo->sdram_size - SOLO_MP4E_EXT_ADDR(__solo)) -    \
+-               __SOLO_JPEG_MIN_SIZE(__solo)), 0x00ff0000))
++      clamp(__solo->sdram_size - SOLO_MP4E_EXT_ADDR(__solo) - \
++            __SOLO_JPEG_MIN_SIZE(__solo),                     \
++            __solo->nr_chans * 0x00080000, 0x00ff0000)
+ #define __SOLO_JPEG_MIN_SIZE(__solo)          (__solo->nr_chans * 0x00080000)
+ #define SOLO_JPEG_EXT_ADDR(__solo) \
+               (SOLO_MP4E_EXT_ADDR(__solo) + SOLO_MP4E_EXT_SIZE(__solo))
+ #define SOLO_JPEG_EXT_SIZE(__solo) \
+-      max(__SOLO_JPEG_MIN_SIZE(__solo),                               \
+-          min((__solo->sdram_size - SOLO_JPEG_EXT_ADDR(__solo)), 0x00ff0000))
++      clamp(__solo->sdram_size - SOLO_JPEG_EXT_ADDR(__solo),  \
++            __SOLO_JPEG_MIN_SIZE(__solo), 0x00ff0000)
+ #define SOLO_SDRAM_END(__solo) \
+       (SOLO_JPEG_EXT_ADDR(__solo) + SOLO_JPEG_EXT_SIZE(__solo))
index 5dbd0cfb61ff387913dfbcfbbda105ebc9c5fa9b..7b62fc09d02c7d046753622ee5945e9feea2680e 100644 (file)
@@ -126,3 +126,4 @@ nfsd-expose-proc-net-sunrpc-nfsd-in-net-namespaces.patch
 nfsd-make-all-of-the-nfsd-stats-per-network-namespace.patch
 nfsd-remove-nfsd_stats-make-th_cnt-a-global-counter.patch
 nfsd-make-svc_stat-per-network-namespace-instead-of-global.patch
+media-solo6x10-replace-max-a-min-b-c-by-clamp-b-a-c.patch