mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-16 09:50:26 +00:00
bad01d4806
Removed because they are upstream: generic/pending-5.15/110-v6.3-0001-spidev-Add-Silicon-Labs-EM3581-device-compatible.patch https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=linux-5.15.y&id=bff165a3993683daddf3f00563960e7675966f91 ipq807x/patches-5.15/0004-v5.16-arm64-dts-qcom-msm8996-Move-clock-cells-to-QMP-PHY-c.patch https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=linux-5.15.y&id=32f0e52f16d45d743b473659329f93d4a27c68bf Manually adapted: bcm27xx/patches-5.15/950-0040-spi-spidev-Completely-disable-the-spidev-warning.patch bcm27xx/patches-5.15/950-0578-spi-spidev-Restore-loading-from-Device-Tree.patch generic/pending-5.15/110-v6.3-0002-spidev-Add-Silicon-Labs-SI3210-device-compatible.patch Adapt kernel configuration for newly added option CONFIG_ARM64_ERRATUM_3194386. The leddev_list_lock attribute changed from rwlock_t to spinlock_t in: https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=linux-5.15.y&id=590304b798a3b89e716b6b564f8ad14bc9373d93 Link: https://github.com/openwrt/openwrt/pull/16366 Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
77 lines
2.0 KiB
Diff
77 lines
2.0 KiB
Diff
From 0d37e6edc09c99e683dd91ca0e83bbc0df8477b3 Mon Sep 17 00:00:00 2001
|
|
From: Felix Fietkau <nbd@nbd.name>
|
|
Date: Sun, 16 Jul 2017 16:56:10 +0200
|
|
Subject: lib: add uevent_next_seqnum()
|
|
|
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
---
|
|
include/linux/kobject.h | 5 +++++
|
|
lib/kobject_uevent.c | 37 +++++++++++++++++++++++++++++++++++++
|
|
2 files changed, 42 insertions(+)
|
|
|
|
--- a/include/linux/kobject.h
|
|
+++ b/include/linux/kobject.h
|
|
@@ -32,6 +32,8 @@
|
|
#define UEVENT_NUM_ENVP 64 /* number of env pointers */
|
|
#define UEVENT_BUFFER_SIZE 2048 /* buffer for the variables */
|
|
|
|
+struct sk_buff;
|
|
+
|
|
#ifdef CONFIG_UEVENT_HELPER
|
|
/* path to the userspace helper executed on an event */
|
|
extern char uevent_helper[];
|
|
@@ -244,4 +246,7 @@ int kobject_synth_uevent(struct kobject
|
|
__printf(2, 3)
|
|
int add_uevent_var(struct kobj_uevent_env *env, const char *format, ...);
|
|
|
|
+int broadcast_uevent(struct sk_buff *skb, __u32 pid, __u32 group,
|
|
+ gfp_t allocation);
|
|
+
|
|
#endif /* _KOBJECT_H_ */
|
|
--- a/lib/kobject_uevent.c
|
|
+++ b/lib/kobject_uevent.c
|
|
@@ -706,6 +706,43 @@ int add_uevent_var(struct kobj_uevent_en
|
|
EXPORT_SYMBOL_GPL(add_uevent_var);
|
|
|
|
#if defined(CONFIG_NET)
|
|
+int broadcast_uevent(struct sk_buff *skb, __u32 pid, __u32 group,
|
|
+ gfp_t allocation)
|
|
+{
|
|
+ struct uevent_sock *ue_sk;
|
|
+ int err = 0;
|
|
+
|
|
+ /* send netlink message */
|
|
+ mutex_lock(&uevent_sock_mutex);
|
|
+ list_for_each_entry(ue_sk, &uevent_sock_list, list) {
|
|
+ struct sock *uevent_sock = ue_sk->sk;
|
|
+ struct sk_buff *skb2;
|
|
+
|
|
+ skb2 = skb_clone(skb, allocation);
|
|
+ if (!skb2)
|
|
+ break;
|
|
+
|
|
+ err = netlink_broadcast(uevent_sock, skb2, pid, group,
|
|
+ allocation);
|
|
+ if (err)
|
|
+ break;
|
|
+ }
|
|
+ mutex_unlock(&uevent_sock_mutex);
|
|
+
|
|
+ kfree_skb(skb);
|
|
+ return err;
|
|
+}
|
|
+#else
|
|
+int broadcast_uevent(struct sk_buff *skb, __u32 pid, __u32 group,
|
|
+ gfp_t allocation)
|
|
+{
|
|
+ kfree_skb(skb);
|
|
+ return 0;
|
|
+}
|
|
+#endif
|
|
+EXPORT_SYMBOL_GPL(broadcast_uevent);
|
|
+
|
|
+#if defined(CONFIG_NET)
|
|
static int uevent_net_broadcast(struct sock *usk, struct sk_buff *skb,
|
|
struct netlink_ext_ack *extack)
|
|
{
|