1 /* 2 * Copyright (c) 2020 iXsystems, Inc. 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 14 * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND 15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE 18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24 * SUCH DAMAGE. 25 * 26 * $FreeBSD$ 27 */ 28 29 #ifndef ZFS_CONTEXT_OS_H_ 30 #define ZFS_CONTEXT_OS_H_ 31 32 #include <sys/condvar.h> 33 #include <sys/rwlock.h> 34 #include <sys/sig.h> 35 #include_next <sys/sdt.h> 36 #include <sys/misc.h> 37 #include <sys/kdb.h> 38 #include <sys/pathname.h> 39 #include <sys/conf.h> 40 #include <sys/types.h> 41 #include <sys/ccompat.h> 42 #include <linux/types.h> 43 44 #define cond_resched() kern_yield(PRI_USER) 45 46 #define taskq_create_sysdc(a, b, d, e, p, dc, f) \ 47 (taskq_create(a, b, maxclsyspri, d, e, f)) 48 49 #define tsd_create(keyp, destructor) do { \ 50 *(keyp) = osd_thread_register((destructor)); \ 51 KASSERT(*(keyp) > 0, ("cannot register OSD")); \ 52 } while (0) 53 54 #define tsd_destroy(keyp) osd_thread_deregister(*(keyp)) 55 #define tsd_get(key) osd_thread_get(curthread, (key)) 56 #define tsd_set(key, value) osd_thread_set(curthread, (key), (value)) 57 #define fm_panic panic 58 59 extern int zfs_debug_level; 60 extern struct mtx zfs_debug_mtx; 61 #define ZFS_LOG(lvl, ...) do { \ 62 if (((lvl) & 0xff) <= zfs_debug_level) { \ 63 mtx_lock(&zfs_debug_mtx); \ 64 printf("%s:%u[%d]: ", \ 65 __func__, __LINE__, (lvl)); \ 66 printf(__VA_ARGS__); \ 67 printf("\n"); \ 68 if ((lvl) & 0x100) \ 69 kdb_backtrace(); \ 70 mtx_unlock(&zfs_debug_mtx); \ 71 } \ 72 } while (0) 73 74 #define MSEC_TO_TICK(msec) (howmany((hrtime_t)(msec) * hz, MILLISEC)) 75 extern int hz; 76 extern int tick; 77 typedef int fstrans_cookie_t; 78 #define spl_fstrans_mark() (0) 79 #define spl_fstrans_unmark(x) (x = 0) 80 #define signal_pending(x) SIGPENDING(x) 81 #define current curthread 82 #define thread_join(x) 83 typedef struct opensolaris_utsname utsname_t; 84 extern utsname_t *utsname(void); 85 extern int spa_import_rootpool(const char *name, bool checkpointrewind); 86 #endif 87