Page MenuHomeFreeBSD

D22597.id65021.diff
No OneTemporary

D22597.id65021.diff

Index: sys/cddl/compat/opensolaris/sys/systm.h
===================================================================
--- sys/cddl/compat/opensolaris/sys/systm.h
+++ sys/cddl/compat/opensolaris/sys/systm.h
@@ -42,9 +42,6 @@
#define delay(x) pause("soldelay", (x))
-#define timeout_generic(type, fn, arg, t, r, f) \
- timeout(fn, arg, t / (NANOSEC/hz) + 1)
-
#endif /* _KERNEL */
#endif /* _OPENSOLARIS_SYS_SYSTM_H_ */
Index: sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zio.h
===================================================================
--- sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zio.h
+++ sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zio.h
@@ -466,6 +466,7 @@
#ifdef __FreeBSD__
struct bio *io_bio;
+ struct callout io_timer;
#endif
/* Internal pipeline state */
Index: sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zio.c
===================================================================
--- sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zio.c
+++ sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zio.c
@@ -658,6 +658,9 @@
mutex_init(&zio->io_lock, NULL, MUTEX_DEFAULT, NULL);
cv_init(&zio->io_cv, NULL, CV_DEFAULT, NULL);
+#ifdef __FreeBSD__
+ callout_init(&zio->io_timer, CALLOUT_MPSAFE);
+#endif
list_create(&zio->io_parent_list, sizeof (zio_link_t),
offsetof(zio_link_t, zl_parent_node));
@@ -723,6 +726,9 @@
static void
zio_destroy(zio_t *zio)
{
+#ifdef __FreeBSD__
+ callout_drain(&zio->io_timer);
+#endif
metaslab_trace_fini(&zio->io_alloc_list);
list_destroy(&zio->io_parent_list);
list_destroy(&zio->io_child_list);
@@ -1707,8 +1713,13 @@
DTRACE_PROBE3(zio__delay__hit, zio_t *, zio,
hrtime_t, now, hrtime_t, diff);
+#ifdef __FreeBSD__
+ callout_reset_sbt(&zio->io_timer, nstosbt(diff), 0,
+ (void (*)(void *))zio_interrupt, zio, C_HARDCLOCK);
+#else
(void) timeout_generic(CALLOUT_NORMAL,
(void (*)(void *))zio_interrupt, zio, diff, 1, 0);
+#endif
}
return;

File Metadata

Mime Type
text/plain
Expires
Mon, Mar 10, 4:11 AM (11 h, 10 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
17079663
Default Alt Text
D22597.id65021.diff (1 KB)

Event Timeline