git: c20cdf8c1239 - stable/12 - pf: Add static DTrace probe points
Kristof Provost
kp at FreeBSD.org
Mon Apr 19 19:21:47 UTC 2021
The branch stable/12 has been updated by kp:
URL: https://cgit.FreeBSD.org/src/commit/?id=c20cdf8c1239efa5d0f3ce14d077b4e6e41daa6a
commit c20cdf8c1239efa5d0f3ce14d077b4e6e41daa6a
Author: Kristof Provost <kp at FreeBSD.org>
AuthorDate: 2021-04-02 13:53:34 +0000
Commit: Kristof Provost <kp at FreeBSD.org>
CommitDate: 2021-04-19 08:20:09 +0000
pf: Add static DTrace probe points
These two have proven to be useful during debugging. We may as well keep
them permanently.
Others will be added as their utility becomes clear.
Reviewed by: gnn
MFC after: 2 weeks
Sponsored by: Rubicon Communications, LLC ("Netgate")
Differential Revision: https://reviews.freebsd.org/D29555
(cherry picked from commit f4c02909167b6f791df470afddfe31cabf009c4d)
---
sys/netpfil/pf/pf.c | 15 +++++++++++++++
1 file changed, 15 insertions(+)
diff --git a/sys/netpfil/pf/pf.c b/sys/netpfil/pf/pf.c
index 155d23c9cfe1..2666fd1155ab 100644
--- a/sys/netpfil/pf/pf.c
+++ b/sys/netpfil/pf/pf.c
@@ -58,6 +58,7 @@ __FBSDID("$FreeBSD$");
#include <sys/md5.h>
#include <sys/random.h>
#include <sys/refcount.h>
+#include <sys/sdt.h>
#include <sys/socket.h>
#include <sys/sysctl.h>
#include <sys/taskqueue.h>
@@ -113,6 +114,15 @@ __FBSDID("$FreeBSD$");
#define DPFPRINTF(n, x) if (V_pf_status.debug >= (n)) printf x
+SDT_PROVIDER_DEFINE(pf);
+SDT_PROBE_DEFINE4(pf, ip, test, done, "int", "int", "struct pf_krule *",
+ "struct pf_state *");
+SDT_PROBE_DEFINE4(pf, ip, test6, done, "int", "int", "struct pf_krule *",
+ "struct pf_state *");
+SDT_PROBE_DEFINE5(pf, ip, state, lookup, "struct pfi_kkif *",
+ "struct pf_state_key_cmp *", "int", "struct pf_pdesc *",
+ "struct pf_state *");
+
/*
* Global variables
*/
@@ -327,6 +337,7 @@ VNET_DEFINE(struct pf_limit, pf_limits[PF_LIMIT_MAX]);
#define STATE_LOOKUP(i, k, d, s, pd) \
do { \
(s) = pf_find_state((i), (k), (d)); \
+ SDT_PROBE5(pf, ip, state, lookup, i, k, d, pd, (s)); \
if ((s) == NULL) \
return (PF_DROP); \
if (PACKET_LOOPED(pd)) \
@@ -6404,6 +6415,8 @@ done:
if (s)
PF_STATE_UNLOCK(s);
+ SDT_PROBE4(pf, ip, test, done, action, reason, r, s);
+
return (action);
}
#endif /* INET */
@@ -6815,6 +6828,8 @@ done:
(mtag = m_tag_find(m, PF_REASSEMBLED, NULL)) != NULL)
action = pf_refragment6(ifp, m0, mtag);
+ SDT_PROBE4(pf, ip, test6, done, action, reason, r, s);
+
return (action);
}
#endif /* INET6 */
More information about the dev-commits-src-all
mailing list