os.h 11.7 KB
Newer Older
1
/*
L
Linus Torvalds 已提交
2 3 4 5 6 7 8
 * Copyright (C) 2002 Jeff Dike (jdike@karaya.com)
 * Licensed under the GPL
 */

#ifndef __OS_H__
#define __OS_H__

9
#include "uml-config.h"
L
Linus Torvalds 已提交
10 11
#include "asm/types.h"
#include "../os/include/file.h"
12 13
#include "sysdep/ptrace.h"
#include "kern_util.h"
14
#include "skas/mm_id.h"
15
#include "irq_user.h"
16
#include "sysdep/tls.h"
J
Jeff Dike 已提交
17
#include "sysdep/archsetjmp.h"
L
Linus Torvalds 已提交
18

19 20
#define CATCH_EINTR(expr) while ((errno = 0, ((expr) < 0)) && (errno == EINTR))

21 22 23
#define OS_TYPE_FILE 1
#define OS_TYPE_DIR 2
#define OS_TYPE_SYMLINK 3
L
Linus Torvalds 已提交
24 25 26 27 28 29 30 31 32 33 34 35 36 37 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
#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 */

/*
 * 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, \
67
					  .t = 0, .a = 0, .e = 0, .cl = 0 })
L
Linus Torvalds 已提交
68 69 70

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

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

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

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

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

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

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

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

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

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

J
Jeff Dike 已提交
129
/* file.c */
L
Linus Torvalds 已提交
130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146
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);
extern void os_print_error(int error, const char* str);
extern int os_get_exec_close(int fd, int *close_on_exec);
extern int os_set_exec_close(int fd, int close_on_exec);
extern int os_ioctl_generic(int fd, unsigned int cmd, unsigned long arg);
extern int os_window_size(int fd, int *rows, int *cols);
extern int os_new_tty_pgrp(int fd, int pid);
extern int os_get_ifname(int fd, char *namebuf);
extern int os_set_slip(int fd);
extern int os_set_owner(int fd, int pid);
extern int os_mode_fd(int fd, int mode);

extern int os_seek_file(int fd, __u64 offset);
extern int os_open_file(char *file, struct openflags flags, int mode);
extern int os_read_file(int fd, void *buf, int len);
147
extern int os_read_file_k(int fd, void *buf, int len);
L
Linus Torvalds 已提交
148
extern int os_write_file(int fd, const void *buf, int count);
149
extern int os_write_file_k(int fd, const void *buf, int len);
J
Jeff Dike 已提交
150
extern int os_file_size(char *file, unsigned long long *size_out);
L
Linus Torvalds 已提交
151 152 153 154 155 156 157 158 159 160 161 162 163 164 165
extern int os_file_modtime(char *file, unsigned long *modtime);
extern int os_pipe(int *fd, int stream, int close_on_exec);
extern int os_set_fd_async(int fd, int owner);
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);
extern int os_create_unix_socket(char *file, int len, int close_on_exec);
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);
extern int os_connect_socket(char *name);
extern int os_file_type(char *file);
extern int os_file_mode(char *file, struct openflags *mode_out);
extern int os_lock_file(int fd, int excl);
J
Jeff Dike 已提交
166 167 168 169 170 171 172 173 174
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);
L
Linus Torvalds 已提交
175

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

182 183
/* Make sure they are clear when running in TT mode. Required by
 * SEGV_MAYBE_FIXABLE */
184
#ifdef UML_CONFIG_MODE_SKAS
185
#define clear_can_do_skas() do { ptrace_faultinfo = proc_mm = 0; } while (0)
186 187 188
#else
#define clear_can_do_skas() do {} while (0)
#endif
189

190
/* mem.c */
J
Jeff Dike 已提交
191
extern int create_mem_file(unsigned long long len);
192

193
/* process.c */
L
Linus Torvalds 已提交
194 195 196 197 198
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);
199
#ifdef UML_CONFIG_MODE_TT
L
Linus Torvalds 已提交
200
extern void os_usr1_process(int pid);
201
#endif
202 203
extern long os_ptrace_ldt(long pid, long addr, long data);

L
Linus Torvalds 已提交
204
extern int os_getpid(void);
J
Jeff Dike 已提交
205
extern int os_getpgrp(void);
206

J
Jeff Dike 已提交
207
#ifdef UML_CONFIG_MODE_TT
208
extern void init_new_thread_stack(void *sig_stack, void (*usr1_handler)(int));
209
extern void stop(void);
J
Jeff Dike 已提交
210
#endif
211
extern void init_new_thread_signals(void);
212
extern int run_kernel_thread(int (*fn)(void *), void *arg, void **jmp_ptr);
L
Linus Torvalds 已提交
213 214 215

extern int os_map_memory(void *virt, int fd, unsigned long long off,
			 unsigned long len, int r, int w, int x);
216
extern int os_protect_memory(void *addr, unsigned long len,
L
Linus Torvalds 已提交
217 218
			     int r, int w, int x);
extern int os_unmap_memory(void *addr, int len);
J
Jeff Dike 已提交
219 220
extern int os_drop_memory(void *addr, int length);
extern int can_drop_memory(void);
L
Linus Torvalds 已提交
221 222
extern void os_flush_stdout(void);

223 224 225
/* tt.c
 * for tt mode only (will be deleted in future...)
 */
226 227
extern void forward_ipi(int fd, int pid);
extern void kill_child_dead(int pid);
228
extern int wait_for_stop(int pid, int sig, int cont_type, void *relay);
229 230
extern int protect_memory(unsigned long addr, unsigned long len,
			  int r, int w, int x, int must_succeed);
231 232 233 234
extern void forward_pending_sigio(int target);
extern int start_fork_tramp(void *arg, unsigned long temp_stack,
			    int clone_flags, int (*tramp)(void *));

235 236 237 238 239 240
/* uaccess.c */
extern unsigned long __do_user_copy(void *to, const void *from, int n,
				    void **fault_addr, void **fault_catcher,
				    void (*op)(void *to, const void *from,
					       int n), int *faulted_out);

241 242
/* execvp.c */
extern int execvp_noalloc(char *buf, const char *file, char *const argv[]);
243 244 245 246 247 248 249 250
/* helper.c */
extern int run_helper(void (*pre_exec)(void *), void *pre_data, char **argv,
		      unsigned long *stack_out);
extern int run_helper_thread(int (*proc)(void *), void *arg,
			     unsigned int flags, unsigned long *stack_out,
			     int stack_order);
extern int helper_wait(int pid);

251 252

/* tls.c */
253 254
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 已提交
255

256
/* umid.c */
257
extern int umid_file_name(char *name, char *buf, int len);
J
Jeff Dike 已提交
258 259
extern int set_umid(char *name);
extern char *get_umid(void);
260

261 262 263 264 265 266 267 268 269 270
/* signal.c */
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);

271 272 273 274
/* trap.c */
extern void os_fill_handlinfo(struct kern_handlers h);
extern void do_longjmp(void *p, int val);

275 276 277 278 279
/* util.c */
extern void stack_protections(unsigned long address);
extern void task_protections(unsigned long address);
extern int raw(int fd);
extern void setup_machinename(char *machine_out);
J
Jeff Dike 已提交
280
extern void setup_hostinfo(char *buf, int len);
281
extern int setjmp_wrapper(void (*proc)(void *, void *), ...);
J
Jeff Dike 已提交
282
extern void os_dump_core(void);
283

284 285 286 287 288
/* time.c */
#define BILLION (1000 * 1000 * 1000)

extern void switch_timers(int to_real);
extern void idle_sleep(int secs);
J
Jeff Dike 已提交
289 290
extern int set_interval(int is_virtual);
#ifdef CONFIG_MODE_TT
291
extern void enable_timer(void);
J
Jeff Dike 已提交
292
#endif
293 294 295 296
extern void disable_timer(void);
extern void uml_idle_timer(void);
extern unsigned long long os_nsecs(void);

297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312
/* 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,
	       unsigned long len, int r, int w, int x, int phys_fd,
	       unsigned long long offset, int done, void **data);
extern int unmap(struct mm_id * mm_idp, void *addr, unsigned long len,
		 int done, void **data);
extern int protect(struct mm_id * mm_idp, unsigned long addr,
		   unsigned long len, int r, int w, int x, int done,
		   void **data);

313 314 315 316 317 318 319
/* 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);
extern void userspace(union uml_pt_regs *regs);
extern void map_stub_pages(int fd, unsigned long code,
			   unsigned long data, unsigned long stack);
J
Jeff Dike 已提交
320 321 322
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);
323 324 325 326 327
extern void initial_thread_cb_skas(void (*proc)(void *),
				 void *arg);
extern void halt_skas(void);
extern void reboot_skas(void);

328 329 330 331 332 333 334 335 336 337 338 339
/* 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);
extern void init_irq_signals(int on_sigstack);

340
/* sigio.c */
J
Jeff Dike 已提交
341
extern int add_sigio_fd(int fd);
342
extern int ignore_sigio_fd(int fd);
J
Jeff Dike 已提交
343
extern void maybe_sigio_broken(int fd, int read);
344

J
Jeff Dike 已提交
345 346 347 348
/* skas/trap */
extern void sig_handler_common_skas(int sig, void *sc_ptr);
extern void user_signal(int sig, union uml_pt_regs *regs, int pid);

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

352 353 354
/* tty.c */
int get_pty(void);

355
#endif