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