syscall_types.h 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330
  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. /* loop device ioctls */
  61. STRUCT(loop_info,
  62. TYPE_INT, /* lo_number */
  63. TYPE_OLDDEVT, /* lo_device */
  64. TYPE_ULONG, /* lo_inode */
  65. TYPE_OLDDEVT, /* lo_rdevice */
  66. TYPE_INT, /* lo_offset */
  67. TYPE_INT, /* lo_encrypt_type */
  68. TYPE_INT, /* lo_encrypt_key_size */
  69. TYPE_INT, /* lo_flags */
  70. MK_ARRAY(TYPE_CHAR, 64), /* lo_name */
  71. MK_ARRAY(TYPE_CHAR, 32), /* lo_encrypt_key */
  72. MK_ARRAY(TYPE_ULONG, 2), /* lo_init */
  73. MK_ARRAY(TYPE_CHAR, 4)) /* reserved */
  74. STRUCT(loop_info64,
  75. TYPE_ULONGLONG, /* lo_device */
  76. TYPE_ULONGLONG, /* lo_inode */
  77. TYPE_ULONGLONG, /* lo_rdevice */
  78. TYPE_ULONGLONG, /* lo_offset */
  79. TYPE_ULONGLONG, /* lo_sizelimit */
  80. TYPE_INT, /* lo_number */
  81. TYPE_INT, /* lo_encrypt_type */
  82. TYPE_INT, /* lo_encrypt_key_size */
  83. TYPE_INT, /* lo_flags */
  84. MK_ARRAY(TYPE_CHAR, 64), /* lo_name */
  85. MK_ARRAY(TYPE_CHAR, 64), /* lo_crypt_name */
  86. MK_ARRAY(TYPE_CHAR, 32), /* lo_encrypt_key */
  87. MK_ARRAY(TYPE_ULONGLONG, 2)) /* lo_init */
  88. /* mag tape ioctls */
  89. STRUCT(mtop, TYPE_SHORT, TYPE_INT)
  90. STRUCT(mtget, TYPE_LONG, TYPE_LONG, TYPE_LONG, TYPE_LONG, TYPE_LONG,
  91. TYPE_INT, TYPE_INT)
  92. STRUCT(mtpos, TYPE_LONG)
  93. STRUCT(fb_fix_screeninfo,
  94. MK_ARRAY(TYPE_CHAR, 16), /* id */
  95. TYPE_ULONG, /* smem_start */
  96. TYPE_INT, /* smem_len */
  97. TYPE_INT, /* type */
  98. TYPE_INT, /* type_aux */
  99. TYPE_INT, /* visual */
  100. TYPE_SHORT, /* xpanstep */
  101. TYPE_SHORT, /* ypanstep */
  102. TYPE_SHORT, /* ywrapstep */
  103. TYPE_INT, /* line_length */
  104. TYPE_ULONG, /* mmio_start */
  105. TYPE_INT, /* mmio_len */
  106. TYPE_INT, /* accel */
  107. MK_ARRAY(TYPE_CHAR, 3)) /* reserved */
  108. STRUCT(fb_var_screeninfo,
  109. TYPE_INT, /* xres */
  110. TYPE_INT, /* yres */
  111. TYPE_INT, /* xres_virtual */
  112. TYPE_INT, /* yres_virtual */
  113. TYPE_INT, /* xoffset */
  114. TYPE_INT, /* yoffset */
  115. TYPE_INT, /* bits_per_pixel */
  116. TYPE_INT, /* grayscale */
  117. MK_ARRAY(TYPE_INT, 3), /* red */
  118. MK_ARRAY(TYPE_INT, 3), /* green */
  119. MK_ARRAY(TYPE_INT, 3), /* blue */
  120. MK_ARRAY(TYPE_INT, 3), /* transp */
  121. TYPE_INT, /* nonstd */
  122. TYPE_INT, /* activate */
  123. TYPE_INT, /* height */
  124. TYPE_INT, /* width */
  125. TYPE_INT, /* accel_flags */
  126. TYPE_INT, /* pixclock */
  127. TYPE_INT, /* left_margin */
  128. TYPE_INT, /* right_margin */
  129. TYPE_INT, /* upper_margin */
  130. TYPE_INT, /* lower_margin */
  131. TYPE_INT, /* hsync_len */
  132. TYPE_INT, /* vsync_len */
  133. TYPE_INT, /* sync */
  134. TYPE_INT, /* vmode */
  135. TYPE_INT, /* rotate */
  136. MK_ARRAY(TYPE_INT, 5)) /* reserved */
  137. STRUCT(fb_cmap,
  138. TYPE_INT, /* start */
  139. TYPE_INT, /* len */
  140. TYPE_PTRVOID, /* red */
  141. TYPE_PTRVOID, /* green */
  142. TYPE_PTRVOID, /* blue */
  143. TYPE_PTRVOID) /* transp */
  144. STRUCT(fb_con2fbmap,
  145. TYPE_INT, /* console */
  146. TYPE_INT) /* framebuffer */
  147. STRUCT(vt_stat,
  148. TYPE_SHORT, /* v_active */
  149. TYPE_SHORT, /* v_signal */
  150. TYPE_SHORT) /* v_state */
  151. STRUCT(vt_mode,
  152. TYPE_CHAR, /* mode */
  153. TYPE_CHAR, /* waitv */
  154. TYPE_SHORT, /* relsig */
  155. TYPE_SHORT, /* acqsig */
  156. TYPE_SHORT) /* frsig */
  157. STRUCT(dm_ioctl,
  158. MK_ARRAY(TYPE_INT, 3), /* version */
  159. TYPE_INT, /* data_size */
  160. TYPE_INT, /* data_start */
  161. TYPE_INT, /* target_count*/
  162. TYPE_INT, /* open_count */
  163. TYPE_INT, /* flags */
  164. TYPE_INT, /* event_nr */
  165. TYPE_INT, /* padding */
  166. TYPE_ULONGLONG, /* dev */
  167. MK_ARRAY(TYPE_CHAR, 128), /* name */
  168. MK_ARRAY(TYPE_CHAR, 129), /* uuid */
  169. MK_ARRAY(TYPE_CHAR, 7)) /* data */
  170. STRUCT(dm_target_spec,
  171. TYPE_ULONGLONG, /* sector_start */
  172. TYPE_ULONGLONG, /* length */
  173. TYPE_INT, /* status */
  174. TYPE_INT, /* next */
  175. MK_ARRAY(TYPE_CHAR, 16)) /* target_type */
  176. STRUCT(dm_target_deps,
  177. TYPE_INT, /* count */
  178. TYPE_INT) /* padding */
  179. STRUCT(dm_name_list,
  180. TYPE_ULONGLONG, /* dev */
  181. TYPE_INT) /* next */
  182. STRUCT(dm_target_versions,
  183. TYPE_INT, /* next */
  184. MK_ARRAY(TYPE_INT, 3)) /* version*/
  185. STRUCT(dm_target_msg,
  186. TYPE_ULONGLONG) /* sector */
  187. STRUCT(file_clone_range,
  188. TYPE_LONGLONG, /* src_fd */
  189. TYPE_ULONGLONG, /* src_offset */
  190. TYPE_ULONGLONG, /* src_length */
  191. TYPE_ULONGLONG) /* dest_offset */
  192. STRUCT(fiemap_extent,
  193. TYPE_ULONGLONG, /* fe_logical */
  194. TYPE_ULONGLONG, /* fe_physical */
  195. TYPE_ULONGLONG, /* fe_length */
  196. MK_ARRAY(TYPE_ULONGLONG, 2), /* fe_reserved64[2] */
  197. TYPE_INT, /* fe_flags */
  198. MK_ARRAY(TYPE_INT, 3)) /* fe_reserved[3] */
  199. STRUCT(fiemap,
  200. TYPE_ULONGLONG, /* fm_start */
  201. TYPE_ULONGLONG, /* fm_length */
  202. TYPE_INT, /* fm_flags */
  203. TYPE_INT, /* fm_mapped_extents */
  204. TYPE_INT, /* fm_extent_count */
  205. TYPE_INT) /* fm_reserved */
  206. STRUCT(blkpg_partition,
  207. TYPE_LONGLONG, /* start */
  208. TYPE_LONGLONG, /* length */
  209. TYPE_INT, /* pno */
  210. MK_ARRAY(TYPE_CHAR, BLKPG_DEVNAMELTH), /* devname */
  211. MK_ARRAY(TYPE_CHAR, BLKPG_VOLNAMELTH)) /* volname */
  212. STRUCT(blkpg_ioctl_arg,
  213. TYPE_INT, /* op */
  214. TYPE_INT, /* flags */
  215. TYPE_INT, /* datalen */
  216. TYPE_PTRVOID) /* data */
  217. #if defined(CONFIG_USBFS)
  218. /* usb device ioctls */
  219. STRUCT(usbdevfs_ctrltransfer,
  220. TYPE_CHAR, /* bRequestType */
  221. TYPE_CHAR, /* bRequest */
  222. TYPE_SHORT, /* wValue */
  223. TYPE_SHORT, /* wIndex */
  224. TYPE_SHORT, /* wLength */
  225. TYPE_INT, /* timeout */
  226. TYPE_PTRVOID) /* data */
  227. STRUCT(usbdevfs_bulktransfer,
  228. TYPE_INT, /* ep */
  229. TYPE_INT, /* len */
  230. TYPE_INT, /* timeout */
  231. TYPE_PTRVOID) /* data */
  232. STRUCT(usbdevfs_setinterface,
  233. TYPE_INT, /* interface */
  234. TYPE_INT) /* altsetting */
  235. STRUCT(usbdevfs_disconnectsignal,
  236. TYPE_INT, /* signr */
  237. TYPE_PTRVOID) /* context */
  238. STRUCT(usbdevfs_getdriver,
  239. TYPE_INT, /* interface */
  240. MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */
  241. STRUCT(usbdevfs_connectinfo,
  242. TYPE_INT, /* devnum */
  243. TYPE_CHAR) /* slow */
  244. STRUCT(usbdevfs_iso_packet_desc,
  245. TYPE_INT, /* length */
  246. TYPE_INT, /* actual_length */
  247. TYPE_INT) /* status */
  248. STRUCT(usbdevfs_urb,
  249. TYPE_CHAR, /* type */
  250. TYPE_CHAR, /* endpoint */
  251. TYPE_INT, /* status */
  252. TYPE_INT, /* flags */
  253. TYPE_PTRVOID, /* buffer */
  254. TYPE_INT, /* buffer_length */
  255. TYPE_INT, /* actual_length */
  256. TYPE_INT, /* start_frame */
  257. TYPE_INT, /* union number_of_packets stream_id */
  258. TYPE_INT, /* error_count */
  259. TYPE_INT, /* signr */
  260. TYPE_PTRVOID, /* usercontext */
  261. MK_ARRAY(MK_STRUCT(STRUCT_usbdevfs_iso_packet_desc), 0)) /* desc */
  262. STRUCT(usbdevfs_ioctl,
  263. TYPE_INT, /* ifno */
  264. TYPE_INT, /* ioctl_code */
  265. TYPE_PTRVOID) /* data */
  266. STRUCT(usbdevfs_hub_portinfo,
  267. TYPE_CHAR, /* nports */
  268. MK_ARRAY(TYPE_CHAR, 127)) /* port */
  269. STRUCT(usbdevfs_disconnect_claim,
  270. TYPE_INT, /* interface */
  271. TYPE_INT, /* flags */
  272. MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */
  273. #endif /* CONFIG_USBFS */