summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sys/kern/kern_ktr.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/sys/kern/kern_ktr.c b/sys/kern/kern_ktr.c
index 01467d1..65a4ac6 100644
--- a/sys/kern/kern_ktr.c
+++ b/sys/kern/kern_ktr.c
@@ -128,7 +128,15 @@ ktr_tracepoint(u_int mask, char *format, u_long arg1, u_long arg2, u_long arg3,
} while (atomic_cmpset_rel_int(&ktr_idx, saveindex, newindex) == 0);
entry = &ktr_buf[saveindex];
restore_intr(saveintr);
- getnanotime(&entry->ktr_tv);
+ if (ktr_mask & KTR_LOCK)
+ /*
+ * We can't use nanotime with KTR_LOCK, it would cause
+ * endless recursion, at least under the Intel
+ * architecture.
+ */
+ getnanotime(&entry->ktr_tv);
+ else
+ nanotime(&entry->ktr_tv);
#ifdef KTR_EXTEND
strncpy(entry->ktr_filename, filename, KTRFILENAMESIZE - 1);
entry->ktr_filename[KTRFILENAMESIZE - 1] = '\0';
OpenPOWER on IntegriCloud