#ifndef _HACK_SCHED_H #define _HACK_SCHED_H #include <linux/wait.h> #include <sys/signal.h> #include <hurd/hurd_types.h> #include <linux/kernel.h> #include <linux/net.h> #include <sys/time.h> #include "mapped-time.h" #include <assert.h> #include <mach.h> #include <asm/system.h> #define jiffies (fetch_jiffies ()) extern struct task_struct *current; extern struct task_struct current_contents; struct task_struct { uid_t pgrp, pid; int flags; int timeout; int signal; int blocked; int state; int isroot; }; /* FLAGS in task_struct's. */ #define PF_EXITING 1 /* STATE in task_struct's. */ #define TASK_INTERRUPTIBLE 1 #define TASK_RUNNING 2 extern inline int suser () { return current->isroot; }; void wake_up_interruptible (struct wait_queue **); void interruptible_sleep_on (struct wait_queue **); void select_wait (struct wait_queue **, select_table *); void schedule (void); #define SEL_IN SELECT_READ #define SEL_OUT SELECT_WRITE #define SEL_EX SELECT_URG /* This function is used only to send SIGPIPE to the current task. In all such cases, EPIPE is returned anyhow. In the Hurd, servers are not responsible for SIGPIPE; the library does that itself upon receiving EPIPE. So we can just NOP such calls. */ extern inline int send_sig (u_long signo, struct task_struct *task, int priv) { assert (signo == SIGPIPE); assert (task == current); return 0; } int fetch_current_time (void); struct timeval fetch_xtime (void); #define xtime (fetch_xtime ()) #define CURRENT_TIME (xtime.tv_sec) static struct timeval _xtime_buf; extern inline struct timeval fetch_xtime () { fill_timeval (&_xtime_buf); return _xtime_buf; } #endif