diff options
author | jhb <jhb@FreeBSD.org> | 2005-12-29 20:54:25 +0000 |
---|---|---|
committer | jhb <jhb@FreeBSD.org> | 2005-12-29 20:54:25 +0000 |
commit | efb6208d84afd810181637220f225dbd024da565 (patch) | |
tree | 68b60e603ba636fd07faefa1ceb6c82c5405f48d /sys | |
parent | e782568056d47ca9a4a92a91f85a894c56443095 (diff) | |
download | FreeBSD-src-efb6208d84afd810181637220f225dbd024da565.zip FreeBSD-src-efb6208d84afd810181637220f225dbd024da565.tar.gz |
Teach WITNESS_SAVE() and WITNESS_RESTORE() to work with spin locks instead
of only sleep locks.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/kern/subr_witness.c | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/sys/kern/subr_witness.c b/sys/kern/subr_witness.c index 12e64f1..55e45e5 100644 --- a/sys/kern/subr_witness.c +++ b/sys/kern/subr_witness.c @@ -1807,15 +1807,20 @@ witness_display_spinlock(struct lock_object *lock, struct thread *owner) void witness_save(struct lock_object *lock, const char **filep, int *linep) { + struct lock_list_entry *lock_list; struct lock_instance *instance; KASSERT(!witness_cold, ("%s: witness_cold", __func__)); if (lock->lo_witness == NULL || witness_watch == 0 || panicstr != NULL) return; - if ((lock->lo_class->lc_flags & LC_SLEEPLOCK) == 0) - panic("%s: lock (%s) %s is not a sleep lock", __func__, - lock->lo_class->lc_name, lock->lo_name); - instance = find_instance(curthread->td_sleeplocks, lock); + if (lock->lo_class->lc_flags & LC_SLEEPLOCK) + lock_list = curthread->td_sleeplocks; + else { + if (witness_skipspin) + return; + lock_list = PCPU_GET(spinlocks); + } + instance = find_instance(lock_list, lock); if (instance == NULL) panic("%s: lock (%s) %s not locked", __func__, lock->lo_class->lc_name, lock->lo_name); @@ -1826,15 +1831,20 @@ witness_save(struct lock_object *lock, const char **filep, int *linep) void witness_restore(struct lock_object *lock, const char *file, int line) { + struct lock_list_entry *lock_list; struct lock_instance *instance; KASSERT(!witness_cold, ("%s: witness_cold", __func__)); if (lock->lo_witness == NULL || witness_watch == 0 || panicstr != NULL) return; - if ((lock->lo_class->lc_flags & LC_SLEEPLOCK) == 0) - panic("%s: lock (%s) %s is not a sleep lock", __func__, - lock->lo_class->lc_name, lock->lo_name); - instance = find_instance(curthread->td_sleeplocks, lock); + if (lock->lo_class->lc_flags & LC_SLEEPLOCK) + lock_list = curthread->td_sleeplocks; + else { + if (witness_skipspin) + return; + lock_list = PCPU_GET(spinlocks); + } + instance = find_instance(lock_list, lock); if (instance == NULL) panic("%s: lock (%s) %s not locked", __func__, lock->lo_class->lc_name, lock->lo_name); |