1 /**
2 * \file
3 * \brief L4 IPC System Calls, ARM
4 * \ingroup api_calls
5 */
6 /*
7 * (c) 2008-2009 Adam Lackorzynski <adam@os.inf.tu-dresden.de>,
8 * Alexander Warg <warg@os.inf.tu-dresden.de>
9 * economic rights: Technische Universität Dresden (Germany)
10 *
11 * This file is part of TUD:OS and distributed under the terms of the
12 * GNU General Public License 2.
13 * Please see the COPYING-GPL-2 file for details.
14 *
15 * As a special exception, you may use this file as part of a free software
16 * library without restriction. Specifically, if other files instantiate
17 * templates or use macros or inline functions from this file, or you compile
18 * this file and link it with other files to produce an executable, this
19 * file does not by itself cause the resulting executable to be covered by
20 * the GNU General Public License. This exception does not however
21 * invalidate any other reasons why the executable file might be covered by
22 * the GNU General Public License.
23 */
24 #pragma once
25
26 #include_next <l4/sys/ipc.h>
27
28 #ifdef __GNUC__
29
30 #include <l4/sys/compiler.h>
31
32 L4_INLINE l4_msgtag_t
l4_ipc(l4_cap_idx_t dest,l4_utcb_t * utcb,l4_umword_t flags,l4_umword_t slabel,l4_msgtag_t tag,l4_umword_t * rlabel,l4_timeout_t timeout)33 l4_ipc(l4_cap_idx_t dest, l4_utcb_t *utcb,
34 l4_umword_t flags,
35 l4_umword_t slabel,
36 l4_msgtag_t tag,
37 l4_umword_t *rlabel,
38 l4_timeout_t timeout) L4_NOTHROW
39 {
40 register l4_umword_t _dest __asm__("x2") = dest | flags;
41 register l4_umword_t _timeout __asm__("x3") = timeout.raw;
42 register l4_mword_t _tag __asm__("x0") = tag.raw;
43 register l4_umword_t _label __asm__("x4") = slabel;
44 (void)utcb;
45
46 __asm__ __volatile__
47 ("bl __l4_sys_syscall"
48 :
49 "+r" (_dest),
50 "+r" (_timeout),
51 "+r" (_label),
52 "+r" (_tag)
53 :
54 :
55 "cc", "memory", "x16", "x17", "x30");
56
57 if (rlabel)
58 *rlabel = _label;
59 tag.raw = _tag;
60
61 return tag;
62 }
63
64 #endif //__GNUC__
65