syscall_types.h 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633
  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(drm_i915_getparam,
  273. TYPE_INT, /* param */
  274. TYPE_PTRVOID) /* value */
  275. STRUCT(file_clone_range,
  276. TYPE_LONGLONG, /* src_fd */
  277. TYPE_ULONGLONG, /* src_offset */
  278. TYPE_ULONGLONG, /* src_length */
  279. TYPE_ULONGLONG) /* dest_offset */
  280. STRUCT(fiemap_extent,
  281. TYPE_ULONGLONG, /* fe_logical */
  282. TYPE_ULONGLONG, /* fe_physical */
  283. TYPE_ULONGLONG, /* fe_length */
  284. MK_ARRAY(TYPE_ULONGLONG, 2), /* fe_reserved64[2] */
  285. TYPE_INT, /* fe_flags */
  286. MK_ARRAY(TYPE_INT, 3)) /* fe_reserved[3] */
  287. STRUCT(fiemap,
  288. TYPE_ULONGLONG, /* fm_start */
  289. TYPE_ULONGLONG, /* fm_length */
  290. TYPE_INT, /* fm_flags */
  291. TYPE_INT, /* fm_mapped_extents */
  292. TYPE_INT, /* fm_extent_count */
  293. TYPE_INT) /* fm_reserved */
  294. STRUCT(blkpg_partition,
  295. TYPE_LONGLONG, /* start */
  296. TYPE_LONGLONG, /* length */
  297. TYPE_INT, /* pno */
  298. MK_ARRAY(TYPE_CHAR, BLKPG_DEVNAMELTH), /* devname */
  299. MK_ARRAY(TYPE_CHAR, BLKPG_VOLNAMELTH)) /* volname */
  300. #if defined(BTRFS_IOC_SUBVOL_CREATE) || defined(BTRFS_IOC_SNAP_CREATE) || \
  301. defined(BTRFS_IOC_SNAP_DESTROY) || defined(BTRFS_IOC_SCAN_DEV) || \
  302. defined(BTRFS_IOC_FORGET_DEV) || defined(BTRFS_IOC_ADD_DEV) || \
  303. defined(BTRFS_IOC_RM_DEV) || defined(BTRFS_IOC_DEV_INFO)
  304. STRUCT(btrfs_ioctl_vol_args,
  305. TYPE_LONGLONG, /* fd */
  306. MK_ARRAY(TYPE_CHAR, BTRFS_PATH_NAME_MAX + 1)) /* name */
  307. #endif
  308. #ifdef BTRFS_IOC_GET_SUBVOL_INFO
  309. STRUCT(btrfs_ioctl_timespec,
  310. TYPE_ULONGLONG, /* sec */
  311. TYPE_INT) /* nsec */
  312. STRUCT(btrfs_ioctl_get_subvol_info_args,
  313. TYPE_ULONGLONG, /* treeid */
  314. MK_ARRAY(TYPE_CHAR, BTRFS_VOL_NAME_MAX + 1),
  315. TYPE_ULONGLONG, /* parentid */
  316. TYPE_ULONGLONG, /* dirid */
  317. TYPE_ULONGLONG, /* generation */
  318. TYPE_ULONGLONG, /* flags */
  319. MK_ARRAY(TYPE_CHAR, BTRFS_UUID_SIZE), /* uuid */
  320. MK_ARRAY(TYPE_CHAR, BTRFS_UUID_SIZE), /* parent_uuid */
  321. MK_ARRAY(TYPE_CHAR, BTRFS_UUID_SIZE), /* received_uuid */
  322. TYPE_ULONGLONG, /* ctransid */
  323. TYPE_ULONGLONG, /* otransid */
  324. TYPE_ULONGLONG, /* stransid */
  325. TYPE_ULONGLONG, /* rtransid */
  326. MK_STRUCT(STRUCT_btrfs_ioctl_timespec), /* ctime */
  327. MK_STRUCT(STRUCT_btrfs_ioctl_timespec), /* otime */
  328. MK_STRUCT(STRUCT_btrfs_ioctl_timespec), /* stime */
  329. MK_STRUCT(STRUCT_btrfs_ioctl_timespec), /* rtime */
  330. MK_ARRAY(TYPE_ULONGLONG, 8)) /* reserved */
  331. #endif
  332. #ifdef BTRFS_IOC_INO_LOOKUP
  333. STRUCT(btrfs_ioctl_ino_lookup_args,
  334. TYPE_ULONGLONG, /* treeid */
  335. TYPE_ULONGLONG, /* objectid */
  336. MK_ARRAY(TYPE_CHAR, BTRFS_INO_LOOKUP_PATH_MAX)) /* name */
  337. #endif
  338. #ifdef BTRFS_IOC_INO_PATHS
  339. STRUCT(btrfs_ioctl_ino_path_args,
  340. TYPE_ULONGLONG, /* inum */
  341. TYPE_ULONGLONG, /* size */
  342. MK_ARRAY(TYPE_ULONGLONG, 4), /* reserved */
  343. TYPE_ULONGLONG) /* fspath */
  344. #endif
  345. #if defined(BTRFS_IOC_LOGICAL_INO) || defined(BTRFS_IOC_LOGICAL_INO_V2)
  346. STRUCT(btrfs_ioctl_logical_ino_args,
  347. TYPE_ULONGLONG, /* logical */
  348. TYPE_ULONGLONG, /* size */
  349. MK_ARRAY(TYPE_ULONGLONG, 3), /* reserved */
  350. TYPE_ULONGLONG, /* flags */
  351. TYPE_ULONGLONG) /* inodes */
  352. #endif
  353. #ifdef BTRFS_IOC_INO_LOOKUP_USER
  354. STRUCT(btrfs_ioctl_ino_lookup_user_args,
  355. TYPE_ULONGLONG, /* dirid */
  356. TYPE_ULONGLONG, /* treeid */
  357. MK_ARRAY(TYPE_CHAR, BTRFS_VOL_NAME_MAX + 1), /* name */
  358. MK_ARRAY(TYPE_CHAR, BTRFS_INO_LOOKUP_USER_PATH_MAX)) /* path */
  359. #endif
  360. #if defined(BTRFS_IOC_SCRUB) || defined(BTRFS_IOC_SCRUB_PROGRESS)
  361. STRUCT(btrfs_scrub_progress,
  362. TYPE_ULONGLONG, /* data_extents_scrubbed */
  363. TYPE_ULONGLONG, /* tree_extents_scrubbed */
  364. TYPE_ULONGLONG, /* data_bytes_scrubbed */
  365. TYPE_ULONGLONG, /* tree_bytes_scrubbed */
  366. TYPE_ULONGLONG, /* read_errors */
  367. TYPE_ULONGLONG, /* csum_errors */
  368. TYPE_ULONGLONG, /* verify_errors */
  369. TYPE_ULONGLONG, /* no_csum */
  370. TYPE_ULONGLONG, /* csum_discards */
  371. TYPE_ULONGLONG, /* super_errors */
  372. TYPE_ULONGLONG, /* malloc_errors */
  373. TYPE_ULONGLONG, /* uncorrectable_errors */
  374. TYPE_ULONGLONG, /* corrected_er */
  375. TYPE_ULONGLONG, /* last_physical */
  376. TYPE_ULONGLONG) /* unverified_errors */
  377. STRUCT(btrfs_ioctl_scrub_args,
  378. TYPE_ULONGLONG, /* devid */
  379. TYPE_ULONGLONG, /* start */
  380. TYPE_ULONGLONG, /* end */
  381. TYPE_ULONGLONG, /* flags */
  382. MK_STRUCT(STRUCT_btrfs_scrub_progress), /* progress */
  383. MK_ARRAY(TYPE_ULONGLONG,
  384. (1024 - 32 -
  385. sizeof(struct btrfs_scrub_progress)) / 8)) /* unused */
  386. #endif
  387. #ifdef BTRFS_IOC_DEV_INFO
  388. STRUCT(btrfs_ioctl_dev_info_args,
  389. TYPE_ULONGLONG, /* devid */
  390. MK_ARRAY(TYPE_CHAR, BTRFS_UUID_SIZE), /* uuid */
  391. TYPE_ULONGLONG, /* bytes_used */
  392. TYPE_ULONGLONG, /* total_bytes */
  393. MK_ARRAY(TYPE_ULONGLONG, 379), /* unused */
  394. MK_ARRAY(TYPE_CHAR, BTRFS_DEVICE_PATH_NAME_MAX)) /* path */
  395. #endif
  396. #ifdef BTRFS_IOC_GET_SUBVOL_ROOTREF
  397. STRUCT(rootref,
  398. TYPE_ULONGLONG, /* treeid */
  399. TYPE_ULONGLONG) /* dirid */
  400. STRUCT(btrfs_ioctl_get_subvol_rootref_args,
  401. TYPE_ULONGLONG, /* min_treeid */
  402. MK_ARRAY(MK_STRUCT(STRUCT_rootref),
  403. BTRFS_MAX_ROOTREF_BUFFER_NUM), /* rootref */
  404. TYPE_CHAR, /* num_items */
  405. MK_ARRAY(TYPE_CHAR, 7)) /* align */
  406. #endif
  407. #ifdef BTRFS_IOC_GET_DEV_STATS
  408. STRUCT(btrfs_ioctl_get_dev_stats,
  409. TYPE_ULONGLONG, /* devid */
  410. TYPE_ULONGLONG, /* nr_items */
  411. TYPE_ULONGLONG, /* flags */
  412. MK_ARRAY(TYPE_ULONGLONG, BTRFS_DEV_STAT_VALUES_MAX), /* values */
  413. MK_ARRAY(TYPE_ULONGLONG,
  414. 128 - 2 - BTRFS_DEV_STAT_VALUES_MAX)) /* unused */
  415. #endif
  416. STRUCT(btrfs_ioctl_quota_ctl_args,
  417. TYPE_ULONGLONG, /* cmd */
  418. TYPE_ULONGLONG) /* status */
  419. STRUCT(btrfs_ioctl_quota_rescan_args,
  420. TYPE_ULONGLONG, /* flags */
  421. TYPE_ULONGLONG, /* progress */
  422. MK_ARRAY(TYPE_ULONGLONG, 6)) /* reserved */
  423. STRUCT(btrfs_ioctl_qgroup_assign_args,
  424. TYPE_ULONGLONG, /* assign */
  425. TYPE_ULONGLONG, /* src */
  426. TYPE_ULONGLONG) /* dst */
  427. STRUCT(btrfs_ioctl_qgroup_create_args,
  428. TYPE_ULONGLONG, /* create */
  429. TYPE_ULONGLONG) /* qgroupid */
  430. STRUCT(btrfs_qgroup_limit,
  431. TYPE_ULONGLONG, /* flags */
  432. TYPE_ULONGLONG, /* max_rfer */
  433. TYPE_ULONGLONG, /* max_excl */
  434. TYPE_ULONGLONG, /* rsv_rfer */
  435. TYPE_ULONGLONG) /* rsv_excl */
  436. STRUCT(btrfs_ioctl_qgroup_limit_args,
  437. TYPE_ULONGLONG, /* qgroupid */
  438. MK_STRUCT(STRUCT_btrfs_qgroup_limit)) /* lim */
  439. STRUCT(btrfs_ioctl_feature_flags,
  440. TYPE_ULONGLONG, /* compat_flags */
  441. TYPE_ULONGLONG, /* compat_ro_flags */
  442. TYPE_ULONGLONG) /* incompat_flags */
  443. STRUCT(rtc_time,
  444. TYPE_INT, /* tm_sec */
  445. TYPE_INT, /* tm_min */
  446. TYPE_INT, /* tm_hour */
  447. TYPE_INT, /* tm_mday */
  448. TYPE_INT, /* tm_mon */
  449. TYPE_INT, /* tm_year */
  450. TYPE_INT, /* tm_wday */
  451. TYPE_INT, /* tm_yday */
  452. TYPE_INT) /* tm_isdst */
  453. STRUCT(rtc_wkalrm,
  454. TYPE_CHAR, /* enabled */
  455. TYPE_CHAR, /* pending */
  456. MK_STRUCT(STRUCT_rtc_time)) /* time */
  457. STRUCT(rtc_pll_info,
  458. TYPE_INT, /* pll_ctrl */
  459. TYPE_INT, /* pll_value */
  460. TYPE_INT, /* pll_max */
  461. TYPE_INT, /* pll_min */
  462. TYPE_INT, /* pll_posmult */
  463. TYPE_INT, /* pll_negmult */
  464. TYPE_LONG) /* pll_clock */
  465. STRUCT(blkpg_ioctl_arg,
  466. TYPE_INT, /* op */
  467. TYPE_INT, /* flags */
  468. TYPE_INT, /* datalen */
  469. TYPE_PTRVOID) /* data */
  470. STRUCT(format_descr,
  471. TYPE_INT, /* device */
  472. TYPE_INT, /* head */
  473. TYPE_INT) /* track */
  474. STRUCT(floppy_max_errors,
  475. TYPE_INT, /* abort */
  476. TYPE_INT, /* read_track */
  477. TYPE_INT, /* reset */
  478. TYPE_INT, /* recal */
  479. TYPE_INT) /* reporting */
  480. #if defined(CONFIG_USBFS)
  481. /* usb device ioctls */
  482. STRUCT(usbdevfs_ctrltransfer,
  483. TYPE_CHAR, /* bRequestType */
  484. TYPE_CHAR, /* bRequest */
  485. TYPE_SHORT, /* wValue */
  486. TYPE_SHORT, /* wIndex */
  487. TYPE_SHORT, /* wLength */
  488. TYPE_INT, /* timeout */
  489. TYPE_PTRVOID) /* data */
  490. STRUCT(usbdevfs_bulktransfer,
  491. TYPE_INT, /* ep */
  492. TYPE_INT, /* len */
  493. TYPE_INT, /* timeout */
  494. TYPE_PTRVOID) /* data */
  495. STRUCT(usbdevfs_setinterface,
  496. TYPE_INT, /* interface */
  497. TYPE_INT) /* altsetting */
  498. STRUCT(usbdevfs_disconnectsignal,
  499. TYPE_INT, /* signr */
  500. TYPE_PTRVOID) /* context */
  501. STRUCT(usbdevfs_getdriver,
  502. TYPE_INT, /* interface */
  503. MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */
  504. STRUCT(usbdevfs_connectinfo,
  505. TYPE_INT, /* devnum */
  506. TYPE_CHAR) /* slow */
  507. STRUCT(usbdevfs_iso_packet_desc,
  508. TYPE_INT, /* length */
  509. TYPE_INT, /* actual_length */
  510. TYPE_INT) /* status */
  511. STRUCT(usbdevfs_urb,
  512. TYPE_CHAR, /* type */
  513. TYPE_CHAR, /* endpoint */
  514. TYPE_INT, /* status */
  515. TYPE_INT, /* flags */
  516. TYPE_PTRVOID, /* buffer */
  517. TYPE_INT, /* buffer_length */
  518. TYPE_INT, /* actual_length */
  519. TYPE_INT, /* start_frame */
  520. TYPE_INT, /* union number_of_packets stream_id */
  521. TYPE_INT, /* error_count */
  522. TYPE_INT, /* signr */
  523. TYPE_PTRVOID, /* usercontext */
  524. MK_ARRAY(MK_STRUCT(STRUCT_usbdevfs_iso_packet_desc), 0)) /* desc */
  525. STRUCT(usbdevfs_ioctl,
  526. TYPE_INT, /* ifno */
  527. TYPE_INT, /* ioctl_code */
  528. TYPE_PTRVOID) /* data */
  529. STRUCT(usbdevfs_hub_portinfo,
  530. TYPE_CHAR, /* nports */
  531. MK_ARRAY(TYPE_CHAR, 127)) /* port */
  532. STRUCT(usbdevfs_disconnect_claim,
  533. TYPE_INT, /* interface */
  534. TYPE_INT, /* flags */
  535. MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */
  536. #endif /* CONFIG_USBFS */