]> rtime.felk.cvut.cz Git - l4.git/blob - l4/pkg/l4sys/include/ARCH-sparc/__semaphore_impl.h
update
[l4.git] / l4 / pkg / l4sys / include / ARCH-sparc / __semaphore_impl.h
1 /**
2  * \file
3  * \brief  User-lock implementation for SPARC
4  */
5 /*
6  * (c) 2008-2009 Adam Lackorzynski <adam@os.inf.tu-dresden.de>,
7  *               Alexander Warg <warg@os.inf.tu-dresden.de>
8  *     economic rights: Technische Universität Dresden (Germany)
9  *
10  * This file is part of TUD:OS and distributed under the terms of the
11  * GNU General Public License 2.
12  * Please see the COPYING-GPL-2 file for details.
13  *
14  * As a special exception, you may use this file as part of a free software
15  * library without restriction.  Specifically, if other files instantiate
16  * templates or use macros or inline functions from this file, or you compile
17  * this file and link it with other files to produce an executable, this
18  * file does not by itself cause the resulting executable to be covered by
19  * the GNU General Public License.  This exception does not however
20  * invalidate any other reasons why the executable file might be covered by
21  * the GNU General Public License.
22  */
23 #pragma once
24
25 #include <l4/sys/utcb.h>
26 // dumb, however atomic sequences are defined in kdebug.h
27 #include <l4/sys/kdebug.h>
28
29 #include <l4/sys/compiler.h>
30 #include <l4/sys/ipc.h>
31
32 L4_INLINE l4_msgtag_t
33 l4_usem_down_to(l4_cap_idx_t lock, l4_u_semaphore_t *sem, l4_timeout_s timeout) L4_NOTHROW
34 {
35         __asm__ __volatile__("ta 0x815\n");
36         return l4_msgtag(1,1,1,1);
37 }
38
39 L4_INLINE l4_msgtag_t
40 l4_usem_up(l4_cap_idx_t lock, l4_u_semaphore_t *sem) L4_NOTHROW
41 {
42         __asm__ __volatile__ ("ta 0x816\n");
43         return l4_msgtag(1,1,1,1);
44 }
45