1 1.67 isaki /* $NetBSD: thunk.h,v 1.67 2019/05/08 13:40:16 isaki Exp $ */ 2 1.1 jmcneill 3 1.1 jmcneill /*- 4 1.1 jmcneill * Copyright (c) 2011 Jared D. McNeill <jmcneill (at) invisible.ca> 5 1.1 jmcneill * All rights reserved. 6 1.1 jmcneill * 7 1.1 jmcneill * Redistribution and use in source and binary forms, with or without 8 1.1 jmcneill * modification, are permitted provided that the following conditions 9 1.1 jmcneill * are met: 10 1.1 jmcneill * 1. Redistributions of source code must retain the above copyright 11 1.1 jmcneill * notice, this list of conditions and the following disclaimer. 12 1.1 jmcneill * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 jmcneill * notice, this list of conditions and the following disclaimer in the 14 1.1 jmcneill * documentation and/or other materials provided with the distribution. 15 1.1 jmcneill * 16 1.1 jmcneill * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 17 1.1 jmcneill * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 18 1.1 jmcneill * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 19 1.1 jmcneill * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 20 1.1 jmcneill * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 1.1 jmcneill * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 1.1 jmcneill * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 23 1.1 jmcneill * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 24 1.1 jmcneill * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 25 1.1 jmcneill * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 1.1 jmcneill * POSSIBILITY OF SUCH DAMAGE. 27 1.1 jmcneill */ 28 1.1 jmcneill 29 1.1 jmcneill #ifndef _ARCH_USERMODE_INCLUDE_THUNK_H 30 1.1 jmcneill #define _ARCH_USERMODE_INCLUDE_THUNK_H 31 1.1 jmcneill 32 1.64 reinoud #include <sys/types.h> 33 1.1 jmcneill #include <sys/time.h> 34 1.3 jmcneill #include <sys/stat.h> 35 1.3 jmcneill #include <sys/fcntl.h> 36 1.1 jmcneill #include <sys/ucontext.h> 37 1.4 jmcneill #include <sys/signal.h> 38 1.1 jmcneill 39 1.11 jmcneill struct thunk_timeval { 40 1.11 jmcneill int64_t tv_sec; 41 1.11 jmcneill int32_t tv_usec; 42 1.11 jmcneill }; 43 1.11 jmcneill 44 1.13 jmcneill struct thunk_itimerval { 45 1.13 jmcneill struct thunk_timeval it_interval; 46 1.13 jmcneill struct thunk_timeval it_value; 47 1.13 jmcneill }; 48 1.13 jmcneill 49 1.20 jmcneill struct thunk_termios { 50 1.20 jmcneill uint32_t c_iflag; 51 1.20 jmcneill uint32_t c_oflag; 52 1.20 jmcneill uint32_t c_cflag; 53 1.20 jmcneill uint32_t c_lflag; 54 1.20 jmcneill uint8_t c_cc[20]; 55 1.20 jmcneill int32_t c_ispeed; 56 1.20 jmcneill int32_t c_ospeed; 57 1.20 jmcneill }; 58 1.20 jmcneill 59 1.25 jmcneill #define THUNK_MAP_ANON 0x0001 60 1.25 jmcneill #define THUNK_MAP_FIXED 0x0002 61 1.25 jmcneill #define THUNK_MAP_FILE 0x0004 62 1.25 jmcneill #define THUNK_MAP_SHARED 0x0010 63 1.25 jmcneill #define THUNK_MAP_PRIVATE 0x0020 64 1.25 jmcneill 65 1.25 jmcneill #define THUNK_PROT_NONE 0x00 66 1.25 jmcneill #define THUNK_PROT_READ 0x01 67 1.25 jmcneill #define THUNK_PROT_WRITE 0x02 68 1.25 jmcneill #define THUNK_PROT_EXEC 0x04 69 1.25 jmcneill 70 1.58 reinoud #define THUNK_MADV_NORMAL 0x01 71 1.58 reinoud #define THUNK_MADV_RANDOM 0x02 72 1.58 reinoud #define THUNK_MADV_SEQUENTIAL 0x04 73 1.58 reinoud #define THUNK_MADV_WILLNEED 0x08 74 1.58 reinoud #define THUNK_MADV_DONTNEED 0x10 75 1.58 reinoud #define THUNK_MADV_FREE 0x20 76 1.58 reinoud 77 1.58 reinoud 78 1.24 jmcneill struct aiocb; 79 1.24 jmcneill 80 1.55 reinoud void thunk_printf_debug(const char *fmt, ...) __attribute__((__format__(__printf__, 1, 2))); 81 1.55 reinoud void thunk_printf(const char *fmt, ...) __attribute__((__format__(__printf__, 1, 2))); 82 1.34 reinoud 83 1.56 jmcneill int thunk_syscallemu_init(void *, void *); 84 1.56 jmcneill 85 1.13 jmcneill int thunk_setitimer(int, const struct thunk_itimerval *, struct thunk_itimerval *); 86 1.11 jmcneill int thunk_gettimeofday(struct thunk_timeval *, void *); 87 1.11 jmcneill unsigned int thunk_getcounter(void); 88 1.10 jmcneill long thunk_clock_getres_monotonic(void); 89 1.1 jmcneill int thunk_usleep(useconds_t); 90 1.1 jmcneill 91 1.41 jmcneill timer_t thunk_timer_attach(void); 92 1.41 jmcneill int thunk_timer_start(timer_t, int); 93 1.41 jmcneill int thunk_timer_getoverrun(timer_t); 94 1.41 jmcneill 95 1.65 reinoud void thunk_kill(pid_t pid, int sig); 96 1.1 jmcneill void thunk_exit(int); 97 1.1 jmcneill void thunk_abort(void); 98 1.1 jmcneill 99 1.24 jmcneill int thunk_geterrno(void); 100 1.27 reinoud void thunk_seterrno(int err); 101 1.24 jmcneill 102 1.1 jmcneill int thunk_getcontext(ucontext_t *); 103 1.1 jmcneill int thunk_setcontext(const ucontext_t *); 104 1.32 reinoud void thunk_makecontext(ucontext_t *ucp, void (*func)(void), 105 1.61 reinoud int nargs, void *arg1, void *arg2, void *arg3, void *arg4); 106 1.1 jmcneill int thunk_swapcontext(ucontext_t *, ucontext_t *); 107 1.1 jmcneill 108 1.20 jmcneill int thunk_tcgetattr(int, struct thunk_termios *); 109 1.20 jmcneill int thunk_tcsetattr(int, int, const struct thunk_termios *); 110 1.20 jmcneill 111 1.37 jmcneill int thunk_set_stdin_sigio(int); 112 1.36 jmcneill int thunk_pollchar(void); 113 1.1 jmcneill int thunk_getchar(void); 114 1.1 jmcneill void thunk_putchar(int); 115 1.1 jmcneill 116 1.2 jmcneill int thunk_execv(const char *, char * const []); 117 1.2 jmcneill 118 1.3 jmcneill int thunk_open(const char *, int, mode_t); 119 1.59 reinoud int thunk_close(int); 120 1.57 jmcneill int thunk_fstat_getsize(int, off_t *, ssize_t *); 121 1.3 jmcneill ssize_t thunk_pread(int, void *, size_t, off_t); 122 1.3 jmcneill ssize_t thunk_pwrite(int, const void *, size_t, off_t); 123 1.45 jmcneill ssize_t thunk_read(int, void *, size_t); 124 1.39 jmcneill ssize_t thunk_write(int, const void *, size_t); 125 1.3 jmcneill int thunk_fsync(int); 126 1.8 reinoud int thunk_mkstemp(char *); 127 1.12 jmcneill int thunk_unlink(const char *); 128 1.47 jmcneill pid_t thunk_getpid(void); 129 1.3 jmcneill 130 1.66 reinoud int thunk_gdb_open(void); 131 1.66 reinoud int thunk_gdb_accept(int sockfd); 132 1.66 reinoud int thunk_kgdb_getc(int fd, char *ch); 133 1.66 reinoud int thunk_kgdb_putc(int fd, char ch); 134 1.66 reinoud 135 1.4 jmcneill int thunk_sigaction(int, const struct sigaction *, struct sigaction *); 136 1.21 reinoud int thunk_sigaltstack(const stack_t *, stack_t *); 137 1.15 jmcneill void thunk_signal(int, void (*)(int)); 138 1.28 jmcneill int thunk_sigblock(int); 139 1.28 jmcneill int thunk_sigunblock(int); 140 1.30 reinoud int thunk_sigemptyset(sigset_t *sa_mask); 141 1.60 reinoud int thunk_sigfillset(sigset_t *sa_mask); 142 1.29 reinoud void thunk_sigaddset(sigset_t *sa_mask, int sig); 143 1.35 reinoud int thunk_sigprocmask(int how, const sigset_t * set, sigset_t *oset); 144 1.18 reinoud int thunk_atexit(void (*function)(void)); 145 1.65 reinoud pid_t thunk_fork(void); 146 1.65 reinoud int thunk_ioctl(int fd, unsigned long request, void *opaque); 147 1.4 jmcneill 148 1.4 jmcneill int thunk_aio_read(struct aiocb *); 149 1.4 jmcneill int thunk_aio_write(struct aiocb *); 150 1.4 jmcneill int thunk_aio_error(const struct aiocb *); 151 1.4 jmcneill int thunk_aio_return(struct aiocb *); 152 1.4 jmcneill 153 1.16 reinoud void * thunk_malloc(size_t len); 154 1.16 reinoud void thunk_free(void *addr); 155 1.6 reinoud void * thunk_sbrk(intptr_t len); 156 1.7 reinoud void * thunk_mmap(void *addr, size_t len, int prot, int flags, int fd, off_t offset); 157 1.16 reinoud int thunk_munmap(void *addr, size_t len); 158 1.8 reinoud int thunk_mprotect(void *addr, size_t len, int prot); 159 1.58 reinoud int thunk_madvise(void *addr, size_t len, int behav); 160 1.25 jmcneill int thunk_posix_memalign(void **, size_t, size_t); 161 1.6 reinoud 162 1.38 jmcneill int thunk_idle(void); 163 1.38 jmcneill 164 1.17 jmcneill char * thunk_getenv(const char *); 165 1.33 reinoud vaddr_t thunk_get_vm_min_address(void); 166 1.17 jmcneill 167 1.62 prlw1 int thunk_getcpuinfo(char *, size_t *); 168 1.40 jmcneill 169 1.44 jmcneill int thunk_getmachine(char *, size_t, char *, size_t); 170 1.43 jmcneill 171 1.45 jmcneill int thunk_setown(int); 172 1.45 jmcneill 173 1.45 jmcneill int thunk_open_tap(const char *); 174 1.45 jmcneill int thunk_pollin_tap(int, int); 175 1.45 jmcneill int thunk_pollout_tap(int, int); 176 1.45 jmcneill 177 1.65 reinoud int thunk_assert_presence(vaddr_t from, size_t size); 178 1.65 reinoud 179 1.46 jmcneill typedef struct { 180 1.46 jmcneill unsigned int sample_rate; 181 1.46 jmcneill unsigned int precision; 182 1.46 jmcneill unsigned int validbits; 183 1.46 jmcneill unsigned int channels; 184 1.46 jmcneill } thunk_audio_config_t; 185 1.46 jmcneill 186 1.46 jmcneill int thunk_audio_open(const char *); 187 1.46 jmcneill int thunk_audio_close(int); 188 1.46 jmcneill int thunk_audio_config(int, const thunk_audio_config_t *, 189 1.46 jmcneill const thunk_audio_config_t *); 190 1.46 jmcneill int thunk_audio_pollout(int); 191 1.46 jmcneill int thunk_audio_pollin(int); 192 1.54 christos ssize_t thunk_audio_write(int, const void *, size_t); 193 1.54 christos ssize_t thunk_audio_read(int, void *, size_t); 194 1.46 jmcneill 195 1.47 jmcneill typedef enum { 196 1.47 jmcneill /* client -> server */ 197 1.47 jmcneill THUNK_RFB_SET_PIXEL_FORMAT = 0, 198 1.47 jmcneill THUNK_RFB_SET_ENCODINGS = 2, 199 1.47 jmcneill THUNK_RFB_FRAMEBUFFER_UPDATE_REQUEST = 3, 200 1.47 jmcneill THUNK_RFB_KEY_EVENT = 4, 201 1.47 jmcneill THUNK_RFB_POINTER_EVENT = 5, 202 1.47 jmcneill THUNK_RFB_CLIENT_CUT_TEXT = 6, 203 1.47 jmcneill } thunk_rfb_message_t; 204 1.47 jmcneill 205 1.47 jmcneill typedef struct { 206 1.47 jmcneill thunk_rfb_message_t message_type; 207 1.47 jmcneill union { 208 1.47 jmcneill struct { 209 1.47 jmcneill uint8_t down_flag; 210 1.47 jmcneill uint32_t keysym; 211 1.47 jmcneill } key_event; 212 1.53 jmcneill struct { 213 1.53 jmcneill uint8_t button_mask; 214 1.53 jmcneill uint16_t absx; 215 1.53 jmcneill uint16_t absy; 216 1.53 jmcneill } pointer_event; 217 1.47 jmcneill } data; 218 1.47 jmcneill } thunk_rfb_event_t; 219 1.47 jmcneill 220 1.49 reinoud 221 1.47 jmcneill typedef struct { 222 1.50 reinoud uint8_t enc; 223 1.47 jmcneill uint16_t x, y, w, h; 224 1.50 reinoud uint16_t srcx, srcy; 225 1.52 jmcneill uint8_t pixel[4]; 226 1.47 jmcneill } thunk_rfb_update_t; 227 1.50 reinoud #define THUNK_RFB_TYPE_RAW 0 228 1.49 reinoud #define THUNK_RFB_TYPE_COPYRECT 1 229 1.49 reinoud #define THUNK_RFB_TYPE_RRE 2 /* rectangle fill */ 230 1.47 jmcneill 231 1.48 jmcneill #define THUNK_RFB_QUEUELEN 128 232 1.48 jmcneill 233 1.47 jmcneill typedef struct { 234 1.47 jmcneill int sockfd; 235 1.47 jmcneill int clientfd; 236 1.47 jmcneill thunk_rfb_event_t event; 237 1.47 jmcneill 238 1.47 jmcneill bool connected; 239 1.47 jmcneill 240 1.47 jmcneill uint16_t width; 241 1.47 jmcneill uint16_t height; 242 1.47 jmcneill uint8_t depth; 243 1.47 jmcneill char name[64]; 244 1.47 jmcneill uint8_t *framebuf; 245 1.49 reinoud 246 1.51 jmcneill bool schedule_bell; 247 1.49 reinoud unsigned int nupdates; 248 1.49 reinoud unsigned int first_mergable; 249 1.48 jmcneill thunk_rfb_update_t update[THUNK_RFB_QUEUELEN]; 250 1.47 jmcneill } thunk_rfb_t; 251 1.47 jmcneill 252 1.47 jmcneill int thunk_rfb_open(thunk_rfb_t *, uint16_t); 253 1.47 jmcneill int thunk_rfb_poll(thunk_rfb_t *, thunk_rfb_event_t *); 254 1.51 jmcneill void thunk_rfb_bell(thunk_rfb_t *); 255 1.47 jmcneill void thunk_rfb_update(thunk_rfb_t *, int, int, int, int); 256 1.50 reinoud void thunk_rfb_copyrect(thunk_rfb_t *, int, int, int, int, int, int); 257 1.52 jmcneill void thunk_rfb_fillrect(thunk_rfb_t *, int, int, int, int, uint8_t *); 258 1.17 jmcneill 259 1.1 jmcneill #endif /* !_ARCH_USERMODE_INCLUDE_THUNK_H */ 260