--- /dev/null
+From 503621628b32782a07b2318e4112bd4372aa3401 Mon Sep 17 00:00:00 2001
+From: Russell King <rmk+kernel@armlinux.org.uk>
+Date: Tue, 23 Apr 2019 17:09:38 +0100
+Subject: ARM: fix function graph tracer and unwinder dependencies
+
+From: Russell King <rmk+kernel@armlinux.org.uk>
+
+commit 503621628b32782a07b2318e4112bd4372aa3401 upstream.
+
+Naresh Kamboju recently reported that the function-graph tracer crashes
+on ARM. The function-graph tracer assumes that the kernel is built with
+frame pointers.
+
+We explicitly disabled the function-graph tracer when building Thumb2,
+since the Thumb2 ABI doesn't have frame pointers.
+
+We recently changed the way the unwinder method was selected, which
+seems to have made it more likely that we can end up with the function-
+graph tracer enabled but without the kernel built with frame pointers.
+
+Fix up the function graph tracer dependencies so the option is not
+available when we have no possibility of having frame pointers, and
+adjust the dependencies on the unwinder option to hide the non-frame
+pointer unwinder options if the function-graph tracer is enabled.
+
+Reviewed-by: Masami Hiramatsu <mhiramat@kernel.org>
+Tested-by: Masami Hiramatsu <mhiramat@kernel.org>
+Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
+Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
+Reported-by: Danilo Cezar Zanella <danilo.zanella@iag.usp.br>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ arch/arm/Kconfig | 2 +-
+ arch/arm/Kconfig.debug | 6 +++---
+ 2 files changed, 4 insertions(+), 4 deletions(-)
+
+--- a/arch/arm/Kconfig
++++ b/arch/arm/Kconfig
+@@ -63,7 +63,7 @@ config ARM
+ select HAVE_EFFICIENT_UNALIGNED_ACCESS if (CPU_V6 || CPU_V6K || CPU_V7) && MMU
+ select HAVE_EXIT_THREAD
+ select HAVE_FTRACE_MCOUNT_RECORD if (!XIP_KERNEL)
+- select HAVE_FUNCTION_GRAPH_TRACER if (!THUMB2_KERNEL)
++ select HAVE_FUNCTION_GRAPH_TRACER if (!THUMB2_KERNEL && !CC_IS_CLANG)
+ select HAVE_FUNCTION_TRACER if (!XIP_KERNEL)
+ select HAVE_FUTEX_CMPXCHG if FUTEX
+ select HAVE_GCC_PLUGINS
+--- a/arch/arm/Kconfig.debug
++++ b/arch/arm/Kconfig.debug
+@@ -18,8 +18,8 @@ config ARM_PTDUMP
+
+ choice
+ prompt "Choose kernel unwinder"
+- default UNWINDER_ARM if AEABI && !FUNCTION_GRAPH_TRACER
+- default UNWINDER_FRAME_POINTER if !AEABI || FUNCTION_GRAPH_TRACER
++ default UNWINDER_ARM if AEABI
++ default UNWINDER_FRAME_POINTER if !AEABI
+ help
+ This determines which method will be used for unwinding kernel stack
+ traces for panics, oopses, bugs, warnings, perf, /proc/<pid>/stack,
+@@ -36,7 +36,7 @@ config UNWINDER_FRAME_POINTER
+
+ config UNWINDER_ARM
+ bool "ARM EABI stack unwinder"
+- depends on AEABI
++ depends on AEABI && !FUNCTION_GRAPH_TRACER
+ select ARM_UNWIND
+ help
+ This option enables stack unwinding support in the kernel
--- /dev/null
+From 23a27722b5292ef0b27403c87a109feea8296a5c Mon Sep 17 00:00:00 2001
+From: Alexander Popov <alex.popov@linux.com>
+Date: Thu, 19 Apr 2018 15:29:22 +0300
+Subject: i2c: dev: prevent ZERO_SIZE_PTR deref in i2cdev_ioctl_rdwr()
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Alexander Popov <alex.popov@linux.com>
+
+commit 23a27722b5292ef0b27403c87a109feea8296a5c upstream.
+
+i2cdev_ioctl_rdwr() allocates i2c_msg.buf using memdup_user(), which
+returns ZERO_SIZE_PTR if i2c_msg.len is zero.
+
+Currently i2cdev_ioctl_rdwr() always dereferences the buf pointer in case
+of I2C_M_RD | I2C_M_RECV_LEN transfer. That causes a kernel oops in
+case of zero len.
+
+Let's check the len against zero before dereferencing buf pointer.
+
+This issue was triggered by syzkaller.
+
+Signed-off-by: Alexander Popov <alex.popov@linux.com>
+Reviewed-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
+[wsa: use '< 1' instead of '!' for easier readability]
+Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
+[Harshit: backport to 4.14.y, use rdwr_pa[i].len instead of msgs[i].len
+as the 4.14.y code uses rdwr_pa.]
+Signed-off-by: Harshit Mogalapalli <harshit.m.mogalapalli@oracle.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/i2c/i2c-dev.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+--- a/drivers/i2c/i2c-dev.c
++++ b/drivers/i2c/i2c-dev.c
+@@ -297,7 +297,7 @@ static noinline int i2cdev_ioctl_rdwr(st
+ */
+ if (rdwr_pa[i].flags & I2C_M_RECV_LEN) {
+ if (!(rdwr_pa[i].flags & I2C_M_RD) ||
+- rdwr_pa[i].buf[0] < 1 ||
++ rdwr_pa[i].len < 1 || rdwr_pa[i].buf[0] < 1 ||
+ rdwr_pa[i].len < rdwr_pa[i].buf[0] +
+ I2C_SMBUS_BLOCK_MAX) {
+ i++;
--- /dev/null
+From d6ffe6067a54972564552ea45d320fb98db1ac5e Mon Sep 17 00:00:00 2001
+From: Mikulas Patocka <mpatocka@redhat.com>
+Date: Fri, 26 Aug 2022 16:43:51 -0400
+Subject: provide arch_test_bit_acquire for architectures that define test_bit
+
+From: Mikulas Patocka <mpatocka@redhat.com>
+
+commit d6ffe6067a54972564552ea45d320fb98db1ac5e upstream.
+
+Some architectures define their own arch_test_bit and they also need
+arch_test_bit_acquire, otherwise they won't compile. We also clean up
+the code by using the generic test_bit if that is equivalent to the
+arch-specific version.
+
+Signed-off-by: Mikulas Patocka <mpatocka@redhat.com>
+Cc: stable@vger.kernel.org
+Fixes: 8238b4579866 ("wait_on_bit: add an acquire memory barrier")
+Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ arch/alpha/include/asm/bitops.h | 7 +++++++
+ arch/hexagon/include/asm/bitops.h | 15 +++++++++++++++
+ arch/ia64/include/asm/bitops.h | 7 +++++++
+ arch/m68k/include/asm/bitops.h | 6 ++++++
+ arch/s390/include/asm/bitops.h | 7 +++++++
+ arch/sh/include/asm/bitops-op32.h | 7 +++++++
+ 6 files changed, 49 insertions(+)
+
+--- a/arch/alpha/include/asm/bitops.h
++++ b/arch/alpha/include/asm/bitops.h
+@@ -289,6 +289,13 @@ test_bit(int nr, const volatile void * a
+ return (1UL & (((const int *) addr)[nr >> 5] >> (nr & 31))) != 0UL;
+ }
+
++static __always_inline bool
++test_bit_acquire(unsigned long nr, const volatile unsigned long *addr)
++{
++ unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
++ return 1UL & (smp_load_acquire(p) >> (nr & (BITS_PER_LONG-1)));
++}
++
+ /*
+ * ffz = Find First Zero in word. Undefined if no zero exists,
+ * so code should check against ~0UL first..
+--- a/arch/hexagon/include/asm/bitops.h
++++ b/arch/hexagon/include/asm/bitops.h
+@@ -186,7 +186,22 @@ static inline int __test_bit(int nr, con
+ return retval;
+ }
+
++static inline int __test_bit_acquire(int nr, const volatile unsigned long *addr)
++{
++ int retval;
++
++ asm volatile(
++ "{P0 = tstbit(%1,%2); if (P0.new) %0 = #1; if (!P0.new) %0 = #0;}\n"
++ : "=&r" (retval)
++ : "r" (addr[BIT_WORD(nr)]), "r" (nr % BITS_PER_LONG)
++ : "p0", "memory"
++ );
++
++ return retval;
++}
++
+ #define test_bit(nr, addr) __test_bit(nr, addr)
++#define test_bit_acquire(nr, addr) __test_bit_acquire(nr, addr)
+
+ /*
+ * ffz - find first zero in word.
+--- a/arch/ia64/include/asm/bitops.h
++++ b/arch/ia64/include/asm/bitops.h
+@@ -337,6 +337,13 @@ test_bit (int nr, const volatile void *a
+ return 1 & (((const volatile __u32 *) addr)[nr >> 5] >> (nr & 31));
+ }
+
++static __always_inline bool
++test_bit_acquire(unsigned long nr, const volatile unsigned long *addr)
++{
++ unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
++ return 1UL & (smp_load_acquire(p) >> (nr & (BITS_PER_LONG-1)));
++}
++
+ /**
+ * ffz - find the first zero bit in a long word
+ * @x: The long word to find the bit in
+--- a/arch/m68k/include/asm/bitops.h
++++ b/arch/m68k/include/asm/bitops.h
+@@ -153,6 +153,12 @@ static inline int test_bit(int nr, const
+ return (vaddr[nr >> 5] & (1UL << (nr & 31))) != 0;
+ }
+
++static __always_inline bool
++test_bit_acquire(unsigned long nr, const volatile unsigned long *addr)
++{
++ unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
++ return 1UL & (smp_load_acquire(p) >> (nr & (BITS_PER_LONG-1)));
++}
+
+ static inline int bset_reg_test_and_set_bit(int nr,
+ volatile unsigned long *vaddr)
+--- a/arch/s390/include/asm/bitops.h
++++ b/arch/s390/include/asm/bitops.h
+@@ -215,6 +215,13 @@ static inline int test_bit(unsigned long
+ return (*addr >> (nr & 7)) & 1;
+ }
+
++static __always_inline bool
++test_bit_acquire(unsigned long nr, const volatile unsigned long *addr)
++{
++ unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
++ return 1UL & (smp_load_acquire(p) >> (nr & (BITS_PER_LONG-1)));
++}
++
+ static inline int test_and_set_bit_lock(unsigned long nr,
+ volatile unsigned long *ptr)
+ {
+--- a/arch/sh/include/asm/bitops-op32.h
++++ b/arch/sh/include/asm/bitops-op32.h
+@@ -140,4 +140,11 @@ static inline int test_bit(int nr, const
+ return 1UL & (addr[BIT_WORD(nr)] >> (nr & (BITS_PER_LONG-1)));
+ }
+
++static __always_inline bool
++test_bit_acquire(unsigned long nr, const volatile unsigned long *addr)
++{
++ unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
++ return 1UL & (smp_load_acquire(p) >> (nr & (BITS_PER_LONG-1)));
++}
++
+ #endif /* __ASM_SH_BITOPS_OP32_H */
clk-iproc-minor-tidy-up-of-iproc-pll-data-structures.patch
clk-iproc-do-not-rely-on-node-name-for-correct-pll-s.patch
makefile.extrawarn-move-wcast-function-type-strict-to-w-1.patch
+i2c-dev-prevent-zero_size_ptr-deref-in-i2cdev_ioctl_rdwr.patch
+arm-fix-function-graph-tracer-and-unwinder-dependencies.patch
+wait_on_bit-add-an-acquire-memory-barrier.patch
+provide-arch_test_bit_acquire-for-architectures-that-define-test_bit.patch
--- /dev/null
+From 8238b4579866b7c1bb99883cfe102a43db5506ff Mon Sep 17 00:00:00 2001
+From: Mikulas Patocka <mpatocka@redhat.com>
+Date: Fri, 26 Aug 2022 09:17:08 -0400
+Subject: wait_on_bit: add an acquire memory barrier
+
+From: Mikulas Patocka <mpatocka@redhat.com>
+
+commit 8238b4579866b7c1bb99883cfe102a43db5506ff upstream.
+
+There are several places in the kernel where wait_on_bit is not followed
+by a memory barrier (for example, in drivers/md/dm-bufio.c:new_read).
+
+On architectures with weak memory ordering, it may happen that memory
+accesses that follow wait_on_bit are reordered before wait_on_bit and
+they may return invalid data.
+
+Fix this class of bugs by introducing a new function "test_bit_acquire"
+that works like test_bit, but has acquire memory ordering semantics.
+
+Signed-off-by: Mikulas Patocka <mpatocka@redhat.com>
+Acked-by: Will Deacon <will@kernel.org>
+Cc: stable@vger.kernel.org
+Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ arch/x86/include/asm/bitops.h | 21 +++++++++++++++++++++
+ include/asm-generic/bitops/non-atomic.h | 14 ++++++++++++++
+ include/linux/buffer_head.h | 2 +-
+ include/linux/wait_bit.h | 8 ++++----
+ kernel/sched/wait_bit.c | 2 +-
+ 5 files changed, 41 insertions(+), 6 deletions(-)
+
+--- a/arch/x86/include/asm/bitops.h
++++ b/arch/x86/include/asm/bitops.h
+@@ -328,6 +328,20 @@ static __always_inline bool constant_tes
+ (addr[nr >> _BITOPS_LONG_SHIFT])) != 0;
+ }
+
++static __always_inline bool constant_test_bit_acquire(long nr, const volatile unsigned long *addr)
++{
++ bool oldbit;
++
++ asm volatile("testb %2,%1"
++ CC_SET(nz)
++ : CC_OUT(nz) (oldbit)
++ : "m" (((unsigned char *)addr)[nr >> 3]),
++ "i" (1 << (nr & 7))
++ :"memory");
++
++ return oldbit;
++}
++
+ static __always_inline bool variable_test_bit(long nr, volatile const unsigned long *addr)
+ {
+ bool oldbit;
+@@ -354,6 +368,13 @@ static bool test_bit(int nr, const volat
+ ? constant_test_bit((nr), (addr)) \
+ : variable_test_bit((nr), (addr)))
+
++static __always_inline bool
++test_bit_acquire(unsigned long nr, const volatile unsigned long *addr)
++{
++ return __builtin_constant_p(nr) ? constant_test_bit_acquire(nr, addr) :
++ variable_test_bit(nr, addr);
++}
++
+ /**
+ * __ffs - find first set bit in word
+ * @word: The word to search
+--- a/include/asm-generic/bitops/non-atomic.h
++++ b/include/asm-generic/bitops/non-atomic.h
+@@ -3,6 +3,7 @@
+ #define _ASM_GENERIC_BITOPS_NON_ATOMIC_H_
+
+ #include <asm/types.h>
++#include <asm/barrier.h>
+
+ /**
+ * __set_bit - Set a bit in memory
+@@ -106,4 +107,17 @@ static inline int test_bit(int nr, const
+ return 1UL & (addr[BIT_WORD(nr)] >> (nr & (BITS_PER_LONG-1)));
+ }
+
++/**
++ * arch_test_bit_acquire - Determine, with acquire semantics, whether a bit is set
++ * @nr: bit number to test
++ * @addr: Address to start counting from
++ */
++static __always_inline bool
++arch_test_bit_acquire(unsigned long nr, const volatile unsigned long *addr)
++{
++ unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
++ return 1UL & (smp_load_acquire(p) >> (nr & (BITS_PER_LONG-1)));
++}
++#define test_bit_acquire arch_test_bit_acquire
++
+ #endif /* _ASM_GENERIC_BITOPS_NON_ATOMIC_H_ */
+--- a/include/linux/buffer_head.h
++++ b/include/linux/buffer_head.h
+@@ -163,7 +163,7 @@ static __always_inline int buffer_uptoda
+ * make it consistent with folio_test_uptodate
+ * pairs with smp_mb__before_atomic in set_buffer_uptodate
+ */
+- return (smp_load_acquire(&bh->b_state) & (1UL << BH_Uptodate)) != 0;
++ return test_bit_acquire(BH_Uptodate, &bh->b_state);
+ }
+
+ #define bh_offset(bh) ((unsigned long)(bh)->b_data & ~PAGE_MASK)
+--- a/include/linux/wait_bit.h
++++ b/include/linux/wait_bit.h
+@@ -76,7 +76,7 @@ static inline int
+ wait_on_bit(unsigned long *word, int bit, unsigned mode)
+ {
+ might_sleep();
+- if (!test_bit(bit, word))
++ if (!test_bit_acquire(bit, word))
+ return 0;
+ return out_of_line_wait_on_bit(word, bit,
+ bit_wait,
+@@ -101,7 +101,7 @@ static inline int
+ wait_on_bit_io(unsigned long *word, int bit, unsigned mode)
+ {
+ might_sleep();
+- if (!test_bit(bit, word))
++ if (!test_bit_acquire(bit, word))
+ return 0;
+ return out_of_line_wait_on_bit(word, bit,
+ bit_wait_io,
+@@ -128,7 +128,7 @@ wait_on_bit_timeout(unsigned long *word,
+ unsigned long timeout)
+ {
+ might_sleep();
+- if (!test_bit(bit, word))
++ if (!test_bit_acquire(bit, word))
+ return 0;
+ return out_of_line_wait_on_bit_timeout(word, bit,
+ bit_wait_timeout,
+@@ -156,7 +156,7 @@ wait_on_bit_action(unsigned long *word,
+ unsigned mode)
+ {
+ might_sleep();
+- if (!test_bit(bit, word))
++ if (!test_bit_acquire(bit, word))
+ return 0;
+ return out_of_line_wait_on_bit(word, bit, action, mode);
+ }
+--- a/kernel/sched/wait_bit.c
++++ b/kernel/sched/wait_bit.c
+@@ -49,7 +49,7 @@ __wait_on_bit(struct wait_queue_head *wq
+ prepare_to_wait(wq_head, &wbq_entry->wq_entry, mode);
+ if (test_bit(wbq_entry->key.bit_nr, wbq_entry->key.flags))
+ ret = (*action)(&wbq_entry->key, mode);
+- } while (test_bit(wbq_entry->key.bit_nr, wbq_entry->key.flags) && !ret);
++ } while (test_bit_acquire(wbq_entry->key.bit_nr, wbq_entry->key.flags) && !ret);
+ finish_wait(wq_head, &wbq_entry->wq_entry);
+ return ret;
+ }