The branch main has been updated by markj:

URL: 
https://cgit.FreeBSD.org/src/commit/?id=bf115203bb8a61bd03ba23931ff0b5bf931b7d1b

commit bf115203bb8a61bd03ba23931ff0b5bf931b7d1b
Author:     Mark Johnston <ma...@freebsd.org>
AuthorDate: 2025-09-17 15:29:48 +0000
Commit:     Mark Johnston <ma...@freebsd.org>
CommitDate: 2025-09-18 22:09:49 +0000

    dtrace: Deduplicate dtrace_sync() and dtrace_xcall() implementations
    
    dtrace_xcall() is just a thin wrapper around smp_rendezvous_cpus().
    There's no need for six identical implementations to live in MD layers.
    
    No functional change intended.
    
    MFC after:      2 weeks
---
 .../contrib/opensolaris/uts/common/dtrace/dtrace.c | 25 ++++++++++++++++++++
 sys/cddl/dev/dtrace/aarch64/dtrace_subr.c          | 27 ----------------------
 sys/cddl/dev/dtrace/amd64/dtrace_subr.c            | 25 --------------------
 sys/cddl/dev/dtrace/arm/dtrace_subr.c              | 25 --------------------
 sys/cddl/dev/dtrace/i386/dtrace_subr.c             | 25 --------------------
 sys/cddl/dev/dtrace/powerpc/dtrace_subr.c          | 25 --------------------
 sys/cddl/dev/dtrace/riscv/dtrace_subr.c            | 27 ----------------------
 7 files changed, 25 insertions(+), 154 deletions(-)

diff --git a/sys/cddl/contrib/opensolaris/uts/common/dtrace/dtrace.c 
b/sys/cddl/contrib/opensolaris/uts/common/dtrace/dtrace.c
index 8078f3f6d4b1..853cfb845878 100644
--- a/sys/cddl/contrib/opensolaris/uts/common/dtrace/dtrace.c
+++ b/sys/cddl/contrib/opensolaris/uts/common/dtrace/dtrace.c
@@ -707,6 +707,31 @@ dtrace_error(uint32_t *counter)
        } while (dtrace_cas32(counter, oval, nval) != oval);
 }
 
+void
+dtrace_xcall(processorid_t cpu, dtrace_xcall_t func, void *arg)
+{
+       cpuset_t cpus;
+
+       if (cpu == DTRACE_CPUALL)
+               cpus = all_cpus;
+       else
+               CPU_SETOF(cpu, &cpus);
+
+       smp_rendezvous_cpus(cpus, smp_no_rendezvous_barrier, func,
+           smp_no_rendezvous_barrier, arg);
+}
+
+static void
+dtrace_sync_func(void)
+{
+}
+
+void
+dtrace_sync(void)
+{
+       dtrace_xcall(DTRACE_CPUALL, (dtrace_xcall_t)dtrace_sync_func, NULL);
+}
+
 /*
  * Use the DTRACE_LOADFUNC macro to define functions for each of loading a
  * uint8_t, a uint16_t, a uint32_t and a uint64_t.
diff --git a/sys/cddl/dev/dtrace/aarch64/dtrace_subr.c 
b/sys/cddl/dev/dtrace/aarch64/dtrace_subr.c
index 32e84d8fbfe9..ff880e804770 100644
--- a/sys/cddl/dev/dtrace/aarch64/dtrace_subr.c
+++ b/sys/cddl/dev/dtrace/aarch64/dtrace_subr.c
@@ -124,33 +124,6 @@ dtrace_toxic_ranges(void (*func)(uintptr_t base, uintptr_t 
limit))
        (*func)(0, (uintptr_t)VM_MIN_KERNEL_ADDRESS);
 }
 
-void
-dtrace_xcall(processorid_t cpu, dtrace_xcall_t func, void *arg)
-{
-       cpuset_t cpus;
-
-       if (cpu == DTRACE_CPUALL)
-               cpus = all_cpus;
-       else
-               CPU_SETOF(cpu, &cpus);
-
-       smp_rendezvous_cpus(cpus, smp_no_rendezvous_barrier, func,
-           smp_no_rendezvous_barrier, arg);
-}
-
-static void
-dtrace_sync_func(void)
-{
-
-}
-
-void
-dtrace_sync(void)
-{
-
-       dtrace_xcall(DTRACE_CPUALL, (dtrace_xcall_t)dtrace_sync_func, NULL);
-}
-
 static uint64_t nsec_scale;
 
 #define SCALE_SHIFT    25
diff --git a/sys/cddl/dev/dtrace/amd64/dtrace_subr.c 
b/sys/cddl/dev/dtrace/amd64/dtrace_subr.c
index 81aa53d00bd8..877d52fe18a7 100644
--- a/sys/cddl/dev/dtrace/amd64/dtrace_subr.c
+++ b/sys/cddl/dev/dtrace/amd64/dtrace_subr.c
@@ -142,31 +142,6 @@ dtrace_toxic_ranges(void (*func)(uintptr_t base, uintptr_t 
limit))
        (*func)(0, la57 ? (uintptr_t)addr_P5Tmap : (uintptr_t)addr_P4Tmap);
 }
 
-void
-dtrace_xcall(processorid_t cpu, dtrace_xcall_t func, void *arg)
-{
-       cpuset_t cpus;
-
-       if (cpu == DTRACE_CPUALL)
-               cpus = all_cpus;
-       else
-               CPU_SETOF(cpu, &cpus);
-
-       smp_rendezvous_cpus(cpus, smp_no_rendezvous_barrier, func,
-           smp_no_rendezvous_barrier, arg);
-}
-
-static void
-dtrace_sync_func(void)
-{
-}
-
-void
-dtrace_sync(void)
-{
-        dtrace_xcall(DTRACE_CPUALL, (dtrace_xcall_t)dtrace_sync_func, NULL);
-}
-
 #ifdef notyet
 void
 dtrace_safe_synchronous_signal(void)
diff --git a/sys/cddl/dev/dtrace/arm/dtrace_subr.c 
b/sys/cddl/dev/dtrace/arm/dtrace_subr.c
index bb42044aa477..10e9281709b6 100644
--- a/sys/cddl/dev/dtrace/arm/dtrace_subr.c
+++ b/sys/cddl/dev/dtrace/arm/dtrace_subr.c
@@ -138,31 +138,6 @@ dtrace_toxic_ranges(void (*func)(uintptr_t base, uintptr_t 
limit))
         */
 }
 
-void
-dtrace_xcall(processorid_t cpu, dtrace_xcall_t func, void *arg)
-{
-       cpuset_t cpus;
-
-       if (cpu == DTRACE_CPUALL)
-               cpus = all_cpus;
-       else
-               CPU_SETOF(cpu, &cpus);
-
-       smp_rendezvous_cpus(cpus, smp_no_rendezvous_barrier, func,
-           smp_no_rendezvous_barrier, arg);
-}
-
-static void
-dtrace_sync_func(void)
-{
-}
-
-void
-dtrace_sync(void)
-{
-       dtrace_xcall(DTRACE_CPUALL, (dtrace_xcall_t)dtrace_sync_func, NULL);
-}
-
 /*
  * DTrace needs a high resolution time function which can
  * be called from a probe context and guaranteed not to have
diff --git a/sys/cddl/dev/dtrace/i386/dtrace_subr.c 
b/sys/cddl/dev/dtrace/i386/dtrace_subr.c
index 026581f5a899..ebe2194a4b2f 100644
--- a/sys/cddl/dev/dtrace/i386/dtrace_subr.c
+++ b/sys/cddl/dev/dtrace/i386/dtrace_subr.c
@@ -139,31 +139,6 @@ dtrace_toxic_ranges(void (*func)(uintptr_t base, uintptr_t 
limit))
        (*func)(0, kernelbase);
 }
 
-void
-dtrace_xcall(processorid_t cpu, dtrace_xcall_t func, void *arg)
-{
-       cpuset_t cpus;
-
-       if (cpu == DTRACE_CPUALL)
-               cpus = all_cpus;
-       else
-               CPU_SETOF(cpu, &cpus);
-
-       smp_rendezvous_cpus(cpus, smp_no_rendezvous_barrier, func,
-           smp_no_rendezvous_barrier, arg);
-}
-
-static void
-dtrace_sync_func(void)
-{
-}
-
-void
-dtrace_sync(void)
-{
-        dtrace_xcall(DTRACE_CPUALL, (dtrace_xcall_t)dtrace_sync_func, NULL);
-}
-
 #ifdef notyet
 void
 dtrace_safe_synchronous_signal(void)
diff --git a/sys/cddl/dev/dtrace/powerpc/dtrace_subr.c 
b/sys/cddl/dev/dtrace/powerpc/dtrace_subr.c
index 5dd083310e6f..ee8be8da642f 100644
--- a/sys/cddl/dev/dtrace/powerpc/dtrace_subr.c
+++ b/sys/cddl/dev/dtrace/powerpc/dtrace_subr.c
@@ -123,31 +123,6 @@ dtrace_toxic_ranges(void (*func)(uintptr_t base, uintptr_t 
limit))
         */
 }
 
-void
-dtrace_xcall(processorid_t cpu, dtrace_xcall_t func, void *arg)
-{
-       cpuset_t cpus;
-
-       if (cpu == DTRACE_CPUALL)
-               cpus = all_cpus;
-       else
-               CPU_SETOF(cpu, &cpus);
-
-       smp_rendezvous_cpus(cpus, smp_no_rendezvous_barrier, func,
-                       smp_no_rendezvous_barrier, arg);
-}
-
-static void
-dtrace_sync_func(void)
-{
-}
-
-void
-dtrace_sync(void)
-{
-       dtrace_xcall(DTRACE_CPUALL, (dtrace_xcall_t)dtrace_sync_func, NULL);
-}
-
 static int64_t tgt_cpu_tsc;
 static int64_t hst_cpu_tsc;
 static int64_t timebase_skew[MAXCPU];
diff --git a/sys/cddl/dev/dtrace/riscv/dtrace_subr.c 
b/sys/cddl/dev/dtrace/riscv/dtrace_subr.c
index 3a6aacd86fcd..ed2c0bdba7e2 100644
--- a/sys/cddl/dev/dtrace/riscv/dtrace_subr.c
+++ b/sys/cddl/dev/dtrace/riscv/dtrace_subr.c
@@ -127,33 +127,6 @@ dtrace_toxic_ranges(void (*func)(uintptr_t base, uintptr_t 
limit))
        (*func)(0, (uintptr_t)VM_MIN_KERNEL_ADDRESS);
 }
 
-void
-dtrace_xcall(processorid_t cpu, dtrace_xcall_t func, void *arg)
-{
-       cpuset_t cpus;
-
-       if (cpu == DTRACE_CPUALL)
-               cpus = all_cpus;
-       else
-               CPU_SETOF(cpu, &cpus);
-
-       smp_rendezvous_cpus(cpus, smp_no_rendezvous_barrier, func,
-           smp_no_rendezvous_barrier, arg);
-}
-
-static void
-dtrace_sync_func(void)
-{
-
-}
-
-void
-dtrace_sync(void)
-{
-
-       dtrace_xcall(DTRACE_CPUALL, (dtrace_xcall_t)dtrace_sync_func, NULL);
-}
-
 /*
  * DTrace needs a high resolution time function which can
  * be called from a probe context and guaranteed not to have

Reply via email to