NetBSD/sys/compat/linux/common/linux_sched.h

89 lines
3.7 KiB
C
Raw Normal View History

/* $NetBSD: linux_sched.h,v 1.8 2011/11/18 04:07:44 christos Exp $ */
/*-
* Copyright (c) 1999 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
* by Jason R. Thorpe of the Numerical Aerospace Simulation Facility,
* NASA Ames Research Center.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef _LINUX_SCHED_H
#define _LINUX_SCHED_H
/*
* Flags passed to the Linux __clone(2) system call.
*/
#define LINUX_CLONE_CSIGNAL 0x000000ff /* signal to be sent at exit */
#define LINUX_CLONE_VM 0x00000100 /* share address space */
#define LINUX_CLONE_FS 0x00000200 /* share "file system" info */
#define LINUX_CLONE_FILES 0x00000400 /* share file descriptors */
#define LINUX_CLONE_SIGHAND 0x00000800 /* share signal actions */
#define LINUX_CLONE_PID 0x00001000 /* share process ID */
#define LINUX_CLONE_PTRACE 0x00002000 /* ptrace(2) continues on
child */
#define LINUX_CLONE_VFORK 0x00004000 /* parent blocks until child
exits */
2004-09-05 11:22:20 +04:00
#define LINUX_CLONE_PARENT 0x00008000 /* want same parent as cloner */
#define LINUX_CLONE_THREAD 0x00010000 /* same thread group */
#define LINUX_CLONE_NEWNS 0x00020000 /* new namespace group */
#define LINUX_CLONE_SYSVSEM 0x00040000 /* share SysV SEM_UNDO */
#define LINUX_CLONE_SETTLS 0x00080000 /* create new TLS for child */
#define LINUX_CLONE_PARENT_SETTID \
0x00100000 /* set TID in the parent */
#define LINUX_CLONE_CHILD_CLEARTID \
0x00200000 /* clear TID in the child */
#define LINUX_CLONE_DETACHED 0x00400000 /* unused */
#define LINUX_CLONE_UNTRACED 0x00800000 /* set if parent cannot force CLONE_PTRACE */
#define LINUX_CLONE_CHILD_SETTID \
0x01000000 /* set TID in the child */
#define LINUX_CLONE_STOPPED 0x02000000 /* start in stopped state */
struct linux_sched_param {
int sched_priority;
};
#define LINUX_SCHED_OTHER 0
#define LINUX_SCHED_FIFO 1
#define LINUX_SCHED_RR 2
struct linux_timespec {
linux_time_t tv_sec; /* seconds */
long tv_nsec; /* nanoseconds */
};
2005-05-17 01:18:34 +04:00
#define LINUX_CLOCK_REALTIME 0
#define LINUX_CLOCK_MONOTONIC 1
#define LINUX_CLOCK_PROCESS_CPUTIME_ID 2
#define LINUX_CLOCK_THREAD_CPUTIME_ID 3
#define LINUX_CLOCK_REALTIME_HR 4
#define LINUX_CLOCK_MONOTONIC_HR 5
int linux_to_native_clockid(clockid_t *, clockid_t);
void native_to_linux_timespec(struct linux_timespec *, struct timespec *);
void linux_to_native_timespec(struct timespec *, struct linux_timespec *);
#endif /* _LINUX_SCHED_H */