]> git.ipfire.org Git - thirdparty/qemu.git/blame - linux-user/syscall_types.h
linux-user: Add support for getting/setting specified alsa timer parameters using...
[thirdparty/qemu.git] / linux-user / syscall_types.h
CommitLineData
31e31b8a
FB
1STRUCT_SPECIAL(termios)
2
3STRUCT(winsize,
4 TYPE_SHORT, TYPE_SHORT, TYPE_SHORT, TYPE_SHORT)
5
6STRUCT(serial_multiport_struct,
7 TYPE_INT, TYPE_INT, TYPE_CHAR, TYPE_CHAR, TYPE_INT, TYPE_CHAR, TYPE_CHAR,
5fafdf24 8 TYPE_INT, TYPE_CHAR, TYPE_CHAR, TYPE_INT, TYPE_CHAR, TYPE_CHAR, TYPE_INT,
31e31b8a
FB
9 MK_ARRAY(TYPE_INT, 32))
10
11STRUCT(serial_icounter_struct,
12 TYPE_INT, TYPE_INT, TYPE_INT, TYPE_INT, MK_ARRAY(TYPE_INT, 16))
13
14STRUCT(sockaddr,
15 TYPE_SHORT, MK_ARRAY(TYPE_CHAR, 14))
16
17STRUCT(rtentry,
5fafdf24
TS
18 TYPE_ULONG, MK_STRUCT(STRUCT_sockaddr), MK_STRUCT(STRUCT_sockaddr), MK_STRUCT(STRUCT_sockaddr),
19 TYPE_SHORT, TYPE_SHORT, TYPE_ULONG, TYPE_PTRVOID, TYPE_SHORT, TYPE_PTRVOID,
31e31b8a
FB
20 TYPE_ULONG, TYPE_ULONG, TYPE_SHORT)
21
22STRUCT(ifmap,
5fafdf24 23 TYPE_ULONG, TYPE_ULONG, TYPE_SHORT, TYPE_CHAR, TYPE_CHAR, TYPE_CHAR,
31e31b8a
FB
24 /* Spare 3 bytes */
25 TYPE_CHAR, TYPE_CHAR, TYPE_CHAR)
26
27/* The *_ifreq_list arrays deal with the fact that struct ifreq has unions */
28
29STRUCT(sockaddr_ifreq,
30 MK_ARRAY(TYPE_CHAR, IFNAMSIZ), MK_STRUCT(STRUCT_sockaddr))
3b46e624 31
31e31b8a
FB
32STRUCT(short_ifreq,
33 MK_ARRAY(TYPE_CHAR, IFNAMSIZ), TYPE_SHORT)
34
35STRUCT(int_ifreq,
36 MK_ARRAY(TYPE_CHAR, IFNAMSIZ), TYPE_INT)
37
38STRUCT(ifmap_ifreq,
39 MK_ARRAY(TYPE_CHAR, IFNAMSIZ), MK_STRUCT(STRUCT_ifmap))
40
41STRUCT(char_ifreq,
42 MK_ARRAY(TYPE_CHAR, IFNAMSIZ),
43 MK_ARRAY(TYPE_CHAR, IFNAMSIZ))
44
45STRUCT(ptr_ifreq,
46 MK_ARRAY(TYPE_CHAR, IFNAMSIZ), TYPE_PTRVOID)
47
48STRUCT(ifconf,
49 TYPE_INT, TYPE_PTRVOID)
50
51STRUCT(arpreq,
5fafdf24 52 MK_STRUCT(STRUCT_sockaddr), MK_STRUCT(STRUCT_sockaddr), TYPE_INT, MK_STRUCT(STRUCT_sockaddr),
31e31b8a
FB
53 MK_ARRAY(TYPE_CHAR, 16))
54
55STRUCT(arpreq_old,
56 MK_STRUCT(STRUCT_sockaddr), MK_STRUCT(STRUCT_sockaddr), TYPE_INT, MK_STRUCT(STRUCT_sockaddr))
57
58STRUCT(cdrom_read_audio,
59 TYPE_CHAR, TYPE_CHAR, TYPE_CHAR, TYPE_CHAR, TYPE_CHAR, TYPE_INT, TYPE_PTRVOID,
60 TYPE_NULL)
61
62STRUCT(hd_geometry,
63 TYPE_CHAR, TYPE_CHAR, TYPE_SHORT, TYPE_ULONG)
1a9353d2
FB
64
65STRUCT(dirent,
66 TYPE_LONG, TYPE_LONG, TYPE_SHORT, MK_ARRAY(TYPE_CHAR, 256))
0221cfcd
FB
67
68STRUCT(kbentry,
69 TYPE_CHAR, TYPE_CHAR, TYPE_SHORT)
2521d698 70
53a5960a
PB
71STRUCT(kbsentry,
72 TYPE_CHAR, MK_ARRAY(TYPE_CHAR, 512))
73
2521d698
FB
74STRUCT(audio_buf_info,
75 TYPE_INT, TYPE_INT, TYPE_INT, TYPE_INT)
76
77STRUCT(count_info,
78 TYPE_INT, TYPE_INT, TYPE_INT)
79
5f72307d
PM
80STRUCT(buffmem_desc,
81 TYPE_PTRVOID, TYPE_INT)
82
2521d698
FB
83STRUCT(mixer_info,
84 MK_ARRAY(TYPE_CHAR, 16), MK_ARRAY(TYPE_CHAR, 32), TYPE_INT, MK_ARRAY(TYPE_INT, 10))
b8005914 85
1c4c6fcd
FB
86STRUCT(snd_timer_id,
87 TYPE_INT, /* dev_class */
88 TYPE_INT, /* dev_sclass */
89 TYPE_INT, /* card */
90 TYPE_INT, /* device */
91 TYPE_INT) /* subdevice */
92
aca7708e
FB
93STRUCT(snd_timer_ginfo,
94 MK_STRUCT(STRUCT_snd_timer_id), /* tid */
95 TYPE_INT, /* flags */
96 TYPE_INT, /* card */
97 MK_ARRAY(TYPE_CHAR, 64), /* id */
98 MK_ARRAY(TYPE_CHAR, 80), /* name */
99 TYPE_ULONG, /* reserved0 */
100 TYPE_ULONG, /* resolution */
101 TYPE_ULONG, /* resolution_min */
102 TYPE_ULONG, /* resolution_max */
103 TYPE_INT, /* clients */
104 MK_ARRAY(TYPE_CHAR, 32)) /* reserved */
105
106STRUCT(snd_timer_gparams,
107 MK_STRUCT(STRUCT_snd_timer_id), /* tid */
108 TYPE_ULONG, /* period_num */
109 TYPE_ULONG, /* period_den */
110 MK_ARRAY(TYPE_CHAR, 32)) /* reserved */
111
112STRUCT(snd_timer_gstatus,
113 MK_STRUCT(STRUCT_snd_timer_id), /* tid */
114 TYPE_ULONG, /* resolution */
115 TYPE_ULONG, /* resolution_num */
116 TYPE_ULONG, /* resolution_den */
117 MK_ARRAY(TYPE_CHAR, 32)) /* reserved */
118
b8005914
AZ
119/* loop device ioctls */
120STRUCT(loop_info,
121 TYPE_INT, /* lo_number */
6083abd9 122 TYPE_OLDDEVT, /* lo_device */
b8005914 123 TYPE_ULONG, /* lo_inode */
6083abd9 124 TYPE_OLDDEVT, /* lo_rdevice */
b8005914
AZ
125 TYPE_INT, /* lo_offset */
126 TYPE_INT, /* lo_encrypt_type */
127 TYPE_INT, /* lo_encrypt_key_size */
128 TYPE_INT, /* lo_flags */
129 MK_ARRAY(TYPE_CHAR, 64), /* lo_name */
130 MK_ARRAY(TYPE_CHAR, 32), /* lo_encrypt_key */
131 MK_ARRAY(TYPE_ULONG, 2), /* lo_init */
132 MK_ARRAY(TYPE_CHAR, 4)) /* reserved */
133
134STRUCT(loop_info64,
135 TYPE_ULONGLONG, /* lo_device */
136 TYPE_ULONGLONG, /* lo_inode */
137 TYPE_ULONGLONG, /* lo_rdevice */
138 TYPE_ULONGLONG, /* lo_offset */
f2c2fb50
PM
139 TYPE_ULONGLONG, /* lo_sizelimit */
140 TYPE_INT, /* lo_number */
141 TYPE_INT, /* lo_encrypt_type */
142 TYPE_INT, /* lo_encrypt_key_size */
143 TYPE_INT, /* lo_flags */
b8005914
AZ
144 MK_ARRAY(TYPE_CHAR, 64), /* lo_name */
145 MK_ARRAY(TYPE_CHAR, 64), /* lo_crypt_name */
146 MK_ARRAY(TYPE_CHAR, 32), /* lo_encrypt_key */
147 MK_ARRAY(TYPE_ULONGLONG, 2)) /* lo_init */
8fbd6b52
AZ
148
149/* mag tape ioctls */
150STRUCT(mtop, TYPE_SHORT, TYPE_INT)
151STRUCT(mtget, TYPE_LONG, TYPE_LONG, TYPE_LONG, TYPE_LONG, TYPE_LONG,
152 TYPE_INT, TYPE_INT)
153STRUCT(mtpos, TYPE_LONG)
f7680a55
UH
154
155STRUCT(fb_fix_screeninfo,
156 MK_ARRAY(TYPE_CHAR, 16), /* id */
157 TYPE_ULONG, /* smem_start */
158 TYPE_INT, /* smem_len */
159 TYPE_INT, /* type */
160 TYPE_INT, /* type_aux */
161 TYPE_INT, /* visual */
162 TYPE_SHORT, /* xpanstep */
163 TYPE_SHORT, /* ypanstep */
164 TYPE_SHORT, /* ywrapstep */
165 TYPE_INT, /* line_length */
166 TYPE_ULONG, /* mmio_start */
167 TYPE_INT, /* mmio_len */
168 TYPE_INT, /* accel */
169 MK_ARRAY(TYPE_CHAR, 3)) /* reserved */
170
171STRUCT(fb_var_screeninfo,
172 TYPE_INT, /* xres */
173 TYPE_INT, /* yres */
174 TYPE_INT, /* xres_virtual */
175 TYPE_INT, /* yres_virtual */
176 TYPE_INT, /* xoffset */
177 TYPE_INT, /* yoffset */
178 TYPE_INT, /* bits_per_pixel */
179 TYPE_INT, /* grayscale */
180 MK_ARRAY(TYPE_INT, 3), /* red */
181 MK_ARRAY(TYPE_INT, 3), /* green */
182 MK_ARRAY(TYPE_INT, 3), /* blue */
183 MK_ARRAY(TYPE_INT, 3), /* transp */
184 TYPE_INT, /* nonstd */
185 TYPE_INT, /* activate */
186 TYPE_INT, /* height */
187 TYPE_INT, /* width */
188 TYPE_INT, /* accel_flags */
189 TYPE_INT, /* pixclock */
190 TYPE_INT, /* left_margin */
191 TYPE_INT, /* right_margin */
192 TYPE_INT, /* upper_margin */
193 TYPE_INT, /* lower_margin */
194 TYPE_INT, /* hsync_len */
195 TYPE_INT, /* vsync_len */
196 TYPE_INT, /* sync */
197 TYPE_INT, /* vmode */
198 TYPE_INT, /* rotate */
199 MK_ARRAY(TYPE_INT, 5)) /* reserved */
200
12b81b71
CV
201STRUCT(fb_cmap,
202 TYPE_INT, /* start */
203 TYPE_INT, /* len */
204 TYPE_PTRVOID, /* red */
205 TYPE_PTRVOID, /* green */
206 TYPE_PTRVOID, /* blue */
207 TYPE_PTRVOID) /* transp */
208
209STRUCT(fb_con2fbmap,
210 TYPE_INT, /* console */
211 TYPE_INT) /* framebuffer */
212
213
f7680a55
UH
214STRUCT(vt_stat,
215 TYPE_SHORT, /* v_active */
216 TYPE_SHORT, /* v_signal */
217 TYPE_SHORT) /* v_state */
285da2b9 218
774750c0
CV
219STRUCT(vt_mode,
220 TYPE_CHAR, /* mode */
221 TYPE_CHAR, /* waitv */
222 TYPE_SHORT, /* relsig */
223 TYPE_SHORT, /* acqsig */
224 TYPE_SHORT) /* frsig */
225
56e904ec
AG
226STRUCT(dm_ioctl,
227 MK_ARRAY(TYPE_INT, 3), /* version */
228 TYPE_INT, /* data_size */
229 TYPE_INT, /* data_start */
230 TYPE_INT, /* target_count*/
231 TYPE_INT, /* open_count */
232 TYPE_INT, /* flags */
233 TYPE_INT, /* event_nr */
234 TYPE_INT, /* padding */
235 TYPE_ULONGLONG, /* dev */
236 MK_ARRAY(TYPE_CHAR, 128), /* name */
237 MK_ARRAY(TYPE_CHAR, 129), /* uuid */
238 MK_ARRAY(TYPE_CHAR, 7)) /* data */
239
240STRUCT(dm_target_spec,
241 TYPE_ULONGLONG, /* sector_start */
242 TYPE_ULONGLONG, /* length */
243 TYPE_INT, /* status */
244 TYPE_INT, /* next */
245 MK_ARRAY(TYPE_CHAR, 16)) /* target_type */
246
247STRUCT(dm_target_deps,
248 TYPE_INT, /* count */
249 TYPE_INT) /* padding */
250
251STRUCT(dm_name_list,
252 TYPE_ULONGLONG, /* dev */
253 TYPE_INT) /* next */
254
255STRUCT(dm_target_versions,
256 TYPE_INT, /* next */
257 MK_ARRAY(TYPE_INT, 3)) /* version*/
258
259STRUCT(dm_target_msg,
260 TYPE_ULONGLONG) /* sector */
261
21992cb6
HD
262STRUCT(file_clone_range,
263 TYPE_LONGLONG, /* src_fd */
264 TYPE_ULONGLONG, /* src_offset */
265 TYPE_ULONGLONG, /* src_length */
266 TYPE_ULONGLONG) /* dest_offset */
267
285da2b9
PM
268STRUCT(fiemap_extent,
269 TYPE_ULONGLONG, /* fe_logical */
270 TYPE_ULONGLONG, /* fe_physical */
271 TYPE_ULONGLONG, /* fe_length */
272 MK_ARRAY(TYPE_ULONGLONG, 2), /* fe_reserved64[2] */
273 TYPE_INT, /* fe_flags */
274 MK_ARRAY(TYPE_INT, 3)) /* fe_reserved[3] */
275
276STRUCT(fiemap,
277 TYPE_ULONGLONG, /* fm_start */
278 TYPE_ULONGLONG, /* fm_length */
279 TYPE_INT, /* fm_flags */
280 TYPE_INT, /* fm_mapped_extents */
281 TYPE_INT, /* fm_extent_count */
282 TYPE_INT) /* fm_reserved */
fff8c539
AF
283
284STRUCT(blkpg_partition,
285 TYPE_LONGLONG, /* start */
286 TYPE_LONGLONG, /* length */
287 TYPE_INT, /* pno */
288 MK_ARRAY(TYPE_CHAR, BLKPG_DEVNAMELTH), /* devname */
289 MK_ARRAY(TYPE_CHAR, BLKPG_VOLNAMELTH)) /* volname */
290
178b14a0
FB
291STRUCT(rtc_time,
292 TYPE_INT, /* tm_sec */
293 TYPE_INT, /* tm_min */
294 TYPE_INT, /* tm_hour */
295 TYPE_INT, /* tm_mday */
296 TYPE_INT, /* tm_mon */
297 TYPE_INT, /* tm_year */
298 TYPE_INT, /* tm_wday */
299 TYPE_INT, /* tm_yday */
300 TYPE_INT) /* tm_isdst */
301
abc81bf6
FB
302STRUCT(rtc_wkalrm,
303 TYPE_CHAR, /* enabled */
304 TYPE_CHAR, /* pending */
305 MK_STRUCT(STRUCT_rtc_time)) /* time */
306
373b067f
FB
307STRUCT(rtc_pll_info,
308 TYPE_INT, /* pll_ctrl */
309 TYPE_INT, /* pll_value */
310 TYPE_INT, /* pll_max */
311 TYPE_INT, /* pll_min */
312 TYPE_INT, /* pll_posmult */
313 TYPE_INT, /* pll_negmult */
314 TYPE_LONG) /* pll_clock */
315
fff8c539
AF
316STRUCT(blkpg_ioctl_arg,
317 TYPE_INT, /* op */
318 TYPE_INT, /* flags */
319 TYPE_INT, /* datalen */
a59b5e35 320 TYPE_PTRVOID) /* data */
6c753a63 321
08e3ce59
AM
322STRUCT(format_descr,
323 TYPE_INT, /* device */
324 TYPE_INT, /* head */
325 TYPE_INT) /* track */
326
81eb1a36
AM
327STRUCT(floppy_max_errors,
328 TYPE_INT, /* abort */
329 TYPE_INT, /* read_track */
330 TYPE_INT, /* reset */
331 TYPE_INT, /* recal */
332 TYPE_INT) /* reporting */
333
6c753a63
CT
334#if defined(CONFIG_USBFS)
335/* usb device ioctls */
336STRUCT(usbdevfs_ctrltransfer,
337 TYPE_CHAR, /* bRequestType */
338 TYPE_CHAR, /* bRequest */
339 TYPE_SHORT, /* wValue */
340 TYPE_SHORT, /* wIndex */
341 TYPE_SHORT, /* wLength */
342 TYPE_INT, /* timeout */
343 TYPE_PTRVOID) /* data */
344
345STRUCT(usbdevfs_bulktransfer,
346 TYPE_INT, /* ep */
347 TYPE_INT, /* len */
348 TYPE_INT, /* timeout */
349 TYPE_PTRVOID) /* data */
350
351STRUCT(usbdevfs_setinterface,
352 TYPE_INT, /* interface */
353 TYPE_INT) /* altsetting */
354
355STRUCT(usbdevfs_disconnectsignal,
356 TYPE_INT, /* signr */
357 TYPE_PTRVOID) /* context */
358
359STRUCT(usbdevfs_getdriver,
360 TYPE_INT, /* interface */
361 MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */
362
363STRUCT(usbdevfs_connectinfo,
364 TYPE_INT, /* devnum */
365 TYPE_CHAR) /* slow */
366
a133367e
CT
367STRUCT(usbdevfs_iso_packet_desc,
368 TYPE_INT, /* length */
369 TYPE_INT, /* actual_length */
370 TYPE_INT) /* status */
371
372STRUCT(usbdevfs_urb,
373 TYPE_CHAR, /* type */
374 TYPE_CHAR, /* endpoint */
375 TYPE_INT, /* status */
376 TYPE_INT, /* flags */
377 TYPE_PTRVOID, /* buffer */
378 TYPE_INT, /* buffer_length */
379 TYPE_INT, /* actual_length */
380 TYPE_INT, /* start_frame */
381 TYPE_INT, /* union number_of_packets stream_id */
382 TYPE_INT, /* error_count */
383 TYPE_INT, /* signr */
384 TYPE_PTRVOID, /* usercontext */
385 MK_ARRAY(MK_STRUCT(STRUCT_usbdevfs_iso_packet_desc), 0)) /* desc */
386
6c753a63
CT
387STRUCT(usbdevfs_ioctl,
388 TYPE_INT, /* ifno */
389 TYPE_INT, /* ioctl_code */
390 TYPE_PTRVOID) /* data */
391
392STRUCT(usbdevfs_hub_portinfo,
393 TYPE_CHAR, /* nports */
394 MK_ARRAY(TYPE_CHAR, 127)) /* port */
395
396STRUCT(usbdevfs_disconnect_claim,
397 TYPE_INT, /* interface */
398 TYPE_INT, /* flags */
399 MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */
400#endif /* CONFIG_USBFS */