qemu/linux-user/ioctls.h
<<
>>
Prefs
   1     /* emulated ioctl list */
   2
   3     IOCTL(TCGETS, IOC_R, MK_PTR(MK_STRUCT(STRUCT_termios)))
   4     IOCTL(TCSETS, IOC_W, MK_PTR(MK_STRUCT(STRUCT_termios)))
   5     IOCTL(TCSETSF, IOC_W, MK_PTR(MK_STRUCT(STRUCT_termios)))
   6     IOCTL(TCSETSW, IOC_W, MK_PTR(MK_STRUCT(STRUCT_termios)))
   7     IOCTL(TIOCGWINSZ, IOC_R, MK_PTR(MK_STRUCT(STRUCT_winsize)))
   8     IOCTL(TIOCSWINSZ, IOC_W, MK_PTR(MK_STRUCT(STRUCT_winsize)))
   9     IOCTL(FIONREAD, IOC_R, MK_PTR(TYPE_INT))
  10     IOCTL(TCGETA, IOC_R, MK_PTR(TYPE_INT))
  11     IOCTL(TCSETA, IOC_W, MK_PTR(TYPE_INT))
  12     IOCTL(TCSETAW, IOC_W, MK_PTR(TYPE_INT))
  13     IOCTL(TCSETAF, IOC_W, MK_PTR(TYPE_INT))
  14     IOCTL(TCSBRK, 0, TYPE_INT)
  15     IOCTL(TCSBRKP, 0, TYPE_INT)
  16     IOCTL(TCXONC, 0, TYPE_INT)
  17     IOCTL(TCFLSH, 0, TYPE_INT)
  18     IOCTL(TIOCEXCL, 0, TYPE_NULL)
  19     IOCTL(TIOCNXCL, 0, TYPE_NULL)
  20     IOCTL(TIOCSCTTY, 0, TYPE_INT)
  21     IOCTL(TIOCGPGRP, IOC_R, MK_PTR(TYPE_INT))
  22     IOCTL(TIOCSPGRP, IOC_W, MK_PTR(TYPE_INT))
  23     IOCTL(TIOCGSID, IOC_W, MK_PTR(TYPE_INT))
  24     IOCTL(TIOCOUTQ, IOC_R, MK_PTR(TYPE_INT))
  25     IOCTL(TIOCSTI, IOC_W, MK_PTR(TYPE_INT))
  26     IOCTL(TIOCMGET, IOC_R, MK_PTR(TYPE_INT))
  27     IOCTL(TIOCMBIS, IOC_W, MK_PTR(TYPE_INT))
  28     IOCTL(TIOCMBIC, IOC_W, MK_PTR(TYPE_INT))
  29     IOCTL(TIOCMSET, IOC_W, MK_PTR(TYPE_INT))
  30     IOCTL(TIOCGSOFTCAR, IOC_R, MK_PTR(TYPE_INT))
  31     IOCTL(TIOCSSOFTCAR, IOC_W, MK_PTR(TYPE_INT))
  32     IOCTL(TIOCLINUX, IOC_R | IOC_W, MK_PTR(TYPE_INT))
  33     IOCTL(TIOCCONS, 0, TYPE_NULL)
  34     IOCTL(TIOCGSERIAL, IOC_R, MK_PTR(TYPE_INT))
  35     IOCTL(TIOCSSERIAL, IOC_W, MK_PTR(TYPE_INT))
  36     IOCTL(TIOCPKT, IOC_W, MK_PTR(TYPE_INT))
  37     IOCTL(FIONBIO, IOC_W, MK_PTR(TYPE_INT))
  38     IOCTL(TIOCNOTTY, 0, TYPE_NULL)
  39     IOCTL(TIOCGETD, IOC_R, MK_PTR(TYPE_INT))
  40     IOCTL(TIOCSETD, IOC_W, MK_PTR(TYPE_INT))
  41     IOCTL(TIOCGPTN, IOC_R, MK_PTR(TYPE_INT))
  42     IOCTL(TIOCSPTLCK, IOC_W, MK_PTR(TYPE_INT))
  43#ifdef TIOCGPTPEER
  44     IOCTL_SPECIAL(TIOCGPTPEER, 0, do_ioctl_tiocgptpeer, TYPE_INT)
  45#endif
  46     IOCTL(FIOCLEX, 0, TYPE_NULL)
  47     IOCTL(FIONCLEX, 0, TYPE_NULL)
  48     IOCTL(FIOASYNC, IOC_W, MK_PTR(TYPE_INT))
  49     IOCTL(TIOCGLCKTRMIOS, IOC_R, MK_PTR(MK_STRUCT(STRUCT_termios)))
  50     IOCTL(TIOCSLCKTRMIOS, IOC_W, MK_PTR(MK_STRUCT(STRUCT_termios)))
  51     IOCTL(TIOCSERCONFIG, 0, TYPE_NULL)
  52     IOCTL(TIOCSERGETLSR, IOC_R, MK_PTR(TYPE_INT))
  53     IOCTL(TIOCSERGETMULTI, IOC_R, MK_PTR(MK_STRUCT(STRUCT_serial_multiport_struct)))
  54     IOCTL(TIOCSERSETMULTI, IOC_W, MK_PTR(MK_STRUCT(STRUCT_serial_multiport_struct)))
  55     IOCTL(TIOCMIWAIT, 0, TYPE_INT)
  56     IOCTL(TIOCGICOUNT, IOC_R, MK_PTR(MK_STRUCT(STRUCT_serial_icounter_struct)))
  57
  58     IOCTL(KIOCSOUND, 0, TYPE_INT)
  59     IOCTL(KDMKTONE, 0, TYPE_INT)
  60     IOCTL(KDSETMODE, 0, TYPE_INT)
  61     IOCTL(KDGKBTYPE, IOC_R, MK_PTR(TYPE_CHAR))
  62     IOCTL(KDGKBMODE, IOC_R, MK_PTR(TYPE_INT))
  63     IOCTL(KDSKBMODE, 0, TYPE_INT)
  64     IOCTL(KDGKBENT, IOC_RW, MK_PTR(MK_STRUCT(STRUCT_kbentry)))
  65     IOCTL(KDGKBSENT, IOC_RW, MK_PTR(MK_STRUCT(STRUCT_kbsentry)))
  66     IOCTL(KDGKBLED, 0, TYPE_INT)
  67     IOCTL(KDSKBLED, 0, TYPE_INT)
  68     IOCTL(KDGETLED, 0, TYPE_INT)
  69     IOCTL(KDSETLED, 0, TYPE_INT)
  70     IOCTL_SPECIAL(KDSIGACCEPT, 0, do_ioctl_kdsigaccept, TYPE_INT)
  71
  72     IOCTL(RTC_AIE_ON, 0, TYPE_NULL)
  73     IOCTL(RTC_AIE_OFF, 0, TYPE_NULL)
  74     IOCTL(RTC_UIE_ON, 0, TYPE_NULL)
  75     IOCTL(RTC_UIE_OFF, 0, TYPE_NULL)
  76     IOCTL(RTC_PIE_ON, 0, TYPE_NULL)
  77     IOCTL(RTC_PIE_OFF, 0, TYPE_NULL)
  78     IOCTL(RTC_WIE_ON, 0, TYPE_NULL)
  79     IOCTL(RTC_WIE_OFF, 0, TYPE_NULL)
  80     IOCTL(RTC_ALM_READ, IOC_R, MK_PTR(MK_STRUCT(STRUCT_rtc_time)))
  81     IOCTL(RTC_ALM_SET, IOC_W, MK_PTR(MK_STRUCT(STRUCT_rtc_time)))
  82     IOCTL(RTC_RD_TIME, IOC_R, MK_PTR(MK_STRUCT(STRUCT_rtc_time)))
  83     IOCTL(RTC_SET_TIME, IOC_W, MK_PTR(MK_STRUCT(STRUCT_rtc_time)))
  84     IOCTL(RTC_IRQP_READ, IOC_R, MK_PTR(TYPE_ULONG))
  85     IOCTL(RTC_IRQP_SET, IOC_W, TYPE_ULONG)
  86     IOCTL(RTC_EPOCH_READ, IOC_R, MK_PTR(TYPE_ULONG))
  87     IOCTL(RTC_EPOCH_SET, IOC_W, TYPE_ULONG)
  88     IOCTL(RTC_WKALM_RD, IOC_R, MK_PTR(MK_STRUCT(STRUCT_rtc_wkalrm)))
  89     IOCTL(RTC_WKALM_SET, IOC_W, MK_PTR(MK_STRUCT(STRUCT_rtc_wkalrm)))
  90     IOCTL(RTC_PLL_GET, IOC_R, MK_PTR(MK_STRUCT(STRUCT_rtc_pll_info)))
  91     IOCTL(RTC_PLL_SET, IOC_W, MK_PTR(MK_STRUCT(STRUCT_rtc_pll_info)))
  92     IOCTL(RTC_VL_READ, IOC_R, MK_PTR(TYPE_INT))
  93     IOCTL(RTC_VL_CLR, 0, TYPE_NULL)
  94
  95     IOCTL(BLKROSET, IOC_W, MK_PTR(TYPE_INT))
  96     IOCTL(BLKROGET, IOC_R, MK_PTR(TYPE_INT))
  97     IOCTL(BLKRRPART, 0, TYPE_NULL)
  98     IOCTL(BLKGETSIZE, IOC_R, MK_PTR(TYPE_ULONG))
  99#ifdef BLKGETSIZE64
 100     IOCTL(BLKGETSIZE64, IOC_R, MK_PTR(TYPE_ULONGLONG))
 101#endif
 102     IOCTL(BLKFLSBUF, 0, TYPE_NULL)
 103     IOCTL(BLKRASET, 0, TYPE_INT)
 104     IOCTL(BLKRAGET, IOC_R, MK_PTR(TYPE_LONG))
 105     IOCTL(BLKSSZGET, IOC_R, MK_PTR(TYPE_INT))
 106     IOCTL(BLKBSZGET, IOC_R, MK_PTR(TYPE_INT))
 107     IOCTL_SPECIAL(BLKPG, IOC_W, do_ioctl_blkpg,
 108                   MK_PTR(MK_STRUCT(STRUCT_blkpg_ioctl_arg)))
 109
 110#ifdef BLKDISCARD
 111     IOCTL(BLKDISCARD, IOC_W, MK_PTR(MK_ARRAY(TYPE_ULONGLONG, 2)))
 112#endif
 113#ifdef BLKIOMIN
 114     IOCTL(BLKIOMIN, IOC_R, MK_PTR(TYPE_INT))
 115#endif
 116#ifdef BLKIOOPT
 117     IOCTL(BLKIOOPT, IOC_R, MK_PTR(TYPE_INT))
 118#endif
 119#ifdef BLKALIGNOFF
 120     IOCTL(BLKALIGNOFF, IOC_R, MK_PTR(TYPE_INT))
 121#endif
 122#ifdef BLKPBSZGET
 123     IOCTL(BLKPBSZGET, IOC_R, MK_PTR(TYPE_INT))
 124#endif
 125#ifdef BLKDISCARDZEROES
 126     IOCTL(BLKDISCARDZEROES, IOC_R, MK_PTR(TYPE_INT))
 127#endif
 128#ifdef BLKSECDISCARD
 129     IOCTL(BLKSECDISCARD, IOC_W, MK_PTR(MK_ARRAY(TYPE_ULONGLONG, 2)))
 130#endif
 131#ifdef BLKROTATIONAL
 132     IOCTL(BLKROTATIONAL, IOC_R, MK_PTR(TYPE_SHORT))
 133#endif
 134#ifdef BLKZEROOUT
 135     IOCTL(BLKZEROOUT, IOC_W, MK_PTR(MK_ARRAY(TYPE_ULONGLONG, 2)))
 136#endif
 137
 138     IOCTL(FDMSGON, 0, TYPE_NULL)
 139     IOCTL(FDMSGOFF, 0, TYPE_NULL)
 140     IOCTL(FDSETEMSGTRESH, 0, TYPE_NULL)
 141     IOCTL(FDFMTBEG, 0, TYPE_NULL)
 142     IOCTL(FDFMTTRK, IOC_W, MK_PTR(MK_STRUCT(STRUCT_format_descr)))
 143     IOCTL(FDFMTEND, 0, TYPE_NULL)
 144     IOCTL(FDFLUSH, 0, TYPE_NULL)
 145     IOCTL(FDSETMAXERRS, IOC_W, MK_PTR(MK_STRUCT(STRUCT_floppy_max_errors)))
 146     IOCTL(FDGETMAXERRS, IOC_R, MK_PTR(MK_STRUCT(STRUCT_floppy_max_errors)))
 147     IOCTL(FDRESET, 0, TYPE_NULL)
 148     IOCTL(FDRAWCMD, 0, TYPE_NULL)
 149     IOCTL(FDTWADDLE, 0, TYPE_NULL)
 150     IOCTL(FDEJECT, 0, TYPE_NULL)
 151
 152#ifdef FIBMAP
 153     IOCTL(FIBMAP, IOC_W | IOC_R, MK_PTR(TYPE_LONG))
 154#endif
 155#ifdef FICLONE
 156     IOCTL(FICLONE, IOC_W, TYPE_INT)
 157     IOCTL(FICLONERANGE, IOC_W, MK_PTR(MK_STRUCT(STRUCT_file_clone_range)))
 158#endif
 159
 160#ifdef FIGETBSZ
 161     IOCTL(FIGETBSZ, IOC_R, MK_PTR(TYPE_LONG))
 162#endif
 163#ifdef CONFIG_FIEMAP
 164     IOCTL_SPECIAL(FS_IOC_FIEMAP, IOC_W | IOC_R, do_ioctl_fs_ioc_fiemap,
 165                   MK_PTR(MK_STRUCT(STRUCT_fiemap)))
 166#endif
 167
 168     IOCTL(FS_IOC_GETFLAGS, IOC_R, MK_PTR(TYPE_INT))
 169     IOCTL(FS_IOC_SETFLAGS, IOC_W, MK_PTR(TYPE_INT))
 170     IOCTL(FS_IOC_GETVERSION, IOC_R, MK_PTR(TYPE_INT))
 171     IOCTL(FS_IOC_SETVERSION, IOC_W, MK_PTR(TYPE_INT))
 172     IOCTL(FS_IOC32_GETFLAGS, IOC_R, MK_PTR(TYPE_INT))
 173     IOCTL(FS_IOC32_SETFLAGS, IOC_W, MK_PTR(TYPE_INT))
 174     IOCTL(FS_IOC32_GETVERSION, IOC_R, MK_PTR(TYPE_INT))
 175     IOCTL(FS_IOC32_SETVERSION, IOC_W, MK_PTR(TYPE_INT))
 176
 177#ifdef BTRFS_IOC_SNAP_CREATE
 178     IOCTL(BTRFS_IOC_SNAP_CREATE, IOC_W,
 179           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_vol_args)))
 180#endif
 181#ifdef BTRFS_IOC_SCAN_DEV
 182     IOCTL(BTRFS_IOC_SCAN_DEV, IOC_W,
 183           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_vol_args)))
 184#endif
 185#ifdef BTRFS_IOC_FORGET_DEV
 186     IOCTL(BTRFS_IOC_FORGET_DEV, IOC_W,
 187           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_vol_args)))
 188#endif
 189#ifdef BTRFS_IOC_ADD_DEV
 190     IOCTL(BTRFS_IOC_ADD_DEV, IOC_W,
 191           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_vol_args)))
 192#endif
 193#ifdef BTRFS_IOC_RM_DEV
 194     IOCTL(BTRFS_IOC_RM_DEV, IOC_W,
 195           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_vol_args)))
 196#endif
 197#ifdef BTRFS_IOC_SUBVOL_CREATE
 198     IOCTL(BTRFS_IOC_SUBVOL_CREATE, IOC_W,
 199           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_vol_args)))
 200#endif
 201#ifdef BTRFS_IOC_SNAP_DESTROY
 202     IOCTL(BTRFS_IOC_SNAP_DESTROY, IOC_W,
 203           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_vol_args)))
 204#endif
 205#ifdef BTRFS_IOC_INO_LOOKUP
 206     IOCTL(BTRFS_IOC_INO_LOOKUP, IOC_RW,
 207           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_ino_lookup_args)))
 208#endif
 209#ifdef BTRFS_IOC_DEFAULT_SUBVOL
 210     IOCTL(BTRFS_IOC_DEFAULT_SUBVOL, IOC_W, MK_PTR(TYPE_ULONGLONG))
 211#endif
 212#ifdef BTRFS_IOC_SUBVOL_GETFLAGS
 213     IOCTL(BTRFS_IOC_SUBVOL_GETFLAGS, IOC_R, MK_PTR(TYPE_ULONGLONG))
 214#endif
 215#ifdef BTRFS_IOC_SUBVOL_SETFLAGS
 216     IOCTL(BTRFS_IOC_SUBVOL_SETFLAGS, IOC_W, MK_PTR(TYPE_ULONGLONG))
 217#endif
 218#ifdef BTRFS_IOC_SCRUB
 219     IOCTL(BTRFS_IOC_SCRUB, IOC_RW,
 220           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_scrub_args)))
 221#endif
 222#ifdef BTRFS_IOC_SCRUB_CANCEL
 223     IOCTL(BTRFS_IOC_SCRUB_CANCEL, 0, TYPE_NULL)
 224#endif
 225#ifdef BTRFS_IOC_SCRUB_PROGRESS
 226     IOCTL(BTRFS_IOC_SCRUB_PROGRESS, IOC_RW,
 227           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_scrub_args)))
 228#endif
 229#ifdef BTRFS_IOC_DEV_INFO
 230     IOCTL(BTRFS_IOC_DEV_INFO, IOC_RW,
 231           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_dev_info_args)))
 232#endif
 233#ifdef BTRFS_IOC_INO_PATHS
 234     IOCTL(BTRFS_IOC_INO_PATHS, IOC_RW,
 235           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_ino_path_args)))
 236#endif
 237#ifdef BTRFS_IOC_LOGICAL_INO
 238     IOCTL(BTRFS_IOC_LOGICAL_INO, IOC_RW,
 239           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_logical_ino_args)))
 240#endif
 241#ifdef BTRFS_IOC_QUOTA_CTL
 242     IOCTL(BTRFS_IOC_QUOTA_CTL, IOC_RW,
 243           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_quota_ctl_args)))
 244#endif
 245#ifdef BTRFS_IOC_QGROUP_ASSIGN
 246     IOCTL(BTRFS_IOC_QGROUP_ASSIGN, IOC_W,
 247           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_qgroup_assign_args)))
 248#endif
 249#ifdef BTRFS_IOC_QGROUP_CREATE
 250     IOCTL(BTRFS_IOC_QGROUP_CREATE, IOC_W,
 251           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_qgroup_create_args)))
 252#endif
 253#ifdef BTRFS_IOC_QGROUP_LIMIT
 254     IOCTL(BTRFS_IOC_QGROUP_LIMIT, IOC_R,
 255           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_qgroup_limit_args)))
 256#endif
 257#ifdef BTRFS_IOC_QUOTA_RESCAN
 258     IOCTL(BTRFS_IOC_QUOTA_RESCAN, IOC_W,
 259           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_quota_rescan_args)))
 260#endif
 261#ifdef BTRFS_IOC_QUOTA_RESCAN_STATUS
 262     IOCTL(BTRFS_IOC_QUOTA_RESCAN_STATUS, IOC_R,
 263           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_quota_rescan_args)))
 264#endif
 265#ifdef BTRFS_IOC_QUOTA_RESCAN_WAIT
 266     IOCTL(BTRFS_IOC_QUOTA_RESCAN_WAIT, 0, TYPE_NULL)
 267#endif
 268#ifdef BTRFS_IOC_GET_DEV_STATS
 269     IOCTL(BTRFS_IOC_GET_DEV_STATS, IOC_RW,
 270           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_get_dev_stats)))
 271#endif
 272#ifdef BTRFS_IOC_GET_FEATURES
 273     IOCTL(BTRFS_IOC_GET_FEATURES, IOC_R,
 274           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_feature_flags)))
 275#endif
 276#ifdef BTRFS_IOC_SET_FEATURES
 277     IOCTL(BTRFS_IOC_SET_FEATURES, IOC_W,
 278           MK_PTR(MK_ARRAY(MK_STRUCT(STRUCT_btrfs_ioctl_feature_flags), 2)))
 279#endif
 280#ifdef BTRFS_IOC_GET_SUPPORTED_FEATURES
 281     IOCTL(BTRFS_IOC_GET_SUPPORTED_FEATURES, IOC_R,
 282           MK_PTR(MK_ARRAY(MK_STRUCT(STRUCT_btrfs_ioctl_feature_flags), 3)))
 283#endif
 284#ifdef BTRFS_IOC_LOGICAL_INO_V2
 285     IOCTL(BTRFS_IOC_LOGICAL_INO_V2, IOC_RW,
 286           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_logical_ino_args)))
 287#endif
 288#ifdef BTRFS_IOC_GET_SUBVOL_INFO
 289     IOCTL(BTRFS_IOC_GET_SUBVOL_INFO, IOC_R,
 290           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_get_subvol_info_args)))
 291#endif
 292#ifdef BTRFS_IOC_GET_SUBVOL_ROOTREF
 293     IOCTL(BTRFS_IOC_GET_SUBVOL_ROOTREF, IOC_RW,
 294           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_get_subvol_rootref_args)))
 295#endif
 296#ifdef BTRFS_IOC_INO_LOOKUP_USER
 297     IOCTL(BTRFS_IOC_INO_LOOKUP_USER, IOC_RW,
 298           MK_PTR(MK_STRUCT(STRUCT_btrfs_ioctl_ino_lookup_user_args)))
 299#endif
 300
 301#ifdef CONFIG_USBFS
 302  /* USB ioctls */
 303  IOCTL(USBDEVFS_CONTROL, IOC_RW,
 304        MK_PTR(MK_STRUCT(STRUCT_usbdevfs_ctrltransfer)))
 305  IOCTL(USBDEVFS_BULK, IOC_RW,
 306        MK_PTR(MK_STRUCT(STRUCT_usbdevfs_bulktransfer)))
 307  IOCTL(USBDEVFS_RESETEP, IOC_W, MK_PTR(TYPE_INT))
 308  IOCTL(USBDEVFS_SETINTERFACE, IOC_W,
 309        MK_PTR(MK_STRUCT(STRUCT_usbdevfs_setinterface)))
 310  IOCTL(USBDEVFS_SETCONFIGURATION, IOC_W, MK_PTR(TYPE_INT))
 311  IOCTL(USBDEVFS_GETDRIVER, IOC_R,
 312        MK_PTR(MK_STRUCT(STRUCT_usbdevfs_getdriver)))
 313  IOCTL_SPECIAL(USBDEVFS_SUBMITURB, IOC_W, do_ioctl_usbdevfs_submiturb,
 314      MK_PTR(MK_STRUCT(STRUCT_usbdevfs_urb)))
 315  IOCTL_SPECIAL(USBDEVFS_DISCARDURB, IOC_RW, do_ioctl_usbdevfs_discardurb,
 316      MK_PTR(MK_STRUCT(STRUCT_usbdevfs_urb)))
 317  IOCTL_SPECIAL(USBDEVFS_REAPURB, IOC_R, do_ioctl_usbdevfs_reapurb,
 318      MK_PTR(TYPE_PTRVOID))
 319  IOCTL_SPECIAL(USBDEVFS_REAPURBNDELAY, IOC_R, do_ioctl_usbdevfs_reapurb,
 320      MK_PTR(TYPE_PTRVOID))
 321  IOCTL(USBDEVFS_DISCSIGNAL, IOC_W,
 322        MK_PTR(MK_STRUCT(STRUCT_usbdevfs_disconnectsignal)))
 323  IOCTL(USBDEVFS_CLAIMINTERFACE, IOC_W, MK_PTR(TYPE_INT))
 324  IOCTL(USBDEVFS_RELEASEINTERFACE, IOC_W, MK_PTR(TYPE_INT))
 325  IOCTL(USBDEVFS_CONNECTINFO, IOC_R,
 326        MK_PTR(MK_STRUCT(STRUCT_usbdevfs_connectinfo)))
 327  IOCTL(USBDEVFS_IOCTL, IOC_RW, MK_PTR(MK_STRUCT(STRUCT_usbdevfs_ioctl)))
 328  IOCTL(USBDEVFS_HUB_PORTINFO, IOC_R,
 329        MK_PTR(MK_STRUCT(STRUCT_usbdevfs_hub_portinfo)))
 330  IOCTL(USBDEVFS_RESET, 0, TYPE_NULL)
 331  IOCTL(USBDEVFS_CLEAR_HALT, IOC_W, MK_PTR(TYPE_INT))
 332  IOCTL(USBDEVFS_DISCONNECT, 0, TYPE_NULL)
 333  IOCTL(USBDEVFS_CONNECT, 0, TYPE_NULL)
 334  IOCTL(USBDEVFS_CLAIM_PORT, IOC_W, MK_PTR(TYPE_INT))
 335  IOCTL(USBDEVFS_RELEASE_PORT, IOC_W, MK_PTR(TYPE_INT))
 336  IOCTL(USBDEVFS_GET_CAPABILITIES, IOC_R, MK_PTR(TYPE_INT))
 337  IOCTL(USBDEVFS_DISCONNECT_CLAIM, IOC_W,
 338        MK_PTR(MK_STRUCT(STRUCT_usbdevfs_disconnect_claim)))
 339#ifdef USBDEVFS_DROP_PRIVILEGES
 340  IOCTL(USBDEVFS_DROP_PRIVILEGES, IOC_W, MK_PTR(TYPE_INT))
 341#endif
 342#ifdef USBDEVFS_GET_SPEED
 343  IOCTL(USBDEVFS_GET_SPEED, 0, TYPE_NULL)
 344#endif
 345#endif /* CONFIG_USBFS */
 346
 347  IOCTL(FIOGETOWN, IOC_R, MK_PTR(TYPE_INT))
 348  IOCTL(FIOSETOWN, IOC_W, MK_PTR(TYPE_INT))
 349  IOCTL(SIOCATMARK, IOC_R, MK_PTR(TYPE_INT))
 350  IOCTL(SIOCGIFNAME, IOC_RW, MK_PTR(MK_STRUCT(STRUCT_int_ifreq)))
 351  IOCTL(SIOCGIFFLAGS, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_short_ifreq)))
 352  IOCTL(SIOCSIFFLAGS, IOC_W, MK_PTR(MK_STRUCT(STRUCT_short_ifreq)))
 353  IOCTL(SIOCGIFADDR, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 354  IOCTL(SIOCSIFADDR, IOC_W, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 355  IOCTL(SIOCGIFBRDADDR, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 356  IOCTL(SIOCSIFBRDADDR, IOC_W, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 357  IOCTL(SIOCGIFDSTADDR, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 358  IOCTL(SIOCSIFDSTADDR, IOC_W, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 359  IOCTL(SIOCGIFNETMASK, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 360  IOCTL(SIOCSIFNETMASK, IOC_W, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 361  IOCTL(SIOCGIFHWADDR, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 362  IOCTL(SIOCSIFHWADDR, IOC_W, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 363  IOCTL(SIOCGIFTXQLEN, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 364  IOCTL(SIOCSIFTXQLEN, IOC_W, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 365  IOCTL(SIOCGIFMETRIC, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_int_ifreq)))
 366  IOCTL(SIOCSIFMETRIC, IOC_W, MK_PTR(MK_STRUCT(STRUCT_int_ifreq)))
 367  IOCTL(SIOCGIFMTU, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_int_ifreq)))
 368  IOCTL(SIOCSIFMTU, IOC_W, MK_PTR(MK_STRUCT(STRUCT_int_ifreq)))
 369  IOCTL(SIOCGIFMAP, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_ifmap_ifreq)))
 370  IOCTL(SIOCSIFMAP, IOC_W, MK_PTR(MK_STRUCT(STRUCT_ifmap_ifreq)))
 371  IOCTL(SIOCGIFSLAVE, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_char_ifreq)))
 372  IOCTL(SIOCSIFSLAVE, IOC_W, MK_PTR(MK_STRUCT(STRUCT_char_ifreq)))
 373  IOCTL(SIOCGIFMEM, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_ptr_ifreq)))
 374  IOCTL(SIOCSIFMEM, IOC_W, MK_PTR(MK_STRUCT(STRUCT_ptr_ifreq)))
 375  IOCTL(SIOCADDMULTI, IOC_W, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 376  IOCTL(SIOCDELMULTI, IOC_W, MK_PTR(MK_STRUCT(STRUCT_sockaddr_ifreq)))
 377  IOCTL(SIOCGIFINDEX, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_int_ifreq)))
 378  IOCTL(SIOCSIFPFLAGS, IOC_W, MK_PTR(MK_STRUCT(STRUCT_short_ifreq)))
 379  IOCTL(SIOCGIFPFLAGS, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_short_ifreq)))
 380  IOCTL(SIOCSIFLINK, 0, TYPE_NULL)
 381  IOCTL_SPECIAL(SIOCGIFCONF, IOC_W | IOC_R, do_ioctl_ifconf,
 382                MK_PTR(MK_STRUCT(STRUCT_ifconf)))
 383  IOCTL(SIOCGIFENCAP, IOC_RW, MK_PTR(TYPE_INT))
 384  IOCTL(SIOCSIFENCAP, IOC_W, MK_PTR(TYPE_INT))
 385  IOCTL(SIOCDARP, IOC_W, MK_PTR(MK_STRUCT(STRUCT_arpreq)))
 386  IOCTL(SIOCSARP, IOC_W, MK_PTR(MK_STRUCT(STRUCT_arpreq)))
 387  IOCTL(SIOCGARP, IOC_R, MK_PTR(MK_STRUCT(STRUCT_arpreq)))
 388  IOCTL(SIOCDRARP, IOC_W, MK_PTR(MK_STRUCT(STRUCT_arpreq)))
 389  IOCTL(SIOCSRARP, IOC_W, MK_PTR(MK_STRUCT(STRUCT_arpreq)))
 390  IOCTL(SIOCGRARP, IOC_R, MK_PTR(MK_STRUCT(STRUCT_arpreq)))
 391  IOCTL(SIOCGIWNAME, IOC_W | IOC_R, MK_PTR(MK_STRUCT(STRUCT_char_ifreq)))
 392  IOCTL(SIOCSPGRP, IOC_W, MK_PTR(TYPE_INT)) /* pid_t */
 393  IOCTL(SIOCGPGRP, IOC_R, MK_PTR(TYPE_INT)) /* pid_t */
 394
 395  /*
 396   * We can't use IOCTL_SPECIAL() because it will set
 397   * host_cmd to XXX_OLD and XXX_NEW and these macros
 398   * are not defined with kernel prior to 5.2.
 399   * We must set host_cmd to the same value as in target_cmd
 400   * otherwise the consistency check in syscall_init()
 401   * will trigger an error.
 402   * host_cmd is ignored by the do_ioctl_XXX() helpers.
 403   * FIXME: create a macro to define this kind of entry
 404   */
 405  { TARGET_SIOCGSTAMP_OLD, TARGET_SIOCGSTAMP_OLD,
 406    "SIOCGSTAMP_OLD", IOC_R, do_ioctl_SIOCGSTAMP,
 407    { MK_PTR(MK_STRUCT(STRUCT_timeval)) } },
 408  { TARGET_SIOCGSTAMPNS_OLD, TARGET_SIOCGSTAMPNS_OLD,
 409    "SIOCGSTAMPNS_OLD", IOC_R, do_ioctl_SIOCGSTAMPNS,
 410    { MK_PTR(MK_STRUCT(STRUCT_timespec)) } },
 411  { TARGET_SIOCGSTAMP_NEW, TARGET_SIOCGSTAMP_NEW,
 412    "SIOCGSTAMP_NEW", IOC_R, do_ioctl_SIOCGSTAMP,
 413    { MK_PTR(MK_STRUCT(STRUCT__kernel_sock_timeval)) } },
 414  { TARGET_SIOCGSTAMPNS_NEW, TARGET_SIOCGSTAMPNS_NEW,
 415    "SIOCGSTAMPNS_NEW", IOC_R, do_ioctl_SIOCGSTAMPNS,
 416    { MK_PTR(MK_STRUCT(STRUCT__kernel_timespec)) } },
 417
 418  IOCTL(RNDGETENTCNT, IOC_R, MK_PTR(TYPE_INT))
 419  IOCTL(RNDADDTOENTCNT, IOC_W, MK_PTR(TYPE_INT))
 420  IOCTL(RNDZAPENTCNT, 0, TYPE_NULL)
 421  IOCTL(RNDCLEARPOOL, 0, TYPE_NULL)
 422#ifdef RNDRESEEDCRNG
 423  IOCTL(RNDRESEEDCRNG, 0, TYPE_NULL)
 424#endif
 425
 426  IOCTL(CDROMPAUSE, 0, TYPE_NULL)
 427  IOCTL(CDROMSTART, 0, TYPE_NULL)
 428  IOCTL(CDROMSTOP, 0, TYPE_NULL)
 429  IOCTL(CDROMRESUME, 0, TYPE_NULL)
 430  IOCTL(CDROMEJECT, 0, TYPE_NULL)
 431  IOCTL(CDROMEJECT_SW, 0, TYPE_INT)
 432  IOCTL(CDROMCLOSETRAY, 0, TYPE_NULL)
 433  IOCTL(CDROMRESET, 0, TYPE_NULL)
 434  IOCTL(CDROMPLAYMSF, IOC_W, MK_PTR(TYPE_INT))
 435  IOCTL(CDROMPLAYTRKIND, IOC_W, MK_PTR(TYPE_INT))
 436  IOCTL(CDROMREADTOCHDR, IOC_R, MK_PTR(TYPE_INT))
 437  IOCTL(CDROMREADTOCENTRY, IOC_RW, MK_PTR(TYPE_INT))
 438  IOCTL(CDROMVOLCTRL, IOC_W, MK_PTR(TYPE_INT))
 439  IOCTL(CDROMSUBCHNL, IOC_RW, MK_PTR(TYPE_INT))
 440  /* XXX: incorrect (need specific handling) */
 441  IOCTL(CDROMREADAUDIO, IOC_W, MK_PTR(MK_STRUCT(STRUCT_cdrom_read_audio)))
 442  IOCTL(CDROMREADCOOKED, IOC_RW, MK_PTR(TYPE_INT))
 443  IOCTL(CDROMREADRAW, IOC_RW, MK_PTR(TYPE_INT))
 444  IOCTL(CDROMREADMODE1, IOC_RW, MK_PTR(TYPE_INT))
 445  IOCTL(CDROMREADMODE2, IOC_RW, MK_PTR(TYPE_INT))
 446  IOCTL(CDROMREADALL, IOC_RW, MK_PTR(TYPE_INT))
 447  IOCTL(CDROMMULTISESSION, IOC_RW, MK_PTR(TYPE_INT))
 448  IOCTL(CDROM_GET_UPC, IOC_R, MK_PTR(TYPE_INT))
 449  IOCTL(CDROMVOLREAD, IOC_R, MK_PTR(TYPE_INT))
 450  IOCTL(CDROMSEEK, IOC_W, MK_PTR(TYPE_INT))
 451  IOCTL(CDROMPLAYBLK, IOC_W, MK_PTR(TYPE_INT))
 452  IOCTL(CDROM_MEDIA_CHANGED, 0, TYPE_NULL)
 453  IOCTL(CDROM_SET_OPTIONS, 0, TYPE_INT)
 454  IOCTL(CDROM_CLEAR_OPTIONS, 0, TYPE_INT)
 455  IOCTL(CDROM_SELECT_SPEED, 0, TYPE_INT)
 456  IOCTL(CDROM_SELECT_DISC, 0, TYPE_INT)
 457  IOCTL(CDROM_DRIVE_STATUS, 0, TYPE_NULL)
 458  IOCTL(CDROM_DISC_STATUS, 0, TYPE_NULL)
 459  IOCTL(CDROMAUDIOBUFSIZ, 0, TYPE_INT)
 460
 461#if 0
 462  IOCTL(SNDCTL_COPR_HALT, IOC_RW, MK_PTR(TYPE_INT))
 463  IOCTL(SNDCTL_COPR_LOAD, IOC_RW, MK_PTR(TYPE_INT))
 464  IOCTL(SNDCTL_COPR_RCODE, IOC_RW, MK_PTR(TYPE_INT))
 465  IOCTL(SNDCTL_COPR_RCVMSG, IOC_R, MK_PTR(TYPE_INT))
 466  IOCTL(SNDCTL_COPR_RDATA, IOC_RW, MK_PTR(TYPE_INT))
 467  IOCTL(SNDCTL_COPR_RESET, 0, TYPE_NULL)
 468  IOCTL(SNDCTL_COPR_RUN, IOC_RW, MK_PTR(TYPE_INT))
 469  IOCTL(SNDCTL_COPR_SENDMSG, IOC_RW, MK_PTR(TYPE_INT))
 470  IOCTL(SNDCTL_COPR_WCODE, IOC_W, MK_PTR(TYPE_INT))
 471  IOCTL(SNDCTL_COPR_WDATA, IOC_W, MK_PTR(TYPE_INT))
 472#endif
 473  IOCTL(SNDCTL_DSP_CHANNELS, IOC_RW, MK_PTR(TYPE_INT))
 474  IOCTL(SNDCTL_DSP_GETBLKSIZE, IOC_RW, MK_PTR(TYPE_INT))
 475  IOCTL(SNDCTL_DSP_GETCAPS, IOC_R, MK_PTR(TYPE_INT))
 476  IOCTL(SNDCTL_DSP_GETFMTS, IOC_R, MK_PTR(TYPE_INT))
 477  IOCTL(SNDCTL_DSP_GETIPTR, IOC_R, MK_PTR(MK_STRUCT(STRUCT_count_info)))
 478  IOCTL(SNDCTL_DSP_GETOPTR, IOC_R, MK_PTR(MK_STRUCT(STRUCT_count_info)))
 479  IOCTL(SNDCTL_DSP_GETISPACE, IOC_R, MK_PTR(MK_STRUCT(STRUCT_audio_buf_info)))
 480  IOCTL(SNDCTL_DSP_GETOSPACE, IOC_R, MK_PTR(MK_STRUCT(STRUCT_audio_buf_info)))
 481  IOCTL(SNDCTL_DSP_GETTRIGGER, IOC_R, MK_PTR(TYPE_INT))
 482  IOCTL(SNDCTL_DSP_MAPINBUF, IOC_R, MK_PTR(MK_STRUCT(STRUCT_buffmem_desc)))
 483  IOCTL(SNDCTL_DSP_MAPOUTBUF, IOC_R, MK_PTR(MK_STRUCT(STRUCT_buffmem_desc)))
 484  IOCTL(SNDCTL_DSP_NONBLOCK, 0, TYPE_NULL)
 485  IOCTL(SNDCTL_DSP_POST, 0, TYPE_NULL)
 486  IOCTL(SNDCTL_DSP_RESET, 0, TYPE_NULL)
 487  IOCTL(SNDCTL_DSP_SETDUPLEX, 0, TYPE_NULL)
 488  IOCTL(SNDCTL_DSP_SETFMT, IOC_RW, MK_PTR(TYPE_INT))
 489  IOCTL(SNDCTL_DSP_SETFRAGMENT, IOC_RW, MK_PTR(TYPE_INT))
 490  IOCTL(SNDCTL_DSP_SETSYNCRO, 0, TYPE_NULL)
 491  IOCTL(SNDCTL_DSP_SETTRIGGER, IOC_W, MK_PTR(TYPE_INT))
 492  IOCTL(SNDCTL_DSP_SPEED, IOC_RW, MK_PTR(TYPE_INT))
 493  IOCTL(SNDCTL_DSP_STEREO, IOC_RW, MK_PTR(TYPE_INT))
 494  IOCTL(SNDCTL_DSP_SUBDIVIDE, IOC_RW, MK_PTR(TYPE_INT))
 495  IOCTL(SNDCTL_DSP_SYNC, 0, TYPE_NULL)
 496#if 0
 497  IOCTL(SNDCTL_FM_4OP_ENABLE, IOC_W, MK_PTR(TYPE_INT))
 498  IOCTL(SNDCTL_FM_LOAD_INSTR, IOC_W, MK_PTR(TYPE_INT))
 499  IOCTL(SNDCTL_MIDI_INFO, IOC_RW, MK_PTR(TYPE_INT))
 500  IOCTL(SNDCTL_MIDI_MPUCMD, IOC_RW, MK_PTR(TYPE_INT))
 501  IOCTL(SNDCTL_MIDI_MPUMODE, IOC_RW, MK_PTR(TYPE_INT))
 502  IOCTL(SNDCTL_MIDI_PRETIME, IOC_RW, MK_PTR(TYPE_INT))
 503  IOCTL(SNDCTL_SEQ_CTRLRATE, IOC_RW, MK_PTR(TYPE_INT))
 504  IOCTL(SNDCTL_SEQ_GETINCOUNT, IOC_R, MK_PTR(TYPE_INT))
 505  IOCTL(SNDCTL_SEQ_GETOUTCOUNT, IOC_R, MK_PTR(TYPE_INT))
 506  IOCTL(SNDCTL_SEQ_NRMIDIS, IOC_R, MK_PTR(TYPE_INT))
 507  IOCTL(SNDCTL_SEQ_NRSYNTHS, IOC_R, MK_PTR(TYPE_INT))
 508  IOCTL(SNDCTL_SEQ_OUTOFBAND, IOC_W, MK_PTR(TYPE_INT))
 509  IOCTL(SNDCTL_SEQ_PANIC, 0, TYPE_NULL)
 510  IOCTL(SNDCTL_SEQ_PERCMODE, IOC_W, MK_PTR(TYPE_INT))
 511  IOCTL(SNDCTL_SEQ_RESET, 0, TYPE_NULL)
 512  IOCTL(SNDCTL_SEQ_RESETSAMPLES, IOC_W, MK_PTR(TYPE_INT))
 513  IOCTL(SNDCTL_SEQ_SYNC, 0, TYPE_NULL)
 514  IOCTL(SNDCTL_SEQ_TESTMIDI, IOC_W, MK_PTR(TYPE_INT))
 515  IOCTL(SNDCTL_SEQ_THRESHOLD, IOC_W, MK_PTR(TYPE_INT))
 516  IOCTL(SNDCTL_SYNTH_INFO, IOC_RW, MK_PTR(TYPE_INT))
 517  IOCTL(SNDCTL_SYNTH_MEMAVL, IOC_RW, MK_PTR(TYPE_INT))
 518  IOCTL(SNDCTL_TMR_CONTINUE, 0, TYPE_NULL)
 519  IOCTL(SNDCTL_TMR_METRONOME, IOC_W, MK_PTR(TYPE_INT))
 520  IOCTL(SNDCTL_TMR_SELECT, IOC_W, MK_PTR(TYPE_INT))
 521  IOCTL(SNDCTL_TMR_SOURCE, IOC_RW, MK_PTR(TYPE_INT))
 522#if 0
 523     /* we invalidate these defines because they have a same number as
 524        termios ioctls */
 525  IOCTL(SNDCTL_TMR_START, 0, TYPE_NULL)
 526  IOCTL(SNDCTL_TMR_STOP, 0, TYPE_NULL)
 527#endif
 528  IOCTL(SNDCTL_TMR_TEMPO, IOC_RW, MK_PTR(TYPE_INT))
 529  IOCTL(SNDCTL_TMR_TIMEBASE, IOC_RW, MK_PTR(TYPE_INT))
 530
 531  IOCTL(SOUND_PCM_WRITE_FILTER, IOC_W | IOC_R, MK_PTR(TYPE_INT))
 532  IOCTL(SOUND_PCM_READ_RATE, IOC_R, MK_PTR(TYPE_INT))
 533  IOCTL(SOUND_PCM_READ_CHANNELS, IOC_R, MK_PTR(TYPE_INT))
 534  IOCTL(SOUND_PCM_READ_BITS, IOC_R, MK_PTR(TYPE_INT))
 535  IOCTL(SOUND_PCM_READ_FILTER, IOC_R, MK_PTR(TYPE_INT))
 536#endif
 537  IOCTL(SOUND_MIXER_INFO, IOC_R, MK_PTR(TYPE_INT))
 538  IOCTL(SOUND_MIXER_ACCESS, 0, TYPE_PTRVOID)
 539  IOCTL(SOUND_MIXER_PRIVATE1, IOC_RW, MK_PTR(TYPE_INT))
 540  IOCTL(SOUND_MIXER_PRIVATE2, IOC_RW, MK_PTR(TYPE_INT))
 541  IOCTL(SOUND_MIXER_PRIVATE3, IOC_RW, MK_PTR(TYPE_INT))
 542  IOCTL(SOUND_MIXER_PRIVATE4, IOC_RW, MK_PTR(TYPE_INT))
 543  IOCTL(SOUND_MIXER_PRIVATE5, IOC_RW, MK_PTR(TYPE_INT))
 544  IOCTL(SOUND_MIXER_READ_VOLUME, IOC_R, MK_PTR(TYPE_INT))
 545  IOCTL(SOUND_MIXER_READ_BASS, IOC_R, MK_PTR(TYPE_INT))
 546  IOCTL(SOUND_MIXER_READ_TREBLE, IOC_R, MK_PTR(TYPE_INT))
 547  IOCTL(SOUND_MIXER_READ_SYNTH, IOC_R, MK_PTR(TYPE_INT))
 548  IOCTL(SOUND_MIXER_READ_PCM, IOC_R, MK_PTR(TYPE_INT))
 549  IOCTL(SOUND_MIXER_READ_SPEAKER, IOC_R, MK_PTR(TYPE_INT))
 550  IOCTL(SOUND_MIXER_READ_LINE, IOC_R, MK_PTR(TYPE_INT))
 551  IOCTL(SOUND_MIXER_READ_MIC, IOC_R, MK_PTR(TYPE_INT))
 552  IOCTL(SOUND_MIXER_READ_CD, IOC_R, MK_PTR(TYPE_INT))
 553  IOCTL(SOUND_MIXER_READ_IMIX, IOC_R, MK_PTR(TYPE_INT))
 554  IOCTL(SOUND_MIXER_READ_ALTPCM, IOC_R, MK_PTR(TYPE_INT))
 555  IOCTL(SOUND_MIXER_READ_RECLEV, IOC_R, MK_PTR(TYPE_INT))
 556  IOCTL(SOUND_MIXER_READ_IGAIN, IOC_R, MK_PTR(TYPE_INT))
 557  IOCTL(SOUND_MIXER_READ_OGAIN, IOC_R, MK_PTR(TYPE_INT))
 558  IOCTL(SOUND_MIXER_READ_LINE1, IOC_R, MK_PTR(TYPE_INT))
 559  IOCTL(SOUND_MIXER_READ_LINE2, IOC_R, MK_PTR(TYPE_INT))
 560  IOCTL(SOUND_MIXER_READ_LINE3, IOC_R, MK_PTR(TYPE_INT))
 561  IOCTL(SOUND_MIXER_READ_MUTE, IOC_R, MK_PTR(TYPE_INT))
 562  IOCTL(SOUND_MIXER_READ_ENHANCE, IOC_R, MK_PTR(TYPE_INT))
 563  IOCTL(SOUND_MIXER_READ_LOUD, IOC_R, MK_PTR(TYPE_INT))
 564  IOCTL(SOUND_MIXER_READ_RECSRC, IOC_R, MK_PTR(TYPE_INT))
 565  IOCTL(SOUND_MIXER_READ_DEVMASK, IOC_R, MK_PTR(TYPE_INT))
 566  IOCTL(SOUND_MIXER_READ_RECMASK, IOC_R, MK_PTR(TYPE_INT))
 567  IOCTL(SOUND_MIXER_READ_STEREODEVS, IOC_R, MK_PTR(TYPE_INT))
 568  IOCTL(SOUND_MIXER_READ_CAPS, IOC_R, MK_PTR(TYPE_INT))
 569
 570  IOCTL(SOUND_MIXER_WRITE_VOLUME, IOC_W, MK_PTR(TYPE_INT))
 571  IOCTL(SOUND_MIXER_WRITE_BASS, IOC_W, MK_PTR(TYPE_INT))
 572  IOCTL(SOUND_MIXER_WRITE_TREBLE, IOC_W, MK_PTR(TYPE_INT))
 573  IOCTL(SOUND_MIXER_WRITE_SYNTH, IOC_W, MK_PTR(TYPE_INT))
 574  IOCTL(SOUND_MIXER_WRITE_PCM, IOC_W, MK_PTR(TYPE_INT))
 575  IOCTL(SOUND_MIXER_WRITE_SPEAKER, IOC_W, MK_PTR(TYPE_INT))
 576  IOCTL(SOUND_MIXER_WRITE_LINE, IOC_W, MK_PTR(TYPE_INT))
 577  IOCTL(SOUND_MIXER_WRITE_MIC, IOC_W, MK_PTR(TYPE_INT))
 578  IOCTL(SOUND_MIXER_WRITE_CD, IOC_W, MK_PTR(TYPE_INT))
 579  IOCTL(SOUND_MIXER_WRITE_IMIX, IOC_W, MK_PTR(TYPE_INT))
 580  IOCTL(SOUND_MIXER_WRITE_ALTPCM, IOC_W, MK_PTR(TYPE_INT))
 581  IOCTL(SOUND_MIXER_WRITE_RECLEV, IOC_W, MK_PTR(TYPE_INT))
 582  IOCTL(SOUND_MIXER_WRITE_IGAIN, IOC_W, MK_PTR(TYPE_INT))
 583  IOCTL(SOUND_MIXER_WRITE_OGAIN, IOC_W, MK_PTR(TYPE_INT))
 584  IOCTL(SOUND_MIXER_WRITE_LINE1, IOC_W, MK_PTR(TYPE_INT))
 585  IOCTL(SOUND_MIXER_WRITE_LINE2, IOC_W, MK_PTR(TYPE_INT))
 586  IOCTL(SOUND_MIXER_WRITE_LINE3, IOC_W, MK_PTR(TYPE_INT))
 587  IOCTL(SOUND_MIXER_WRITE_MUTE, IOC_W, MK_PTR(TYPE_INT))
 588  IOCTL(SOUND_MIXER_WRITE_ENHANCE, IOC_W, MK_PTR(TYPE_INT))
 589  IOCTL(SOUND_MIXER_WRITE_LOUD, IOC_W, MK_PTR(TYPE_INT))
 590  IOCTL(SOUND_MIXER_WRITE_RECSRC, IOC_W, MK_PTR(TYPE_INT))
 591
 592  IOCTL(SNDRV_TIMER_IOCTL_PVERSION, IOC_R, MK_PTR(TYPE_INT))
 593  IOCTL(SNDRV_TIMER_IOCTL_NEXT_DEVICE, IOC_RW,
 594        MK_PTR(MK_STRUCT(STRUCT_snd_timer_id)))
 595  IOCTL(SNDRV_TIMER_IOCTL_GINFO, IOC_RW,
 596        MK_PTR(MK_STRUCT(STRUCT_snd_timer_ginfo)))
 597  IOCTL(SNDRV_TIMER_IOCTL_GPARAMS, IOC_W,
 598        MK_PTR(MK_STRUCT(STRUCT_snd_timer_gparams)))
 599  IOCTL(SNDRV_TIMER_IOCTL_GSTATUS, IOC_RW,
 600        MK_PTR(MK_STRUCT(STRUCT_snd_timer_gstatus)))
 601  IOCTL(SNDRV_TIMER_IOCTL_SELECT, IOC_W,
 602        MK_PTR(MK_STRUCT(STRUCT_snd_timer_select)))
 603  IOCTL(SNDRV_TIMER_IOCTL_INFO, IOC_R, MK_PTR(MK_STRUCT(STRUCT_snd_timer_info)))
 604  IOCTL(SNDRV_TIMER_IOCTL_PARAMS, IOC_W,
 605        MK_PTR(MK_STRUCT(STRUCT_snd_timer_params)))
 606  IOCTL(SNDRV_TIMER_IOCTL_STATUS, IOC_R,
 607        MK_PTR(MK_STRUCT(STRUCT_snd_timer_status)))
 608  IOCTL(SNDRV_TIMER_IOCTL_START, 0, TYPE_NULL)
 609  IOCTL(SNDRV_TIMER_IOCTL_STOP, 0, TYPE_NULL)
 610  IOCTL(SNDRV_TIMER_IOCTL_CONTINUE, 0, TYPE_NULL)
 611  IOCTL(SNDRV_TIMER_IOCTL_PAUSE, 0, TYPE_NULL)
 612
 613  IOCTL(HDIO_GETGEO, IOC_R, MK_PTR(MK_STRUCT(STRUCT_hd_geometry)))
 614  IOCTL(HDIO_GET_UNMASKINTR, IOC_R, MK_PTR(TYPE_INT))
 615  IOCTL(HDIO_GET_MULTCOUNT, IOC_R, MK_PTR(TYPE_INT))
 616  IOCTL(HDIO_GET_IDENTITY, IOC_R, MK_PTR(TYPE_INT))
 617  IOCTL(HDIO_GET_KEEPSETTINGS, IOC_R, MK_PTR(TYPE_INT))
 618  IOCTL(HDIO_GET_NOWERR, IOC_R, MK_PTR(TYPE_INT))
 619  IOCTL(HDIO_GET_DMA, IOC_R, MK_PTR(TYPE_INT))
 620  IOCTL(HDIO_GET_32BIT, IOC_R, MK_PTR(TYPE_INT))
 621  IOCTL(HDIO_DRIVE_CMD, IOC_R, MK_PTR(TYPE_INT))
 622  IOCTL(HDIO_SET_UNMASKINTR, 0, TYPE_INT)
 623  IOCTL(HDIO_SET_MULTCOUNT, 0, TYPE_INT)
 624  IOCTL(HDIO_SET_KEEPSETTINGS, 0, TYPE_INT)
 625  IOCTL(HDIO_SET_NOWERR, 0, TYPE_INT)
 626  IOCTL(HDIO_SET_DMA, 0, TYPE_INT)
 627  IOCTL(HDIO_SET_32BIT, 0, TYPE_INT)
 628  IOCTL(HDIO_SET_PIO_MODE, 0, TYPE_INT)
 629
 630  IOCTL(VFAT_IOCTL_READDIR_BOTH, IOC_R, MK_PTR(MK_ARRAY(MK_STRUCT(STRUCT_dirent), 2)))
 631  IOCTL(VFAT_IOCTL_READDIR_SHORT, IOC_R, MK_PTR(MK_ARRAY(MK_STRUCT(STRUCT_dirent), 2)))
 632
 633  IOCTL(LOOP_SET_FD, 0, TYPE_INT)
 634  IOCTL(LOOP_CLR_FD, 0, TYPE_INT)
 635  IOCTL(LOOP_SET_STATUS, IOC_W, MK_PTR(MK_STRUCT(STRUCT_loop_info)))
 636  IOCTL(LOOP_GET_STATUS, IOC_R, MK_PTR(MK_STRUCT(STRUCT_loop_info)))
 637  IOCTL(LOOP_SET_STATUS64, IOC_W, MK_PTR(MK_STRUCT(STRUCT_loop_info64)))
 638  IOCTL(LOOP_GET_STATUS64, IOC_R, MK_PTR(MK_STRUCT(STRUCT_loop_info64)))
 639  IOCTL(LOOP_CHANGE_FD, 0, TYPE_INT)
 640  IOCTL(LOOP_SET_CAPACITY, 0, TYPE_INT)
 641  IOCTL(LOOP_SET_DIRECT_IO, 0, TYPE_INT)
 642  IOCTL(LOOP_SET_BLOCK_SIZE, 0, TYPE_INT)
 643  IOCTL(LOOP_CONFIGURE, IOC_W, MK_PTR(MK_STRUCT(STRUCT_loop_config)))
 644
 645  IOCTL(LOOP_CTL_ADD, 0, TYPE_INT)
 646  IOCTL(LOOP_CTL_REMOVE, 0, TYPE_INT)
 647  IOCTL(LOOP_CTL_GET_FREE, 0, TYPE_NULL)
 648
 649  IOCTL(MTIOCTOP, IOC_W, MK_PTR(MK_STRUCT(STRUCT_mtop)))
 650  IOCTL(MTIOCGET, IOC_R, MK_PTR(MK_STRUCT(STRUCT_mtget)))
 651  IOCTL(MTIOCPOS, IOC_R, MK_PTR(MK_STRUCT(STRUCT_mtpos)))
 652
 653  IOCTL(FBIOGET_FSCREENINFO, IOC_R, MK_PTR(MK_STRUCT(STRUCT_fb_fix_screeninfo)))
 654  IOCTL(FBIOGET_VSCREENINFO, IOC_R, MK_PTR(MK_STRUCT(STRUCT_fb_var_screeninfo)))
 655  IOCTL(FBIOPUT_VSCREENINFO, IOC_W, MK_PTR(MK_STRUCT(STRUCT_fb_var_screeninfo)))
 656  IOCTL(FBIOGETCMAP,        IOC_RW, MK_PTR(MK_STRUCT(STRUCT_fb_cmap)))
 657  IOCTL(FBIOPUTCMAP,        IOC_RW, MK_PTR(MK_STRUCT(STRUCT_fb_cmap)))
 658  IOCTL(FBIOPAN_DISPLAY,    IOC_RW, MK_PTR(MK_STRUCT(STRUCT_fb_var_screeninfo)))
 659  IOCTL(FBIOGET_CON2FBMAP,  IOC_RW, MK_PTR(MK_STRUCT(STRUCT_fb_con2fbmap)))
 660  IOCTL(FBIOPUT_CON2FBMAP,  IOC_RW, MK_PTR(MK_STRUCT(STRUCT_fb_con2fbmap)))
 661
 662  IOCTL(VT_OPENQRY, IOC_R, MK_PTR(TYPE_INT))
 663  IOCTL(VT_GETSTATE, IOC_R, MK_PTR(MK_STRUCT(STRUCT_vt_stat)))
 664  IOCTL(VT_ACTIVATE, 0, TYPE_INT)
 665  IOCTL(VT_WAITACTIVE, 0, TYPE_INT)
 666  IOCTL(VT_LOCKSWITCH, 0, TYPE_INT)
 667  IOCTL(VT_UNLOCKSWITCH, 0, TYPE_INT)
 668  IOCTL(VT_GETMODE, IOC_RW, MK_PTR(MK_STRUCT(STRUCT_vt_mode)))
 669  IOCTL(VT_SETMODE, IOC_RW, MK_PTR(MK_STRUCT(STRUCT_vt_mode)))
 670  IOCTL(VT_RELDISP, 0, TYPE_INT)
 671  IOCTL(VT_DISALLOCATE, 0, TYPE_INT)
 672
 673  IOCTL(DM_VERSION, IOC_RW, MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 674  IOCTL_SPECIAL(DM_REMOVE_ALL,   IOC_RW, do_ioctl_dm,
 675                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 676  IOCTL_SPECIAL(DM_LIST_DEVICES, IOC_RW, do_ioctl_dm,
 677                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 678  IOCTL_SPECIAL(DM_DEV_CREATE,   IOC_RW, do_ioctl_dm,
 679                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 680  IOCTL_SPECIAL(DM_DEV_REMOVE,   IOC_RW, do_ioctl_dm,
 681                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 682  IOCTL_SPECIAL(DM_DEV_RENAME,   IOC_RW, do_ioctl_dm,
 683                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 684  IOCTL_SPECIAL(DM_DEV_SUSPEND,  IOC_RW, do_ioctl_dm,
 685                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 686  IOCTL_SPECIAL(DM_DEV_STATUS,   IOC_RW, do_ioctl_dm,
 687                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 688  IOCTL_SPECIAL(DM_DEV_WAIT,     IOC_RW, do_ioctl_dm,
 689                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 690  IOCTL_SPECIAL(DM_TABLE_LOAD,   IOC_RW, do_ioctl_dm,
 691                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 692  IOCTL_SPECIAL(DM_TABLE_CLEAR,  IOC_RW, do_ioctl_dm,
 693                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 694  IOCTL_SPECIAL(DM_TABLE_DEPS,   IOC_RW, do_ioctl_dm,
 695                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 696  IOCTL_SPECIAL(DM_TABLE_STATUS, IOC_RW, do_ioctl_dm,
 697                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 698  IOCTL_SPECIAL(DM_LIST_VERSIONS,IOC_RW, do_ioctl_dm,
 699                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 700  IOCTL_SPECIAL(DM_TARGET_MSG,   IOC_RW, do_ioctl_dm,
 701                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 702  IOCTL_SPECIAL(DM_DEV_SET_GEOMETRY, IOC_RW, do_ioctl_dm,
 703                MK_PTR(MK_STRUCT(STRUCT_dm_ioctl)))
 704  IOCTL_SPECIAL(SIOCADDRT, IOC_W, do_ioctl_rt,
 705                MK_PTR(MK_STRUCT(STRUCT_rtentry)))
 706  IOCTL_SPECIAL(SIOCDELRT, IOC_W, do_ioctl_rt,
 707                MK_PTR(MK_STRUCT(STRUCT_rtentry)))
 708
 709#ifdef HAVE_DRM_H
 710  IOCTL_SPECIAL(DRM_IOCTL_VERSION, IOC_RW, do_ioctl_drm,
 711                MK_PTR(MK_STRUCT(STRUCT_drm_version)))
 712
 713  IOCTL_SPECIAL(DRM_IOCTL_I915_GETPARAM, IOC_RW, do_ioctl_drm_i915,
 714                MK_PTR(MK_STRUCT(STRUCT_drm_i915_getparam)))
 715#endif
 716
 717#ifdef TARGET_TIOCSTART
 718  IOCTL_IGNORE(TIOCSTART)
 719  IOCTL_IGNORE(TIOCSTOP)
 720#endif
 721
 722#ifdef HAVE_SYS_KCOV_H
 723  IOCTL(KCOV_ENABLE, 0, TYPE_NULL)
 724  IOCTL(KCOV_DISABLE, 0, TYPE_NULL)
 725  IOCTL(KCOV_INIT_TRACE, IOC_R, TYPE_ULONG)
 726#endif
 727
 728  IOCTL(TUNSETDEBUG,     IOC_W, TYPE_INT)
 729  IOCTL(TUNSETIFF,       IOC_RW, MK_PTR(MK_STRUCT(STRUCT_short_ifreq)))
 730  IOCTL(TUNSETPERSIST,   IOC_W, TYPE_INT)
 731  IOCTL(TUNSETOWNER,     IOC_W, TYPE_INT)
 732  IOCTL(TUNSETLINK,      IOC_W, TYPE_INT)
 733  IOCTL(TUNSETGROUP,     IOC_W, TYPE_INT)
 734  IOCTL(TUNGETFEATURES,  IOC_R, MK_PTR(TYPE_INT))
 735  IOCTL(TUNSETOFFLOAD,   IOC_W, TYPE_LONG)
 736  IOCTL_SPECIAL(TUNSETTXFILTER, IOC_W, do_ioctl_TUNSETTXFILTER,
 737                /*
 738                 * We can't represent `struct tun_filter` in thunk so leaving
 739                 * it uninterpreted. do_ioctl_TUNSETTXFILTER will do the
 740                 * conversion.
 741                 */
 742                TYPE_PTRVOID)
 743  IOCTL(TUNGETIFF,       IOC_R, MK_PTR(MK_STRUCT(STRUCT_short_ifreq)))
 744  IOCTL(TUNGETSNDBUF,    IOC_R, MK_PTR(TYPE_INT))
 745  IOCTL(TUNSETSNDBUF,    IOC_W, MK_PTR(TYPE_INT))
 746  /*
 747   * TUNATTACHFILTER and TUNDETACHFILTER are not supported. Linux kernel keeps a
 748   * user pointer in TUNATTACHFILTER, which we are not able to correctly handle.
 749   */
 750  IOCTL(TUNGETVNETHDRSZ, IOC_R, MK_PTR(TYPE_INT))
 751  IOCTL(TUNSETVNETHDRSZ, IOC_W, MK_PTR(TYPE_INT))
 752  IOCTL(TUNSETQUEUE,     IOC_W, MK_PTR(MK_STRUCT(STRUCT_short_ifreq)))
 753  IOCTL(TUNSETIFINDEX ,  IOC_W, MK_PTR(TYPE_INT))
 754  /* TUNGETFILTER is not supported: see TUNATTACHFILTER. */
 755#ifdef TUNSETVNETLE
 756  IOCTL(TUNSETVNETLE,    IOC_W, MK_PTR(TYPE_INT))
 757  IOCTL(TUNGETVNETLE,    IOC_R, MK_PTR(TYPE_INT))
 758#endif
 759#ifdef TUNSETVNETBE
 760  IOCTL(TUNSETVNETBE,    IOC_W, MK_PTR(TYPE_INT))
 761  IOCTL(TUNGETVNETBE,    IOC_R, MK_PTR(TYPE_INT))
 762#endif
 763#ifdef TUNSETSTEERINGEBPF
 764  IOCTL(TUNSETSTEERINGEBPF, IOC_W, MK_PTR(TYPE_INT))
 765#endif
 766#ifdef TUNSETFILTEREBPF
 767  IOCTL(TUNSETFILTEREBPF, IOC_W, MK_PTR(TYPE_INT))
 768#endif
 769#ifdef TUNSETCARRIER
 770  IOCTL(TUNSETCARRIER,   IOC_W, MK_PTR(TYPE_INT))
 771#endif
 772#ifdef TUNGETDEVNETNS
 773  IOCTL(TUNGETDEVNETNS,  IOC_R, TYPE_NULL)
 774#endif
 775