os.h 10.0 KB
Newer Older
1
/*
J
Jeff Dike 已提交
2
 * Copyright (C) 2002 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
L
Linus Torvalds 已提交
3 4 5 6 7 8
 * Licensed under the GPL
 */

#ifndef __OS_H__
#define __OS_H__

J
Jeff Dike 已提交
9
#include <stdarg.h>
10
#include "irq_user.h"
J
Jeff Dike 已提交
11 12
#include "longjmp.h"
#include "mm_id.h"
13
#include "sysdep/tls.h"
L
Linus Torvalds 已提交
14

15 16
#define CATCH_EINTR(expr) while ((errno = 0, ((expr) < 0)) && (errno == EINTR))

17 18 19
#define OS_TYPE_FILE 1
#define OS_TYPE_DIR 2
#define OS_TYPE_SYMLINK 3
L
Linus Torvalds 已提交
20 21 22 23 24 25 26 27 28 29 30 31
#define OS_TYPE_CHARDEV 4
#define OS_TYPE_BLOCKDEV 5
#define OS_TYPE_FIFO 6
#define OS_TYPE_SOCK 7

/* os_access() flags */
#define OS_ACC_F_OK    0       /* Test for existence.  */
#define OS_ACC_X_OK    1       /* Test for execute permission.  */
#define OS_ACC_W_OK    2       /* Test for write permission.  */
#define OS_ACC_R_OK    4       /* Test for read permission.  */
#define OS_ACC_RW_OK   (OS_ACC_W_OK | OS_ACC_R_OK) /* Test for RW permission */

R
Richard Weinberger 已提交
32 33 34 35 36 37
#ifdef CONFIG_64BIT
#define OS_LIB_PATH	"/usr/lib64/"
#else
#define OS_LIB_PATH	"/usr/lib/"
#endif

L
Linus Torvalds 已提交
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
/*
 * types taken from stat_file() in hostfs_user.c
 * (if they are wrong here, they are wrong there...).
 */
struct uml_stat {
	int                ust_dev;        /* device */
	unsigned long long ust_ino;        /* inode */
	int                ust_mode;       /* protection */
	int                ust_nlink;      /* number of hard links */
	int                ust_uid;        /* user ID of owner */
	int                ust_gid;        /* group ID of owner */
	unsigned long long ust_size;       /* total size, in bytes */
	int                ust_blksize;    /* blocksize for filesystem I/O */
	unsigned long long ust_blocks;     /* number of blocks allocated */
	unsigned long      ust_atime;      /* time of last access */
	unsigned long      ust_mtime;      /* time of last modification */
	unsigned long      ust_ctime;      /* time of last change */
};

struct openflags {
	unsigned int r : 1;
	unsigned int w : 1;
	unsigned int s : 1;	/* O_SYNC */
	unsigned int c : 1;	/* O_CREAT */
	unsigned int t : 1;	/* O_TRUNC */
	unsigned int a : 1;	/* O_APPEND */
	unsigned int e : 1;	/* O_EXCL */
	unsigned int cl : 1;    /* FD_CLOEXEC */
};

#define OPENFLAGS() ((struct openflags) { .r = 0, .w = 0, .s = 0, .c = 0, \
69
					  .t = 0, .a = 0, .e = 0, .cl = 0 })
L
Linus Torvalds 已提交
70 71 72

static inline struct openflags of_read(struct openflags flags)
{
73 74
	flags.r = 1;
	return flags;
L
Linus Torvalds 已提交
75 76 77 78
}

static inline struct openflags of_write(struct openflags flags)
{
79 80
	flags.w = 1;
	return flags;
L
Linus Torvalds 已提交
81 82 83 84
}

static inline struct openflags of_rdwr(struct openflags flags)
{
85
	return of_read(of_write(flags));
L
Linus Torvalds 已提交
86 87 88 89 90 91
}

static inline struct openflags of_set_rw(struct openflags flags, int r, int w)
{
	flags.r = r;
	flags.w = w;
92
	return flags;
L
Linus Torvalds 已提交
93 94 95
}

static inline struct openflags of_sync(struct openflags flags)
96 97 98
{
	flags.s = 1;
	return flags;
L
Linus Torvalds 已提交
99 100 101
}

static inline struct openflags of_create(struct openflags flags)
102 103 104
{
	flags.c = 1;
	return flags;
L
Linus Torvalds 已提交
105
}
106

L
Linus Torvalds 已提交
107
static inline struct openflags of_trunc(struct openflags flags)
108 109 110
{
	flags.t = 1;
	return flags;
L
Linus Torvalds 已提交
111
}
112

L
Linus Torvalds 已提交
113
static inline struct openflags of_append(struct openflags flags)
114 115 116
{
	flags.a = 1;
	return flags;
L
Linus Torvalds 已提交
117
}
118

L
Linus Torvalds 已提交
119
static inline struct openflags of_excl(struct openflags flags)
120 121 122
{
	flags.e = 1;
	return flags;
L
Linus Torvalds 已提交
123 124 125
}

static inline struct openflags of_cloexec(struct openflags flags)
126 127 128
{
	flags.cl = 1;
	return flags;
L
Linus Torvalds 已提交
129
}
130

J
Jeff Dike 已提交
131
/* file.c */
L
Linus Torvalds 已提交
132 133 134
extern int os_stat_file(const char *file_name, struct uml_stat *buf);
extern int os_stat_fd(const int fd, struct uml_stat *buf);
extern int os_access(const char *file, int mode);
135
extern int os_set_exec_close(int fd);
L
Linus Torvalds 已提交
136 137 138 139 140
extern int os_ioctl_generic(int fd, unsigned int cmd, unsigned long arg);
extern int os_get_ifname(int fd, char *namebuf);
extern int os_set_slip(int fd);
extern int os_mode_fd(int fd, int mode);

J
Jeff Dike 已提交
141
extern int os_seek_file(int fd, unsigned long long offset);
142
extern int os_open_file(const char *file, struct openflags flags, int mode);
L
Linus Torvalds 已提交
143 144
extern int os_read_file(int fd, void *buf, int len);
extern int os_write_file(int fd, const void *buf, int count);
145 146
extern int os_file_size(const char *file, unsigned long long *size_out);
extern int os_file_modtime(const char *file, unsigned long *modtime);
L
Linus Torvalds 已提交
147
extern int os_pipe(int *fd, int stream, int close_on_exec);
J
Jeff Dike 已提交
148
extern int os_set_fd_async(int fd);
L
Linus Torvalds 已提交
149 150 151
extern int os_clear_fd_async(int fd);
extern int os_set_fd_block(int fd, int blocking);
extern int os_accept_connection(int fd);
152
extern int os_create_unix_socket(const char *file, int len, int close_on_exec);
L
Linus Torvalds 已提交
153 154 155 156
extern int os_shutdown_socket(int fd, int r, int w);
extern void os_close_file(int fd);
extern int os_rcv_fd(int fd, int *helper_pid_out);
extern int create_unix_socket(char *file, int len, int close_on_exec);
157
extern int os_connect_socket(const char *name);
L
Linus Torvalds 已提交
158
extern int os_file_type(char *file);
159
extern int os_file_mode(const char *file, struct openflags *mode_out);
L
Linus Torvalds 已提交
160
extern int os_lock_file(int fd, int excl);
J
Jeff Dike 已提交
161 162 163 164 165 166 167 168 169
extern void os_flush_stdout(void);
extern int os_stat_filesystem(char *path, long *bsize_out,
			      long long *blocks_out, long long *bfree_out,
			      long long *bavail_out, long long *files_out,
			      long long *ffree_out, void *fsid_out,
			      int fsid_size, long *namelen_out,
			      long *spare_out);
extern int os_change_dir(char *dir);
extern int os_fchange_dir(int fd);
A
Al Viro 已提交
170 171 172
extern unsigned os_major(unsigned long long dev);
extern unsigned os_minor(unsigned long long dev);
extern unsigned long long os_makedev(unsigned major, unsigned minor);
L
Linus Torvalds 已提交
173

174 175
/* start_up.c */
extern void os_early_checks(void);
176
extern void can_do_skas(void);
177
extern void os_check_bugs(void);
178
extern void check_host_supports_tls(int *supports_tls, int *tls_min);
179

180
/* mem.c */
J
Jeff Dike 已提交
181
extern int create_mem_file(unsigned long long len);
182

183
/* process.c */
L
Linus Torvalds 已提交
184 185 186 187 188
extern unsigned long os_process_pc(int pid);
extern int os_process_parent(int pid);
extern void os_stop_process(int pid);
extern void os_kill_process(int pid, int reap_child);
extern void os_kill_ptraced_process(int pid, int reap_child);
189 190
extern long os_ptrace_ldt(long pid, long addr, long data);

L
Linus Torvalds 已提交
191
extern int os_getpid(void);
J
Jeff Dike 已提交
192
extern int os_getpgrp(void);
193

194
extern void init_new_thread_signals(void);
J
Jeff Dike 已提交
195
extern int run_kernel_thread(int (*fn)(void *), void *arg, jmp_buf **jmp_ptr);
L
Linus Torvalds 已提交
196 197 198

extern int os_map_memory(void *virt, int fd, unsigned long long off,
			 unsigned long len, int r, int w, int x);
199
extern int os_protect_memory(void *addr, unsigned long len,
L
Linus Torvalds 已提交
200 201
			     int r, int w, int x);
extern int os_unmap_memory(void *addr, int len);
J
Jeff Dike 已提交
202 203
extern int os_drop_memory(void *addr, int length);
extern int can_drop_memory(void);
L
Linus Torvalds 已提交
204 205
extern void os_flush_stdout(void);

206 207
/* execvp.c */
extern int execvp_noalloc(char *buf, const char *file, char *const argv[]);
208
/* helper.c */
J
Jeff Dike 已提交
209
extern int run_helper(void (*pre_exec)(void *), void *pre_data, char **argv);
210
extern int run_helper_thread(int (*proc)(void *), void *arg,
J
Jeff Dike 已提交
211
			     unsigned int flags, unsigned long *stack_out);
J
Jeff Dike 已提交
212
extern int helper_wait(int pid);
213

214 215

/* tls.c */
216 217
extern int os_set_thread_area(user_desc_t *info, int pid);
extern int os_get_thread_area(user_desc_t *info, int pid);
L
Linus Torvalds 已提交
218

219
/* umid.c */
220
extern int umid_file_name(char *name, char *buf, int len);
J
Jeff Dike 已提交
221 222
extern int set_umid(char *name);
extern char *get_umid(void);
223

224
/* signal.c */
J
Jeff Dike 已提交
225
extern void timer_init(void);
226 227 228 229 230 231 232 233 234
extern void set_sigstack(void *sig_stack, int size);
extern void remove_sigstack(void);
extern void set_handler(int sig, void (*handler)(int), int flags, ...);
extern int change_sig(int signal, int on);
extern void block_signals(void);
extern void unblock_signals(void);
extern int get_signals(void);
extern int set_signals(int enable);

235 236 237 238
/* util.c */
extern void stack_protections(unsigned long address);
extern int raw(int fd);
extern void setup_machinename(char *machine_out);
J
Jeff Dike 已提交
239
extern void setup_hostinfo(char *buf, int len);
240
extern void os_dump_core(void) __attribute__ ((noreturn));
R
Richard Weinberger 已提交
241
extern void um_early_printk(const char *s, unsigned int n);
242

243
/* time.c */
244
extern void idle_sleep(unsigned long long nsecs);
J
Jeff Dike 已提交
245
extern int set_interval(void);
J
Jeff Dike 已提交
246
extern int timer_one_shot(int ticks);
J
Jeff Dike 已提交
247
extern long long disable_timer(void);
248
extern void uml_idle_timer(void);
J
Jeff Dike 已提交
249
extern long long os_nsecs(void);
250

251 252 253 254 255 256 257 258
/* skas/mem.c */
extern long run_syscall_stub(struct mm_id * mm_idp,
			     int syscall, unsigned long *args, long expected,
			     void **addr, int done);
extern long syscall_stub_data(struct mm_id * mm_idp,
			      unsigned long *data, int data_count,
			      void **addr, void **stub_addr);
extern int map(struct mm_id * mm_idp, unsigned long virt,
J
Jeff Dike 已提交
259
	       unsigned long len, int prot, int phys_fd,
260
	       unsigned long long offset, int done, void **data);
J
Jeff Dike 已提交
261
extern int unmap(struct mm_id * mm_idp, unsigned long addr, unsigned long len,
262 263
		 int done, void **data);
extern int protect(struct mm_id * mm_idp, unsigned long addr,
J
Jeff Dike 已提交
264
		   unsigned long len, unsigned int prot, int done, void **data);
265

266 267 268 269
/* skas/process.c */
extern int is_skas_winch(int pid, int fd, void *data);
extern int start_userspace(unsigned long stub_stack);
extern int copy_context_skas0(unsigned long stack, int pid);
270
extern void userspace(struct uml_pt_regs *regs);
271 272
extern int map_stub_pages(int fd, unsigned long code, unsigned long data,
			  unsigned long stack);
J
Jeff Dike 已提交
273 274 275
extern void new_thread(void *stack, jmp_buf *buf, void (*handler)(void));
extern void switch_threads(jmp_buf *me, jmp_buf *you);
extern int start_idle_thread(void *stack, jmp_buf *switch_buf);
276 277 278 279 280
extern void initial_thread_cb_skas(void (*proc)(void *),
				 void *arg);
extern void halt_skas(void);
extern void reboot_skas(void);

281 282 283 284 285 286 287 288 289 290 291
/* irq.c */
extern int os_waiting_for_events(struct irq_fd *active_fds);
extern int os_create_pollfd(int fd, int events, void *tmp_pfd, int size_tmpfds);
extern void os_free_irq_by_cb(int (*test)(struct irq_fd *, void *), void *arg,
		struct irq_fd *active_fds, struct irq_fd ***last_irq_ptr2);
extern void os_free_irq_later(struct irq_fd *active_fds,
		int irq, void *dev_id);
extern int os_get_pollfd(int i);
extern void os_set_pollfd(int i, int fd);
extern void os_set_ioignore(void);

292
/* sigio.c */
J
Jeff Dike 已提交
293
extern int add_sigio_fd(int fd);
294
extern int ignore_sigio_fd(int fd);
J
Jeff Dike 已提交
295
extern void maybe_sigio_broken(int fd, int read);
J
Jeff Dike 已提交
296
extern void sigio_broken(int fd, int read);
297

298
/* sys-x86_64/prctl.c */
J
Jeff Dike 已提交
299 300
extern int os_arch_prctl(int pid, int code, unsigned long *addr);

301
/* tty.c */
J
Jeff Dike 已提交
302 303 304
extern int get_pty(void);

/* sys-$ARCH/task_size.c */
305
extern unsigned long os_get_top_address(void);
306

307
#endif