syscall_types.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466
  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. #if defined(TARGET_SPARC64) && !defined(TARGET_ABI32)
  108. STRUCT(timeval,
  109. TYPE_LONG, /* tv_sec */
  110. TYPE_INT) /* tv_usec */
  111. STRUCT(_kernel_sock_timeval,
  112. TYPE_LONG, /* tv_sec */
  113. TYPE_INT) /* tv_usec */
  114. #else
  115. STRUCT(timeval,
  116. TYPE_LONG, /* tv_sec */
  117. TYPE_LONG) /* tv_usec */
  118. STRUCT(_kernel_sock_timeval,
  119. TYPE_LONGLONG, /* tv_sec */
  120. TYPE_LONGLONG) /* tv_usec */
  121. #endif
  122. STRUCT(timespec,
  123. TYPE_LONG, /* tv_sec */
  124. TYPE_LONG) /* tv_nsec */
  125. STRUCT(_kernel_timespec,
  126. TYPE_LONGLONG, /* tv_sec */
  127. TYPE_LONGLONG) /* tv_nsec */
  128. STRUCT(snd_timer_status,
  129. MK_STRUCT(STRUCT_timespec), /* tstamp */
  130. TYPE_INT, /* resolution */
  131. TYPE_INT, /* lost */
  132. TYPE_INT, /* overrun */
  133. TYPE_INT, /* queue */
  134. MK_ARRAY(TYPE_CHAR, 64)) /* reserved */
  135. /* loop device ioctls */
  136. STRUCT(loop_info,
  137. TYPE_INT, /* lo_number */
  138. TYPE_OLDDEVT, /* lo_device */
  139. TYPE_ULONG, /* lo_inode */
  140. TYPE_OLDDEVT, /* lo_rdevice */
  141. TYPE_INT, /* lo_offset */
  142. TYPE_INT, /* lo_encrypt_type */
  143. TYPE_INT, /* lo_encrypt_key_size */
  144. TYPE_INT, /* lo_flags */
  145. MK_ARRAY(TYPE_CHAR, 64), /* lo_name */
  146. MK_ARRAY(TYPE_CHAR, 32), /* lo_encrypt_key */
  147. MK_ARRAY(TYPE_ULONG, 2), /* lo_init */
  148. MK_ARRAY(TYPE_CHAR, 4)) /* reserved */
  149. STRUCT(loop_info64,
  150. TYPE_ULONGLONG, /* lo_device */
  151. TYPE_ULONGLONG, /* lo_inode */
  152. TYPE_ULONGLONG, /* lo_rdevice */
  153. TYPE_ULONGLONG, /* lo_offset */
  154. TYPE_ULONGLONG, /* lo_sizelimit */
  155. TYPE_INT, /* lo_number */
  156. TYPE_INT, /* lo_encrypt_type */
  157. TYPE_INT, /* lo_encrypt_key_size */
  158. TYPE_INT, /* lo_flags */
  159. MK_ARRAY(TYPE_CHAR, 64), /* lo_name */
  160. MK_ARRAY(TYPE_CHAR, 64), /* lo_crypt_name */
  161. MK_ARRAY(TYPE_CHAR, 32), /* lo_encrypt_key */
  162. MK_ARRAY(TYPE_ULONGLONG, 2)) /* lo_init */
  163. /* mag tape ioctls */
  164. STRUCT(mtop, TYPE_SHORT, TYPE_INT)
  165. STRUCT(mtget, TYPE_LONG, TYPE_LONG, TYPE_LONG, TYPE_LONG, TYPE_LONG,
  166. TYPE_INT, TYPE_INT)
  167. STRUCT(mtpos, TYPE_LONG)
  168. STRUCT(fb_fix_screeninfo,
  169. MK_ARRAY(TYPE_CHAR, 16), /* id */
  170. TYPE_ULONG, /* smem_start */
  171. TYPE_INT, /* smem_len */
  172. TYPE_INT, /* type */
  173. TYPE_INT, /* type_aux */
  174. TYPE_INT, /* visual */
  175. TYPE_SHORT, /* xpanstep */
  176. TYPE_SHORT, /* ypanstep */
  177. TYPE_SHORT, /* ywrapstep */
  178. TYPE_INT, /* line_length */
  179. TYPE_ULONG, /* mmio_start */
  180. TYPE_INT, /* mmio_len */
  181. TYPE_INT, /* accel */
  182. MK_ARRAY(TYPE_CHAR, 3)) /* reserved */
  183. STRUCT(fb_var_screeninfo,
  184. TYPE_INT, /* xres */
  185. TYPE_INT, /* yres */
  186. TYPE_INT, /* xres_virtual */
  187. TYPE_INT, /* yres_virtual */
  188. TYPE_INT, /* xoffset */
  189. TYPE_INT, /* yoffset */
  190. TYPE_INT, /* bits_per_pixel */
  191. TYPE_INT, /* grayscale */
  192. MK_ARRAY(TYPE_INT, 3), /* red */
  193. MK_ARRAY(TYPE_INT, 3), /* green */
  194. MK_ARRAY(TYPE_INT, 3), /* blue */
  195. MK_ARRAY(TYPE_INT, 3), /* transp */
  196. TYPE_INT, /* nonstd */
  197. TYPE_INT, /* activate */
  198. TYPE_INT, /* height */
  199. TYPE_INT, /* width */
  200. TYPE_INT, /* accel_flags */
  201. TYPE_INT, /* pixclock */
  202. TYPE_INT, /* left_margin */
  203. TYPE_INT, /* right_margin */
  204. TYPE_INT, /* upper_margin */
  205. TYPE_INT, /* lower_margin */
  206. TYPE_INT, /* hsync_len */
  207. TYPE_INT, /* vsync_len */
  208. TYPE_INT, /* sync */
  209. TYPE_INT, /* vmode */
  210. TYPE_INT, /* rotate */
  211. MK_ARRAY(TYPE_INT, 5)) /* reserved */
  212. STRUCT(fb_cmap,
  213. TYPE_INT, /* start */
  214. TYPE_INT, /* len */
  215. TYPE_PTRVOID, /* red */
  216. TYPE_PTRVOID, /* green */
  217. TYPE_PTRVOID, /* blue */
  218. TYPE_PTRVOID) /* transp */
  219. STRUCT(fb_con2fbmap,
  220. TYPE_INT, /* console */
  221. TYPE_INT) /* framebuffer */
  222. STRUCT(vt_stat,
  223. TYPE_SHORT, /* v_active */
  224. TYPE_SHORT, /* v_signal */
  225. TYPE_SHORT) /* v_state */
  226. STRUCT(vt_mode,
  227. TYPE_CHAR, /* mode */
  228. TYPE_CHAR, /* waitv */
  229. TYPE_SHORT, /* relsig */
  230. TYPE_SHORT, /* acqsig */
  231. TYPE_SHORT) /* frsig */
  232. STRUCT(dm_ioctl,
  233. MK_ARRAY(TYPE_INT, 3), /* version */
  234. TYPE_INT, /* data_size */
  235. TYPE_INT, /* data_start */
  236. TYPE_INT, /* target_count*/
  237. TYPE_INT, /* open_count */
  238. TYPE_INT, /* flags */
  239. TYPE_INT, /* event_nr */
  240. TYPE_INT, /* padding */
  241. TYPE_ULONGLONG, /* dev */
  242. MK_ARRAY(TYPE_CHAR, 128), /* name */
  243. MK_ARRAY(TYPE_CHAR, 129), /* uuid */
  244. MK_ARRAY(TYPE_CHAR, 7)) /* data */
  245. STRUCT(dm_target_spec,
  246. TYPE_ULONGLONG, /* sector_start */
  247. TYPE_ULONGLONG, /* length */
  248. TYPE_INT, /* status */
  249. TYPE_INT, /* next */
  250. MK_ARRAY(TYPE_CHAR, 16)) /* target_type */
  251. STRUCT(dm_target_deps,
  252. TYPE_INT, /* count */
  253. TYPE_INT) /* padding */
  254. STRUCT(dm_name_list,
  255. TYPE_ULONGLONG, /* dev */
  256. TYPE_INT) /* next */
  257. STRUCT(dm_target_versions,
  258. TYPE_INT, /* next */
  259. MK_ARRAY(TYPE_INT, 3)) /* version*/
  260. STRUCT(dm_target_msg,
  261. TYPE_ULONGLONG) /* sector */
  262. STRUCT(drm_version,
  263. TYPE_INT, /* version_major */
  264. TYPE_INT, /* version_minor */
  265. TYPE_INT, /* version_patchlevel */
  266. TYPE_ULONG, /* name_len */
  267. TYPE_PTRVOID, /* name */
  268. TYPE_ULONG, /* date_len */
  269. TYPE_PTRVOID, /* date */
  270. TYPE_ULONG, /* desc_len */
  271. TYPE_PTRVOID) /* desc */
  272. STRUCT(file_clone_range,
  273. TYPE_LONGLONG, /* src_fd */
  274. TYPE_ULONGLONG, /* src_offset */
  275. TYPE_ULONGLONG, /* src_length */
  276. TYPE_ULONGLONG) /* dest_offset */
  277. STRUCT(fiemap_extent,
  278. TYPE_ULONGLONG, /* fe_logical */
  279. TYPE_ULONGLONG, /* fe_physical */
  280. TYPE_ULONGLONG, /* fe_length */
  281. MK_ARRAY(TYPE_ULONGLONG, 2), /* fe_reserved64[2] */
  282. TYPE_INT, /* fe_flags */
  283. MK_ARRAY(TYPE_INT, 3)) /* fe_reserved[3] */
  284. STRUCT(fiemap,
  285. TYPE_ULONGLONG, /* fm_start */
  286. TYPE_ULONGLONG, /* fm_length */
  287. TYPE_INT, /* fm_flags */
  288. TYPE_INT, /* fm_mapped_extents */
  289. TYPE_INT, /* fm_extent_count */
  290. TYPE_INT) /* fm_reserved */
  291. STRUCT(blkpg_partition,
  292. TYPE_LONGLONG, /* start */
  293. TYPE_LONGLONG, /* length */
  294. TYPE_INT, /* pno */
  295. MK_ARRAY(TYPE_CHAR, BLKPG_DEVNAMELTH), /* devname */
  296. MK_ARRAY(TYPE_CHAR, BLKPG_VOLNAMELTH)) /* volname */
  297. STRUCT(rtc_time,
  298. TYPE_INT, /* tm_sec */
  299. TYPE_INT, /* tm_min */
  300. TYPE_INT, /* tm_hour */
  301. TYPE_INT, /* tm_mday */
  302. TYPE_INT, /* tm_mon */
  303. TYPE_INT, /* tm_year */
  304. TYPE_INT, /* tm_wday */
  305. TYPE_INT, /* tm_yday */
  306. TYPE_INT) /* tm_isdst */
  307. STRUCT(rtc_wkalrm,
  308. TYPE_CHAR, /* enabled */
  309. TYPE_CHAR, /* pending */
  310. MK_STRUCT(STRUCT_rtc_time)) /* time */
  311. STRUCT(rtc_pll_info,
  312. TYPE_INT, /* pll_ctrl */
  313. TYPE_INT, /* pll_value */
  314. TYPE_INT, /* pll_max */
  315. TYPE_INT, /* pll_min */
  316. TYPE_INT, /* pll_posmult */
  317. TYPE_INT, /* pll_negmult */
  318. TYPE_LONG) /* pll_clock */
  319. STRUCT(blkpg_ioctl_arg,
  320. TYPE_INT, /* op */
  321. TYPE_INT, /* flags */
  322. TYPE_INT, /* datalen */
  323. TYPE_PTRVOID) /* data */
  324. STRUCT(format_descr,
  325. TYPE_INT, /* device */
  326. TYPE_INT, /* head */
  327. TYPE_INT) /* track */
  328. STRUCT(floppy_max_errors,
  329. TYPE_INT, /* abort */
  330. TYPE_INT, /* read_track */
  331. TYPE_INT, /* reset */
  332. TYPE_INT, /* recal */
  333. TYPE_INT) /* reporting */
  334. #if defined(CONFIG_USBFS)
  335. /* usb device ioctls */
  336. STRUCT(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. STRUCT(usbdevfs_bulktransfer,
  345. TYPE_INT, /* ep */
  346. TYPE_INT, /* len */
  347. TYPE_INT, /* timeout */
  348. TYPE_PTRVOID) /* data */
  349. STRUCT(usbdevfs_setinterface,
  350. TYPE_INT, /* interface */
  351. TYPE_INT) /* altsetting */
  352. STRUCT(usbdevfs_disconnectsignal,
  353. TYPE_INT, /* signr */
  354. TYPE_PTRVOID) /* context */
  355. STRUCT(usbdevfs_getdriver,
  356. TYPE_INT, /* interface */
  357. MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */
  358. STRUCT(usbdevfs_connectinfo,
  359. TYPE_INT, /* devnum */
  360. TYPE_CHAR) /* slow */
  361. STRUCT(usbdevfs_iso_packet_desc,
  362. TYPE_INT, /* length */
  363. TYPE_INT, /* actual_length */
  364. TYPE_INT) /* status */
  365. STRUCT(usbdevfs_urb,
  366. TYPE_CHAR, /* type */
  367. TYPE_CHAR, /* endpoint */
  368. TYPE_INT, /* status */
  369. TYPE_INT, /* flags */
  370. TYPE_PTRVOID, /* buffer */
  371. TYPE_INT, /* buffer_length */
  372. TYPE_INT, /* actual_length */
  373. TYPE_INT, /* start_frame */
  374. TYPE_INT, /* union number_of_packets stream_id */
  375. TYPE_INT, /* error_count */
  376. TYPE_INT, /* signr */
  377. TYPE_PTRVOID, /* usercontext */
  378. MK_ARRAY(MK_STRUCT(STRUCT_usbdevfs_iso_packet_desc), 0)) /* desc */
  379. STRUCT(usbdevfs_ioctl,
  380. TYPE_INT, /* ifno */
  381. TYPE_INT, /* ioctl_code */
  382. TYPE_PTRVOID) /* data */
  383. STRUCT(usbdevfs_hub_portinfo,
  384. TYPE_CHAR, /* nports */
  385. MK_ARRAY(TYPE_CHAR, 127)) /* port */
  386. STRUCT(usbdevfs_disconnect_claim,
  387. TYPE_INT, /* interface */
  388. TYPE_INT, /* flags */
  389. MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */
  390. #endif /* CONFIG_USBFS */