summaryrefslogtreecommitdiff
path: root/include/net/dropreason-core.h
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2023-04-19 15:52:53 +0300
committerJakub Kicinski <kuba@kernel.org>2023-04-21 06:20:49 +0300
commit071c0fc6fb919dcf29c676a842dda08a674877d7 (patch)
tree7062c1fde75461ef4cb2a5a3395f6d56b8812b70 /include/net/dropreason-core.h
parent5b8285cca6fed9bc5baabe2e5699a5a5c0d96371 (diff)
downloadlinux-071c0fc6fb919dcf29c676a842dda08a674877d7.tar.xz
net: extend drop reasons for multiple subsystems
Extend drop reasons to make them usable by subsystems other than core by reserving the high 16 bits for a new subsystem ID, of which 0 of course is used for the existing reasons immediately. To still be able to have string reasons, restructure that code a bit to make the loopup under RCU, the only user of this (right now) is drop_monitor. Link: https://lore.kernel.org/netdev/00659771ed54353f92027702c5bbb84702da62ce.camel@sipsolutions.net Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'include/net/dropreason-core.h')
-rw-r--r--include/net/dropreason-core.h14
1 files changed, 10 insertions, 4 deletions
diff --git a/include/net/dropreason-core.h b/include/net/dropreason-core.h
index ade6d5b9186c..a2b953b57689 100644
--- a/include/net/dropreason-core.h
+++ b/include/net/dropreason-core.h
@@ -340,12 +340,20 @@ enum skb_drop_reason {
*/
SKB_DROP_REASON_IPV6_NDISC_NS_OTHERHOST,
/**
- * @SKB_DROP_REASON_MAX: the maximum of drop reason, which shouldn't be
- * used as a real 'reason'
+ * @SKB_DROP_REASON_MAX: the maximum of core drop reasons, which
+ * shouldn't be used as a real 'reason' - only for tracing code gen
*/
SKB_DROP_REASON_MAX,
+
+ /**
+ * @SKB_DROP_REASON_SUBSYS_MASK: subsystem mask in drop reasons,
+ * see &enum skb_drop_reason_subsys
+ */
+ SKB_DROP_REASON_SUBSYS_MASK = 0xffff0000,
};
+#define SKB_DROP_REASON_SUBSYS_SHIFT 16
+
#define SKB_DR_INIT(name, reason) \
enum skb_drop_reason name = SKB_DROP_REASON_##reason
#define SKB_DR(name) \
@@ -359,6 +367,4 @@ enum skb_drop_reason {
SKB_DR_SET(name, reason); \
} while (0)
-extern const char * const drop_reasons[];
-
#endif