xref: /openbsd-src/sys/arch/hppa/include/mplock.h (revision 9593dc34da13a12012033a17061c846c208061c2)
1 /*	$OpenBSD: mplock.h,v 1.7 2024/09/04 07:54:51 mglocker Exp $	*/
2 
3 /*
4  * Copyright (c) 2004 Niklas Hallqvist.  All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
16  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
18  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
19  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
20  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
24  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25  */
26 
27 #ifndef _MACHINE_MPLOCK_H_
28 #define _MACHINE_MPLOCK_H_
29 
30 /*
31  * Really simple spinlock implementation with recursive capabilities.
32  * Correctness is paramount, no fanciness allowed.
33  */
34 
35 #define	MPL_LOCKED	0
36 #define	MPL_UNLOCKED	1
37 
38 struct __mp_lock {
39 	volatile int mpl_lock[4];
40 	volatile struct cpu_info *mpl_cpu;
41 	volatile long mpl_count;
42 #ifdef WITNESS
43 	struct lock_object	mpl_lock_obj;
44 #endif
45 };
46 
47 #ifndef _LOCORE
48 
49 void	___mp_lock_init(struct __mp_lock *);
50 void	__mp_lock(struct __mp_lock *);
51 void	__mp_unlock(struct __mp_lock *);
52 int	__mp_release_all(struct __mp_lock *);
53 void	__mp_acquire_count(struct __mp_lock *, int);
54 int	__mp_lock_held(struct __mp_lock *, struct cpu_info *);
55 
56 #ifdef WITNESS
57 
58 void	_mp_lock_init(struct __mp_lock *, const struct lock_type *);
59 
60 #define __mp_lock_init(mpl) do {					\
61 	static const struct lock_type __lock_type = { .lt_name = #mpl };\
62 	_mp_lock_init((mpl), &__lock_type);				\
63 } while (0)
64 
65 #else /* WITNESS */
66 
67 #define __mp_lock_init		___mp_lock_init
68 
69 #endif /* WITNESS */
70 
71 #endif
72 
73 #endif /* !_MACHINE_MPLOCK_H */
74