Statistics
| Branch: | Revision:

root / linux-user / syscall_defs.h @ 4021dab0

History | View | Annotate | Download (52.8 kB)

1
/* common syscall defines for all architectures */
2

    
3
/* Note: although the syscall numbers change between architectures,
4
   most of them stay the same, so we handle it by puting ifdefs if
5
   necessary */
6

    
7
#define TARGET_NR_exit                  1
8
#define TARGET_NR_fork                  2
9
#define TARGET_NR_read                  3
10
#define TARGET_NR_write                  4
11
#define TARGET_NR_open                  5
12
#define TARGET_NR_close                  6
13
#define TARGET_NR_waitpid                  7
14
#define TARGET_NR_creat                  8
15
#define TARGET_NR_link                  9
16
#define TARGET_NR_unlink                 10
17
#define TARGET_NR_execve                 11
18
#define TARGET_NR_chdir                 12
19
#define TARGET_NR_time                 13
20
#define TARGET_NR_mknod                 14
21
#define TARGET_NR_chmod                 15
22
#define TARGET_NR_lchown                 16
23
#define TARGET_NR_break                 17
24
#define TARGET_NR_oldstat                 18
25
#define TARGET_NR_lseek                 19
26
#define TARGET_NR_getpid                 20
27
#define TARGET_NR_mount                 21
28
#define TARGET_NR_umount                 22
29
#define TARGET_NR_setuid                 23
30
#define TARGET_NR_getuid                 24
31
#define TARGET_NR_stime                 25
32
#define TARGET_NR_ptrace                 26
33
#define TARGET_NR_alarm                 27
34
#define TARGET_NR_oldfstat                 28
35
#define TARGET_NR_pause                 29
36
#define TARGET_NR_utime                 30
37
#define TARGET_NR_stty                 31
38
#define TARGET_NR_gtty                 32
39
#define TARGET_NR_access                 33
40
#define TARGET_NR_nice                 34
41
#define TARGET_NR_ftime                 35
42
#define TARGET_NR_sync                 36
43
#define TARGET_NR_kill                 37
44
#define TARGET_NR_rename                 38
45
#define TARGET_NR_mkdir                 39
46
#define TARGET_NR_rmdir                 40
47
#define TARGET_NR_dup                 41
48
#define TARGET_NR_pipe                 42
49
#define TARGET_NR_times                 43
50
#define TARGET_NR_prof                 44
51
#define TARGET_NR_brk                 45
52
#define TARGET_NR_setgid                 46
53
#define TARGET_NR_getgid                 47
54
#define TARGET_NR_signal                 48
55
#define TARGET_NR_geteuid                 49
56
#define TARGET_NR_getegid                 50
57
#define TARGET_NR_acct                 51
58
#define TARGET_NR_umount2                 52
59
#define TARGET_NR_lock                 53
60
#define TARGET_NR_ioctl                 54
61
#define TARGET_NR_fcntl                 55
62
#define TARGET_NR_mpx                 56
63
#define TARGET_NR_setpgid                 57
64
#define TARGET_NR_ulimit                 58
65
#define TARGET_NR_oldolduname         59
66
#define TARGET_NR_umask                 60
67
#define TARGET_NR_chroot                 61
68
#define TARGET_NR_ustat                 62
69
#define TARGET_NR_dup2                 63
70
#define TARGET_NR_getppid                 64
71
#define TARGET_NR_getpgrp                 65
72
#define TARGET_NR_setsid                 66
73
#define TARGET_NR_sigaction                 67
74
#define TARGET_NR_sgetmask                 68
75
#define TARGET_NR_ssetmask                 69
76
#define TARGET_NR_setreuid                 70
77
#define TARGET_NR_setregid                 71
78
#define TARGET_NR_sigsuspend                 72
79
#define TARGET_NR_sigpending                 73
80
#define TARGET_NR_sethostname         74
81
#define TARGET_NR_setrlimit                 75
82
#define TARGET_NR_getrlimit                 76        /* Back compatible 2Gig limited rlimit */
83
#define TARGET_NR_getrusage                 77
84
#define TARGET_NR_gettimeofday         78
85
#define TARGET_NR_settimeofday         79
86
#define TARGET_NR_getgroups                 80
87
#define TARGET_NR_setgroups                 81
88
#define TARGET_NR_select                 82
89
#define TARGET_NR_symlink                 83
90
#define TARGET_NR_oldlstat                 84
91
#define TARGET_NR_readlink                 85
92
#define TARGET_NR_uselib                 86
93
#define TARGET_NR_swapon                 87
94
#define TARGET_NR_reboot                 88
95
#define TARGET_NR_readdir                 89
96
#define TARGET_NR_mmap                 90
97
#define TARGET_NR_munmap                 91
98
#define TARGET_NR_truncate                 92
99
#define TARGET_NR_ftruncate                 93
100
#define TARGET_NR_fchmod                 94
101
#define TARGET_NR_fchown                 95
102
#define TARGET_NR_getpriority         96
103
#define TARGET_NR_setpriority         97
104
#define TARGET_NR_profil                 98
105
#define TARGET_NR_statfs                 99
106
#define TARGET_NR_fstatfs                100
107
#define TARGET_NR_ioperm                101
108
#define TARGET_NR_socketcall                102
109
#define TARGET_NR_syslog                103
110
#define TARGET_NR_setitimer                104
111
#define TARGET_NR_getitimer                105
112
#define TARGET_NR_stat                106
113
#define TARGET_NR_lstat                107
114
#define TARGET_NR_fstat                108
115
#define TARGET_NR_olduname                109
116
#define TARGET_NR_iopl                110
117
#define TARGET_NR_vhangup                111
118
#define TARGET_NR_idle                112
119
#define TARGET_NR_vm86old                113
120
#define TARGET_NR_wait4                114
121
#define TARGET_NR_swapoff                115
122
#define TARGET_NR_sysinfo                116
123
#define TARGET_NR_ipc                117
124
#define TARGET_NR_fsync                118
125
#define TARGET_NR_sigreturn                119
126
#define TARGET_NR_clone                120
127
#define TARGET_NR_setdomainname        121
128
#define TARGET_NR_uname                122
129
#define TARGET_NR_modify_ldt                123
130
#define TARGET_NR_adjtimex                124
131
#define TARGET_NR_mprotect                125
132
#define TARGET_NR_sigprocmask        126
133
#define TARGET_NR_create_module        127
134
#define TARGET_NR_init_module        128
135
#define TARGET_NR_delete_module        129
136
#define TARGET_NR_get_kernel_syms        130
137
#define TARGET_NR_quotactl                131
138
#define TARGET_NR_getpgid                132
139
#define TARGET_NR_fchdir                133
140
#define TARGET_NR_bdflush                134
141
#define TARGET_NR_sysfs                135
142
#define TARGET_NR_personality        136
143
#define TARGET_NR_afs_syscall        137 /* Syscall for Andrew File System */
144
#define TARGET_NR_setfsuid                138
145
#define TARGET_NR_setfsgid                139
146
#define TARGET_NR__llseek                140
147
#define TARGET_NR_getdents                141
148
#define TARGET_NR__newselect                142
149
#define TARGET_NR_flock                143
150
#define TARGET_NR_msync                144
151
#define TARGET_NR_readv                145
152
#define TARGET_NR_writev                146
153
#define TARGET_NR_getsid                147
154
#define TARGET_NR_fdatasync                148
155
#define TARGET_NR__sysctl                149
156
#define TARGET_NR_mlock                150
157
#define TARGET_NR_munlock                151
158
#define TARGET_NR_mlockall                152
159
#define TARGET_NR_munlockall                153
160
#define TARGET_NR_sched_setparam                154
161
#define TARGET_NR_sched_getparam                155
162
#define TARGET_NR_sched_setscheduler                156
163
#define TARGET_NR_sched_getscheduler                157
164
#define TARGET_NR_sched_yield                158
165
#define TARGET_NR_sched_get_priority_max        159
166
#define TARGET_NR_sched_get_priority_min        160
167
#define TARGET_NR_sched_rr_get_interval        161
168
#define TARGET_NR_nanosleep                162
169
#define TARGET_NR_mremap                163
170
#define TARGET_NR_setresuid                164
171
#define TARGET_NR_getresuid                165
172
#define TARGET_NR_vm86                166
173
#define TARGET_NR_query_module        167
174
#define TARGET_NR_poll                168
175
#define TARGET_NR_nfsservctl                169
176
#define TARGET_NR_setresgid                170
177
#define TARGET_NR_getresgid                171
178
#define TARGET_NR_prctl              172
179
#define TARGET_NR_rt_sigreturn        173
180
#define TARGET_NR_rt_sigaction        174
181
#define TARGET_NR_rt_sigprocmask        175
182
#define TARGET_NR_rt_sigpending        176
183
#define TARGET_NR_rt_sigtimedwait        177
184
#define TARGET_NR_rt_sigqueueinfo        178
185
#define TARGET_NR_rt_sigsuspend        179
186
#define TARGET_NR_pread                180
187
#define TARGET_NR_pwrite                181
188
#define TARGET_NR_chown                182
189
#define TARGET_NR_getcwd                183
190
#define TARGET_NR_capget                184
191
#define TARGET_NR_capset                185
192
#define TARGET_NR_sigaltstack        186
193
#define TARGET_NR_sendfile                187
194
#define TARGET_NR_getpmsg                188        /* some people actually want streams */
195
#define TARGET_NR_putpmsg                189        /* some people actually want streams */
196
#define TARGET_NR_vfork                190
197
#define TARGET_NR_ugetrlimit                191        /* SuS compliant getrlimit */
198
#define TARGET_NR_mmap2                192
199
#define TARGET_NR_truncate64                193
200
#define TARGET_NR_ftruncate64        194
201
#define TARGET_NR_stat64                195
202
#define TARGET_NR_lstat64                196
203
#define TARGET_NR_fstat64                197
204
#define TARGET_NR_lchown32                198
205
#define TARGET_NR_getuid32                199
206
#define TARGET_NR_getgid32                200
207
#define TARGET_NR_geteuid32                201
208
#define TARGET_NR_getegid32                202
209
#define TARGET_NR_setreuid32                203
210
#define TARGET_NR_setregid32                204
211
#define TARGET_NR_getgroups32        205
212
#define TARGET_NR_setgroups32        206
213
#define TARGET_NR_fchown32                207
214
#define TARGET_NR_setresuid32        208
215
#define TARGET_NR_getresuid32        209
216
#define TARGET_NR_setresgid32        210
217
#define TARGET_NR_getresgid32        211
218
#define TARGET_NR_chown32                212
219
#define TARGET_NR_setuid32                213
220
#define TARGET_NR_setgid32                214
221
#define TARGET_NR_setfsuid32                215
222
#define TARGET_NR_setfsgid32                216
223

    
224
#if defined(TARGET_I386)
225
#define TARGET_NR_pivot_root                217
226
#define TARGET_NR_mincore                218
227
#define TARGET_NR_madvise                219
228
#define TARGET_NR_madvise1                219        /* delete when C lib stub is removed */
229
#define TARGET_NR_getdents64                220
230
#endif
231

    
232
#if defined(TARGET_ARM)
233
#define TARGET_NR_getdents64                217
234
#define TARGET_NR_pivot_root                218
235
#define TARGET_NR_mincore                219
236
#define TARGET_NR_madvise                220
237
#endif
238

    
239
#define TARGET_NR_fcntl64                221
240
#define TARGET_NR_security                223        /* syscall for security modules */
241
#define TARGET_NR_gettid                224
242
#define TARGET_NR_readahead                225
243
#define TARGET_NR_setxattr                226
244
#define TARGET_NR_lsetxattr                227
245
#define TARGET_NR_fsetxattr                228
246
#define TARGET_NR_getxattr                229
247
#define TARGET_NR_lgetxattr                230
248
#define TARGET_NR_fgetxattr                231
249
#define TARGET_NR_listxattr                232
250
#define TARGET_NR_llistxattr                233
251
#define TARGET_NR_flistxattr                234
252
#define TARGET_NR_removexattr        235
253
#define TARGET_NR_lremovexattr        236
254
#define TARGET_NR_fremovexattr        237
255
#define TARGET_NR_tkill                238
256
#define TARGET_NR_sendfile64                239
257
#define TARGET_NR_futex                240
258
#define TARGET_NR_sched_setaffinity        241
259
#define TARGET_NR_sched_getaffinity        242
260
#define TARGET_NR_set_thread_area        243
261
#define TARGET_NR_get_thread_area        244
262
#define TARGET_NR_io_setup                245
263
#define TARGET_NR_io_destroy                246
264
#define TARGET_NR_io_getevents        247
265
#define TARGET_NR_io_submit                248
266
#define TARGET_NR_io_cancel                249
267
#define TARGET_NR_fadvise64                250
268

    
269
#define TARGET_NR_exit_group                252
270
#define TARGET_NR_lookup_dcookie        253
271
#define TARGET_NR_epoll_create        254
272
#define TARGET_NR_epoll_ctl                255
273
#define TARGET_NR_epoll_wait                256
274
#define TARGET_NR_remap_file_pages        257
275
#define TARGET_NR_set_tid_address        258
276
#define TARGET_NR_timer_create        259
277
#define TARGET_NR_timer_settime        (TARGET_NR_timer_create+1)
278
#define TARGET_NR_timer_gettime        (TARGET_NR_timer_create+2)
279
#define TARGET_NR_timer_getoverrun        (TARGET_NR_timer_create+3)
280
#define TARGET_NR_timer_delete        (TARGET_NR_timer_create+4)
281
#define TARGET_NR_clock_settime        (TARGET_NR_timer_create+5)
282
#define TARGET_NR_clock_gettime        (TARGET_NR_timer_create+6)
283
#define TARGET_NR_clock_getres        (TARGET_NR_timer_create+7)
284
#define TARGET_NR_clock_nanosleep        (TARGET_NR_timer_create+8)
285

    
286
#define SOCKOP_socket           1
287
#define SOCKOP_bind             2
288
#define SOCKOP_connect          3
289
#define SOCKOP_listen           4
290
#define SOCKOP_accept           5
291
#define SOCKOP_getsockname      6
292
#define SOCKOP_getpeername      7
293
#define SOCKOP_socketpair       8
294
#define SOCKOP_send             9
295
#define SOCKOP_recv             10
296
#define SOCKOP_sendto           11
297
#define SOCKOP_recvfrom         12
298
#define SOCKOP_shutdown         13
299
#define SOCKOP_setsockopt       14
300
#define SOCKOP_getsockopt       15
301
#define SOCKOP_sendmsg          16
302
#define SOCKOP_recvmsg          17
303

    
304
/*
305
 * The following is for compatibility across the various Linux
306
 * platforms.  The i386 ioctl numbering scheme doesn't really enforce
307
 * a type field.  De facto, however, the top 8 bits of the lower 16
308
 * bits are indeed used as a type field, so we might just as well make
309
 * this explicit here.  Please be sure to use the decoding macros
310
 * below from now on.
311
 */
312
#define TARGET_IOC_NRBITS        8
313
#define TARGET_IOC_TYPEBITS        8
314

    
315
#if defined(TARGET_I386) || defined(TARGET_ARM)
316

    
317
#define TARGET_IOC_SIZEBITS        14
318
#define TARGET_IOC_DIRBITS        2
319

    
320
#define TARGET_IOC_NONE          0U
321
#define TARGET_IOC_WRITE  1U
322
#define TARGET_IOC_READ          2U
323

    
324
#elif defined(TARGET_PPC) || defined(TARGET_ALPHA)
325

    
326
#define TARGET_IOC_SIZEBITS        13
327
#define TARGET_IOC_DIRBITS        3
328

    
329
#define TARGET_IOC_NONE          1U
330
#define TARGET_IOC_READ          2U
331
#define TARGET_IOC_WRITE  4U
332

    
333
#else
334
#error unsupported CPU
335
#endif
336

    
337
#define TARGET_IOC_NRMASK        ((1 << TARGET_IOC_NRBITS)-1)
338
#define TARGET_IOC_TYPEMASK        ((1 << TARGET_IOC_TYPEBITS)-1)
339
#define TARGET_IOC_SIZEMASK        ((1 << TARGET_IOC_SIZEBITS)-1)
340
#define TARGET_IOC_DIRMASK        ((1 << TARGET_IOC_DIRBITS)-1)
341

    
342
#define TARGET_IOC_NRSHIFT        0
343
#define TARGET_IOC_TYPESHIFT        (TARGET_IOC_NRSHIFT+TARGET_IOC_NRBITS)
344
#define TARGET_IOC_SIZESHIFT        (TARGET_IOC_TYPESHIFT+TARGET_IOC_TYPEBITS)
345
#define TARGET_IOC_DIRSHIFT        (TARGET_IOC_SIZESHIFT+TARGET_IOC_SIZEBITS)
346

    
347
#define TARGET_IOC(dir,type,nr,size) \
348
        (((dir)  << TARGET_IOC_DIRSHIFT) | \
349
         ((type) << TARGET_IOC_TYPESHIFT) | \
350
         ((nr)   << TARGET_IOC_NRSHIFT) | \
351
         ((size) << TARGET_IOC_SIZESHIFT))
352

    
353
/* used to create numbers */
354
#define TARGET_IO(type,nr)                TARGET_IOC(TARGET_IOC_NONE,(type),(nr),0)
355
#define TARGET_IOR(type,nr,size)        TARGET_IOC(TARGET_IOC_READ,(type),(nr),sizeof(size))
356
#define TARGET_IOW(type,nr,size)        TARGET_IOC(TARGET_IOC_WRITE,(type),(nr),sizeof(size))
357
#define TARGET_IOWR(type,nr,size)        TARGET_IOC(TARGET_IOC_READ|TARGET_IOC_WRITE,(type),(nr),sizeof(size))
358

    
359
/* the size is automatically computed for these defines */
360
#define TARGET_IORU(type,nr)        TARGET_IOC(TARGET_IOC_READ,(type),(nr),TARGET_IOC_SIZEMASK)
361
#define TARGET_IOWU(type,nr)        TARGET_IOC(TARGET_IOC_WRITE,(type),(nr),TARGET_IOC_SIZEMASK)
362
#define TARGET_IOWRU(type,nr)        TARGET_IOC(TARGET_IOC_READ|TARGET_IOC_WRITE,(type),(nr),TARGET_IOC_SIZEMASK)
363

    
364
struct target_sockaddr {
365
    uint16_t sa_family;
366
    uint8_t sa_data[14];
367
};
368

    
369
struct target_timeval {
370
    target_long tv_sec;
371
    target_long tv_usec;
372
};
373

    
374
struct target_timespec {
375
    target_long tv_sec;
376
    target_long tv_nsec;
377
};
378

    
379
struct target_itimerval {
380
    struct target_timeval it_interval;
381
    struct target_timeval it_value;
382
};
383

    
384
typedef target_long target_clock_t;
385

    
386
#define TARGET_HZ 100
387

    
388
struct target_tms {
389
    target_clock_t tms_utime;
390
    target_clock_t tms_stime;
391
    target_clock_t tms_cutime;
392
    target_clock_t tms_cstime;
393
};
394

    
395
struct target_sel_arg_struct {
396
    target_long n;
397
    target_long inp, outp, exp;
398
    target_long tvp;
399
};
400

    
401
struct target_iovec {
402
    target_long iov_base;   /* Starting address */
403
    target_long iov_len;   /* Number of bytes */
404
};
405

    
406
struct target_msghdr {
407
    target_long         msg_name;        /* Socket name                        */
408
    int                 msg_namelen;        /* Length of name                */
409
    target_long         msg_iov;        /* Data blocks                        */
410
    target_long         msg_iovlen;        /* Number of blocks                */
411
    target_long  msg_control;        /* Per protocol magic (eg BSD file descriptor passing) */
412
    target_long         msg_controllen;        /* Length of cmsg list */
413
    unsigned int msg_flags;
414
};
415

    
416
struct target_cmsghdr {
417
    target_long  cmsg_len;
418
    int          cmsg_level;
419
    int          cmsg_type;
420
};
421

    
422
#define TARGET_CMSG_DATA(cmsg) ((unsigned char *) ((struct target_cmsghdr *) (cmsg) + 1))
423
#define TARGET_CMSG_NXTHDR(mhdr, cmsg) __target_cmsg_nxthdr (mhdr, cmsg)
424
#define TARGET_CMSG_FIRSTHDR(mhdr) \
425
  ((size_t) tswapl((mhdr)->msg_controllen) >= sizeof (struct target_cmsghdr) \
426
   ? (struct target_cmsghdr *) tswapl((mhdr)->msg_control) : (struct target_cmsghdr *) NULL)
427
#define TARGET_CMSG_ALIGN(len) (((len) + sizeof (target_long) - 1) \
428
                               & (size_t) ~(sizeof (target_long) - 1))
429
#define TARGET_CMSG_SPACE(len) (TARGET_CMSG_ALIGN (len) \
430
                               + TARGET_CMSG_ALIGN (sizeof (struct target_cmsghdr)))
431
#define TARGET_CMSG_LEN(len)   (TARGET_CMSG_ALIGN (sizeof (struct target_cmsghdr)) + (len))
432

    
433
static __inline__ struct target_cmsghdr *
434
__target_cmsg_nxthdr (struct target_msghdr *__mhdr, struct target_cmsghdr *__cmsg)
435
{
436
  if (tswapl(__cmsg->cmsg_len) < sizeof (struct target_cmsghdr))
437
    /* The kernel header does this so there may be a reason.  */
438
    return 0;
439

    
440
  __cmsg = (struct target_cmsghdr *) ((unsigned char *) __cmsg
441
                               + TARGET_CMSG_ALIGN (tswapl(__cmsg->cmsg_len)));
442
  if ((unsigned char *) (__cmsg + 1) > ((unsigned char *) tswapl(__mhdr->msg_control)
443
                                        + tswapl(__mhdr->msg_controllen))
444
      || ((unsigned char *) __cmsg + TARGET_CMSG_ALIGN (tswapl(__cmsg->cmsg_len))
445
          > ((unsigned char *) tswapl(__mhdr->msg_control) 
446
             + tswapl(__mhdr->msg_controllen))))
447
    /* No more entries.  */
448
    return 0;
449
  return __cmsg;
450
}
451

    
452

    
453
struct  target_rusage {
454
        struct target_timeval ru_utime;        /* user time used */
455
        struct target_timeval ru_stime;        /* system time used */
456
        target_long    ru_maxrss;              /* maximum resident set size */
457
        target_long    ru_ixrss;               /* integral shared memory size */
458
        target_long    ru_idrss;               /* integral unshared data size */
459
        target_long    ru_isrss;               /* integral unshared stack size */
460
        target_long    ru_minflt;              /* page reclaims */
461
        target_long    ru_majflt;              /* page faults */
462
        target_long    ru_nswap;               /* swaps */
463
        target_long    ru_inblock;             /* block input operations */
464
        target_long    ru_oublock;             /* block output operations */
465
        target_long    ru_msgsnd;              /* messages sent */
466
        target_long    ru_msgrcv;              /* messages received */
467
        target_long    ru_nsignals;            /* signals received */
468
        target_long    ru_nvcsw;               /* voluntary context switches */
469
        target_long    ru_nivcsw;              /* involuntary " */
470
};
471

    
472
typedef struct {
473
        int     val[2];
474
} kernel_fsid_t;
475

    
476
struct kernel_statfs {
477
        int f_type;
478
        int f_bsize;
479
        int f_blocks;
480
        int f_bfree;
481
        int f_bavail;
482
        int f_files;
483
        int f_ffree;
484
        kernel_fsid_t f_fsid;
485
        int f_namelen;
486
        int f_spare[6];
487
};
488

    
489
struct target_dirent {
490
        target_long        d_ino;
491
        target_long        d_off;
492
        unsigned short        d_reclen;
493
        char                d_name[256]; /* We must not include limits.h! */
494
};
495

    
496
struct target_dirent64 {
497
        uint64_t        d_ino;
498
        int64_t                d_off;
499
        unsigned short        d_reclen;
500
        unsigned char        d_type;
501
        char                d_name[256];
502
};
503

    
504

    
505
/* mostly generic signal stuff */
506
#define TARGET_SIG_DFL        ((target_long)0)        /* default signal handling */
507
#define TARGET_SIG_IGN        ((target_long)1)        /* ignore signal */
508
#define TARGET_SIG_ERR        ((target_long)-1)        /* error return from signal */
509

    
510
#ifdef TARGET_MIPS
511
#define TARGET_NSIG           128
512
#else
513
#define TARGET_NSIG           64
514
#endif
515
#define TARGET_NSIG_BPW           TARGET_LONG_BITS
516
#define TARGET_NSIG_WORDS  (TARGET_NSIG / TARGET_NSIG_BPW)
517

    
518
typedef struct {
519
    target_ulong sig[TARGET_NSIG_WORDS];
520
} target_sigset_t;
521

    
522
#ifdef BSWAP_NEEDED
523
static inline void tswap_sigset(target_sigset_t *d, const target_sigset_t *s)
524
{
525
    int i;
526
    for(i = 0;i < TARGET_NSIG_WORDS; i++)
527
        d->sig[i] = tswapl(s->sig[i]);
528
}
529
#else
530
static inline void tswap_sigset(target_sigset_t *d, const target_sigset_t *s)
531
{
532
    *d = *s;
533
}
534
#endif
535

    
536
static inline void target_siginitset(target_sigset_t *d, target_ulong set)
537
{
538
    int i;
539
    d->sig[0] = set;
540
    for(i = 1;i < TARGET_NSIG_WORDS; i++)
541
        d->sig[i] = 0;
542
}
543

    
544
void host_to_target_sigset(target_sigset_t *d, const sigset_t *s);
545
void target_to_host_sigset(sigset_t *d, const target_sigset_t *s);
546
void host_to_target_old_sigset(target_ulong *old_sigset, 
547
                               const sigset_t *sigset);
548
void target_to_host_old_sigset(sigset_t *sigset, 
549
                               const target_ulong *old_sigset);
550
struct target_sigaction;
551
int do_sigaction(int sig, const struct target_sigaction *act,
552
                 struct target_sigaction *oact);
553

    
554
#if defined(TARGET_I386) || defined(TARGET_ARM)
555

    
556
#define TARGET_SA_NOCLDSTOP        0x00000001
557
#define TARGET_SA_NOCLDWAIT        0x00000002 /* not supported yet */
558
#define TARGET_SA_SIGINFO        0x00000004
559
#define TARGET_SA_ONSTACK        0x08000000
560
#define TARGET_SA_RESTART        0x10000000
561
#define TARGET_SA_NODEFER        0x40000000
562
#define TARGET_SA_RESETHAND        0x80000000
563
#define TARGET_SA_RESTORER        0x04000000
564

    
565
#define TARGET_SIGHUP                 1
566
#define TARGET_SIGINT                 2
567
#define TARGET_SIGQUIT                 3
568
#define TARGET_SIGILL                 4
569
#define TARGET_SIGTRAP                 5
570
#define TARGET_SIGABRT                 6
571
#define TARGET_SIGIOT                 6
572
#define TARGET_SIGBUS                 7
573
#define TARGET_SIGFPE                 8
574
#define TARGET_SIGKILL                 9
575
#define TARGET_SIGUSR1                10
576
#define TARGET_SIGSEGV                11
577
#define TARGET_SIGUSR2                12
578
#define TARGET_SIGPIPE                13
579
#define TARGET_SIGALRM                14
580
#define TARGET_SIGTERM                15
581
#define TARGET_SIGSTKFLT        16
582
#define TARGET_SIGCHLD                17
583
#define TARGET_SIGCONT                18
584
#define TARGET_SIGSTOP                19
585
#define TARGET_SIGTSTP                20
586
#define TARGET_SIGTTIN                21
587
#define TARGET_SIGTTOU                22
588
#define TARGET_SIGURG                23
589
#define TARGET_SIGXCPU                24
590
#define TARGET_SIGXFSZ                25
591
#define TARGET_SIGVTALRM        26
592
#define TARGET_SIGPROF                27
593
#define TARGET_SIGWINCH                28
594
#define TARGET_SIGIO                29
595
#define TARGET_SIGPWR                30
596
#define TARGET_SIGSYS                31
597
#define TARGET_SIGRTMIN         32
598

    
599
#define TARGET_SIG_BLOCK          0    /* for blocking signals */
600
#define TARGET_SIG_UNBLOCK        1    /* for unblocking signals */
601
#define TARGET_SIG_SETMASK        2    /* for setting the signal mask */
602

    
603
struct target_old_sigaction {
604
        target_ulong _sa_handler;
605
        target_ulong sa_mask;
606
        target_ulong sa_flags;
607
        target_ulong sa_restorer;
608
};
609

    
610
struct target_sigaction {
611
        target_ulong _sa_handler;
612
        target_ulong sa_flags;
613
        target_ulong sa_restorer;
614
        target_sigset_t sa_mask;
615
};
616

    
617
typedef union target_sigval {
618
        int sival_int;
619
        target_ulong sival_ptr;
620
} target_sigval_t;
621

    
622
#define TARGET_SI_MAX_SIZE        128
623
#define TARGET_SI_PAD_SIZE        ((TARGET_SI_MAX_SIZE/sizeof(int)) - 3)
624

    
625
typedef struct target_siginfo {
626
        int si_signo;
627
        int si_errno;
628
        int si_code;
629

    
630
        union {
631
                int _pad[TARGET_SI_PAD_SIZE];
632

    
633
                /* kill() */
634
                struct {
635
                        pid_t _pid;                /* sender's pid */
636
                        uid_t _uid;                /* sender's uid */
637
                } _kill;
638

    
639
                /* POSIX.1b timers */
640
                struct {
641
                        unsigned int _timer1;
642
                        unsigned int _timer2;
643
                } _timer;
644

    
645
                /* POSIX.1b signals */
646
                struct {
647
                        pid_t _pid;                /* sender's pid */
648
                        uid_t _uid;                /* sender's uid */
649
                        target_sigval_t _sigval;
650
                } _rt;
651

    
652
                /* SIGCHLD */
653
                struct {
654
                        pid_t _pid;                /* which child */
655
                        uid_t _uid;                /* sender's uid */
656
                        int _status;                /* exit code */
657
                        target_clock_t _utime;
658
                        target_clock_t _stime;
659
                } _sigchld;
660

    
661
                /* SIGILL, SIGFPE, SIGSEGV, SIGBUS */
662
                struct {
663
                        target_ulong _addr; /* faulting insn/memory ref. */
664
                } _sigfault;
665

    
666
                /* SIGPOLL */
667
                struct {
668
                        int _band;        /* POLL_IN, POLL_OUT, POLL_MSG */
669
                        int _fd;
670
                } _sigpoll;
671
        } _sifields;
672
} target_siginfo_t;
673

    
674
/*
675
 * si_code values
676
 * Digital reserves positive values for kernel-generated signals.
677
 */
678
#define TARGET_SI_USER                0        /* sent by kill, sigsend, raise */
679
#define TARGET_SI_KERNEL        0x80        /* sent by the kernel from somewhere */
680
#define TARGET_SI_QUEUE        -1                /* sent by sigqueue */
681
#define TARGET_SI_TIMER -2              /* sent by timer expiration */
682
#define TARGET_SI_MESGQ        -3                /* sent by real time mesq state change */
683
#define TARGET_SI_ASYNCIO        -4        /* sent by AIO completion */
684
#define TARGET_SI_SIGIO        -5                /* sent by queued SIGIO */
685

    
686
/*
687
 * SIGILL si_codes
688
 */
689
#define TARGET_ILL_ILLOPN        (2)        /* illegal operand */
690

    
691
/*
692
 * SIGFPE si_codes
693
 */
694
#define TARGET_FPE_INTDIV      (1)  /* integer divide by zero */
695
#define TARGET_FPE_INTOVF      (2)  /* integer overflow */
696
#define TARGET_FPE_FLTDIV      (3)  /* floating point divide by zero */
697
#define TARGET_FPE_FLTOVF      (4)  /* floating point overflow */
698
#define TARGET_FPE_FLTUND      (5)  /* floating point underflow */
699
#define TARGET_FPE_FLTRES      (6)  /* floating point inexact result */
700
#define TARGET_FPE_FLTINV      (7)  /* floating point invalid operation */
701
#define TARGET_FPE_FLTSUB      (8)  /* subscript out of range */
702
#define TARGET_NSIGFPE         8
703

    
704
/*
705
 * SIGSEGV si_codes
706
 */
707
#define TARGET_SEGV_MAPERR     (1)  /* address not mapped to object */
708
#define TARGET_SEGV_ACCERR     (2)  /* invalid permissions for mapped object */
709

    
710
/*
711
 * SIGTRAP si_codes
712
 */
713
#define TARGET_TRAP_BRKPT        (1)        /* process breakpoint */
714
#define TARGET_TRAP_TRACE        (2)        /* process trace trap */
715

    
716
#endif /* defined(TARGET_I386) || defined(TARGET_ARM) */
717

    
718
struct target_rlimit {
719
        target_ulong   rlim_cur;
720
        target_ulong   rlim_max;
721
};
722

    
723
struct target_pollfd {
724
    int fd;           /* file descriptor */
725
    short events;     /* requested events */
726
    short revents;    /* returned events */
727
};
728

    
729
/* virtual terminal ioctls */
730
#define TARGET_KIOCSOUND       0x4B2F        /* start sound generation (0 for off) */
731
#define TARGET_KDMKTONE               0x4B30        /* generate tone */
732
#define TARGET_KDGKBTYPE       0x4b33
733
#define TARGET_KDGKBENT               0x4B46        /* gets one entry in translation table */
734
#define TARGET_KDGKBSENT       0x4B48        /* gets one function key string entry */
735

    
736
#define TARGET_SIOCATMARK      0x8905
737

    
738
/* Networking ioctls */
739
#define TARGET_SIOCADDRT       0x890B          /* add routing table entry */
740
#define TARGET_SIOCDELRT       0x890C          /* delete routing table entry */
741
#define TARGET_SIOCGIFNAME     0x8910          /* get iface name               */
742
#define TARGET_SIOCSIFLINK     0x8911          /* set iface channel            */
743
#define TARGET_SIOCGIFCONF     0x8912          /* get iface list               */
744
#define TARGET_SIOCGIFFLAGS    0x8913          /* get flags                    */
745
#define TARGET_SIOCSIFFLAGS    0x8914          /* set flags                    */
746
#define TARGET_SIOCGIFADDR     0x8915          /* get PA address               */
747
#define TARGET_SIOCSIFADDR     0x8916          /* set PA address               */
748
#define TARGET_SIOCGIFDSTADDR  0x8917          /* get remote PA address        */
749
#define TARGET_SIOCSIFDSTADDR  0x8918          /* set remote PA address        */
750
#define TARGET_SIOCGIFBRDADDR  0x8919          /* get broadcast PA address     */
751
#define TARGET_SIOCSIFBRDADDR  0x891a          /* set broadcast PA address     */
752
#define TARGET_SIOCGIFNETMASK  0x891b          /* get network PA mask          */
753
#define TARGET_SIOCSIFNETMASK  0x891c          /* set network PA mask          */
754
#define TARGET_SIOCGIFMETRIC   0x891d          /* get metric                   */
755
#define TARGET_SIOCSIFMETRIC   0x891e          /* set metric                   */
756
#define TARGET_SIOCGIFMEM      0x891f          /* get memory address (BSD)     */
757
#define TARGET_SIOCSIFMEM      0x8920          /* set memory address (BSD)     */
758
#define TARGET_SIOCGIFMTU      0x8921          /* get MTU size                 */
759
#define TARGET_SIOCSIFMTU      0x8922          /* set MTU size                 */
760
#define TARGET_SIOCSIFHWADDR   0x8924          /* set hardware address (NI)    */
761
#define TARGET_SIOCGIFENCAP    0x8925          /* get/set slip encapsulation   */
762
#define TARGET_SIOCSIFENCAP    0x8926
763
#define TARGET_SIOCGIFHWADDR   0x8927          /* Get hardware address         */
764
#define TARGET_SIOCGIFSLAVE    0x8929          /* Driver slaving support       */
765
#define TARGET_SIOCSIFSLAVE    0x8930
766
#define TARGET_SIOCADDMULTI    0x8931          /* Multicast address lists      */
767
#define TARGET_SIOCDELMULTI    0x8932
768

    
769
/* Bridging control calls */
770
#define TARGET_SIOCGIFBR       0x8940          /* Bridging support             */
771
#define TARGET_SIOCSIFBR       0x8941          /* Set bridging options         */
772

    
773
#define TARGET_SIOCGIFTXQLEN   0x8942          /* Get the tx queue length      */
774
#define TARGET_SIOCSIFTXQLEN   0x8943          /* Set the tx queue length      */
775

    
776
/* ARP cache control calls. */
777
#define TARGET_OLD_SIOCDARP    0x8950          /* old delete ARP table entry   */
778
#define TARGET_OLD_SIOCGARP    0x8951          /* old get ARP table entry      */
779
#define TARGET_OLD_SIOCSARP    0x8952          /* old set ARP table entry      */
780
#define TARGET_SIOCDARP        0x8953          /* delete ARP table entry       */
781
#define TARGET_SIOCGARP        0x8954          /* get ARP table entry          */
782
#define TARGET_SIOCSARP        0x8955          /* set ARP table entry          */
783

    
784
/* RARP cache control calls. */
785
#define TARGET_SIOCDRARP       0x8960          /* delete RARP table entry      */
786
#define TARGET_SIOCGRARP       0x8961          /* get RARP table entry         */
787
#define TARGET_SIOCSRARP       0x8962          /* set RARP table entry         */
788

    
789
/* Driver configuration calls */
790
#define TARGET_SIOCGIFMAP      0x8970          /* Get device parameters        */
791
#define TARGET_SIOCSIFMAP      0x8971          /* Set device parameters        */
792

    
793
/* DLCI configuration calls */
794
#define TARGET_SIOCADDDLCI     0x8980          /* Create new DLCI device       */
795
#define TARGET_SIOCDELDLCI     0x8981          /* Delete DLCI device           */
796

    
797

    
798
/* From <linux/fs.h> */
799

    
800
#define TARGET_BLKROSET   TARGET_IO(0x12,93) /* set device read-only (0 = read-write) */
801
#define TARGET_BLKROGET   TARGET_IO(0x12,94) /* get read-only status (0 = read_write) */
802
#define TARGET_BLKRRPART  TARGET_IO(0x12,95) /* re-read partition table */
803
#define TARGET_BLKGETSIZE TARGET_IO(0x12,96) /* return device size /512 (long *arg) */
804
#define TARGET_BLKFLSBUF  TARGET_IO(0x12,97) /* flush buffer cache */
805
#define TARGET_BLKRASET   TARGET_IO(0x12,98) /* Set read ahead for block device */
806
#define TARGET_BLKRAGET   TARGET_IO(0x12,99) /* get current read ahead setting */
807
#define TARGET_BLKFRASET  TARGET_IO(0x12,100)/* set filesystem (mm/filemap.c) read-ahead */
808
#define TARGET_BLKFRAGET  TARGET_IO(0x12,101)/* get filesystem (mm/filemap.c) read-ahead */
809
#define TARGET_BLKSECTSET TARGET_IO(0x12,102)/* set max sectors per request (ll_rw_blk.c) */
810
#define TARGET_BLKSECTGET TARGET_IO(0x12,103)/* get max sectors per request (ll_rw_blk.c) */
811
#define TARGET_BLKSSZGET  TARGET_IO(0x12,104)/* get block device sector size */
812
/* A jump here: 108-111 have been used for various private purposes. */
813
#define TARGET_BLKBSZGET  TARGET_IOR(0x12,112,sizeof(int))
814
#define TARGET_BLKBSZSET  TARGET_IOW(0x12,113,sizeof(int))
815
#define TARGET_BLKGETSIZE64 TARGET_IOR(0x12,114,sizeof(uint64_t)) /* return device size in bytes (u64 *arg) */
816
#define TARGET_FIBMAP     TARGET_IO(0x00,1)  /* bmap access */
817
#define TARGET_FIGETBSZ   TARGET_IO(0x00,2)  /* get the block size used for bmap */
818

    
819
/* cdrom commands */
820
#define TARGET_CDROMPAUSE                0x5301 /* Pause Audio Operation */ 
821
#define TARGET_CDROMRESUME                0x5302 /* Resume paused Audio Operation */
822
#define TARGET_CDROMPLAYMSF                0x5303 /* Play Audio MSF (struct cdrom_msf) */
823
#define TARGET_CDROMPLAYTRKIND                0x5304 /* Play Audio Track/index 
824
                                           (struct cdrom_ti) */
825
#define TARGET_CDROMREADTOCHDR                0x5305 /* Read TOC header 
826
                                           (struct cdrom_tochdr) */
827
#define TARGET_CDROMREADTOCENTRY        0x5306 /* Read TOC entry 
828
                                           (struct cdrom_tocentry) */
829
#define TARGET_CDROMSTOP                0x5307 /* Stop the cdrom drive */
830
#define TARGET_CDROMSTART                0x5308 /* Start the cdrom drive */
831
#define TARGET_CDROMEJECT                0x5309 /* Ejects the cdrom media */
832
#define TARGET_CDROMVOLCTRL                0x530a /* Control output volume 
833
                                           (struct cdrom_volctrl) */
834
#define TARGET_CDROMSUBCHNL                0x530b /* Read subchannel data 
835
                                           (struct cdrom_subchnl) */
836
#define TARGET_CDROMREADMODE2                0x530c /* Read TARGET_CDROM mode 2 data (2336 Bytes) 
837
                                           (struct cdrom_read) */
838
#define TARGET_CDROMREADMODE1                0x530d /* Read TARGET_CDROM mode 1 data (2048 Bytes)
839
                                           (struct cdrom_read) */
840
#define TARGET_CDROMREADAUDIO                0x530e /* (struct cdrom_read_audio) */
841
#define TARGET_CDROMEJECT_SW                0x530f /* enable(1)/disable(0) auto-ejecting */
842
#define TARGET_CDROMMULTISESSION        0x5310 /* Obtain the start-of-last-session 
843
                                           address of multi session disks 
844
                                           (struct cdrom_multisession) */
845
#define TARGET_CDROM_GET_MCN                0x5311 /* Obtain the "Universal Product Code" 
846
                                           if available (struct cdrom_mcn) */
847
#define TARGET_CDROM_GET_UPC                TARGET_CDROM_GET_MCN  /* This one is depricated, 
848
                                          but here anyway for compatability */
849
#define TARGET_CDROMRESET                0x5312 /* hard-reset the drive */
850
#define TARGET_CDROMVOLREAD                0x5313 /* Get the drive's volume setting 
851
                                          (struct cdrom_volctrl) */
852
#define TARGET_CDROMREADRAW                0x5314        /* read data in raw mode (2352 Bytes)
853
                                           (struct cdrom_read) */
854
/* 
855
 * These ioctls are used only used in aztcd.c and optcd.c
856
 */
857
#define TARGET_CDROMREADCOOKED                0x5315        /* read data in cooked mode */
858
#define TARGET_CDROMSEEK                0x5316  /* seek msf address */
859
  
860
/*
861
 * This ioctl is only used by the scsi-cd driver.  
862
   It is for playing audio in logical block addressing mode.
863
 */
864
#define TARGET_CDROMPLAYBLK                0x5317        /* (struct cdrom_blk) */
865

    
866
/* 
867
 * These ioctls are only used in optcd.c
868
 */
869
#define TARGET_CDROMREADALL                0x5318        /* read all 2646 bytes */
870

    
871
/* 
872
 * These ioctls are (now) only in ide-cd.c for controlling 
873
 * drive spindown time.  They should be implemented in the
874
 * Uniform driver, via generic packet commands, GPCMD_MODE_SELECT_10,
875
 * GPCMD_MODE_SENSE_10 and the GPMODE_POWER_PAGE...
876
 *  -Erik
877
 */
878
#define TARGET_CDROMGETSPINDOWN        0x531d
879
#define TARGET_CDROMSETSPINDOWN        0x531e
880

    
881
/* 
882
 * These ioctls are implemented through the uniform CD-ROM driver
883
 * They _will_ be adopted by all CD-ROM drivers, when all the CD-ROM
884
 * drivers are eventually ported to the uniform CD-ROM driver interface.
885
 */
886
#define TARGET_CDROMCLOSETRAY                0x5319        /* pendant of CDROMEJECT */
887
#define TARGET_CDROM_SET_OPTIONS        0x5320  /* Set behavior options */
888
#define TARGET_CDROM_CLEAR_OPTIONS        0x5321  /* Clear behavior options */
889
#define TARGET_CDROM_SELECT_SPEED        0x5322  /* Set the CD-ROM speed */
890
#define TARGET_CDROM_SELECT_DISC        0x5323  /* Select disc (for juke-boxes) */
891
#define TARGET_CDROM_MEDIA_CHANGED        0x5325  /* Check is media changed  */
892
#define TARGET_CDROM_DRIVE_STATUS        0x5326  /* Get tray position, etc. */
893
#define TARGET_CDROM_DISC_STATUS        0x5327  /* Get disc type, etc. */
894
#define TARGET_CDROM_CHANGER_NSLOTS    0x5328  /* Get number of slots */
895
#define TARGET_CDROM_LOCKDOOR                0x5329  /* lock or unlock door */
896
#define TARGET_CDROM_DEBUG                0x5330        /* Turn debug messages on/off */
897
#define TARGET_CDROM_GET_CAPABILITY        0x5331        /* get capabilities */
898

    
899
/* Note that scsi/scsi_ioctl.h also uses 0x5382 - 0x5386.
900
 * Future CDROM ioctls should be kept below 0x537F
901
 */
902

    
903
/* This ioctl is only used by sbpcd at the moment */
904
#define TARGET_CDROMAUDIOBUFSIZ        0x5382        /* set the audio buffer size */
905
                                        /* conflict with SCSI_IOCTL_GET_IDLUN */
906

    
907
/* DVD-ROM Specific ioctls */
908
#define TARGET_DVD_READ_STRUCT                0x5390  /* Read structure */
909
#define TARGET_DVD_WRITE_STRUCT        0x5391  /* Write structure */
910
#define TARGET_DVD_AUTH                0x5392  /* Authentication */
911

    
912
#define TARGET_CDROM_SEND_PACKET        0x5393        /* send a packet to the drive */
913
#define TARGET_CDROM_NEXT_WRITABLE        0x5394        /* get next writable block */
914
#define TARGET_CDROM_LAST_WRITTEN        0x5395        /* get last block written on disc */
915

    
916
/* HD commands */
917

    
918
/* hd/ide ctl's that pass (arg) ptrs to user space are numbered 0x030n/0x031n */
919
#define TARGET_HDIO_GETGEO            0x0301  /* get device geometry */
920
#define TARGET_HDIO_GET_UNMASKINTR    0x0302  /* get current unmask setting */
921
#define TARGET_HDIO_GET_MULTCOUNT     0x0304  /* get current IDE blockmode setting */
922
#define TARGET_HDIO_GET_KEEPSETTINGS  0x0308  /* get keep-settings-on-reset flag */
923
#define TARGET_HDIO_GET_32BIT         0x0309  /* get current io_32bit setting */
924
#define TARGET_HDIO_GET_NOWERR        0x030a  /* get ignore-write-error flag */
925
#define TARGET_HDIO_GET_DMA           0x030b  /* get use-dma flag */
926
#define TARGET_HDIO_GET_IDENTITY      0x030d  /* get IDE identification info */
927
#define TARGET_HDIO_DRIVE_CMD         0x031f  /* execute a special drive command */
928

    
929
/* hd/ide ctl's that pass (arg) non-ptr values are numbered 0x032n/0x033n */
930
#define TARGET_HDIO_SET_MULTCOUNT     0x0321  /* change IDE blockmode */
931
#define TARGET_HDIO_SET_UNMASKINTR    0x0322  /* permit other irqs during I/O */
932
#define TARGET_HDIO_SET_KEEPSETTINGS  0x0323  /* keep ioctl settings on reset */
933
#define TARGET_HDIO_SET_32BIT         0x0324  /* change io_32bit flags */
934
#define TARGET_HDIO_SET_NOWERR        0x0325  /* change ignore-write-error flag */
935
#define TARGET_HDIO_SET_DMA           0x0326  /* change use-dma flag */
936
#define TARGET_HDIO_SET_PIO_MODE      0x0327  /* reconfig interface to new speed */
937

    
938

    
939
#if defined(TARGET_I386) || defined(TARGET_ARM)
940

    
941
/* 0x54 is just a magic number to make these relatively unique ('T') */
942

    
943
#define TARGET_TCGETS                0x5401
944
#define TARGET_TCSETS                0x5402
945
#define TARGET_TCSETSW                0x5403
946
#define TARGET_TCSETSF                0x5404
947
#define TARGET_TCGETA                0x5405
948
#define TARGET_TCSETA                0x5406
949
#define TARGET_TCSETAW                0x5407
950
#define TARGET_TCSETAF                0x5408
951
#define TARGET_TCSBRK                0x5409
952
#define TARGET_TCXONC                0x540A
953
#define TARGET_TCFLSH                0x540B
954
#define TARGET_TIOCEXCL        0x540C
955
#define TARGET_TIOCNXCL        0x540D
956
#define TARGET_TIOCSCTTY        0x540E
957
#define TARGET_TIOCGPGRP        0x540F
958
#define TARGET_TIOCSPGRP        0x5410
959
#define TARGET_TIOCOUTQ        0x5411
960
#define TARGET_TIOCSTI                0x5412
961
#define TARGET_TIOCGWINSZ        0x5413
962
#define TARGET_TIOCSWINSZ        0x5414
963
#define TARGET_TIOCMGET        0x5415
964
#define TARGET_TIOCMBIS        0x5416
965
#define TARGET_TIOCMBIC        0x5417
966
#define TARGET_TIOCMSET        0x5418
967
#define TARGET_TIOCGSOFTCAR        0x5419
968
#define TARGET_TIOCSSOFTCAR        0x541A
969
#define TARGET_FIONREAD        0x541B
970
#define TARGET_TIOCINQ                FIONREAD
971
#define TARGET_TIOCLINUX        0x541C
972
#define TARGET_TIOCCONS        0x541D
973
#define TARGET_TIOCGSERIAL        0x541E
974
#define TARGET_TIOCSSERIAL        0x541F
975
#define TARGET_TIOCPKT                0x5420
976
#define TARGET_FIONBIO                0x5421
977
#define TARGET_TIOCNOTTY        0x5422
978
#define TARGET_TIOCSETD        0x5423
979
#define TARGET_TIOCGETD        0x5424
980
#define TARGET_TCSBRKP                0x5425        /* Needed for POSIX tcsendbreak() */
981
#define TARGET_TIOCTTYGSTRUCT        0x5426  /* For debugging only */
982
#define TARGET_TIOCSBRK        0x5427  /* BSD compatibility */
983
#define TARGET_TIOCCBRK        0x5428  /* BSD compatibility */
984
#define TARGET_TIOCGSID        0x5429  /* Return the session ID of FD */
985
#define TARGET_TIOCGPTN        TARGET_IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */
986
#define TARGET_TIOCSPTLCK        TARGET_IOW('T',0x31, int)  /* Lock/unlock Pty */
987

    
988
#define TARGET_FIONCLEX        0x5450  /* these numbers need to be adjusted. */
989
#define TARGET_FIOCLEX                0x5451
990
#define TARGET_FIOASYNC        0x5452
991
#define TARGET_TIOCSERCONFIG        0x5453
992
#define TARGET_TIOCSERGWILD        0x5454
993
#define TARGET_TIOCSERSWILD        0x5455
994
#define TARGET_TIOCGLCKTRMIOS        0x5456
995
#define TARGET_TIOCSLCKTRMIOS        0x5457
996
#define TARGET_TIOCSERGSTRUCT        0x5458 /* For debugging only */
997
#define TARGET_TIOCSERGETLSR   0x5459 /* Get line status register */
998
#define TARGET_TIOCSERGETMULTI 0x545A /* Get multiport config  */
999
#define TARGET_TIOCSERSETMULTI 0x545B /* Set multiport config */
1000

    
1001
#define TARGET_TIOCMIWAIT        0x545C        /* wait for a change on serial input line(s) */
1002
#define TARGET_TIOCGICOUNT        0x545D        /* read serial port inline interrupt counts */
1003
#define TARGET_TIOCGHAYESESP   0x545E  /* Get Hayes ESP configuration */
1004
#define TARGET_TIOCSHAYESESP   0x545F  /* Set Hayes ESP configuration */
1005

    
1006
/* Used for packet mode */
1007
#define TARGET_TIOCPKT_DATA                 0
1008
#define TARGET_TIOCPKT_FLUSHREAD         1
1009
#define TARGET_TIOCPKT_FLUSHWRITE         2
1010
#define TARGET_TIOCPKT_STOP                 4
1011
#define TARGET_TIOCPKT_START                 8
1012
#define TARGET_TIOCPKT_NOSTOP                16
1013
#define TARGET_TIOCPKT_DOSTOP                32
1014

    
1015
#define TARGET_TIOCSER_TEMT    0x01        /* Transmitter physically empty */
1016

    
1017
/* from asm/termbits.h */
1018

    
1019
#define TARGET_NCCS 19
1020

    
1021
struct target_termios {
1022
    unsigned int c_iflag;               /* input mode flags */
1023
    unsigned int c_oflag;               /* output mode flags */
1024
    unsigned int c_cflag;               /* control mode flags */
1025
    unsigned int c_lflag;               /* local mode flags */
1026
    unsigned char c_line;                    /* line discipline */
1027
    unsigned char c_cc[TARGET_NCCS];                /* control characters */
1028
};
1029

    
1030
/* c_iflag bits */
1031
#define TARGET_IGNBRK  0000001
1032
#define TARGET_BRKINT  0000002
1033
#define TARGET_IGNPAR  0000004
1034
#define TARGET_PARMRK  0000010
1035
#define TARGET_INPCK   0000020
1036
#define TARGET_ISTRIP  0000040
1037
#define TARGET_INLCR   0000100
1038
#define TARGET_IGNCR   0000200
1039
#define TARGET_ICRNL   0000400
1040
#define TARGET_IUCLC   0001000
1041
#define TARGET_IXON    0002000
1042
#define TARGET_IXANY   0004000
1043
#define TARGET_IXOFF   0010000
1044
#define TARGET_IMAXBEL 0020000
1045

    
1046
/* c_oflag bits */
1047
#define TARGET_OPOST   0000001
1048
#define TARGET_OLCUC   0000002
1049
#define TARGET_ONLCR   0000004
1050
#define TARGET_OCRNL   0000010
1051
#define TARGET_ONOCR   0000020
1052
#define TARGET_ONLRET  0000040
1053
#define TARGET_OFILL   0000100
1054
#define TARGET_OFDEL   0000200
1055
#define TARGET_NLDLY   0000400
1056
#define   TARGET_NL0   0000000
1057
#define   TARGET_NL1   0000400
1058
#define TARGET_CRDLY   0003000
1059
#define   TARGET_CR0   0000000
1060
#define   TARGET_CR1   0001000
1061
#define   TARGET_CR2   0002000
1062
#define   TARGET_CR3   0003000
1063
#define TARGET_TABDLY  0014000
1064
#define   TARGET_TAB0  0000000
1065
#define   TARGET_TAB1  0004000
1066
#define   TARGET_TAB2  0010000
1067
#define   TARGET_TAB3  0014000
1068
#define   TARGET_XTABS 0014000
1069
#define TARGET_BSDLY   0020000
1070
#define   TARGET_BS0   0000000
1071
#define   TARGET_BS1   0020000
1072
#define TARGET_VTDLY   0040000
1073
#define   TARGET_VT0   0000000
1074
#define   TARGET_VT1   0040000
1075
#define TARGET_FFDLY   0100000
1076
#define   TARGET_FF0   0000000
1077
#define   TARGET_FF1   0100000
1078

    
1079
/* c_cflag bit meaning */
1080
#define TARGET_CBAUD   0010017
1081
#define  TARGET_B0     0000000         /* hang up */
1082
#define  TARGET_B50    0000001
1083
#define  TARGET_B75    0000002
1084
#define  TARGET_B110   0000003
1085
#define  TARGET_B134   0000004
1086
#define  TARGET_B150   0000005
1087
#define  TARGET_B200   0000006
1088
#define  TARGET_B300   0000007
1089
#define  TARGET_B600   0000010
1090
#define  TARGET_B1200  0000011
1091
#define  TARGET_B1800  0000012
1092
#define  TARGET_B2400  0000013
1093
#define  TARGET_B4800  0000014
1094
#define  TARGET_B9600  0000015
1095
#define  TARGET_B19200 0000016
1096
#define  TARGET_B38400 0000017
1097
#define TARGET_EXTA B19200
1098
#define TARGET_EXTB B38400
1099
#define TARGET_CSIZE   0000060
1100
#define   TARGET_CS5   0000000
1101
#define   TARGET_CS6   0000020
1102
#define   TARGET_CS7   0000040
1103
#define   TARGET_CS8   0000060
1104
#define TARGET_CSTOPB  0000100
1105
#define TARGET_CREAD   0000200
1106
#define TARGET_PARENB  0000400
1107
#define TARGET_PARODD  0001000
1108
#define TARGET_HUPCL   0002000
1109
#define TARGET_CLOCAL  0004000
1110
#define TARGET_CBAUDEX 0010000
1111
#define  TARGET_B57600  0010001
1112
#define  TARGET_B115200 0010002
1113
#define  TARGET_B230400 0010003
1114
#define  TARGET_B460800 0010004
1115
#define TARGET_CIBAUD    002003600000  /* input baud rate (not used) */
1116
#define TARGET_CRTSCTS   020000000000          /* flow control */
1117

    
1118
/* c_lflag bits */
1119
#define TARGET_ISIG    0000001
1120
#define TARGET_ICANON  0000002
1121
#define TARGET_XCASE   0000004
1122
#define TARGET_ECHO    0000010
1123
#define TARGET_ECHOE   0000020
1124
#define TARGET_ECHOK   0000040
1125
#define TARGET_ECHONL  0000100
1126
#define TARGET_NOFLSH  0000200
1127
#define TARGET_TOSTOP  0000400
1128
#define TARGET_ECHOCTL 0001000
1129
#define TARGET_ECHOPRT 0002000
1130
#define TARGET_ECHOKE  0004000
1131
#define TARGET_FLUSHO  0010000
1132
#define TARGET_PENDIN  0040000
1133
#define TARGET_IEXTEN  0100000
1134

    
1135
/* c_cc character offsets */
1136
#define TARGET_VINTR        0
1137
#define TARGET_VQUIT        1
1138
#define TARGET_VERASE        2
1139
#define TARGET_VKILL        3
1140
#define TARGET_VEOF        4
1141
#define TARGET_VTIME        5
1142
#define TARGET_VMIN        6
1143
#define TARGET_VSWTC        7
1144
#define TARGET_VSTART        8
1145
#define TARGET_VSTOP        9
1146
#define TARGET_VSUSP        10
1147
#define TARGET_VEOL        11
1148
#define TARGET_VREPRINT        12
1149
#define TARGET_VDISCARD        13
1150
#define TARGET_VWERASE        14
1151
#define TARGET_VLNEXT        15
1152
#define TARGET_VEOL2        16
1153

    
1154
#define TARGET_MAP_SHARED        0x01                /* Share changes */
1155
#define TARGET_MAP_PRIVATE        0x02                /* Changes are private */
1156
#define TARGET_MAP_TYPE        0x0f                /* Mask for type of mapping */
1157
#define TARGET_MAP_FIXED        0x10                /* Interpret addr exactly */
1158
#define TARGET_MAP_ANONYMOUS        0x20                /* don't use a file */
1159

    
1160
#define TARGET_MAP_GROWSDOWN        0x0100                /* stack-like segment */
1161
#define TARGET_MAP_DENYWRITE        0x0800                /* ETXTBSY */
1162
#define TARGET_MAP_EXECUTABLE        0x1000                /* mark it as an executable */
1163
#define TARGET_MAP_LOCKED        0x2000                /* pages are locked */
1164
#define TARGET_MAP_NORESERVE        0x4000                /* don't check for reservations */
1165

    
1166
struct target_stat {
1167
        unsigned short st_dev;
1168
        unsigned short __pad1;
1169
        target_ulong st_ino;
1170
        unsigned short st_mode;
1171
        unsigned short st_nlink;
1172
        unsigned short st_uid;
1173
        unsigned short st_gid;
1174
        unsigned short st_rdev;
1175
        unsigned short __pad2;
1176
        target_ulong  st_size;
1177
        target_ulong  st_blksize;
1178
        target_ulong  st_blocks;
1179
        target_ulong  target_st_atime;
1180
        target_ulong  __unused1;
1181
        target_ulong  target_st_mtime;
1182
        target_ulong  __unused2;
1183
        target_ulong  target_st_ctime;
1184
        target_ulong  __unused3;
1185
        target_ulong  __unused4;
1186
        target_ulong  __unused5;
1187
};
1188

    
1189
/* This matches struct stat64 in glibc2.1, hence the absolutely
1190
 * insane amounts of padding around dev_t's.
1191
 */
1192
struct target_stat64 {
1193
        unsigned short        st_dev;
1194
        unsigned char        __pad0[10];
1195

    
1196
#define TARGET_STAT64_HAS_BROKEN_ST_INO        1
1197
        target_ulong        __st_ino;
1198

    
1199
        unsigned int        st_mode;
1200
        unsigned int        st_nlink;
1201

    
1202
        target_ulong        st_uid;
1203
        target_ulong        st_gid;
1204

    
1205
        unsigned short        st_rdev;
1206
        unsigned char        __pad3[10];
1207

    
1208
        long long        st_size;
1209
        target_ulong        st_blksize;
1210

    
1211
        target_ulong        st_blocks;        /* Number 512-byte blocks allocated. */
1212
        target_ulong        __pad4;                /* future possible st_blocks high bits */
1213

    
1214
        target_ulong        target_st_atime;
1215
        target_ulong        __pad5;
1216

    
1217
        target_ulong        target_st_mtime;
1218
        target_ulong        __pad6;
1219

    
1220
        target_ulong        target_st_ctime;
1221
        target_ulong        __pad7;                /* will be high 32 bits of ctime someday */
1222

    
1223
        unsigned long long        st_ino;
1224
} __attribute__((packed));
1225

    
1226
#endif /* defined(TARGET_I386) || defined(TARGET_ARM) */
1227

    
1228
#define TARGET_F_DUPFD         0       /* dup */
1229
#define TARGET_F_GETFD         1       /* get close_on_exec */
1230
#define TARGET_F_SETFD         2       /* set/clear close_on_exec */
1231
#define TARGET_F_GETFL         3       /* get file->f_flags */
1232
#define TARGET_F_SETFL         4       /* set file->f_flags */
1233

    
1234
#if defined(TARGET_ALPHA)
1235
#define TARGET_F_GETLK         7
1236
#define TARGET_F_SETLK         8
1237
#define TARGET_F_SETLKW        9
1238
#define TARGET_F_SETOWN        5       /*  for sockets. */
1239
#define TARGET_F_GETOWN        6       /*  for sockets. */
1240
#else
1241
#define TARGET_F_GETLK         5
1242
#define TARGET_F_SETLK         6
1243
#define TARGET_F_SETLKW        7
1244
#define TARGET_F_SETOWN        8       /*  for sockets. */
1245
#define TARGET_F_GETOWN        9       /*  for sockets. */
1246
#endif
1247

    
1248
#define TARGET_F_SETSIG        10      /*  for sockets. */
1249
#define TARGET_F_GETSIG        11      /*  for sockets. */
1250

    
1251
#define TARGET_F_GETLK64       12      /*  using 'struct flock64' */
1252
#define TARGET_F_SETLK64       13
1253
#define TARGET_F_SETLKW64      14
1254

    
1255
struct target_flock {
1256
        short l_type;
1257
        short l_whence;
1258
        target_ulong l_start;
1259
        target_ulong l_len;
1260
        int l_pid;
1261
};
1262

    
1263
struct target_flock64 {
1264
        short  l_type;
1265
        short  l_whence;
1266
        unsigned long long l_start;
1267
        unsigned long long l_len;
1268
        int  l_pid;
1269
};
1270

    
1271

    
1272
/* soundcard defines */
1273
/* XXX: convert them all to arch indepedent entries */
1274
#define TARGET_SNDCTL_COPR_HALT           TARGET_IOWR('C',  7, int);
1275
#define TARGET_SNDCTL_COPR_LOAD           0xcfb04301
1276
#define TARGET_SNDCTL_COPR_RCODE          0xc0144303
1277
#define TARGET_SNDCTL_COPR_RCVMSG         0x8fa44309
1278
#define TARGET_SNDCTL_COPR_RDATA          0xc0144302
1279
#define TARGET_SNDCTL_COPR_RESET          0x00004300
1280
#define TARGET_SNDCTL_COPR_RUN            0xc0144306
1281
#define TARGET_SNDCTL_COPR_SENDMSG        0xcfa44308
1282
#define TARGET_SNDCTL_COPR_WCODE          0x40144305
1283
#define TARGET_SNDCTL_COPR_WDATA          0x40144304
1284
#define TARGET_SNDCTL_DSP_RESET           TARGET_IO('P', 0)
1285
#define TARGET_SNDCTL_DSP_SYNC            TARGET_IO('P', 1)
1286
#define TARGET_SNDCTL_DSP_SPEED           TARGET_IOWR('P', 2, int)
1287
#define TARGET_SNDCTL_DSP_STEREO          TARGET_IOWR('P', 3, int)
1288
#define TARGET_SNDCTL_DSP_GETBLKSIZE      TARGET_IOWR('P', 4, int)
1289
#define TARGET_SNDCTL_DSP_SETFMT          TARGET_IOWR('P', 5, int)
1290
#define TARGET_SNDCTL_DSP_CHANNELS        TARGET_IOWR('P', 6, int)
1291
#define TARGET_SOUND_PCM_WRITE_FILTER     TARGET_IOWR('P', 7, int)
1292
#define TARGET_SNDCTL_DSP_POST            TARGET_IO('P', 8)
1293
#define TARGET_SNDCTL_DSP_SUBDIVIDE       TARGET_IOWR('P', 9, int)
1294
#define TARGET_SNDCTL_DSP_SETFRAGMENT     TARGET_IOWR('P',10, int)
1295
#define TARGET_SNDCTL_DSP_GETFMTS         TARGET_IOR('P', 11, int)
1296
#define TARGET_SNDCTL_DSP_GETOSPACE       TARGET_IORU('P',12)
1297
#define TARGET_SNDCTL_DSP_GETISPACE       TARGET_IORU('P',13)
1298
#define TARGET_SNDCTL_DSP_GETCAPS         TARGET_IOR('P', 15, int)
1299
#define TARGET_SNDCTL_DSP_GETTRIGGER      TARGET_IOR('P',16, int)
1300
#define TARGET_SNDCTL_DSP_GETIPTR         TARGET_IORU('P',17)
1301
#define TARGET_SNDCTL_DSP_GETOPTR         TARGET_IORU('P',18)
1302
#define TARGET_SNDCTL_DSP_MAPINBUF        0x80085013
1303
#define TARGET_SNDCTL_DSP_MAPOUTBUF       0x80085014
1304
#define TARGET_SNDCTL_DSP_NONBLOCK        0x0000500e
1305
#define TARGET_SNDCTL_DSP_SAMPLESIZE      0xc0045005
1306
#define TARGET_SNDCTL_DSP_SETDUPLEX       0x00005016
1307
#define TARGET_SNDCTL_DSP_SETSYNCRO       0x00005015
1308
#define TARGET_SNDCTL_DSP_SETTRIGGER      0x40045010
1309
#define TARGET_SNDCTL_FM_4OP_ENABLE       0x4004510f
1310
#define TARGET_SNDCTL_FM_LOAD_INSTR       0x40285107
1311
#define TARGET_SNDCTL_MIDI_INFO           0xc074510c
1312
#define TARGET_SNDCTL_MIDI_MPUCMD         0xc0216d02
1313
#define TARGET_SNDCTL_MIDI_MPUMODE        0xc0046d01
1314
#define TARGET_SNDCTL_MIDI_PRETIME        0xc0046d00
1315
#define TARGET_SNDCTL_PMGR_ACCESS         0xcfb85110
1316
#define TARGET_SNDCTL_PMGR_IFACE          0xcfb85001
1317
#define TARGET_SNDCTL_SEQ_CTRLRATE        0xc0045103
1318
#define TARGET_SNDCTL_SEQ_GETINCOUNT      0x80045105
1319
#define TARGET_SNDCTL_SEQ_GETOUTCOUNT     0x80045104
1320
#define TARGET_SNDCTL_SEQ_NRMIDIS         0x8004510b
1321
#define TARGET_SNDCTL_SEQ_NRSYNTHS        0x8004510a
1322
#define TARGET_SNDCTL_SEQ_OUTOFBAND       0x40085112
1323
#define TARGET_SNDCTL_SEQ_PANIC           0x00005111
1324
#define TARGET_SNDCTL_SEQ_PERCMODE        0x40045106
1325
#define TARGET_SNDCTL_SEQ_RESET           0x00005100
1326
#define TARGET_SNDCTL_SEQ_RESETSAMPLES    0x40045109
1327
#define TARGET_SNDCTL_SEQ_SYNC            0x00005101
1328
#define TARGET_SNDCTL_SEQ_TESTMIDI        0x40045108
1329
#define TARGET_SNDCTL_SEQ_THRESHOLD       0x4004510d
1330
#define TARGET_SNDCTL_SEQ_TRESHOLD        0x4004510d
1331
#define TARGET_SNDCTL_SYNTH_INFO          0xc08c5102
1332
#define TARGET_SNDCTL_SYNTH_MEMAVL        0xc004510e
1333
#define TARGET_SNDCTL_TMR_CONTINUE        0x00005404
1334
#define TARGET_SNDCTL_TMR_METRONOME       0x40045407
1335
#define TARGET_SNDCTL_TMR_SELECT          0x40045408
1336
#define TARGET_SNDCTL_TMR_SOURCE          0xc0045406
1337
#define TARGET_SNDCTL_TMR_START           0x00005402
1338
#define TARGET_SNDCTL_TMR_STOP            0x00005403
1339
#define TARGET_SNDCTL_TMR_TEMPO           0xc0045405
1340
#define TARGET_SNDCTL_TMR_TIMEBASE        0xc0045401
1341
#define TARGET_SOUND_PCM_READ_RATE        0x80045002
1342
#define TARGET_SOUND_PCM_READ_CHANNELS    0x80045006
1343
#define TARGET_SOUND_PCM_READ_BITS        0x80045005
1344
#define TARGET_SOUND_PCM_READ_FILTER      0x80045007
1345
#define TARGET_SOUND_MIXER_INFO           TARGET_IOR ('M', 101, mixer_info)
1346
#define TARGET_SOUND_MIXER_ACCESS         0xc0804d66
1347
#define TARGET_SOUND_MIXER_PRIVATE1       TARGET_IOWR('M', 111, int)
1348
#define TARGET_SOUND_MIXER_PRIVATE2       TARGET_IOWR('M', 112, int)
1349
#define TARGET_SOUND_MIXER_PRIVATE3       TARGET_IOWR('M', 113, int)
1350
#define TARGET_SOUND_MIXER_PRIVATE4       TARGET_IOWR('M', 114, int)
1351
#define TARGET_SOUND_MIXER_PRIVATE5       TARGET_IOWR('M', 115, int)
1352

    
1353
#define TARGET_MIXER_READ(dev)        TARGET_IOR('M', dev, int)
1354

    
1355
#define TARGET_SOUND_MIXER_READ_VOLUME                TARGET_MIXER_READ(SOUND_MIXER_VOLUME)
1356
#define TARGET_SOUND_MIXER_READ_BASS                TARGET_MIXER_READ(SOUND_MIXER_BASS)
1357
#define TARGET_SOUND_MIXER_READ_TREBLE                TARGET_MIXER_READ(SOUND_MIXER_TREBLE)
1358
#define TARGET_SOUND_MIXER_READ_SYNTH                TARGET_MIXER_READ(SOUND_MIXER_SYNTH)
1359
#define TARGET_SOUND_MIXER_READ_PCM                TARGET_MIXER_READ(SOUND_MIXER_PCM)
1360
#define TARGET_SOUND_MIXER_READ_SPEAKER                TARGET_MIXER_READ(SOUND_MIXER_SPEAKER)
1361
#define TARGET_SOUND_MIXER_READ_LINE                TARGET_MIXER_READ(SOUND_MIXER_LINE)
1362
#define TARGET_SOUND_MIXER_READ_MIC                TARGET_MIXER_READ(SOUND_MIXER_MIC)
1363
#define TARGET_SOUND_MIXER_READ_CD                TARGET_MIXER_READ(SOUND_MIXER_CD)
1364
#define TARGET_SOUND_MIXER_READ_IMIX                TARGET_MIXER_READ(SOUND_MIXER_IMIX)
1365
#define TARGET_SOUND_MIXER_READ_ALTPCM                TARGET_MIXER_READ(SOUND_MIXER_ALTPCM)
1366
#define TARGET_SOUND_MIXER_READ_RECLEV                TARGET_MIXER_READ(SOUND_MIXER_RECLEV)
1367
#define TARGET_SOUND_MIXER_READ_IGAIN                TARGET_MIXER_READ(SOUND_MIXER_IGAIN)
1368
#define TARGET_SOUND_MIXER_READ_OGAIN                TARGET_MIXER_READ(SOUND_MIXER_OGAIN)
1369
#define TARGET_SOUND_MIXER_READ_LINE1                TARGET_MIXER_READ(SOUND_MIXER_LINE1)
1370
#define TARGET_SOUND_MIXER_READ_LINE2                TARGET_MIXER_READ(SOUND_MIXER_LINE2)
1371
#define TARGET_SOUND_MIXER_READ_LINE3                TARGET_MIXER_READ(SOUND_MIXER_LINE3)
1372

    
1373
/* Obsolete macros */
1374
#define TARGET_SOUND_MIXER_READ_MUTE                TARGET_MIXER_READ(SOUND_MIXER_MUTE)
1375
#define TARGET_SOUND_MIXER_READ_ENHANCE                TARGET_MIXER_READ(SOUND_MIXER_ENHANCE)
1376
#define TARGET_SOUND_MIXER_READ_LOUD                TARGET_MIXER_READ(SOUND_MIXER_LOUD)
1377

    
1378
#define TARGET_SOUND_MIXER_READ_RECSRC                TARGET_MIXER_READ(SOUND_MIXER_RECSRC)
1379
#define TARGET_SOUND_MIXER_READ_DEVMASK                TARGET_MIXER_READ(SOUND_MIXER_DEVMASK)
1380
#define TARGET_SOUND_MIXER_READ_RECMASK                TARGET_MIXER_READ(SOUND_MIXER_RECMASK)
1381
#define TARGET_SOUND_MIXER_READ_STEREODEVS        TARGET_MIXER_READ(SOUND_MIXER_STEREODEVS)
1382
#define TARGET_SOUND_MIXER_READ_CAPS                TARGET_MIXER_READ(SOUND_MIXER_CAPS)
1383

    
1384
#define TARGET_MIXER_WRITE(dev)                TARGET_IOWR('M', dev, int)
1385

    
1386
#define TARGET_SOUND_MIXER_WRITE_VOLUME        TARGET_MIXER_WRITE(SOUND_MIXER_VOLUME)
1387
#define TARGET_SOUND_MIXER_WRITE_BASS                TARGET_MIXER_WRITE(SOUND_MIXER_BASS)
1388
#define TARGET_SOUND_MIXER_WRITE_TREBLE        TARGET_MIXER_WRITE(SOUND_MIXER_TREBLE)
1389
#define TARGET_SOUND_MIXER_WRITE_SYNTH                TARGET_MIXER_WRITE(SOUND_MIXER_SYNTH)
1390
#define TARGET_SOUND_MIXER_WRITE_PCM                TARGET_MIXER_WRITE(SOUND_MIXER_PCM)
1391
#define TARGET_SOUND_MIXER_WRITE_SPEAKER        TARGET_MIXER_WRITE(SOUND_MIXER_SPEAKER)
1392
#define TARGET_SOUND_MIXER_WRITE_LINE                TARGET_MIXER_WRITE(SOUND_MIXER_LINE)
1393
#define TARGET_SOUND_MIXER_WRITE_MIC                TARGET_MIXER_WRITE(SOUND_MIXER_MIC)
1394
#define TARGET_SOUND_MIXER_WRITE_CD                TARGET_MIXER_WRITE(SOUND_MIXER_CD)
1395
#define TARGET_SOUND_MIXER_WRITE_IMIX                TARGET_MIXER_WRITE(SOUND_MIXER_IMIX)
1396
#define TARGET_SOUND_MIXER_WRITE_ALTPCM        TARGET_MIXER_WRITE(SOUND_MIXER_ALTPCM)
1397
#define TARGET_SOUND_MIXER_WRITE_RECLEV        TARGET_MIXER_WRITE(SOUND_MIXER_RECLEV)
1398
#define TARGET_SOUND_MIXER_WRITE_IGAIN                TARGET_MIXER_WRITE(SOUND_MIXER_IGAIN)
1399
#define TARGET_SOUND_MIXER_WRITE_OGAIN                TARGET_MIXER_WRITE(SOUND_MIXER_OGAIN)
1400
#define TARGET_SOUND_MIXER_WRITE_LINE1                TARGET_MIXER_WRITE(SOUND_MIXER_LINE1)
1401
#define TARGET_SOUND_MIXER_WRITE_LINE2                TARGET_MIXER_WRITE(SOUND_MIXER_LINE2)
1402
#define TARGET_SOUND_MIXER_WRITE_LINE3                TARGET_MIXER_WRITE(SOUND_MIXER_LINE3)
1403

    
1404
/* Obsolete macros */
1405
#define TARGET_SOUND_MIXER_WRITE_MUTE                TARGET_MIXER_WRITE(SOUND_MIXER_MUTE)
1406
#define TARGET_SOUND_MIXER_WRITE_ENHANCE        TARGET_MIXER_WRITE(SOUND_MIXER_ENHANCE)
1407
#define TARGET_SOUND_MIXER_WRITE_LOUD                TARGET_MIXER_WRITE(SOUND_MIXER_LOUD)
1408

    
1409
#define TARGET_SOUND_MIXER_WRITE_RECSRC        TARGET_MIXER_WRITE(SOUND_MIXER_RECSRC)
1410

    
1411
/* vfat ioctls */
1412
#define TARGET_VFAT_IOCTL_READDIR_BOTH    TARGET_IORU('r', 1)
1413
#define TARGET_VFAT_IOCTL_READDIR_SHORT   TARGET_IORU('r', 2)