vchi_bsd.h revision 1.15
1/*- 2 * Copyright (c) 2010 Max Khon <fjoe@freebsd.org> 3 * Copyright (c) 2012 Oleksandr Tymoshenko <gonzo@bluezbox.com> 4 * Copyright (c) 2013 Jared D. McNeill <jmcneill@invisible.ca> 5 * All rights reserved. 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 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 * SUCH DAMAGE. 27 */ 28#ifndef __VCHI_NETBSD_H__ 29#define __VCHI_NETBSD_H__ 30 31#include <sys/systm.h> 32#include <sys/param.h> 33#include <sys/bus.h> 34#include <sys/conf.h> 35#include <sys/lock.h> 36#include <sys/kernel.h> 37#include <sys/kthread.h> 38#include <sys/mutex.h> 39#include <sys/malloc.h> 40#include <sys/proc.h> 41#include <sys/types.h> 42#include <sys/ioccom.h> 43#include <sys/atomic.h> 44#include <sys/rwlock.h> 45#include <sys/callout.h> 46 47#include <linux/completion.h> 48#include <asm/barrier.h> 49 50/* 51 * Copy from/to user API 52 */ 53#define copy_from_user(to, from, n) copyin((from), (to), (n)) 54#define copy_to_user(to, from, n) copyout((from), (to), (n)) 55 56/* 57 * Atomic API 58 */ 59typedef volatile unsigned int atomic_t; 60 61#define atomic_set(p, v) (*(p) = (v)) 62#define atomic_read(p) (*(volatile int *)(p)) 63#define atomic_inc(p) atomic_inc_uint(p) 64#define atomic_dec(p) atomic_dec_uint(p) 65#define atomic_dec_and_test(p) (atomic_dec_uint_nv(p) == 0) 66#define atomic_inc_return(v) atomic_inc_uint_nv(v) 67#define atomic_dec_return(v) atomic_dec_uint_nv(v) 68#define atomic_add(v, p) atomic_add_int(p, v) 69#define atomic_sub(v, p) atomic_add_int(p, -(v)) 70#define atomic_add_return(v, p) atomic_add_int_nv(p, v) 71#define atomic_sub_return(v, p) atomic_add_int_nv(p, -(v)) 72#define atomic_xchg(p, v) atomic_swap_uint(p, v) 73#define atomic_cmpxchg(p, oldv, newv) atomic_cas_uint(p, oldv, newv) 74 75#define ATOMIC_INIT(v) (v) 76 77/* 78 * Spinlock API 79 */ 80typedef kmutex_t spinlock_t; 81 82/* 83 * NB: Need to initialize these at attach time! 84 */ 85#define DEFINE_SPINLOCK(name) kmutex_t name 86 87#define spin_lock_init(lock) mutex_init(lock, MUTEX_DEFAULT, IPL_VM) 88#define spin_lock_destroy(lock) mutex_destroy(lock) 89#define spin_lock(lock) mutex_spin_enter(lock) 90#define spin_unlock(lock) mutex_spin_exit(lock) 91 92/* 93 * Mutex API 94 */ 95struct mutex { 96 kmutex_t mtx; 97}; 98 99#define lmutex_init(lock) mutex_init(&(lock)->mtx, MUTEX_DEFAULT, IPL_NONE) 100#define lmutex_destroy(lock) mutex_destroy(&(lock)->mtx) 101#define lmutex_lock(lock) mutex_enter(&(lock)->mtx) 102#define lmutex_lock_interruptible(lock) (mutex_enter(&(lock)->mtx),0) 103#define lmutex_unlock(lock) mutex_exit(&(lock)->mtx) 104 105/* 106 * Rwlock API 107 */ 108typedef kmutex_t rwlock_t; 109 110#define DEFINE_RWLOCK(name) kmutex_t name 111 112#define rwlock_init(rwlock) mutex_init(rwlock, MUTEX_DEFAULT, IPL_VM) 113#define read_lock(rwlock) mutex_spin_enter(rwlock) 114#define read_unlock(rwlock) mutex_spin_exit(rwlock) 115 116#define write_lock(rwlock) mutex_spin_enter(rwlock) 117#define write_unlock(rwlock) mutex_spin_exit(rwlock) 118 119#define read_lock_bh(rwlock) read_lock(rwlock) 120#define read_unlock_bh(rwlock) read_unlock(rwlock) 121#define write_lock_bh(rwlock) write_lock(rwlock) 122#define write_unlock_bh(rwlock) write_unlock(rwlock) 123 124/* 125 * Timer API 126 */ 127struct timer_list { 128 kmutex_t mtx; 129 callout_t callout; 130 131 unsigned long expires; 132 void (*function)(unsigned long); 133 unsigned long data; 134}; 135 136void init_timer(struct timer_list *t); 137void setup_timer(struct timer_list *t, void (*function)(unsigned long), unsigned long data); 138void mod_timer(struct timer_list *t, unsigned long expires); 139void add_timer(struct timer_list *t); 140int del_timer(struct timer_list *t); 141int del_timer_sync(struct timer_list *t); 142 143/* 144 * Semaphore API 145 */ 146struct semaphore { 147 kmutex_t mtx; 148 kcondvar_t cv; 149 int value; 150 int waiters; 151}; 152 153/* 154 * NB: Need to initialize these at attach time! 155 */ 156#define DEFINE_SEMAPHORE(name) struct semaphore name 157 158void sema_sysinit(void *arg); 159void _sema_init(struct semaphore *s, int value); 160void _sema_destroy(struct semaphore *s); 161void down(struct semaphore *s); 162int down_interruptible(struct semaphore *s); 163int down_trylock(struct semaphore *s); 164void up(struct semaphore *s); 165 166/* 167 * Logging and assertions API 168 */ 169void rlprintf(int pps, const char *fmt, ...) 170 __printflike(2, 3); 171 172void 173device_rlprintf(int pps, device_t dev, const char *fmt, ...) 174 __printflike(3, 4); 175 176#define might_sleep() 177 178#define WARN(condition, msg) \ 179({ \ 180 int __ret_warn_on = !!(condition); \ 181 if (unlikely(__ret_warn_on)) \ 182 printf((msg)); \ 183 unlikely(__ret_warn_on); \ 184}) 185 186 187 188#define WARN_ON(condition) \ 189({ \ 190 int __ret_warn_on = !!(condition); \ 191 if (unlikely(__ret_warn_on)) \ 192 printf("WARN_ON: " #condition "\n"); \ 193 unlikely(__ret_warn_on); \ 194}) 195 196#define WARN_ON_ONCE(condition) ({ \ 197 static int __warned; \ 198 int __ret_warn_once = !!(condition); \ 199 \ 200 if (unlikely(__ret_warn_once)) \ 201 if (WARN_ON(!__warned)) \ 202 __warned = 1; \ 203 unlikely(__ret_warn_once); \ 204}) 205 206#define BUG_ON(cond) \ 207 do { \ 208 if (cond) \ 209 panic("BUG_ON: " #cond); \ 210 } while (0) 211 212#define BUG() \ 213 do { \ 214 panic("BUG: %s:%d", __FILE__, __LINE__); \ 215 } while (0) 216 217#define vchiq_static_assert(cond) CTASSERT(cond) 218 219/* 220 * Kernel module API 221 */ 222#define __init 223#define __exit 224#define __devinit 225#define __devexit 226#define __devinitdata 227 228/* 229 * Time API 230 */ 231#if 1 232/* emulate jiffies */ 233static inline unsigned long 234_jiffies(void) 235{ 236 struct timeval tv; 237 238 microuptime(&tv); 239 return tvtohz(&tv); 240} 241 242static inline unsigned long 243msecs_to_jiffies(unsigned long msecs) 244{ 245 struct timeval tv; 246 247 tv.tv_sec = msecs / 1000000UL; 248 tv.tv_usec = msecs % 1000000UL; 249 return tvtohz(&tv); 250} 251 252#define jiffies _jiffies() 253#else 254#define jiffies ticks 255#endif 256#define HZ hz 257 258#define udelay(usec) DELAY(usec) 259#define mdelay(msec) DELAY((msec) * 1000) 260 261#define schedule_timeout(jiff) kpause("dhdslp", false, jiff, NULL) 262 263#if defined(msleep) 264#undef msleep 265#endif 266#define msleep(msec) mdelay(msec) 267 268#define time_after(a, b) ((a) > (b)) 269#define time_after_eq(a, b) ((a) >= (b)) 270#define time_before(a, b) time_after((b), (a)) 271 272/* 273 * kthread API (we use lwp) 274 */ 275typedef lwp_t * VCHIQ_THREAD_T; 276 277VCHIQ_THREAD_T vchiq_thread_create(int (*threadfn)(void *data), 278 void *data, 279 const char namefmt[], ...); 280void set_user_nice(VCHIQ_THREAD_T p, int nice); 281void wake_up_process(VCHIQ_THREAD_T p); 282 283/* 284 * Proc APIs 285 */ 286void flush_signals(VCHIQ_THREAD_T); 287int fatal_signal_pending(VCHIQ_THREAD_T); 288 289/* 290 * Misc API 291 */ 292 293#define __user 294 295#define current curlwp 296#define EXPORT_SYMBOL(x) 297#define PAGE_ALIGN(addr) round_page(addr) 298 299typedef void irqreturn_t; 300typedef off_t loff_t; 301 302#define BCM2835_MBOX_CHAN_VCHIQ 3 303#define bcm_mbox_write bcmmbox_write 304 305#define dsb membar_producer 306 307#define device_print_prettyname(dev) device_printf((dev), "") 308 309#endif /* __VCHI_NETBSD_H__ */ 310