source: mainline/kernel/generic/include/syscall/syscall.h@ 62550dce

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 62550dce was 62550dce, checked in by Stanislav Kozina <stanislav.kozina@…>, 15 years ago

ps -c echoes info about CPU's
cpu count is accessible through sysinfo("cpu.count")

  • Property mode set to 100644
File size: 3.0 KB
RevLine 
[7ae4443]1/*
[df4ed85]2 * Copyright (c) 2005 Martin Decky
[7ae4443]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
[42d3be3]29/** @addtogroup generic
[b45c443]30 * @{
31 */
32/** @file
33 */
34
[002e613]35#ifndef KERN_SYSCALL_H_
36#define KERN_SYSCALL_H_
[7ae4443]37
38typedef enum {
[c05a50f]39 SYS_KLOG = 0,
[e686744c]40 SYS_TLS_SET = 1, /* Hardcoded in AMD64, IA32 uspace - fibril.S */
[7ac426e]41
[9f52563]42 SYS_THREAD_CREATE,
43 SYS_THREAD_EXIT,
[3ce7f082]44 SYS_THREAD_GET_ID,
[d9ece1cb]45 SYS_THREAD_USLEEP,
[7ac426e]46
[24f3874]47 SYS_TASK_GET_ID,
[bc18d63]48 SYS_TASK_SET_NAME,
[c98e6ee]49 SYS_PROGRAM_SPAWN_LOADER,
[7ac426e]50
[9aa72b4]51 SYS_FUTEX_SLEEP,
52 SYS_FUTEX_WAKEUP,
[c98e6ee]53 SYS_SMC_COHERENCE,
[7ac426e]54
[24f3874]55 SYS_AS_AREA_CREATE,
56 SYS_AS_AREA_RESIZE,
[c98e6ee]57 SYS_AS_AREA_CHANGE_FLAGS,
[7242a78e]58 SYS_AS_AREA_DESTROY,
[7ac426e]59
[5f62ef9]60 SYS_IPC_CALL_SYNC_FAST,
[2e51969]61 SYS_IPC_CALL_SYNC_SLOW,
[5f62ef9]62 SYS_IPC_CALL_ASYNC_FAST,
[3209923]63 SYS_IPC_CALL_ASYNC_SLOW,
[286e03d]64 SYS_IPC_ANSWER_FAST,
[b74959bd]65 SYS_IPC_ANSWER_SLOW,
[2ba7810]66 SYS_IPC_FORWARD_FAST,
[48daf64]67 SYS_IPC_FORWARD_SLOW,
[631ca4d]68 SYS_IPC_WAIT,
[057d21a]69 SYS_IPC_POKE,
[fbcfd458]70 SYS_IPC_HANGUP,
[5626277]71 SYS_IPC_REGISTER_IRQ,
72 SYS_IPC_UNREGISTER_IRQ,
[05641a9e]73
74 SYS_EVENT_SUBSCRIBE,
[7ac426e]75
[2bb8648]76 SYS_CAP_GRANT,
77 SYS_CAP_REVOKE,
[7ac426e]78
[84afc7b]79 SYS_DEVICE_ASSIGN_DEVNO,
[5a8b2a2]80 SYS_PHYSMEM_MAP,
[429ff2ea]81 SYS_IOSPACE_ENABLE,
[2bb8648]82 SYS_PREEMPT_CONTROL,
[7ac426e]83
[35a96cf]84 SYS_SYSINFO_VALID,
85 SYS_SYSINFO_VALUE,
[7ac426e]86
[41d33ac]87 SYS_DEBUG_ENABLE_CONSOLE,
[516ff92]88 SYS_DEBUG_DISABLE_CONSOLE,
[18b5402c]89
[62550dce]90 SYS_PS_GET_CPU_INFO,
[18b5402c]91 SYS_PS_GET_TASKS,
92 SYS_PS_GET_TASK_INFO,
93 SYS_PS_GET_THREADS,
[c0379fc]94 SYS_PS_GET_UPTIME,
[944f2cab]95 SYS_PS_GET_LOAD,
[18b5402c]96
[9a1b20c]97 SYS_IPC_CONNECT_KBOX,
[7ae4443]98 SYSCALL_END
99} syscall_t;
100
[6d9c49a]101#ifdef KERNEL
102
[d99c1d2]103#include <typedefs.h>
[7ae4443]104
[e686744c]105typedef unative_t (*syshandler_t)(unative_t, unative_t, unative_t, unative_t,
106 unative_t, unative_t);
[7ae4443]107
108extern syshandler_t syscall_table[SYSCALL_END];
[e686744c]109extern unative_t syscall_handler(unative_t, unative_t, unative_t, unative_t,
110 unative_t, unative_t, unative_t);
111extern unative_t sys_tls_set(unative_t);
[281b607]112
[7ae4443]113#endif
[6d9c49a]114
115#endif
[b45c443]116
[42d3be3]117/** @}
[b45c443]118 */
Note: See TracBrowser for help on using the repository browser.