]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
5.10-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 12 Apr 2021 07:07:02 +0000 (09:07 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 12 Apr 2021 07:07:02 +0000 (09:07 +0200)
added patches:
clk-socfpga-fix-iomem-pointer-cast-on-64-bit.patch
dt-bindings-net-ethernet-controller-fix-typo-in-nvmem.patch
lockdep-address-clang-wformat-warning-printing-for-hd.patch
net-sched-bump-refcount-for-new-action-in-act-replace-mode.patch

queue-5.10/clk-socfpga-fix-iomem-pointer-cast-on-64-bit.patch [new file with mode: 0644]
queue-5.10/dt-bindings-net-ethernet-controller-fix-typo-in-nvmem.patch [new file with mode: 0644]
queue-5.10/lockdep-address-clang-wformat-warning-printing-for-hd.patch [new file with mode: 0644]
queue-5.10/net-sched-bump-refcount-for-new-action-in-act-replace-mode.patch [new file with mode: 0644]
queue-5.10/series

diff --git a/queue-5.10/clk-socfpga-fix-iomem-pointer-cast-on-64-bit.patch b/queue-5.10/clk-socfpga-fix-iomem-pointer-cast-on-64-bit.patch
new file mode 100644 (file)
index 0000000..9bf1504
--- /dev/null
@@ -0,0 +1,39 @@
+From 2867b9746cef78745c594894aece6f8ef826e0b4 Mon Sep 17 00:00:00 2001
+From: Krzysztof Kozlowski <krzysztof.kozlowski@canonical.com>
+Date: Sun, 14 Mar 2021 12:07:09 +0100
+Subject: clk: socfpga: fix iomem pointer cast on 64-bit
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Krzysztof Kozlowski <krzysztof.kozlowski@canonical.com>
+
+commit 2867b9746cef78745c594894aece6f8ef826e0b4 upstream.
+
+Pointers should be cast with uintptr_t instead of integer.  This fixes
+warning when compile testing on ARM64:
+
+  drivers/clk/socfpga/clk-gate.c: In function ‘socfpga_clk_recalc_rate’:
+  drivers/clk/socfpga/clk-gate.c:102:7: warning: cast from pointer to integer of different size [-Wpointer-to-int-cast]
+
+Fixes: b7cec13f082f ("clk: socfpga: Look for the GPIO_DB_CLK by its offset")
+Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@canonical.com>
+Acked-by: Dinh Nguyen <dinguyen@kernel.org>
+Link: https://lore.kernel.org/r/20210314110709.32599-1-krzysztof.kozlowski@canonical.com
+Signed-off-by: Stephen Boyd <sboyd@kernel.org>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/clk/socfpga/clk-gate.c |    2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+--- a/drivers/clk/socfpga/clk-gate.c
++++ b/drivers/clk/socfpga/clk-gate.c
+@@ -99,7 +99,7 @@ static unsigned long socfpga_clk_recalc_
+               val = readl(socfpgaclk->div_reg) >> socfpgaclk->shift;
+               val &= GENMASK(socfpgaclk->width - 1, 0);
+               /* Check for GPIO_DB_CLK by its offset */
+-              if ((int) socfpgaclk->div_reg & SOCFPGA_GPIO_DB_CLK_OFFSET)
++              if ((uintptr_t) socfpgaclk->div_reg & SOCFPGA_GPIO_DB_CLK_OFFSET)
+                       div = val + 1;
+               else
+                       div = (1 << val);
diff --git a/queue-5.10/dt-bindings-net-ethernet-controller-fix-typo-in-nvmem.patch b/queue-5.10/dt-bindings-net-ethernet-controller-fix-typo-in-nvmem.patch
new file mode 100644 (file)
index 0000000..4fa9946
--- /dev/null
@@ -0,0 +1,37 @@
+From af9d316f3dd6d1385fbd1631b5103e620fc4298a Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <rafal@milecki.pl>
+Date: Mon, 29 Mar 2021 16:03:17 +0200
+Subject: dt-bindings: net: ethernet-controller: fix typo in NVMEM
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Rafał Miłecki <rafal@milecki.pl>
+
+commit af9d316f3dd6d1385fbd1631b5103e620fc4298a upstream.
+
+The correct property name is "nvmem-cell-names". This is what:
+1. Was originally documented in the ethernet.txt
+2. Is used in DTS files
+3. Matches standard syntax for phandles
+4. Linux net subsystem checks for
+
+Fixes: 9d3de3c58347 ("dt-bindings: net: Add YAML schemas for the generic Ethernet options")
+Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
+Signed-off-by: David S. Miller <davem@davemloft.net>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ Documentation/devicetree/bindings/net/ethernet-controller.yaml |    2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+--- a/Documentation/devicetree/bindings/net/ethernet-controller.yaml
++++ b/Documentation/devicetree/bindings/net/ethernet-controller.yaml
+@@ -49,7 +49,7 @@ properties:
+     description:
+       Reference to an nvmem node for the MAC address
+-  nvmem-cells-names:
++  nvmem-cell-names:
+     const: mac-address
+   phy-connection-type:
diff --git a/queue-5.10/lockdep-address-clang-wformat-warning-printing-for-hd.patch b/queue-5.10/lockdep-address-clang-wformat-warning-printing-for-hd.patch
new file mode 100644 (file)
index 0000000..798886a
--- /dev/null
@@ -0,0 +1,43 @@
+From 6d48b7912cc72275dc7c59ff961c8bac7ef66a92 Mon Sep 17 00:00:00 2001
+From: Arnd Bergmann <arnd@arndb.de>
+Date: Mon, 22 Mar 2021 12:55:25 +0100
+Subject: lockdep: Address clang -Wformat warning printing for %hd
+
+From: Arnd Bergmann <arnd@arndb.de>
+
+commit 6d48b7912cc72275dc7c59ff961c8bac7ef66a92 upstream.
+
+Clang doesn't like format strings that truncate a 32-bit
+value to something shorter:
+
+  kernel/locking/lockdep.c:709:4: error: format specifies type 'short' but the argument has type 'int' [-Werror,-Wformat]
+
+In this case, the warning is a slightly questionable, as it could realize
+that both class->wait_type_outer and class->wait_type_inner are in fact
+8-bit struct members, even though the result of the ?: operator becomes an
+'int'.
+
+However, there is really no point in printing the number as a 16-bit
+'short' rather than either an 8-bit or 32-bit number, so just change
+it to a normal %d.
+
+Fixes: de8f5e4f2dc1 ("lockdep: Introduce wait-type checks")
+Signed-off-by: Arnd Bergmann <arnd@arndb.de>
+Signed-off-by: Ingo Molnar <mingo@kernel.org>
+Link: https://lore.kernel.org/r/20210322115531.3987555-1-arnd@kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ kernel/locking/lockdep.c |    2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+--- a/kernel/locking/lockdep.c
++++ b/kernel/locking/lockdep.c
+@@ -705,7 +705,7 @@ static void print_lock_name(struct lock_
+       printk(KERN_CONT " (");
+       __print_lock_name(class);
+-      printk(KERN_CONT "){%s}-{%hd:%hd}", usage,
++      printk(KERN_CONT "){%s}-{%d:%d}", usage,
+                       class->wait_type_outer ?: class->wait_type_inner,
+                       class->wait_type_inner);
+ }
diff --git a/queue-5.10/net-sched-bump-refcount-for-new-action-in-act-replace-mode.patch b/queue-5.10/net-sched-bump-refcount-for-new-action-in-act-replace-mode.patch
new file mode 100644 (file)
index 0000000..6aaff9d
--- /dev/null
@@ -0,0 +1,83 @@
+From 6855e8213e06efcaf7c02a15e12b1ae64b9a7149 Mon Sep 17 00:00:00 2001
+From: Kumar Kartikeya Dwivedi <memxor@gmail.com>
+Date: Tue, 30 Mar 2021 04:23:23 +0530
+Subject: net: sched: bump refcount for new action in ACT replace mode
+
+From: Kumar Kartikeya Dwivedi <memxor@gmail.com>
+
+commit 6855e8213e06efcaf7c02a15e12b1ae64b9a7149 upstream.
+
+Currently, action creation using ACT API in replace mode is buggy.
+When invoking for non-existent action index 42,
+
+       tc action replace action bpf obj foo.o sec <xyz> index 42
+
+kernel creates the action, fills up the netlink response, and then just
+deletes the action after notifying userspace.
+
+       tc action show action bpf
+
+doesn't list the action.
+
+This happens due to the following sequence when ovr = 1 (replace mode)
+is enabled:
+
+tcf_idr_check_alloc is used to atomically check and either obtain
+reference for existing action at index, or reserve the index slot using
+a dummy entry (ERR_PTR(-EBUSY)).
+
+This is necessary as pointers to these actions will be held after
+dropping the idrinfo lock, so bumping the reference count is necessary
+as we need to insert the actions, and notify userspace by dumping their
+attributes. Finally, we drop the reference we took using the
+tcf_action_put_many call in tcf_action_add. However, for the case where
+a new action is created due to free index, its refcount remains one.
+This when paired with the put_many call leads to the kernel setting up
+the action, notifying userspace of its creation, and then tearing it
+down. For existing actions, the refcount is still held so they remain
+unaffected.
+
+Fortunately due to rtnl_lock serialization requirement, such an action
+with refcount == 1 will not be concurrently deleted by anything else, at
+best CLS API can move its refcount up and down by binding to it after it
+has been published from tcf_idr_insert_many. Since refcount is atleast
+one until put_many call, CLS API cannot delete it. Also __tcf_action_put
+release path already ensures deterministic outcome (either new action
+will be created or existing action will be reused in case CLS API tries
+to bind to action concurrently) due to idr lock serialization.
+
+We fix this by making refcount of newly created actions as 2 in ACT API
+replace mode. A relaxed store will suffice as visibility is ensured only
+after the tcf_idr_insert_many call.
+
+Note that in case of creation or overwriting using CLS API only (i.e.
+bind = 1), overwriting existing action object is not allowed, and any
+such request is silently ignored (without error).
+
+The refcount bump that occurs in tcf_idr_check_alloc call there for
+existing action will pair with tcf_exts_destroy call made from the
+owner module for the same action. In case of action creation, there
+is no existing action, so no tcf_exts_destroy callback happens.
+
+This means no code changes for CLS API.
+
+Fixes: cae422f379f3 ("net: sched: use reference counting action init")
+Signed-off-by: Kumar Kartikeya Dwivedi <memxor@gmail.com>
+Signed-off-by: David S. Miller <davem@davemloft.net>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ net/sched/act_api.c |    3 +++
+ 1 file changed, 3 insertions(+)
+
+--- a/net/sched/act_api.c
++++ b/net/sched/act_api.c
+@@ -1029,6 +1029,9 @@ struct tc_action *tcf_action_init_1(stru
+       if (!name)
+               a->hw_stats = hw_stats;
++      if (!bind && ovr && err == ACT_P_CREATED)
++              refcount_set(&a->tcfa_refcnt, 2);
++
+       return a;
+ err_out:
index 319d9d5d9539440fcd7d193ee3d0e2fe4c9fe00b..1cc193b388ef482e5f09c1498aca20c7ec0688ac 100644 (file)
@@ -167,3 +167,7 @@ rdma-addr-be-strict-with-gid-size.patch
 vdpa-mlx5-should-exclude-header-length-and-fcs-from-.patch
 vdpa-mlx5-fix-wrong-use-of-bit-numbers.patch
 ras-cec-correct-ce_add_elem-s-returned-values.patch
+clk-socfpga-fix-iomem-pointer-cast-on-64-bit.patch
+lockdep-address-clang-wformat-warning-printing-for-hd.patch
+dt-bindings-net-ethernet-controller-fix-typo-in-nvmem.patch
+net-sched-bump-refcount-for-new-action-in-act-replace-mode.patch