syscall_types.h 13 KB

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