From: Sasha Levin <sashal@kernel.org>
To: patches@lists.linux.dev, stable@vger.kernel.org
Cc: Martin KaFai Lau <martin.lau@kernel.org>,
Kumar Kartikeya Dwivedi <memxor@gmail.com>,
Alexei Starovoitov <ast@kernel.org>,
Sasha Levin <sashal@kernel.org>,
daniel@iogearbox.net, andrii@kernel.org, bpf@vger.kernel.org
Subject: [PATCH AUTOSEL 6.15 068/118] bpf: Add bpf_rbtree_{root,left,right} kfunc
Date: Tue, 3 Jun 2025 20:49:59 -0400 [thread overview]
Message-ID: <20250604005049.4147522-68-sashal@kernel.org> (raw)
In-Reply-To: <20250604005049.4147522-1-sashal@kernel.org>
From: Martin KaFai Lau <martin.lau@kernel.org>
[ Upstream commit 9e3e66c553f705de51707c7ddc7f35ce159a8ef1 ]
In a bpf fq implementation that is much closer to the kernel fq,
it will need to traverse the rbtree:
https://lore.kernel.org/bpf/20250418224652.105998-13-martin.lau@linux.dev/
The much simplified logic that uses the bpf_rbtree_{root,left,right}
to traverse the rbtree is like:
struct fq_flow {
struct bpf_rb_node fq_node;
struct bpf_rb_node rate_node;
struct bpf_refcount refcount;
unsigned long sk_long;
};
struct fq_flow_root {
struct bpf_spin_lock lock;
struct bpf_rb_root root __contains(fq_flow, fq_node);
};
struct fq_flow *fq_classify(...)
{
struct bpf_rb_node *tofree[FQ_GC_MAX];
struct fq_flow_root *root;
struct fq_flow *gc_f, *f;
struct bpf_rb_node *p;
int i, fcnt = 0;
/* ... */
f = NULL;
bpf_spin_lock(&root->lock);
p = bpf_rbtree_root(&root->root);
while (can_loop) {
if (!p)
break;
gc_f = bpf_rb_entry(p, struct fq_flow, fq_node);
if (gc_f->sk_long == sk_long) {
f = bpf_refcount_acquire(gc_f);
break;
}
/* To be removed from the rbtree */
if (fcnt < FQ_GC_MAX && fq_gc_candidate(gc_f, jiffies_now))
tofree[fcnt++] = p;
if (gc_f->sk_long > sk_long)
p = bpf_rbtree_left(&root->root, p);
else
p = bpf_rbtree_right(&root->root, p);
}
/* remove from the rbtree */
for (i = 0; i < fcnt; i++) {
p = tofree[i];
tofree[i] = bpf_rbtree_remove(&root->root, p);
}
bpf_spin_unlock(&root->lock);
/* bpf_obj_drop the fq_flow(s) that have just been removed
* from the rbtree.
*/
for (i = 0; i < fcnt; i++) {
p = tofree[i];
if (p) {
gc_f = bpf_rb_entry(p, struct fq_flow, fq_node);
bpf_obj_drop(gc_f);
}
}
return f;
}
The above simplified code needs to traverse the rbtree for two purposes,
1) find the flow with the desired sk_long value
2) while searching for the sk_long, collect flows that are
the fq_gc_candidate. They will be removed from the rbtree.
This patch adds the bpf_rbtree_{root,left,right} kfunc to enable
the rbtree traversal. The returned bpf_rb_node pointer will be a
non-owning reference which is the same as the returned pointer
of the exisiting bpf_rbtree_first kfunc.
Acked-by: Kumar Kartikeya Dwivedi <memxor@gmail.com>
Signed-off-by: Martin KaFai Lau <martin.lau@kernel.org>
Link: https://lore.kernel.org/r/20250506015857.817950-4-martin.lau@linux.dev
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
---
NO This commit should not be backported to stable kernel trees. Here's
my extensive analysis: ## Primary Reason: New Feature Addition This
commit adds three new kfunc functions (`bpf_rbtree_root`,
`bpf_rbtree_left`, `bpf_rbtree_right`) to the BPF rbtree API. These are
entirely new capabilities that enable rbtree traversal functionality
that did not exist before. ## Specific Code Analysis ### 1. New Function
Implementations ```c __bpf_kfunc struct bpf_rb_node
*bpf_rbtree_root(struct bpf_rb_root *root) { struct rb_root_cached *r =
(struct rb_root_cached *)root; return (struct bpf_rb_node
*)r->rb_root.rb_node; } __bpf_kfunc struct bpf_rb_node
*bpf_rbtree_left(struct bpf_rb_root *root, struct bpf_rb_node *node) {
struct bpf_rb_node_kern *node_internal = (struct bpf_rb_node_kern
*)node; if (READ_ONCE(node_internal->owner) != root) return NULL; return
(struct bpf_rb_node *)node_internal->rb_node.rb_left; } __bpf_kfunc
struct bpf_rb_node *bpf_rbtree_right(struct bpf_rb_root *root, struct
bpf_rb_node *node) { struct bpf_rb_node_kern *node_internal = (struct
bpf_rb_node_kern *)node; if (READ_ONCE(node_internal->owner) != root)
return NULL; return (struct bpf_rb_node
*)node_internal->rb_node.rb_right; } ``` These are completely new
functions that extend the BPF API surface, which is characteristic of
feature additions rather than bug fixes. ### 2. Verifier Infrastructure
Expansion The commit adds these new functions to multiple verifier
tables: ```c enum special_kfunc_type { // ... existing entries ...
KF_bpf_rbtree_root, KF_bpf_rbtree_left, KF_bpf_rbtree_right, // ... }
BTF_SET_START(special_kfunc_set) // ... existing entries ...
BTF_ID(func, bpf_rbtree_root) BTF_ID(func, bpf_rbtree_left) BTF_ID(func,
bpf_rbtree_right) BTF_SET_END(special_kfunc_set) ``` This systematic
addition to verifier infrastructure demonstrates this is an API
expansion, not a fix. ### 3. Enhanced Function Classification Logic ```c
static bool is_bpf_rbtree_api_kfunc(u32 btf_id) { return btf_id ==
special_kfunc_list[KF_bpf_rbtree_add_impl] || btf_id ==
special_kfunc_list[KF_bpf_rbtree_remove] || btf_id ==
special_kfunc_list[KF_bpf_rbtree_first] || + btf_id ==
special_kfunc_list[KF_bpf_rbtree_root] || + btf_id ==
special_kfunc_list[KF_bpf_rbtree_left] || + btf_id ==
special_kfunc_list[KF_bpf_rbtree_right]; } ``` The functions are being
added to existing classification systems, expanding the API scope. ###
4. New Argument Validation Logic ```c static bool
check_kfunc_is_graph_node_api(struct bpf_verifier_env *env, enum
btf_field_type node_field_type, u32 kfunc_btf_id) { // ... existing
logic ... case BPF_RB_NODE: ret = (kfunc_btf_id ==
special_kfunc_list[KF_bpf_rbtree_remove] || kfunc_btf_id ==
special_kfunc_list[KF_bpf_rbtree_add_impl] || + kfunc_btf_id ==
special_kfunc_list[KF_bpf_rbtree_left] || + kfunc_btf_id ==
special_kfunc_list[KF_bpf_rbtree_right]); break; } ``` This adds new
argument validation paths for the new functions. ## Comparison with
Similar Commits Looking at the historical examples: - **Similar Commit
#1 (YES)**: Added basic rbtree kfuncs - this was part of the
foundational rbtree infrastructure - **Similar Commit #2 (YES)**: Added
argument support for rbtree types - essential for the basic
functionality - **Similar Commit #3 (NO)**: Added function declarations
to test headers - clearly test infrastructure - **Similar Commit #4
(NO)**: Added special verifier handling - complex new feature logic -
**Similar Commit #5 (YES)**: Added basic BTF support for rbtree types -
foundational infrastructure ## Use Case Analysis The commit message
describes a complex use case for implementing a Fair Queuing (FQ)
algorithm that requires traversal capabilities. This is clearly an
advanced feature for specialized networking applications, not a bug fix
for existing functionality. ## Risk Assessment Adding new kfuncs carries
several risks: 1. **API Stability**: New functions become part of the
stable ABI 2. **Complexity**: Introduces new code paths in verifier
logic 3. **Testing**: New functionality may not have complete test
coverage in stable kernels 4. **Dependencies**: May rely on other recent
changes not present in stable trees ## Conclusion This commit represents
a clear feature addition that extends the BPF rbtree API with new
traversal capabilities. It does not fix any existing bugs or address
critical issues. The functionality is designed for advanced use cases
and represents an expansion of the BPF programming model rather than
maintenance of existing capabilities. Following stable tree guidelines,
this should remain in mainline development kernels and not be backported
to stable releases.
kernel/bpf/helpers.c | 30 ++++++++++++++++++++++++++++++
kernel/bpf/verifier.c | 22 ++++++++++++++++++----
2 files changed, 48 insertions(+), 4 deletions(-)
diff --git a/kernel/bpf/helpers.c b/kernel/bpf/helpers.c
index a71aa4cb85fae..6a55198c2d9ad 100644
--- a/kernel/bpf/helpers.c
+++ b/kernel/bpf/helpers.c
@@ -2367,6 +2367,33 @@ __bpf_kfunc struct bpf_rb_node *bpf_rbtree_first(struct bpf_rb_root *root)
return (struct bpf_rb_node *)rb_first_cached(r);
}
+__bpf_kfunc struct bpf_rb_node *bpf_rbtree_root(struct bpf_rb_root *root)
+{
+ struct rb_root_cached *r = (struct rb_root_cached *)root;
+
+ return (struct bpf_rb_node *)r->rb_root.rb_node;
+}
+
+__bpf_kfunc struct bpf_rb_node *bpf_rbtree_left(struct bpf_rb_root *root, struct bpf_rb_node *node)
+{
+ struct bpf_rb_node_kern *node_internal = (struct bpf_rb_node_kern *)node;
+
+ if (READ_ONCE(node_internal->owner) != root)
+ return NULL;
+
+ return (struct bpf_rb_node *)node_internal->rb_node.rb_left;
+}
+
+__bpf_kfunc struct bpf_rb_node *bpf_rbtree_right(struct bpf_rb_root *root, struct bpf_rb_node *node)
+{
+ struct bpf_rb_node_kern *node_internal = (struct bpf_rb_node_kern *)node;
+
+ if (READ_ONCE(node_internal->owner) != root)
+ return NULL;
+
+ return (struct bpf_rb_node *)node_internal->rb_node.rb_right;
+}
+
/**
* bpf_task_acquire - Acquire a reference to a task. A task acquired by this
* kfunc which is not stored in a map as a kptr, must be released by calling
@@ -3215,6 +3242,9 @@ BTF_ID_FLAGS(func, bpf_task_release, KF_RELEASE)
BTF_ID_FLAGS(func, bpf_rbtree_remove, KF_ACQUIRE | KF_RET_NULL)
BTF_ID_FLAGS(func, bpf_rbtree_add_impl)
BTF_ID_FLAGS(func, bpf_rbtree_first, KF_RET_NULL)
+BTF_ID_FLAGS(func, bpf_rbtree_root, KF_RET_NULL)
+BTF_ID_FLAGS(func, bpf_rbtree_left, KF_RET_NULL)
+BTF_ID_FLAGS(func, bpf_rbtree_right, KF_RET_NULL)
#ifdef CONFIG_CGROUPS
BTF_ID_FLAGS(func, bpf_cgroup_acquire, KF_ACQUIRE | KF_RCU | KF_RET_NULL)
diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c
index 54c6953a8b84c..180b4edd2392b 100644
--- a/kernel/bpf/verifier.c
+++ b/kernel/bpf/verifier.c
@@ -12076,6 +12076,9 @@ enum special_kfunc_type {
KF_bpf_rbtree_remove,
KF_bpf_rbtree_add_impl,
KF_bpf_rbtree_first,
+ KF_bpf_rbtree_root,
+ KF_bpf_rbtree_left,
+ KF_bpf_rbtree_right,
KF_bpf_dynptr_from_skb,
KF_bpf_dynptr_from_xdp,
KF_bpf_dynptr_slice,
@@ -12116,6 +12119,9 @@ BTF_ID(func, bpf_rdonly_cast)
BTF_ID(func, bpf_rbtree_remove)
BTF_ID(func, bpf_rbtree_add_impl)
BTF_ID(func, bpf_rbtree_first)
+BTF_ID(func, bpf_rbtree_root)
+BTF_ID(func, bpf_rbtree_left)
+BTF_ID(func, bpf_rbtree_right)
#ifdef CONFIG_NET
BTF_ID(func, bpf_dynptr_from_skb)
BTF_ID(func, bpf_dynptr_from_xdp)
@@ -12151,6 +12157,9 @@ BTF_ID(func, bpf_rcu_read_unlock)
BTF_ID(func, bpf_rbtree_remove)
BTF_ID(func, bpf_rbtree_add_impl)
BTF_ID(func, bpf_rbtree_first)
+BTF_ID(func, bpf_rbtree_root)
+BTF_ID(func, bpf_rbtree_left)
+BTF_ID(func, bpf_rbtree_right)
#ifdef CONFIG_NET
BTF_ID(func, bpf_dynptr_from_skb)
BTF_ID(func, bpf_dynptr_from_xdp)
@@ -12586,7 +12595,10 @@ static bool is_bpf_rbtree_api_kfunc(u32 btf_id)
{
return btf_id == special_kfunc_list[KF_bpf_rbtree_add_impl] ||
btf_id == special_kfunc_list[KF_bpf_rbtree_remove] ||
- btf_id == special_kfunc_list[KF_bpf_rbtree_first];
+ btf_id == special_kfunc_list[KF_bpf_rbtree_first] ||
+ btf_id == special_kfunc_list[KF_bpf_rbtree_root] ||
+ btf_id == special_kfunc_list[KF_bpf_rbtree_left] ||
+ btf_id == special_kfunc_list[KF_bpf_rbtree_right];
}
static bool is_bpf_iter_num_api_kfunc(u32 btf_id)
@@ -12686,7 +12698,9 @@ static bool check_kfunc_is_graph_node_api(struct bpf_verifier_env *env,
break;
case BPF_RB_NODE:
ret = (kfunc_btf_id == special_kfunc_list[KF_bpf_rbtree_remove] ||
- kfunc_btf_id == special_kfunc_list[KF_bpf_rbtree_add_impl]);
+ kfunc_btf_id == special_kfunc_list[KF_bpf_rbtree_add_impl] ||
+ kfunc_btf_id == special_kfunc_list[KF_bpf_rbtree_left] ||
+ kfunc_btf_id == special_kfunc_list[KF_bpf_rbtree_right]);
break;
default:
verbose(env, "verifier internal error: unexpected graph node argument type %s\n",
@@ -13202,11 +13216,11 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
case KF_ARG_PTR_TO_RB_NODE:
if (meta->func_id == special_kfunc_list[KF_bpf_rbtree_remove]) {
if (!type_is_non_owning_ref(reg->type) || reg->ref_obj_id) {
- verbose(env, "rbtree_remove node input must be non-owning ref\n");
+ verbose(env, "%s node input must be non-owning ref\n", func_name);
return -EINVAL;
}
if (in_rbtree_lock_required_cb(env)) {
- verbose(env, "rbtree_remove not allowed in rbtree cb\n");
+ verbose(env, "%s not allowed in rbtree cb\n", func_name);
return -EINVAL;
}
} else {
--
2.39.5
next prev parent reply other threads:[~2025-06-04 0:53 UTC|newest]
Thread overview: 127+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-06-04 0:48 [PATCH AUTOSEL 6.15 001/118] net: macb: Check return value of dma_set_mask_and_coherent() Sasha Levin
2025-06-04 0:48 ` [PATCH AUTOSEL 6.15 002/118] net: lan743x: Modify the EEPROM and OTP size for PCI1xxxx devices Sasha Levin
2025-06-04 0:48 ` [PATCH AUTOSEL 6.15 003/118] tipc: use kfree_sensitive() for aead cleanup Sasha Levin
2025-06-04 0:48 ` [PATCH AUTOSEL 6.15 004/118] f2fs: use vmalloc instead of kvmalloc in .init_{,de}compress_ctx Sasha Levin
2025-06-04 0:48 ` [PATCH AUTOSEL 6.15 005/118] bpf: Check rcu_read_lock_trace_held() in bpf_map_lookup_percpu_elem() Sasha Levin
2025-06-04 0:48 ` [PATCH AUTOSEL 6.15 006/118] Bluetooth: btusb: Add new VID/PID 13d3/3584 for MT7922 Sasha Levin
2025-06-04 0:48 ` [PATCH AUTOSEL 6.15 007/118] i2c: designware: Invoke runtime suspend on quick slave re-registration Sasha Levin
2025-06-04 0:48 ` [PATCH AUTOSEL 6.15 008/118] wifi: mt76: mt7996: drop fragments with multicast or broadcast RA Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 009/118] emulex/benet: correct command version selection in be_cmd_get_stats() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 010/118] Bluetooth: btusb: Add new VID/PID 13d3/3630 for MT7925 Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 011/118] Bluetooth: btusb: Add RTL8851BE device 0x0bda:0xb850 Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 012/118] Bluetooth: ISO: Fix not using SID from adv report Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 013/118] Bluetooth: btmrvl_sdio: Fix wakeup source leaks on device unbind Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 014/118] Bluetooth: btmtksdio: " Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 015/118] wifi: mt76: mt7996: fix uninitialized symbol warning Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 016/118] wifi: mt76: mt76x2: Add support for LiteOn WN4516R,WN4519R Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 017/118] wifi: mt76: mt7921: add 160 MHz AP for mt7922 device Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 018/118] wifi: mt76: mt7925: introduce thermal protection Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 019/118] wifi: mac80211: validate SCAN_FLAG_AP in scan request during MLO Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 020/118] sctp: Do not wake readers in __sctp_write_space() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 021/118] libbpf/btf: Fix string handling to support multi-split BTF Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 022/118] cpufreq: scmi: Skip SCMI devices that aren't used by the CPUs Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 023/118] i2c: tegra: check msg length in SMBUS block read Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 024/118] i2c: pasemi: Enable the unjam machine Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 025/118] i2c: npcm: Add clock toggle recovery Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 026/118] clk: qcom: gcc-x1e80100: Set FORCE MEM CORE for UFS clocks Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 027/118] clk: qcom: gcc: Set FORCE_MEM_CORE_ON for gcc_ufs_axi_clk for 8650/8750 Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 028/118] net: dlink: add synchronization for stats update Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 029/118] net: phy: mediatek: do not require syscon compatible for pio property Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 030/118] wifi: ath12k: fix macro definition HAL_RX_MSDU_PKT_LENGTH_GET Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 031/118] wifi: ath12k: fix a possible dead lock caused by ab->base_lock Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 032/118] wifi: ath11k: Fix QMI memory reuse logic Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 033/118] iommu/amd: Allow matching ACPI HID devices without matching UIDs Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 034/118] wifi: rtw89: leave idle mode when setting WEP encryption for AP mode Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 035/118] tcp: always seek for minimal rtt in tcp_rcv_rtt_update() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 036/118] tcp: remove zero TCP TS samples for autotuning Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 037/118] tcp: fix initial tp->rcvq_space.space value for passive TS enabled flows Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 038/118] tcp: add receive queue awareness in tcp_rcv_space_adjust() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 039/118] x86/sgx: Prevent attempts to reclaim poisoned pages Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 040/118] ipv4/route: Use this_cpu_inc() for stats on PREEMPT_RT Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 041/118] net: page_pool: Don't recycle into cache " Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 042/118] xfrm: validate assignment of maximal possible SEQ number Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 043/118] net: phy: marvell-88q2xxx: Enable temperature measurement in probe again Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 044/118] openvswitch: Stricter validation for the userspace action Sasha Levin
2025-06-04 7:57 ` Ilya Maximets
2025-06-04 8:03 ` Greg KH
2025-06-04 8:19 ` Ilya Maximets
2025-06-04 8:28 ` Greg KH
2025-06-04 8:47 ` Ilya Maximets
2025-06-05 14:23 ` Jakub Kicinski
2025-06-05 14:45 ` Greg KH
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 045/118] net: atlantic: generate software timestamp just before the doorbell Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 046/118] pinctrl: armada-37xx: propagate error from armada_37xx_pmx_set_by_name() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 047/118] pinctrl: armada-37xx: propagate error from armada_37xx_gpio_get_direction() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 048/118] bpf: Pass the same orig_call value to trampoline functions Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 049/118] net: stmmac: generate software timestamp just before the doorbell Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 050/118] pinctrl: armada-37xx: propagate error from armada_37xx_pmx_gpio_set_direction() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 051/118] libbpf: Check bpf_map_skeleton link for NULL Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 052/118] pinctrl: armada-37xx: propagate error from armada_37xx_gpio_get() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 053/118] net/mlx5: HWS, fix counting of rules in the matcher Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 054/118] net: mlx4: add SOF_TIMESTAMPING_TX_SOFTWARE flag when getting ts info Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 055/118] net: vertexcom: mse102x: Return code for mse102x_rx_pkt_spi Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 056/118] wifi: rtw88: rtw8822bu VID/PID for BUFFALO WI-U2-866DM Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 057/118] wifi: iwlwifi: mld: call thermal exit without wiphy lock held Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 058/118] wireless: purelifi: plfxlc: fix memory leak in plfxlc_usb_wreq_asyn() Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 059/118] wifi: mac80211: do not offer a mesh path if forwarding is disabled Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 060/118] bpftool: Fix cgroup command to only show cgroup bpf programs Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 061/118] clk: rockchip: rk3036: mark ddrphy as critical Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 062/118] hid-asus: check ROG Ally MCU version and warn Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 063/118] ipmi:ssif: Fix a shutdown race Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 064/118] rtla: Define __NR_sched_setattr for LoongArch Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 065/118] wifi: iwlwifi: mvm: fix beacon CCK flag Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 066/118] wifi: iwlwifi: dvm: pair transport op-mode enter/leave Sasha Levin
2025-06-04 0:49 ` [PATCH AUTOSEL 6.15 067/118] wifi: iwlwifi: mld: check for NULL before referencing a pointer Sasha Levin
2025-06-04 0:49 ` Sasha Levin [this message]
2025-06-14 4:29 ` [PATCH AUTOSEL 6.15 068/118] bpf: Add bpf_rbtree_{root,left,right} kfunc Shung-Hsi Yu
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 069/118] f2fs: fix to bail out in get_new_segment() Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 070/118] tracing: Only return an adjusted address if it matches the kernel address Sasha Levin
2025-06-04 1:15 ` Steven Rostedt
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 071/118] netfilter: nft_set_pipapo: clamp maximum map bucket size to INT_MAX Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 072/118] libbpf: Add identical pointer detection to btf_dedup_is_equiv() Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 073/118] scsi: lpfc: Fix lpfc_check_sli_ndlp() handling for GEN_REQUEST64 commands Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 074/118] scsi: smartpqi: Add new PCI IDs Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 075/118] iommu/amd: Ensure GA log notifier callbacks finish running before module unload Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 076/118] wifi: iwlwifi: pcie: make sure to lock rxq->read Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 077/118] wifi: rtw89: 8922a: fix TX fail with wrong VCO setting Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 078/118] wifi: mac80211_hwsim: Prevent tsf from setting if beacon is disabled Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 079/118] netdevsim: Mark NAPI ID on skb in nsim_rcv Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 080/118] net/mlx5: HWS, Fix IP version decision Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 081/118] bpf: Use proper type to calculate bpf_raw_tp_null_args.mask index Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 082/118] wifi: mac80211: VLAN traffic in multicast path Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 083/118] Revert "mac80211: Dynamically set CoDel parameters per station" Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 084/118] wifi: iwlwifi: Add missing MODULE_FIRMWARE for Qu-c0-jf-b0 Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 085/118] net: bridge: mcast: update multicast contex when vlan state is changed Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 086/118] net: bridge: mcast: re-implement br_multicast_{enable, disable}_port functions Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 087/118] vxlan: Do not treat dst cache initialization errors as fatal Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 088/118] bnxt_en: Remove unused field "ref_count" in struct bnxt_ulp Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 089/118] vxlan: Add RCU read-side critical sections in the Tx path Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 090/118] wifi: ath12k: correctly handle mcast packets for clients Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 091/118] wifi: ath12k: using msdu end descriptor to check for rx multicast packets Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 092/118] iommu: Avoid introducing more races Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 093/118] net: ethernet: ti: am65-cpsw: handle -EPROBE_DEFER Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 094/118] software node: Correct a OOB check in software_node_get_reference_args() Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 095/118] wifi: ath12k: make assoc link associate first Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 096/118] isofs: fix Y2038 and Y2156 issues in Rock Ridge TF entry Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 097/118] pinctrl: mcp23s08: Reset all pins to input at probe Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 098/118] wifi: ath12k: fix failed to set mhi state error during reboot with hardware grouping Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 099/118] scsi: lpfc: Use memcpy() for BIOS version Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 100/118] sock: Correct error checking condition for (assign|release)_proto_idx() Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 101/118] i40e: fix MMIO write access to an invalid page in i40e_clear_hw Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 102/118] ixgbe: Fix unreachable retry logic in combined and byte I2C write functions Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 103/118] RDMA/hns: initialize db in update_srq_db() Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 104/118] ice: fix check for existing switch rule Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 105/118] usbnet: asix AX88772: leave the carrier control to phylink Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 106/118] f2fs: fix to set atomic write status more clear Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 107/118] bpf, sockmap: Fix data lost during EAGAIN retries Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 108/118] net: ethernet: cortina: Use TOE/TSO on all TCP Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 109/118] octeontx2-pf: Add error log forcn10k_map_unmap_rq_policer() Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 110/118] wifi: rtw88: Set AMPDU factor to hardware for RTL8814A Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 111/118] wifi: ath12k: Fix incorrect rates sent to firmware Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 112/118] wifi: ath12k: Fix the enabling of REO queue lookup table feature Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 113/118] wifi: ath12k: Fix memory leak due to multiple rx_stats allocation Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 114/118] wifi: ath11k: determine PM policy based on machine model Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 115/118] wifi: ath12k: fix link valid field initialization in the monitor Rx Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 116/118] wifi: ath12k: fix incorrect CE addresses Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 117/118] wifi: ath12k: Pass correct values of center freq1 and center freq2 for 160 MHz Sasha Levin
2025-06-04 0:50 ` [PATCH AUTOSEL 6.15 118/118] net/mlx5: HWS, Harden IP version definer checks Sasha Levin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250604005049.4147522-68-sashal@kernel.org \
--to=sashal@kernel.org \
--cc=andrii@kernel.org \
--cc=ast@kernel.org \
--cc=bpf@vger.kernel.org \
--cc=daniel@iogearbox.net \
--cc=martin.lau@kernel.org \
--cc=memxor@gmail.com \
--cc=patches@lists.linux.dev \
--cc=stable@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox