source: mainline/kernel/generic/include/syscall/syscall.h@ 48daf64

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

Introduce a new syscall: SYS_IPC_FORWARD_SLOW.

  • Property mode set to 100644
File size: 2.7 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_KLOG = 0,
40 SYS_TLS_SET = 1, /* Hardcoded in AMD64, IA32 uspace - fibril.S */
41
42 SYS_THREAD_CREATE,
43 SYS_THREAD_EXIT,
44 SYS_THREAD_GET_ID,
45
46 SYS_TASK_GET_ID,
47 SYS_PROGRAM_SPAWN_LOADER,
48
49 SYS_FUTEX_SLEEP,
50 SYS_FUTEX_WAKEUP,
51 SYS_SMC_COHERENCE,
52
53 SYS_AS_AREA_CREATE,
54 SYS_AS_AREA_RESIZE,
55 SYS_AS_AREA_CHANGE_FLAGS,
56 SYS_AS_AREA_DESTROY,
57
58 SYS_IPC_CALL_SYNC_FAST,
59 SYS_IPC_CALL_SYNC_SLOW,
60 SYS_IPC_CALL_ASYNC_FAST,
61 SYS_IPC_CALL_ASYNC_SLOW,
62 SYS_IPC_ANSWER_FAST,
63 SYS_IPC_ANSWER_SLOW,
64 SYS_IPC_FORWARD_FAST,
65 SYS_IPC_FORWARD_SLOW,
66 SYS_IPC_WAIT,
67 SYS_IPC_HANGUP,
68 SYS_IPC_REGISTER_IRQ,
69 SYS_IPC_UNREGISTER_IRQ,
70
71 SYS_CAP_GRANT,
72 SYS_CAP_REVOKE,
73
74 SYS_PHYSMEM_MAP,
75 SYS_IOSPACE_ENABLE,
76 SYS_PREEMPT_CONTROL,
77
78 SYS_SYSINFO_VALID,
79 SYS_SYSINFO_VALUE,
80
81 SYS_DEBUG_ENABLE_CONSOLE,
82 SYS_IPC_CONNECT_KBOX,
83 SYSCALL_END
84} syscall_t;
85
86#ifdef KERNEL
87
88#include <arch/types.h>
89
90typedef unative_t (*syshandler_t)(unative_t, unative_t, unative_t, unative_t,
91 unative_t, unative_t);
92
93extern syshandler_t syscall_table[SYSCALL_END];
94extern unative_t syscall_handler(unative_t, unative_t, unative_t, unative_t,
95 unative_t, unative_t, unative_t);
96extern unative_t sys_tls_set(unative_t);
97
98#endif
99
100#endif
101
102/** @}
103 */
Note: See TracBrowser for help on using the repository browser.