ioctls.h 33 KB

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