source: mainline/kernel/generic/include/syscall/syscall.h@ 3209923

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 3209923 was 3209923, checked in by Jakub Jermar <jakub@…>, 18 years ago

Modify asynchronous IPC to make use of all six syscall arguments. The preferred
means of asynchronous communication is now via the set of ipc_call_async_m()
macros, where m is the number of payload arguments passed to the kernel. These
macros will automatically decide between the fast and the universal slow version
of ipc_call_async.

  • Property mode set to 100644
File size: 2.6 KB
Line 
1/*
2 * Copyright (c) 2005 Martin Decky
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - 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 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup generic
30 * @{
31 */
32/** @file
33 */
34
35#ifndef KERN_SYSCALL_H_
36#define KERN_SYSCALL_H_
37
38typedef enum {
39 SYS_IO = 0,
40 SYS_TLS_SET = 1, /* Hardcoded in AMD64, IA32 uspace - fibril.S */
41 SYS_THREAD_CREATE,
42 SYS_THREAD_EXIT,
43 SYS_THREAD_GET_ID,
44 SYS_TASK_GET_ID,
45 SYS_FUTEX_SLEEP,
46 SYS_FUTEX_WAKEUP,
47 SYS_AS_AREA_CREATE,
48 SYS_AS_AREA_RESIZE,
49 SYS_AS_AREA_DESTROY,
50 SYS_IPC_CALL_SYNC_FAST,
51 SYS_IPC_CALL_SYNC_SLOW,
52 SYS_IPC_CALL_ASYNC_FAST,
53 SYS_IPC_CALL_ASYNC_SLOW,
54 SYS_IPC_ANSWER_FAST,
55 SYS_IPC_ANSWER,
56 SYS_IPC_FORWARD_FAST,
57 SYS_IPC_WAIT,
58 SYS_IPC_HANGUP,
59 SYS_IPC_REGISTER_IRQ,
60 SYS_IPC_UNREGISTER_IRQ,
61 SYS_CAP_GRANT,
62 SYS_CAP_REVOKE,
63 SYS_PHYSMEM_MAP,
64 SYS_IOSPACE_ENABLE,
65 SYS_PREEMPT_CONTROL,
66 SYS_SYSINFO_VALID,
67 SYS_SYSINFO_VALUE,
68 SYS_DEBUG_ENABLE_CONSOLE,
69 SYSCALL_END
70} syscall_t;
71
72#ifdef KERNEL
73
74#include <arch/types.h>
75
76typedef unative_t (*syshandler_t)(unative_t, unative_t, unative_t, unative_t,
77 unative_t, unative_t);
78
79extern syshandler_t syscall_table[SYSCALL_END];
80extern unative_t syscall_handler(unative_t, unative_t, unative_t, unative_t,
81 unative_t, unative_t, unative_t);
82extern unative_t sys_tls_set(unative_t);
83
84#endif
85
86#endif
87
88/** @}
89 */
Note: See TracBrowser for help on using the repository browser.