1262f27b2SOleksandr Tymoshenko /*- 2262f27b2SOleksandr Tymoshenko * Copyright (c) 2010 Max Khon <fjoe@freebsd.org> 3262f27b2SOleksandr Tymoshenko * Copyright (c) 2012 Oleksandr Tymoshenko <gonzo@bluezbox.com> 4262f27b2SOleksandr Tymoshenko * Copyright (c) 2013 Jared D. McNeill <jmcneill@invisible.ca> 5262f27b2SOleksandr Tymoshenko * All rights reserved. 6262f27b2SOleksandr Tymoshenko * 7262f27b2SOleksandr Tymoshenko * Redistribution and use in source and binary forms, with or without 8262f27b2SOleksandr Tymoshenko * modification, are permitted provided that the following conditions 9262f27b2SOleksandr Tymoshenko * are met: 10262f27b2SOleksandr Tymoshenko * 1. Redistributions of source code must retain the above copyright 11262f27b2SOleksandr Tymoshenko * notice, this list of conditions and the following disclaimer. 12262f27b2SOleksandr Tymoshenko * 2. Redistributions in binary form must reproduce the above copyright 13262f27b2SOleksandr Tymoshenko * notice, this list of conditions and the following disclaimer in the 14262f27b2SOleksandr Tymoshenko * documentation and/or other materials provided with the distribution. 15262f27b2SOleksandr Tymoshenko * 16262f27b2SOleksandr Tymoshenko * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 17262f27b2SOleksandr Tymoshenko * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18262f27b2SOleksandr Tymoshenko * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19262f27b2SOleksandr Tymoshenko * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 20262f27b2SOleksandr Tymoshenko * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21262f27b2SOleksandr Tymoshenko * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22262f27b2SOleksandr Tymoshenko * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23262f27b2SOleksandr Tymoshenko * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24262f27b2SOleksandr Tymoshenko * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25262f27b2SOleksandr Tymoshenko * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26262f27b2SOleksandr Tymoshenko * SUCH DAMAGE. 27262f27b2SOleksandr Tymoshenko */ 28262f27b2SOleksandr Tymoshenko #ifndef __VCHI_BSD_H__ 29262f27b2SOleksandr Tymoshenko #define __VCHI_BSD_H__ 30262f27b2SOleksandr Tymoshenko 31262f27b2SOleksandr Tymoshenko #include <sys/systm.h> 32262f27b2SOleksandr Tymoshenko #include <sys/param.h> 33262f27b2SOleksandr Tymoshenko #include <sys/bus.h> 34262f27b2SOleksandr Tymoshenko #include <sys/conf.h> 35262f27b2SOleksandr Tymoshenko #include <sys/lock.h> 36262f27b2SOleksandr Tymoshenko #include <sys/kernel.h> 37262f27b2SOleksandr Tymoshenko #include <sys/kthread.h> 38262f27b2SOleksandr Tymoshenko #include <sys/mutex.h> 39262f27b2SOleksandr Tymoshenko #include <sys/sx.h> 40262f27b2SOleksandr Tymoshenko #include <sys/sema.h> 41262f27b2SOleksandr Tymoshenko #include <sys/malloc.h> 42262f27b2SOleksandr Tymoshenko #include <sys/proc.h> 43262f27b2SOleksandr Tymoshenko #include <sys/types.h> 44262f27b2SOleksandr Tymoshenko #include <sys/ioccom.h> 45262f27b2SOleksandr Tymoshenko 46262f27b2SOleksandr Tymoshenko /* 47262f27b2SOleksandr Tymoshenko * Copy from/to user API 48262f27b2SOleksandr Tymoshenko */ 49262f27b2SOleksandr Tymoshenko #define copy_from_user(to, from, n) copyin((from), (to), (n)) 50262f27b2SOleksandr Tymoshenko #define copy_to_user(to, from, n) copyout((from), (to), (n)) 51262f27b2SOleksandr Tymoshenko 52262f27b2SOleksandr Tymoshenko /* 53262f27b2SOleksandr Tymoshenko * Bit API 54262f27b2SOleksandr Tymoshenko */ 55262f27b2SOleksandr Tymoshenko 56262f27b2SOleksandr Tymoshenko static __inline int 57262f27b2SOleksandr Tymoshenko test_and_set_bit(int nr, volatile void *addr) 58262f27b2SOleksandr Tymoshenko { 59262f27b2SOleksandr Tymoshenko int val; 60262f27b2SOleksandr Tymoshenko 61262f27b2SOleksandr Tymoshenko do { 62262f27b2SOleksandr Tymoshenko val = *(volatile int *) addr; 63262f27b2SOleksandr Tymoshenko } while (atomic_cmpset_int(addr, val, val | (1 << nr)) == 0); 64262f27b2SOleksandr Tymoshenko return (val & (1 << nr)); 65262f27b2SOleksandr Tymoshenko } 66262f27b2SOleksandr Tymoshenko 67262f27b2SOleksandr Tymoshenko static __inline__ 68262f27b2SOleksandr Tymoshenko int test_and_clear_bit(int nr, volatile void *addr) 69262f27b2SOleksandr Tymoshenko { 70262f27b2SOleksandr Tymoshenko int val; 71262f27b2SOleksandr Tymoshenko 72262f27b2SOleksandr Tymoshenko do { 73262f27b2SOleksandr Tymoshenko val = *(volatile int *) addr; 74262f27b2SOleksandr Tymoshenko } while (atomic_cmpset_int(addr, val, val & ~(1 << nr)) == 0); 75262f27b2SOleksandr Tymoshenko return (val & (1 << nr)); 76262f27b2SOleksandr Tymoshenko } 77262f27b2SOleksandr Tymoshenko 78262f27b2SOleksandr Tymoshenko /* 79262f27b2SOleksandr Tymoshenko * Atomic API 80262f27b2SOleksandr Tymoshenko */ 81262f27b2SOleksandr Tymoshenko typedef volatile unsigned atomic_t; 82262f27b2SOleksandr Tymoshenko 83262f27b2SOleksandr Tymoshenko #define atomic_set(p, v) (*(p) = (v)) 84262f27b2SOleksandr Tymoshenko #define atomic_read(p) (*(p)) 85262f27b2SOleksandr Tymoshenko #define atomic_inc(p) atomic_add_int(p, 1) 86262f27b2SOleksandr Tymoshenko #define atomic_dec(p) atomic_subtract_int(p, 1) 87262f27b2SOleksandr Tymoshenko #define atomic_dec_and_test(p) (atomic_fetchadd_int(p, -1) == 1) 88262f27b2SOleksandr Tymoshenko #define atomic_inc_return(v) atomic_add_return(1, (v)) 89262f27b2SOleksandr Tymoshenko #define atomic_dec_return(v) atomic_sub_return(1, (v)) 90262f27b2SOleksandr Tymoshenko #define atomic_add(v, p) atomic_add_int(p, v) 91262f27b2SOleksandr Tymoshenko #define atomic_sub(v, p) atomic_subtract_int(p, v) 92262f27b2SOleksandr Tymoshenko 93262f27b2SOleksandr Tymoshenko #define ATOMIC_INIT(v) (v) 94262f27b2SOleksandr Tymoshenko 95262f27b2SOleksandr Tymoshenko static inline int 96262f27b2SOleksandr Tymoshenko atomic_add_return(int i, atomic_t *v) 97262f27b2SOleksandr Tymoshenko { 98262f27b2SOleksandr Tymoshenko return i + atomic_fetchadd_int(v, i); 99262f27b2SOleksandr Tymoshenko } 100262f27b2SOleksandr Tymoshenko 101262f27b2SOleksandr Tymoshenko static inline int 102262f27b2SOleksandr Tymoshenko atomic_sub_return(int i, atomic_t *v) 103262f27b2SOleksandr Tymoshenko { 104262f27b2SOleksandr Tymoshenko return atomic_fetchadd_int(v, -i) - i; 105262f27b2SOleksandr Tymoshenko } 106262f27b2SOleksandr Tymoshenko 107262f27b2SOleksandr Tymoshenko static inline int 108262f27b2SOleksandr Tymoshenko atomic_cmpxchg(atomic_t *v, int oldv, int newv) 109262f27b2SOleksandr Tymoshenko { 110262f27b2SOleksandr Tymoshenko if (atomic_cmpset_rel_int(v, oldv, newv)) 111262f27b2SOleksandr Tymoshenko return newv; 112262f27b2SOleksandr Tymoshenko else 113262f27b2SOleksandr Tymoshenko return *v; 114262f27b2SOleksandr Tymoshenko } 115262f27b2SOleksandr Tymoshenko 116262f27b2SOleksandr Tymoshenko static inline int 117262f27b2SOleksandr Tymoshenko atomic_xchg(atomic_t *v, int newv) 118262f27b2SOleksandr Tymoshenko { 119262f27b2SOleksandr Tymoshenko int oldv; 120262f27b2SOleksandr Tymoshenko if (newv == 0) 121262f27b2SOleksandr Tymoshenko return atomic_readandclear_int(v); 122262f27b2SOleksandr Tymoshenko else { 123262f27b2SOleksandr Tymoshenko do { 124262f27b2SOleksandr Tymoshenko oldv = atomic_load_acq_int(v); 125262f27b2SOleksandr Tymoshenko } while (!atomic_cmpset_rel_int(v, oldv, newv)); 126262f27b2SOleksandr Tymoshenko } 127262f27b2SOleksandr Tymoshenko 128262f27b2SOleksandr Tymoshenko return (oldv); 129262f27b2SOleksandr Tymoshenko } 130262f27b2SOleksandr Tymoshenko 131262f27b2SOleksandr Tymoshenko /* 132262f27b2SOleksandr Tymoshenko * Spinlock API 133262f27b2SOleksandr Tymoshenko */ 134262f27b2SOleksandr Tymoshenko typedef struct mtx spinlock_t; 135262f27b2SOleksandr Tymoshenko 136262f27b2SOleksandr Tymoshenko #define DEFINE_SPINLOCK(name) \ 137262f27b2SOleksandr Tymoshenko struct mtx name 138262f27b2SOleksandr Tymoshenko #define spin_lock_init(lock) mtx_init(lock, "VCHI spinlock " # lock, NULL, MTX_DEF) 139262f27b2SOleksandr Tymoshenko #define spin_lock_destroy(lock) mtx_destroy(lock) 140262f27b2SOleksandr Tymoshenko #define spin_lock(lock) mtx_lock(lock) 141262f27b2SOleksandr Tymoshenko #define spin_unlock(lock) mtx_unlock(lock) 142262f27b2SOleksandr Tymoshenko #define spin_lock_bh(lock) spin_lock(lock) 143262f27b2SOleksandr Tymoshenko #define spin_unlock_bh(lock) spin_unlock(lock) 144262f27b2SOleksandr Tymoshenko 145262f27b2SOleksandr Tymoshenko /* 146262f27b2SOleksandr Tymoshenko * Mutex API 147262f27b2SOleksandr Tymoshenko */ 148262f27b2SOleksandr Tymoshenko struct mutex { 149262f27b2SOleksandr Tymoshenko struct mtx mtx; 150262f27b2SOleksandr Tymoshenko }; 151262f27b2SOleksandr Tymoshenko 152262f27b2SOleksandr Tymoshenko #define lmutex_init(lock) mtx_init(&(lock)->mtx, #lock, NULL, MTX_DEF) 153262f27b2SOleksandr Tymoshenko #define lmutex_lock(lock) mtx_lock(&(lock)->mtx) 154262f27b2SOleksandr Tymoshenko #define lmutex_unlock(lock) mtx_unlock(&(lock)->mtx) 155262f27b2SOleksandr Tymoshenko #define lmutex_destroy(lock) mtx_destroy(&(lock)->mtx) 156262f27b2SOleksandr Tymoshenko 157*e6c4672eSOleksandr Tymoshenko static __inline int 158*e6c4672eSOleksandr Tymoshenko lmutex_lock_interruptible(struct mutex *lock) 159*e6c4672eSOleksandr Tymoshenko { 160*e6c4672eSOleksandr Tymoshenko mtx_lock(&(lock)->mtx); 161*e6c4672eSOleksandr Tymoshenko return 0; 162*e6c4672eSOleksandr Tymoshenko } 163*e6c4672eSOleksandr Tymoshenko 164262f27b2SOleksandr Tymoshenko /* 165262f27b2SOleksandr Tymoshenko * Rwlock API 166262f27b2SOleksandr Tymoshenko */ 167262f27b2SOleksandr Tymoshenko typedef struct sx rwlock_t; 168262f27b2SOleksandr Tymoshenko 169262f27b2SOleksandr Tymoshenko #if defined(SX_ADAPTIVESPIN) && !defined(SX_NOADAPTIVE) 170262f27b2SOleksandr Tymoshenko #define SX_NOADAPTIVE SX_ADAPTIVESPIN 171262f27b2SOleksandr Tymoshenko #endif 172262f27b2SOleksandr Tymoshenko 173262f27b2SOleksandr Tymoshenko #define DEFINE_RWLOCK(name) \ 174262f27b2SOleksandr Tymoshenko struct sx name; \ 175262f27b2SOleksandr Tymoshenko SX_SYSINIT(name, &name, #name) 176262f27b2SOleksandr Tymoshenko #define rwlock_init(rwlock) sx_init_flags(rwlock, "VCHI rwlock", SX_NOADAPTIVE) 177262f27b2SOleksandr Tymoshenko #define read_lock(rwlock) sx_slock(rwlock) 178262f27b2SOleksandr Tymoshenko #define read_unlock(rwlock) sx_sunlock(rwlock) 179262f27b2SOleksandr Tymoshenko 180262f27b2SOleksandr Tymoshenko #define write_lock(rwlock) sx_xlock(rwlock) 181262f27b2SOleksandr Tymoshenko #define write_unlock(rwlock) sx_xunlock(rwlock) 182262f27b2SOleksandr Tymoshenko #define write_lock_irqsave(rwlock, flags) \ 183262f27b2SOleksandr Tymoshenko do { \ 184262f27b2SOleksandr Tymoshenko sx_xlock(rwlock); \ 185262f27b2SOleksandr Tymoshenko (void) &(flags); \ 186262f27b2SOleksandr Tymoshenko } while (0) 187262f27b2SOleksandr Tymoshenko #define write_unlock_irqrestore(rwlock, flags) \ 188262f27b2SOleksandr Tymoshenko sx_xunlock(rwlock) 189262f27b2SOleksandr Tymoshenko 190262f27b2SOleksandr Tymoshenko #define read_lock_bh(rwlock) sx_slock(rwlock) 191262f27b2SOleksandr Tymoshenko #define read_unlock_bh(rwlock) sx_sunlock(rwlock) 192262f27b2SOleksandr Tymoshenko #define write_lock_bh(rwlock) sx_xlock(rwlock) 193262f27b2SOleksandr Tymoshenko #define write_unlock_bh(rwlock) sx_xunlock(rwlock) 194262f27b2SOleksandr Tymoshenko 195262f27b2SOleksandr Tymoshenko /* 196262f27b2SOleksandr Tymoshenko * Timer API 197262f27b2SOleksandr Tymoshenko */ 198262f27b2SOleksandr Tymoshenko struct timer_list { 199262f27b2SOleksandr Tymoshenko struct mtx mtx; 200262f27b2SOleksandr Tymoshenko struct callout callout; 201262f27b2SOleksandr Tymoshenko 202262f27b2SOleksandr Tymoshenko unsigned long expires; 203262f27b2SOleksandr Tymoshenko void (*function)(unsigned long); 204262f27b2SOleksandr Tymoshenko unsigned long data; 205262f27b2SOleksandr Tymoshenko }; 206262f27b2SOleksandr Tymoshenko 207262f27b2SOleksandr Tymoshenko void init_timer(struct timer_list *t); 208262f27b2SOleksandr Tymoshenko void setup_timer(struct timer_list *t, void (*function)(unsigned long), unsigned long data); 209262f27b2SOleksandr Tymoshenko void mod_timer(struct timer_list *t, unsigned long expires); 210262f27b2SOleksandr Tymoshenko void add_timer(struct timer_list *t); 211262f27b2SOleksandr Tymoshenko int del_timer(struct timer_list *t); 212262f27b2SOleksandr Tymoshenko int del_timer_sync(struct timer_list *t); 213262f27b2SOleksandr Tymoshenko 214262f27b2SOleksandr Tymoshenko /* 215262f27b2SOleksandr Tymoshenko * Completion API 216262f27b2SOleksandr Tymoshenko */ 217262f27b2SOleksandr Tymoshenko struct completion { 218262f27b2SOleksandr Tymoshenko struct cv cv; 219262f27b2SOleksandr Tymoshenko struct mtx lock; 220262f27b2SOleksandr Tymoshenko int done; 221262f27b2SOleksandr Tymoshenko }; 222262f27b2SOleksandr Tymoshenko 223262f27b2SOleksandr Tymoshenko void init_completion(struct completion *c); 224262f27b2SOleksandr Tymoshenko void destroy_completion(struct completion *c); 225262f27b2SOleksandr Tymoshenko int try_wait_for_completion(struct completion *); 226262f27b2SOleksandr Tymoshenko int wait_for_completion_interruptible(struct completion *); 227262f27b2SOleksandr Tymoshenko int wait_for_completion_interruptible_timeout(struct completion *, unsigned long ticks); 228262f27b2SOleksandr Tymoshenko int wait_for_completion_killable(struct completion *); 229262f27b2SOleksandr Tymoshenko void wait_for_completion(struct completion *c); 230262f27b2SOleksandr Tymoshenko void complete(struct completion *c); 231262f27b2SOleksandr Tymoshenko void complete_all(struct completion *c); 232262f27b2SOleksandr Tymoshenko void INIT_COMPLETION_locked(struct completion *c); 233262f27b2SOleksandr Tymoshenko 234262f27b2SOleksandr Tymoshenko #define INIT_COMPLETION(x) INIT_COMPLETION_locked(&(x)) 235262f27b2SOleksandr Tymoshenko 236262f27b2SOleksandr Tymoshenko /* 237262f27b2SOleksandr Tymoshenko * Semaphore API 238262f27b2SOleksandr Tymoshenko */ 239262f27b2SOleksandr Tymoshenko struct semaphore { 240262f27b2SOleksandr Tymoshenko struct mtx mtx; 241262f27b2SOleksandr Tymoshenko struct cv cv; 242262f27b2SOleksandr Tymoshenko int value; 243262f27b2SOleksandr Tymoshenko int waiters; 244262f27b2SOleksandr Tymoshenko }; 245262f27b2SOleksandr Tymoshenko 246262f27b2SOleksandr Tymoshenko #define DEFINE_SEMAPHORE(name) \ 247262f27b2SOleksandr Tymoshenko struct semaphore name; \ 248262f27b2SOleksandr Tymoshenko SYSINIT(name##_sema_sysinit, SI_SUB_LOCK, SI_ORDER_MIDDLE, \ 249262f27b2SOleksandr Tymoshenko sema_sysinit, &name); \ 250262f27b2SOleksandr Tymoshenko SYSUNINIT(name##_sema_sysuninit, SI_SUB_LOCK, SI_ORDER_MIDDLE, \ 251262f27b2SOleksandr Tymoshenko _sema_destroy, __DEVOLATILE(void *, &(name))) 252262f27b2SOleksandr Tymoshenko 253262f27b2SOleksandr Tymoshenko void sema_sysinit(void *arg); 254262f27b2SOleksandr Tymoshenko void _sema_init(struct semaphore *s, int value); 255262f27b2SOleksandr Tymoshenko void _sema_destroy(struct semaphore *s); 256262f27b2SOleksandr Tymoshenko void down(struct semaphore *s); 257262f27b2SOleksandr Tymoshenko int down_interruptible(struct semaphore *s); 258262f27b2SOleksandr Tymoshenko int down_trylock(struct semaphore *s); 259262f27b2SOleksandr Tymoshenko void up(struct semaphore *s); 260262f27b2SOleksandr Tymoshenko 261262f27b2SOleksandr Tymoshenko /* 262262f27b2SOleksandr Tymoshenko * Logging and assertions API 263262f27b2SOleksandr Tymoshenko */ 264262f27b2SOleksandr Tymoshenko void rlprintf(int pps, const char *fmt, ...) 265262f27b2SOleksandr Tymoshenko __printflike(2, 3); 266262f27b2SOleksandr Tymoshenko 267262f27b2SOleksandr Tymoshenko void 268262f27b2SOleksandr Tymoshenko device_rlprintf(int pps, device_t dev, const char *fmt, ...) 269262f27b2SOleksandr Tymoshenko __printflike(3, 4); 270262f27b2SOleksandr Tymoshenko 271262f27b2SOleksandr Tymoshenko #define might_sleep() 272262f27b2SOleksandr Tymoshenko 273262f27b2SOleksandr Tymoshenko #define WARN(condition, msg) \ 274262f27b2SOleksandr Tymoshenko ({ \ 275262f27b2SOleksandr Tymoshenko int __ret_warn_on = !!(condition); \ 276262f27b2SOleksandr Tymoshenko if (unlikely(__ret_warn_on)) \ 277262f27b2SOleksandr Tymoshenko printf((msg)); \ 278262f27b2SOleksandr Tymoshenko unlikely(__ret_warn_on); \ 279262f27b2SOleksandr Tymoshenko }) 280262f27b2SOleksandr Tymoshenko 281262f27b2SOleksandr Tymoshenko 282262f27b2SOleksandr Tymoshenko 283262f27b2SOleksandr Tymoshenko #define WARN_ON(condition) \ 284262f27b2SOleksandr Tymoshenko ({ \ 285262f27b2SOleksandr Tymoshenko int __ret_warn_on = !!(condition); \ 286262f27b2SOleksandr Tymoshenko if (unlikely(__ret_warn_on)) \ 287262f27b2SOleksandr Tymoshenko printf("WARN_ON: " #condition "\n"); \ 288262f27b2SOleksandr Tymoshenko unlikely(__ret_warn_on); \ 289262f27b2SOleksandr Tymoshenko }) 290262f27b2SOleksandr Tymoshenko 291262f27b2SOleksandr Tymoshenko #define WARN_ON_ONCE(condition) ({ \ 292262f27b2SOleksandr Tymoshenko static int __warned; \ 293262f27b2SOleksandr Tymoshenko int __ret_warn_once = !!(condition); \ 294262f27b2SOleksandr Tymoshenko \ 295262f27b2SOleksandr Tymoshenko if (unlikely(__ret_warn_once)) \ 296262f27b2SOleksandr Tymoshenko if (WARN_ON(!__warned)) \ 297262f27b2SOleksandr Tymoshenko __warned = 1; \ 298262f27b2SOleksandr Tymoshenko unlikely(__ret_warn_once); \ 299262f27b2SOleksandr Tymoshenko }) 300262f27b2SOleksandr Tymoshenko 301262f27b2SOleksandr Tymoshenko #define BUG_ON(cond) \ 302262f27b2SOleksandr Tymoshenko do { \ 303262f27b2SOleksandr Tymoshenko if (cond) \ 304262f27b2SOleksandr Tymoshenko panic("BUG_ON: " #cond); \ 305262f27b2SOleksandr Tymoshenko } while (0) 306262f27b2SOleksandr Tymoshenko 307262f27b2SOleksandr Tymoshenko #define BUG() \ 308262f27b2SOleksandr Tymoshenko do { \ 309262f27b2SOleksandr Tymoshenko panic("BUG: %s:%d", __FILE__, __LINE__); \ 310262f27b2SOleksandr Tymoshenko } while (0) 311262f27b2SOleksandr Tymoshenko 312262f27b2SOleksandr Tymoshenko #define vchiq_static_assert(cond) CTASSERT(cond) 313262f27b2SOleksandr Tymoshenko 314262f27b2SOleksandr Tymoshenko #define KERN_EMERG "<0>" /* system is unusable */ 315262f27b2SOleksandr Tymoshenko #define KERN_ALERT "<1>" /* action must be taken immediately */ 316262f27b2SOleksandr Tymoshenko #define KERN_CRIT "<2>" /* critical conditions */ 317262f27b2SOleksandr Tymoshenko #define KERN_ERR "<3>" /* error conditions */ 318262f27b2SOleksandr Tymoshenko #define KERN_WARNING "<4>" /* warning conditions */ 319262f27b2SOleksandr Tymoshenko #define KERN_NOTICE "<5>" /* normal but significant condition */ 320262f27b2SOleksandr Tymoshenko #define KERN_INFO "<6>" /* informational */ 321262f27b2SOleksandr Tymoshenko #define KERN_DEBUG "<7>" /* debug-level messages */ 322262f27b2SOleksandr Tymoshenko #define KERN_CONT "" 323262f27b2SOleksandr Tymoshenko 324262f27b2SOleksandr Tymoshenko #define printk(fmt, args...) printf(fmt, ##args) 325262f27b2SOleksandr Tymoshenko #define vprintk(fmt, args) vprintf(fmt, args) 326262f27b2SOleksandr Tymoshenko 327262f27b2SOleksandr Tymoshenko /* 328262f27b2SOleksandr Tymoshenko * Malloc API 329262f27b2SOleksandr Tymoshenko */ 330262f27b2SOleksandr Tymoshenko #define GFP_KERNEL 0 331262f27b2SOleksandr Tymoshenko #define GFP_ATOMIC 0 332262f27b2SOleksandr Tymoshenko 333262f27b2SOleksandr Tymoshenko MALLOC_DECLARE(M_VCHI); 334262f27b2SOleksandr Tymoshenko 335262f27b2SOleksandr Tymoshenko #define kmalloc(size, flags) malloc((size), M_VCHI, M_NOWAIT | M_ZERO) 336262f27b2SOleksandr Tymoshenko #define kcalloc(n, size, flags) malloc((n) * (size), M_VCHI, M_NOWAIT | M_ZERO) 337262f27b2SOleksandr Tymoshenko #define kzalloc(a, b) kcalloc(1, (a), (b)) 338262f27b2SOleksandr Tymoshenko #define kfree(p) free(p, M_VCHI) 339262f27b2SOleksandr Tymoshenko 340262f27b2SOleksandr Tymoshenko /* 341262f27b2SOleksandr Tymoshenko * Kernel module API 342262f27b2SOleksandr Tymoshenko */ 343262f27b2SOleksandr Tymoshenko #define __init 344262f27b2SOleksandr Tymoshenko #define __exit 345262f27b2SOleksandr Tymoshenko #define __devinit 346262f27b2SOleksandr Tymoshenko #define __devexit 347262f27b2SOleksandr Tymoshenko #define __devinitdata 348262f27b2SOleksandr Tymoshenko 349262f27b2SOleksandr Tymoshenko /* 350262f27b2SOleksandr Tymoshenko * Time API 351262f27b2SOleksandr Tymoshenko */ 352262f27b2SOleksandr Tymoshenko #if 1 353262f27b2SOleksandr Tymoshenko /* emulate jiffies */ 354262f27b2SOleksandr Tymoshenko static inline unsigned long 355262f27b2SOleksandr Tymoshenko _jiffies(void) 356262f27b2SOleksandr Tymoshenko { 357262f27b2SOleksandr Tymoshenko struct timeval tv; 358262f27b2SOleksandr Tymoshenko 359262f27b2SOleksandr Tymoshenko microuptime(&tv); 360262f27b2SOleksandr Tymoshenko return tvtohz(&tv); 361262f27b2SOleksandr Tymoshenko } 362262f27b2SOleksandr Tymoshenko 363262f27b2SOleksandr Tymoshenko static inline unsigned long 364262f27b2SOleksandr Tymoshenko msecs_to_jiffies(unsigned long msecs) 365262f27b2SOleksandr Tymoshenko { 366262f27b2SOleksandr Tymoshenko struct timeval tv; 367262f27b2SOleksandr Tymoshenko 368262f27b2SOleksandr Tymoshenko tv.tv_sec = msecs / 1000000UL; 369262f27b2SOleksandr Tymoshenko tv.tv_usec = msecs % 1000000UL; 370262f27b2SOleksandr Tymoshenko return tvtohz(&tv); 371262f27b2SOleksandr Tymoshenko } 372262f27b2SOleksandr Tymoshenko 373262f27b2SOleksandr Tymoshenko #define jiffies _jiffies() 374262f27b2SOleksandr Tymoshenko #else 375262f27b2SOleksandr Tymoshenko #define jiffies ticks 376262f27b2SOleksandr Tymoshenko #endif 377262f27b2SOleksandr Tymoshenko #define HZ hz 378262f27b2SOleksandr Tymoshenko 379262f27b2SOleksandr Tymoshenko #define udelay(usec) DELAY(usec) 380262f27b2SOleksandr Tymoshenko #define mdelay(msec) DELAY((msec) * 1000) 381262f27b2SOleksandr Tymoshenko 382262f27b2SOleksandr Tymoshenko #define schedule_timeout(jiff) pause("dhdslp", jiff) 383262f27b2SOleksandr Tymoshenko 384262f27b2SOleksandr Tymoshenko #if defined(msleep) 385262f27b2SOleksandr Tymoshenko #undef msleep 386262f27b2SOleksandr Tymoshenko #endif 387262f27b2SOleksandr Tymoshenko #define msleep(msec) mdelay(msec) 388262f27b2SOleksandr Tymoshenko 389262f27b2SOleksandr Tymoshenko #define time_after(a, b) ((a) > (b)) 390262f27b2SOleksandr Tymoshenko #define time_after_eq(a, b) ((a) >= (b)) 391262f27b2SOleksandr Tymoshenko #define time_before(a, b) time_after((b), (a)) 392262f27b2SOleksandr Tymoshenko 393262f27b2SOleksandr Tymoshenko /* 394262f27b2SOleksandr Tymoshenko * kthread API (we use proc) 395262f27b2SOleksandr Tymoshenko */ 396262f27b2SOleksandr Tymoshenko typedef struct proc * VCHIQ_THREAD_T; 397262f27b2SOleksandr Tymoshenko 398262f27b2SOleksandr Tymoshenko VCHIQ_THREAD_T vchiq_thread_create(int (*threadfn)(void *data), 399262f27b2SOleksandr Tymoshenko void *data, 400262f27b2SOleksandr Tymoshenko const char namefmt[], ...); 401262f27b2SOleksandr Tymoshenko void set_user_nice(VCHIQ_THREAD_T p, int nice); 402262f27b2SOleksandr Tymoshenko void wake_up_process(VCHIQ_THREAD_T p); 403262f27b2SOleksandr Tymoshenko 404262f27b2SOleksandr Tymoshenko /* 405262f27b2SOleksandr Tymoshenko * Proc APIs 406262f27b2SOleksandr Tymoshenko */ 407262f27b2SOleksandr Tymoshenko void flush_signals(VCHIQ_THREAD_T); 408262f27b2SOleksandr Tymoshenko int fatal_signal_pending(VCHIQ_THREAD_T); 409262f27b2SOleksandr Tymoshenko 410262f27b2SOleksandr Tymoshenko /* 411262f27b2SOleksandr Tymoshenko * mbox API 412262f27b2SOleksandr Tymoshenko */ 413262f27b2SOleksandr Tymoshenko void bcm_mbox_write(int channel, uint32_t data); 414262f27b2SOleksandr Tymoshenko 415262f27b2SOleksandr Tymoshenko /* 416262f27b2SOleksandr Tymoshenko * Misc API 417262f27b2SOleksandr Tymoshenko */ 418262f27b2SOleksandr Tymoshenko 419262f27b2SOleksandr Tymoshenko #define ENODATA EINVAL 420262f27b2SOleksandr Tymoshenko 421262f27b2SOleksandr Tymoshenko #define __user 422262f27b2SOleksandr Tymoshenko 423262f27b2SOleksandr Tymoshenko #define likely(x) __builtin_expect(!!(x), 1) 424262f27b2SOleksandr Tymoshenko #define unlikely(x) __builtin_expect(!!(x), 0) 425262f27b2SOleksandr Tymoshenko #define current curproc 426262f27b2SOleksandr Tymoshenko #define EXPORT_SYMBOL(x) 427262f27b2SOleksandr Tymoshenko #define PAGE_ALIGN(addr) round_page(addr) 428262f27b2SOleksandr Tymoshenko 429262f27b2SOleksandr Tymoshenko typedef void irqreturn_t; 430262f27b2SOleksandr Tymoshenko typedef off_t loff_t; 431262f27b2SOleksandr Tymoshenko 432262f27b2SOleksandr Tymoshenko #define BCM2835_MBOX_CHAN_VCHIQ 3 433262f27b2SOleksandr Tymoshenko 434262f27b2SOleksandr Tymoshenko #define smp_mb wmb 435262f27b2SOleksandr Tymoshenko #define smp_rmb rmb 436262f27b2SOleksandr Tymoshenko #define smp_wmb wmb 437262f27b2SOleksandr Tymoshenko 438262f27b2SOleksandr Tymoshenko #define device_print_prettyname(dev) device_printf((dev), "") 439262f27b2SOleksandr Tymoshenko 440262f27b2SOleksandr Tymoshenko #endif /* __VCHI_BSD_H__ */ 441