xref: /freebsd/sys/contrib/vchiq/interface/compat/vchi_bsd.h (revision 04b8208fc0d4f17fc43a189baa395d9a2a66acd2)
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/param.h>
329fc7a59fSIan Lepore #include <sys/systm.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>
39e88b3f2eSOleksandr Tymoshenko #include <sys/rwlock.h>
40262f27b2SOleksandr Tymoshenko #include <sys/sx.h>
41262f27b2SOleksandr Tymoshenko #include <sys/sema.h>
42262f27b2SOleksandr Tymoshenko #include <sys/malloc.h>
43262f27b2SOleksandr Tymoshenko #include <sys/proc.h>
44262f27b2SOleksandr Tymoshenko #include <sys/types.h>
45262f27b2SOleksandr Tymoshenko #include <sys/ioccom.h>
46262f27b2SOleksandr Tymoshenko 
47262f27b2SOleksandr Tymoshenko /*
48262f27b2SOleksandr Tymoshenko  * Copy from/to user API
49262f27b2SOleksandr Tymoshenko  */
50262f27b2SOleksandr Tymoshenko #define copy_from_user(to, from, n)	copyin((from), (to), (n))
51262f27b2SOleksandr Tymoshenko #define copy_to_user(to, from, n)	copyout((from), (to), (n))
52262f27b2SOleksandr Tymoshenko 
53262f27b2SOleksandr Tymoshenko /*
54262f27b2SOleksandr Tymoshenko  * Bit API
55262f27b2SOleksandr Tymoshenko  */
56262f27b2SOleksandr Tymoshenko 
57262f27b2SOleksandr Tymoshenko static __inline int
test_and_set_bit(int nr,volatile void * addr)58262f27b2SOleksandr Tymoshenko test_and_set_bit(int nr, volatile void *addr)
59262f27b2SOleksandr Tymoshenko {
60262f27b2SOleksandr Tymoshenko 	int val;
61262f27b2SOleksandr Tymoshenko 
62262f27b2SOleksandr Tymoshenko 	do {
63262f27b2SOleksandr Tymoshenko 		val = *(volatile int *) addr;
64262f27b2SOleksandr Tymoshenko 	} while (atomic_cmpset_int(addr, val, val | (1 << nr)) == 0);
65262f27b2SOleksandr Tymoshenko 	return (val & (1 << nr));
66262f27b2SOleksandr Tymoshenko }
67262f27b2SOleksandr Tymoshenko 
68262f27b2SOleksandr Tymoshenko static __inline__
test_and_clear_bit(int nr,volatile void * addr)69262f27b2SOleksandr Tymoshenko int test_and_clear_bit(int nr, volatile void *addr)
70262f27b2SOleksandr Tymoshenko {
71262f27b2SOleksandr Tymoshenko 	int val;
72262f27b2SOleksandr Tymoshenko 
73262f27b2SOleksandr Tymoshenko 	do {
74262f27b2SOleksandr Tymoshenko 		val = *(volatile int *) addr;
75262f27b2SOleksandr Tymoshenko 	} while (atomic_cmpset_int(addr, val, val & ~(1 << nr)) == 0);
76262f27b2SOleksandr Tymoshenko 	return (val & (1 << nr));
77262f27b2SOleksandr Tymoshenko }
78262f27b2SOleksandr Tymoshenko 
79262f27b2SOleksandr Tymoshenko /*
80262f27b2SOleksandr Tymoshenko  * Atomic API
81262f27b2SOleksandr Tymoshenko  */
82262f27b2SOleksandr Tymoshenko typedef volatile unsigned atomic_t;
83262f27b2SOleksandr Tymoshenko 
84262f27b2SOleksandr Tymoshenko #define atomic_set(p, v)	(*(p) = (v))
85262f27b2SOleksandr Tymoshenko #define atomic_read(p)		(*(p))
86262f27b2SOleksandr Tymoshenko #define atomic_inc(p)		atomic_add_int(p, 1)
87262f27b2SOleksandr Tymoshenko #define atomic_dec(p)		atomic_subtract_int(p, 1)
88262f27b2SOleksandr Tymoshenko #define atomic_dec_and_test(p)	(atomic_fetchadd_int(p, -1) == 1)
89262f27b2SOleksandr Tymoshenko #define	atomic_inc_return(v)	atomic_add_return(1, (v))
90262f27b2SOleksandr Tymoshenko #define	atomic_dec_return(v)	atomic_sub_return(1, (v))
91262f27b2SOleksandr Tymoshenko #define atomic_add(v, p)	atomic_add_int(p, v)
92262f27b2SOleksandr Tymoshenko #define atomic_sub(v, p)	atomic_subtract_int(p, v)
93262f27b2SOleksandr Tymoshenko 
94262f27b2SOleksandr Tymoshenko #define ATOMIC_INIT(v)		(v)
95262f27b2SOleksandr Tymoshenko 
96262f27b2SOleksandr Tymoshenko static inline int
atomic_add_return(int i,atomic_t * v)97262f27b2SOleksandr Tymoshenko atomic_add_return(int i, atomic_t *v)
98262f27b2SOleksandr Tymoshenko {
99262f27b2SOleksandr Tymoshenko 	return i + atomic_fetchadd_int(v, i);
100262f27b2SOleksandr Tymoshenko }
101262f27b2SOleksandr Tymoshenko 
102262f27b2SOleksandr Tymoshenko static inline int
atomic_sub_return(int i,atomic_t * v)103262f27b2SOleksandr Tymoshenko atomic_sub_return(int i, atomic_t *v)
104262f27b2SOleksandr Tymoshenko {
105262f27b2SOleksandr Tymoshenko 	return atomic_fetchadd_int(v, -i) - i;
106262f27b2SOleksandr Tymoshenko }
107262f27b2SOleksandr Tymoshenko 
108262f27b2SOleksandr Tymoshenko static inline int
atomic_cmpxchg(atomic_t * v,int oldv,int newv)109262f27b2SOleksandr Tymoshenko atomic_cmpxchg(atomic_t *v, int oldv, int newv)
110262f27b2SOleksandr Tymoshenko {
111262f27b2SOleksandr Tymoshenko 	if (atomic_cmpset_rel_int(v, oldv, newv))
112262f27b2SOleksandr Tymoshenko 		return newv;
113262f27b2SOleksandr Tymoshenko 	else
114262f27b2SOleksandr Tymoshenko 		return *v;
115262f27b2SOleksandr Tymoshenko }
116262f27b2SOleksandr Tymoshenko 
117262f27b2SOleksandr Tymoshenko static inline int
atomic_xchg(atomic_t * v,int newv)118262f27b2SOleksandr Tymoshenko atomic_xchg(atomic_t *v, int newv)
119262f27b2SOleksandr Tymoshenko {
120262f27b2SOleksandr Tymoshenko 	int oldv;
121262f27b2SOleksandr Tymoshenko 	if (newv == 0)
122262f27b2SOleksandr Tymoshenko 		return atomic_readandclear_int(v);
123262f27b2SOleksandr Tymoshenko 	else {
124262f27b2SOleksandr Tymoshenko 		do {
125262f27b2SOleksandr Tymoshenko 			oldv = atomic_load_acq_int(v);
126262f27b2SOleksandr Tymoshenko 		} while (!atomic_cmpset_rel_int(v, oldv, newv));
127262f27b2SOleksandr Tymoshenko 	}
128262f27b2SOleksandr Tymoshenko 
129262f27b2SOleksandr Tymoshenko 	return (oldv);
130262f27b2SOleksandr Tymoshenko }
131262f27b2SOleksandr Tymoshenko 
132262f27b2SOleksandr Tymoshenko /*
133262f27b2SOleksandr Tymoshenko  * Spinlock API
134262f27b2SOleksandr Tymoshenko  */
135262f27b2SOleksandr Tymoshenko typedef struct mtx spinlock_t;
136262f27b2SOleksandr Tymoshenko 
137262f27b2SOleksandr Tymoshenko #define DEFINE_SPINLOCK(name)				\
138262f27b2SOleksandr Tymoshenko 	struct mtx name
139262f27b2SOleksandr Tymoshenko #define spin_lock_init(lock)	mtx_init(lock, "VCHI spinlock " # lock, NULL, MTX_DEF)
140262f27b2SOleksandr Tymoshenko #define spin_lock_destroy(lock)	mtx_destroy(lock)
141262f27b2SOleksandr Tymoshenko #define spin_lock(lock)		mtx_lock(lock)
142262f27b2SOleksandr Tymoshenko #define spin_unlock(lock)	mtx_unlock(lock)
143262f27b2SOleksandr Tymoshenko #define spin_lock_bh(lock)	spin_lock(lock)
144262f27b2SOleksandr Tymoshenko #define spin_unlock_bh(lock)	spin_unlock(lock)
145262f27b2SOleksandr Tymoshenko 
146262f27b2SOleksandr Tymoshenko /*
147262f27b2SOleksandr Tymoshenko  * Mutex API
148262f27b2SOleksandr Tymoshenko  */
149262f27b2SOleksandr Tymoshenko struct mutex {
150e88b3f2eSOleksandr Tymoshenko 	struct sx	mtx;
151262f27b2SOleksandr Tymoshenko };
152262f27b2SOleksandr Tymoshenko 
153e88b3f2eSOleksandr Tymoshenko #define	lmutex_init(lock)	sx_init(&(lock)->mtx, #lock)
154e88b3f2eSOleksandr Tymoshenko #define lmutex_lock(lock)	sx_xlock(&(lock)->mtx)
155e88b3f2eSOleksandr Tymoshenko #define	lmutex_unlock(lock)	sx_unlock(&(lock)->mtx)
156e88b3f2eSOleksandr Tymoshenko #define	lmutex_destroy(lock)	sx_destroy(&(lock)->mtx)
157262f27b2SOleksandr Tymoshenko 
158e88b3f2eSOleksandr Tymoshenko #define lmutex_lock_interruptible(lock)	sx_xlock_sig(&(lock)->mtx)
159e6c4672eSOleksandr Tymoshenko 
160262f27b2SOleksandr Tymoshenko /*
161262f27b2SOleksandr Tymoshenko  * Rwlock API
162262f27b2SOleksandr Tymoshenko  */
163e88b3f2eSOleksandr Tymoshenko typedef struct rwlock rwlock_t;
164262f27b2SOleksandr Tymoshenko 
165262f27b2SOleksandr Tymoshenko #define DEFINE_RWLOCK(name)				\
166e88b3f2eSOleksandr Tymoshenko 	struct rwlock name;					\
167262f27b2SOleksandr Tymoshenko 	SX_SYSINIT(name, &name, #name)
168e88b3f2eSOleksandr Tymoshenko #define rwlock_init(rwlock)	rw_init(rwlock, "VCHI rwlock")
169e88b3f2eSOleksandr Tymoshenko #define read_lock(rwlock)	rw_rlock(rwlock)
170e88b3f2eSOleksandr Tymoshenko #define read_unlock(rwlock)	rw_unlock(rwlock)
171262f27b2SOleksandr Tymoshenko 
172e88b3f2eSOleksandr Tymoshenko #define write_lock(rwlock)	rw_wlock(rwlock)
173e88b3f2eSOleksandr Tymoshenko #define write_unlock(rwlock)	rw_unlock(rwlock)
174262f27b2SOleksandr Tymoshenko #define write_lock_irqsave(rwlock, flags)		\
175262f27b2SOleksandr Tymoshenko 	do {						\
176e88b3f2eSOleksandr Tymoshenko 		rw_wlock(rwlock);			\
177262f27b2SOleksandr Tymoshenko 		(void) &(flags);			\
178262f27b2SOleksandr Tymoshenko 	} while (0)
179262f27b2SOleksandr Tymoshenko #define write_unlock_irqrestore(rwlock, flags)		\
180e88b3f2eSOleksandr Tymoshenko 	rw_unlock(rwlock)
181262f27b2SOleksandr Tymoshenko 
182e88b3f2eSOleksandr Tymoshenko #define read_lock_bh(rwlock)	rw_rlock(rwlock)
183e88b3f2eSOleksandr Tymoshenko #define read_unlock_bh(rwlock)	rw_unlock(rwlock)
184e88b3f2eSOleksandr Tymoshenko #define write_lock_bh(rwlock)	rw_wlock(rwlock)
185e88b3f2eSOleksandr Tymoshenko #define write_unlock_bh(rwlock)	rw_unlock(rwlock)
186262f27b2SOleksandr Tymoshenko 
187262f27b2SOleksandr Tymoshenko /*
188262f27b2SOleksandr Tymoshenko  * Timer API
189262f27b2SOleksandr Tymoshenko  */
190262f27b2SOleksandr Tymoshenko struct timer_list {
191262f27b2SOleksandr Tymoshenko 	struct mtx mtx;
192262f27b2SOleksandr Tymoshenko 	struct callout callout;
193262f27b2SOleksandr Tymoshenko 
194262f27b2SOleksandr Tymoshenko 	unsigned long expires;
195262f27b2SOleksandr Tymoshenko 	void (*function)(unsigned long);
196262f27b2SOleksandr Tymoshenko 	unsigned long data;
197262f27b2SOleksandr Tymoshenko };
198262f27b2SOleksandr Tymoshenko 
199*04b8208fSEmmanuel Vadot void vchiq_init_timer(struct timer_list *t);
200*04b8208fSEmmanuel Vadot void vchiq_setup_timer(struct timer_list *t, void (*function)(unsigned long), unsigned long data);
201*04b8208fSEmmanuel Vadot void vchiq_mod_timer(struct timer_list *t, unsigned long expires);
202*04b8208fSEmmanuel Vadot void vchiq_add_timer(struct timer_list *t);
203*04b8208fSEmmanuel Vadot int vchiq_del_timer(struct timer_list *t);
204*04b8208fSEmmanuel Vadot int vchiq_del_timer_sync(struct timer_list *t);
205262f27b2SOleksandr Tymoshenko 
206262f27b2SOleksandr Tymoshenko /*
207262f27b2SOleksandr Tymoshenko  * Completion API
208262f27b2SOleksandr Tymoshenko  */
209262f27b2SOleksandr Tymoshenko struct completion {
210262f27b2SOleksandr Tymoshenko 	struct cv cv;
211262f27b2SOleksandr Tymoshenko 	struct mtx lock;
212262f27b2SOleksandr Tymoshenko 	int done;
213262f27b2SOleksandr Tymoshenko };
214262f27b2SOleksandr Tymoshenko 
215262f27b2SOleksandr Tymoshenko void init_completion(struct completion *c);
216262f27b2SOleksandr Tymoshenko void destroy_completion(struct completion *c);
217262f27b2SOleksandr Tymoshenko int try_wait_for_completion(struct completion *);
218262f27b2SOleksandr Tymoshenko int wait_for_completion_interruptible(struct completion *);
219262f27b2SOleksandr Tymoshenko int wait_for_completion_interruptible_timeout(struct completion *, unsigned long ticks);
220262f27b2SOleksandr Tymoshenko int wait_for_completion_killable(struct completion *);
221262f27b2SOleksandr Tymoshenko void wait_for_completion(struct completion *c);
222262f27b2SOleksandr Tymoshenko void complete(struct completion *c);
223262f27b2SOleksandr Tymoshenko void complete_all(struct completion *c);
224262f27b2SOleksandr Tymoshenko void INIT_COMPLETION_locked(struct completion *c);
225262f27b2SOleksandr Tymoshenko 
226262f27b2SOleksandr Tymoshenko #define	INIT_COMPLETION(x)	INIT_COMPLETION_locked(&(x))
227262f27b2SOleksandr Tymoshenko 
228262f27b2SOleksandr Tymoshenko /*
229262f27b2SOleksandr Tymoshenko  * Semaphore API
230262f27b2SOleksandr Tymoshenko  */
231262f27b2SOleksandr Tymoshenko struct semaphore {
232262f27b2SOleksandr Tymoshenko 	struct mtx	mtx;
233262f27b2SOleksandr Tymoshenko 	struct cv	cv;
234262f27b2SOleksandr Tymoshenko 	int		value;
235262f27b2SOleksandr Tymoshenko 	int		waiters;
236262f27b2SOleksandr Tymoshenko };
237262f27b2SOleksandr Tymoshenko 
238262f27b2SOleksandr Tymoshenko #define	DEFINE_SEMAPHORE(name)		\
239262f27b2SOleksandr Tymoshenko 	struct semaphore name;		\
240262f27b2SOleksandr Tymoshenko 	SYSINIT(name##_sema_sysinit, SI_SUB_LOCK, SI_ORDER_MIDDLE,	\
241262f27b2SOleksandr Tymoshenko 	    sema_sysinit, &name);					\
242262f27b2SOleksandr Tymoshenko 	SYSUNINIT(name##_sema_sysuninit, SI_SUB_LOCK, SI_ORDER_MIDDLE,	\
243262f27b2SOleksandr Tymoshenko 	    _sema_destroy, __DEVOLATILE(void *, &(name)))
244262f27b2SOleksandr Tymoshenko 
245262f27b2SOleksandr Tymoshenko void sema_sysinit(void *arg);
246262f27b2SOleksandr Tymoshenko void _sema_init(struct semaphore *s, int value);
247262f27b2SOleksandr Tymoshenko void _sema_destroy(struct semaphore *s);
248262f27b2SOleksandr Tymoshenko void down(struct semaphore *s);
249262f27b2SOleksandr Tymoshenko int down_interruptible(struct semaphore *s);
250262f27b2SOleksandr Tymoshenko int down_trylock(struct semaphore *s);
251262f27b2SOleksandr Tymoshenko void up(struct semaphore *s);
252262f27b2SOleksandr Tymoshenko 
253262f27b2SOleksandr Tymoshenko /*
254262f27b2SOleksandr Tymoshenko  * Logging and assertions API
255262f27b2SOleksandr Tymoshenko  */
256262f27b2SOleksandr Tymoshenko void rlprintf(int pps, const char *fmt, ...)
257262f27b2SOleksandr Tymoshenko 	__printflike(2, 3);
258262f27b2SOleksandr Tymoshenko 
259262f27b2SOleksandr Tymoshenko void
260262f27b2SOleksandr Tymoshenko device_rlprintf(int pps, device_t dev, const char *fmt, ...)
261262f27b2SOleksandr Tymoshenko 	__printflike(3, 4);
262262f27b2SOleksandr Tymoshenko 
263262f27b2SOleksandr Tymoshenko #define might_sleep()
264262f27b2SOleksandr Tymoshenko 
265262f27b2SOleksandr Tymoshenko #define WARN(condition, msg)				\
266262f27b2SOleksandr Tymoshenko ({							\
267262f27b2SOleksandr Tymoshenko 	int __ret_warn_on = !!(condition);		\
268262f27b2SOleksandr Tymoshenko 	if (unlikely(__ret_warn_on))			\
269262f27b2SOleksandr Tymoshenko 		printf((msg));				\
270262f27b2SOleksandr Tymoshenko 	unlikely(__ret_warn_on);			\
271262f27b2SOleksandr Tymoshenko })
272262f27b2SOleksandr Tymoshenko 
273262f27b2SOleksandr Tymoshenko 
274262f27b2SOleksandr Tymoshenko 
275262f27b2SOleksandr Tymoshenko #define WARN_ON(condition)				\
276262f27b2SOleksandr Tymoshenko ({							\
277262f27b2SOleksandr Tymoshenko 	int __ret_warn_on = !!(condition);		\
278262f27b2SOleksandr Tymoshenko 	if (unlikely(__ret_warn_on))			\
279262f27b2SOleksandr Tymoshenko 		printf("WARN_ON: " #condition "\n");	\
280262f27b2SOleksandr Tymoshenko 	unlikely(__ret_warn_on);			\
281262f27b2SOleksandr Tymoshenko })
282262f27b2SOleksandr Tymoshenko 
283262f27b2SOleksandr Tymoshenko #define WARN_ON_ONCE(condition) ({			\
284262f27b2SOleksandr Tymoshenko 	static int __warned;				\
285262f27b2SOleksandr Tymoshenko 	int __ret_warn_once = !!(condition);		\
286262f27b2SOleksandr Tymoshenko 							\
287262f27b2SOleksandr Tymoshenko 	if (unlikely(__ret_warn_once))			\
288262f27b2SOleksandr Tymoshenko 		if (WARN_ON(!__warned))			\
289262f27b2SOleksandr Tymoshenko 			__warned = 1;			\
290262f27b2SOleksandr Tymoshenko 	unlikely(__ret_warn_once);			\
291262f27b2SOleksandr Tymoshenko })
292262f27b2SOleksandr Tymoshenko 
293262f27b2SOleksandr Tymoshenko #define BUG_ON(cond)					\
294262f27b2SOleksandr Tymoshenko 	do {						\
295262f27b2SOleksandr Tymoshenko 		if (cond)				\
296262f27b2SOleksandr Tymoshenko 			panic("BUG_ON: " #cond);	\
297262f27b2SOleksandr Tymoshenko 	} while (0)
298262f27b2SOleksandr Tymoshenko 
299262f27b2SOleksandr Tymoshenko #define BUG()						\
300262f27b2SOleksandr Tymoshenko 	do {						\
301262f27b2SOleksandr Tymoshenko 		panic("BUG: %s:%d", __FILE__, __LINE__);	\
302262f27b2SOleksandr Tymoshenko 	} while (0)
303262f27b2SOleksandr Tymoshenko 
304262f27b2SOleksandr Tymoshenko #define vchiq_static_assert(cond) CTASSERT(cond)
305262f27b2SOleksandr Tymoshenko 
306262f27b2SOleksandr Tymoshenko #define KERN_EMERG	"<0>"	/* system is unusable			*/
307262f27b2SOleksandr Tymoshenko #define KERN_ALERT	"<1>"	/* action must be taken immediately	*/
308262f27b2SOleksandr Tymoshenko #define KERN_CRIT	"<2>"	/* critical conditions			*/
309262f27b2SOleksandr Tymoshenko #define KERN_ERR	"<3>"	/* error conditions			*/
310262f27b2SOleksandr Tymoshenko #define KERN_WARNING	"<4>"	/* warning conditions			*/
311262f27b2SOleksandr Tymoshenko #define KERN_NOTICE	"<5>"	/* normal but significant condition	*/
312262f27b2SOleksandr Tymoshenko #define KERN_INFO	"<6>"	/* informational			*/
313262f27b2SOleksandr Tymoshenko #define KERN_DEBUG	"<7>"	/* debug-level messages			*/
314262f27b2SOleksandr Tymoshenko #define KERN_CONT	""
315262f27b2SOleksandr Tymoshenko 
316262f27b2SOleksandr Tymoshenko #define printk(fmt, args...)		printf(fmt, ##args)
317262f27b2SOleksandr Tymoshenko #define vprintk(fmt, args)		vprintf(fmt, args)
318262f27b2SOleksandr Tymoshenko 
319262f27b2SOleksandr Tymoshenko /*
320262f27b2SOleksandr Tymoshenko  * Malloc API
321262f27b2SOleksandr Tymoshenko  */
322262f27b2SOleksandr Tymoshenko #define GFP_KERNEL	0
323262f27b2SOleksandr Tymoshenko #define GFP_ATOMIC	0
324262f27b2SOleksandr Tymoshenko 
325262f27b2SOleksandr Tymoshenko MALLOC_DECLARE(M_VCHI);
326262f27b2SOleksandr Tymoshenko 
327262f27b2SOleksandr Tymoshenko #define kmalloc(size, flags)	malloc((size), M_VCHI, M_NOWAIT | M_ZERO)
3285cf32a6eSKristof Provost #define kcalloc(n, size, flags)	mallocarray((n), (size), M_VCHI, \
3295cf32a6eSKristof Provost 				    M_NOWAIT | M_ZERO)
330262f27b2SOleksandr Tymoshenko #define kzalloc(a, b)		kcalloc(1, (a), (b))
331262f27b2SOleksandr Tymoshenko #define kfree(p)		free(p, M_VCHI)
332262f27b2SOleksandr Tymoshenko 
333262f27b2SOleksandr Tymoshenko /*
334262f27b2SOleksandr Tymoshenko  * Kernel module API
335262f27b2SOleksandr Tymoshenko  */
336262f27b2SOleksandr Tymoshenko #define __init
337262f27b2SOleksandr Tymoshenko #define __exit
338262f27b2SOleksandr Tymoshenko #define __devinit
339262f27b2SOleksandr Tymoshenko #define __devexit
340262f27b2SOleksandr Tymoshenko #define __devinitdata
341262f27b2SOleksandr Tymoshenko 
342262f27b2SOleksandr Tymoshenko /*
343262f27b2SOleksandr Tymoshenko  * Time API
344262f27b2SOleksandr Tymoshenko  */
345262f27b2SOleksandr Tymoshenko #if 1
346262f27b2SOleksandr Tymoshenko /* emulate jiffies */
347262f27b2SOleksandr Tymoshenko static inline unsigned long
_jiffies(void)348262f27b2SOleksandr Tymoshenko _jiffies(void)
349262f27b2SOleksandr Tymoshenko {
350262f27b2SOleksandr Tymoshenko 	struct timeval tv;
351262f27b2SOleksandr Tymoshenko 
352262f27b2SOleksandr Tymoshenko 	microuptime(&tv);
353262f27b2SOleksandr Tymoshenko 	return tvtohz(&tv);
354262f27b2SOleksandr Tymoshenko }
355262f27b2SOleksandr Tymoshenko 
356262f27b2SOleksandr Tymoshenko static inline unsigned long
msecs_to_jiffies(unsigned long msecs)357262f27b2SOleksandr Tymoshenko msecs_to_jiffies(unsigned long msecs)
358262f27b2SOleksandr Tymoshenko {
359262f27b2SOleksandr Tymoshenko 	struct timeval tv;
360262f27b2SOleksandr Tymoshenko 
361262f27b2SOleksandr Tymoshenko 	tv.tv_sec = msecs / 1000000UL;
362262f27b2SOleksandr Tymoshenko 	tv.tv_usec = msecs % 1000000UL;
363262f27b2SOleksandr Tymoshenko 	return tvtohz(&tv);
364262f27b2SOleksandr Tymoshenko }
365262f27b2SOleksandr Tymoshenko 
366262f27b2SOleksandr Tymoshenko #define jiffies			_jiffies()
367262f27b2SOleksandr Tymoshenko #else
368262f27b2SOleksandr Tymoshenko #define jiffies			ticks
369262f27b2SOleksandr Tymoshenko #endif
370262f27b2SOleksandr Tymoshenko #define HZ			hz
371262f27b2SOleksandr Tymoshenko 
372262f27b2SOleksandr Tymoshenko #define udelay(usec)		DELAY(usec)
373262f27b2SOleksandr Tymoshenko #define mdelay(msec)		DELAY((msec) * 1000)
374262f27b2SOleksandr Tymoshenko 
375262f27b2SOleksandr Tymoshenko #define schedule_timeout(jiff)	pause("dhdslp", jiff)
376262f27b2SOleksandr Tymoshenko 
377262f27b2SOleksandr Tymoshenko #if defined(msleep)
378262f27b2SOleksandr Tymoshenko #undef msleep
379262f27b2SOleksandr Tymoshenko #endif
380262f27b2SOleksandr Tymoshenko #define msleep(msec)		mdelay(msec)
381262f27b2SOleksandr Tymoshenko 
382262f27b2SOleksandr Tymoshenko #define time_after(a, b)	((a) > (b))
383262f27b2SOleksandr Tymoshenko #define time_after_eq(a, b)	((a) >= (b))
384262f27b2SOleksandr Tymoshenko #define time_before(a, b)	time_after((b), (a))
385262f27b2SOleksandr Tymoshenko 
386262f27b2SOleksandr Tymoshenko /*
387262f27b2SOleksandr Tymoshenko  * kthread API (we use proc)
388262f27b2SOleksandr Tymoshenko  */
389262f27b2SOleksandr Tymoshenko typedef struct proc * VCHIQ_THREAD_T;
390262f27b2SOleksandr Tymoshenko 
391262f27b2SOleksandr Tymoshenko VCHIQ_THREAD_T vchiq_thread_create(int (*threadfn)(void *data),
392262f27b2SOleksandr Tymoshenko                                    void *data,
393262f27b2SOleksandr Tymoshenko                                    const char namefmt[], ...);
394262f27b2SOleksandr Tymoshenko void set_user_nice(VCHIQ_THREAD_T p, int nice);
395262f27b2SOleksandr Tymoshenko void wake_up_process(VCHIQ_THREAD_T p);
396262f27b2SOleksandr Tymoshenko 
397262f27b2SOleksandr Tymoshenko /*
398262f27b2SOleksandr Tymoshenko  * Proc APIs
399262f27b2SOleksandr Tymoshenko  */
400262f27b2SOleksandr Tymoshenko void flush_signals(VCHIQ_THREAD_T);
401262f27b2SOleksandr Tymoshenko int fatal_signal_pending(VCHIQ_THREAD_T);
402262f27b2SOleksandr Tymoshenko 
403262f27b2SOleksandr Tymoshenko /*
404262f27b2SOleksandr Tymoshenko  * mbox API
405262f27b2SOleksandr Tymoshenko  */
406262f27b2SOleksandr Tymoshenko void bcm_mbox_write(int channel, uint32_t data);
407262f27b2SOleksandr Tymoshenko 
408262f27b2SOleksandr Tymoshenko /*
409262f27b2SOleksandr Tymoshenko  * Misc API
410262f27b2SOleksandr Tymoshenko  */
411262f27b2SOleksandr Tymoshenko 
412262f27b2SOleksandr Tymoshenko #define ENODATA EINVAL
413262f27b2SOleksandr Tymoshenko 
414262f27b2SOleksandr Tymoshenko #define __user
415262f27b2SOleksandr Tymoshenko 
416262f27b2SOleksandr Tymoshenko #define likely(x)		__builtin_expect(!!(x), 1)
417262f27b2SOleksandr Tymoshenko #define unlikely(x)		__builtin_expect(!!(x), 0)
418262f27b2SOleksandr Tymoshenko #define	current			curproc
419262f27b2SOleksandr Tymoshenko #define EXPORT_SYMBOL(x)
420262f27b2SOleksandr Tymoshenko #define PAGE_ALIGN(addr)	round_page(addr)
421262f27b2SOleksandr Tymoshenko 
422262f27b2SOleksandr Tymoshenko typedef	void	irqreturn_t;
423262f27b2SOleksandr Tymoshenko typedef	off_t	loff_t;
424262f27b2SOleksandr Tymoshenko 
425262f27b2SOleksandr Tymoshenko #define BCM2835_MBOX_CHAN_VCHIQ	3
426262f27b2SOleksandr Tymoshenko 
427262f27b2SOleksandr Tymoshenko #define smp_mb	wmb
428262f27b2SOleksandr Tymoshenko #define smp_rmb	rmb
429262f27b2SOleksandr Tymoshenko #define smp_wmb	wmb
430262f27b2SOleksandr Tymoshenko 
431262f27b2SOleksandr Tymoshenko #define device_print_prettyname(dev)	device_printf((dev), "")
432262f27b2SOleksandr Tymoshenko 
433262f27b2SOleksandr Tymoshenko #endif /* __VCHI_BSD_H__ */
434