1 /* 2 * Copyright (c) 2008 The DragonFly Project. All rights reserved. 3 * 4 * This code is derived from software contributed to The DragonFly Project 5 * by Matthew Dillon <dillon@backplane.com> 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in 15 * the documentation and/or other materials provided with the 16 * distribution. 17 * 3. Neither the name of The DragonFly Project nor the names of its 18 * contributors may be used to endorse or promote products derived 19 * from this software without specific, prior written permission. 20 * 21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 22 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 25 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 26 * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, 27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 28 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 29 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 31 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 32 * SUCH DAMAGE. 33 * 34 * $DragonFly: src/sys/netgraph7/dragonfly.h,v 1.1 2008/06/26 23:05:35 dillon Exp $ 35 */ 36 37 #include <sys/lock.h> 38 #include <sys/objcache.h> 39 40 #ifndef _VA_LIST_DECLARED 41 #define _VA_LIST_DECLARED 42 typedef __va_list va_list; 43 #endif 44 #define va_start(ap,last) __va_start(ap,last) 45 #define va_end(ap) __va_end(ap) 46 47 int linker_api_available(void); 48 int ng_load_module(const char *); 49 int ng_unload_module(const char *); 50 51 /* Temporary lock stuff */ 52 int lock_sleep(void *, int, const char *, int, struct lock *); 53 int lockstatus_owned(struct lock *, struct thread *); 54 /* End Temporary lock stuff */ 55 56 struct mtx { 57 struct lock lock; 58 }; 59 60 #define MA_OWNED LK_EXCLUSIVE 61 #define MA_NOTOWNED 0 62 #define mtx_contested(mtx) 0 63 64 #define mtx_lock(mtx) lockmgr(&(mtx)->lock, LK_EXCLUSIVE|LK_RETRY) 65 #define mtx_unlock(mtx) lockmgr(&(mtx)->lock, LK_RELEASE) 66 #define mtx_assert(mtx, mode) \ 67 KKASSERT(lockstatus(&(mtx)->lock, curthread) == mode) 68 #define mtx_init(mtx, name, something, type) \ 69 lockinit(&(mtx)->lock, name, 0, 0) 70 #define mtx_destroy(mtx) \ 71 lockuninit(&(mtx)->lock) 72 #define mtx_trylock(mtx) \ 73 (lockmgr(&(mtx)->lock, LK_EXCLUSIVE|LK_NOWAIT) == 0) 74 75 #define IFNET_RLOCK() crit_enter() 76 #define IFNET_RUNLOCK() crit_exit() 77 78 #define IFQ_LOCK(ifp) lwkt_serialize_enter(&(ifp)->altq_lock) 79 #define IFQ_UNLOCK(ifp) lwkt_serialize_exit(&(ifp)->altq_lock) 80 81 #define printf kprintf 82 #define sprintf ksprintf 83 #define snprintf ksnprintf 84 #define vsnprintf kvsnprintf 85 86 typedef struct objcache *objcache_t; 87 #define uma_zone_t objcache_t 88 typedef void * uma_ctor; 89 typedef void * uma_dtor; 90 typedef void * uma_init; 91 typedef void * uma_fini; 92 93 #define UMA_ALIGN_CACHE 0 94 95 #define uma_zcreate(name, size, ctor, dtor, uminit, fini, align, flags) \ 96 objcache_create_mbacked(M_NETGRAPH, size, \ 97 NULL, 0, \ 98 bzero_ctor, NULL, \ 99 NULL) 100 #define uma_zalloc(zone, flags) \ 101 objcache_get(zone, flags) 102 #define uma_zfree(zone, item) \ 103 objcache_put(zone, item) 104 #define uma_zone_set_max(zone, nitems) 105 106 #define CTR1(ktr_line, ...) 107 #define CTR2(ktr_line, ...) 108 #define CTR3(ktr_line, ...) 109 #define CTR4(ktr_line, ...) 110 #define CTR5(ktr_line, ...) 111 #define CTR6(ktr_line, ...) 112 #define cpu_spinwait() cpu_pause() 113 114 #define splnet() 0 115 #define splx(v) 116 117 #define CTLFLAG_RDTUN CTLFLAG_RD 118 119 #define SI_SUB_NETGRAPH SI_SUB_DRIVERS 120