From: Ned Bass Date: Thu, 15 Jul 2010 16:49:38 +0000 (-0700) Subject: Proposed fix for oops on SIGINT in splat atomic:64-bit test. X-Git-Tag: zfs-0.8.0-rc1~152^2~558 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8f813bb168eb21cd5d64b930ee015dcf93575331;p=zfs Proposed fix for oops on SIGINT in splat atomic:64-bit test. The threads in the splat atomic:64-bit test share the data structure atomic_priv_t ap, which lives on the kernel stack of the splat user-space utility. If splat terminates before the threads, accesses to that memory location by the other threads become invalid. Splat synchronizes with the threads with the call: wait_event_interruptible(ap.ap_waitq, splat_atomic_test1_cond(&ap, i)); Apparently, the SIGINT wakes and terminates splat prematurely, so that GPFs or other bad things happen when the threads subsequently access ap. This commit prevents this by using the uninterruptible form: wait_event(ap.ap_waitq, splat_atomic_test1_cond(&ap, i)); --- diff --git a/module/splat/splat-atomic.c b/module/splat/splat-atomic.c index 9cdaa69df..fd86a9fa8 100644 --- a/module/splat/splat-atomic.c +++ b/module/splat/splat-atomic.c @@ -165,7 +165,7 @@ splat_atomic_test1(struct file *file, void *arg) schedule(); } - wait_event_interruptible(ap.ap_waitq, splat_atomic_test1_cond(&ap, i)); + wait_event(ap.ap_waitq, splat_atomic_test1_cond(&ap, i)); if (rc) { splat_vprint(file, SPLAT_ATOMIC_TEST1_NAME, "Only started "