|  | STRUCT_SPECIAL(termios) | 
|  |  | 
|  | STRUCT(winsize, | 
|  | TYPE_SHORT, TYPE_SHORT, TYPE_SHORT, TYPE_SHORT) | 
|  |  | 
|  | STRUCT(serial_multiport_struct, | 
|  | TYPE_INT, TYPE_INT, TYPE_CHAR, TYPE_CHAR, TYPE_INT, TYPE_CHAR, TYPE_CHAR, | 
|  | TYPE_INT, TYPE_CHAR, TYPE_CHAR, TYPE_INT, TYPE_CHAR, TYPE_CHAR, TYPE_INT, | 
|  | MK_ARRAY(TYPE_INT, 32)) | 
|  |  | 
|  | STRUCT(serial_icounter_struct, | 
|  | TYPE_INT, TYPE_INT, TYPE_INT, TYPE_INT, MK_ARRAY(TYPE_INT, 16)) | 
|  |  | 
|  | STRUCT(sockaddr, | 
|  | TYPE_SHORT, MK_ARRAY(TYPE_CHAR, 14)) | 
|  |  | 
|  | STRUCT(rtentry, | 
|  | TYPE_ULONG, MK_STRUCT(STRUCT_sockaddr), MK_STRUCT(STRUCT_sockaddr), MK_STRUCT(STRUCT_sockaddr), | 
|  | TYPE_SHORT, TYPE_SHORT, TYPE_ULONG, TYPE_PTRVOID, TYPE_SHORT, TYPE_PTRVOID, | 
|  | TYPE_ULONG, TYPE_ULONG, TYPE_SHORT) | 
|  |  | 
|  | STRUCT(ifmap, | 
|  | TYPE_ULONG, TYPE_ULONG, TYPE_SHORT, TYPE_CHAR, TYPE_CHAR, TYPE_CHAR, | 
|  | /* Spare 3 bytes */ | 
|  | TYPE_CHAR, TYPE_CHAR, TYPE_CHAR) | 
|  |  | 
|  | /* The *_ifreq_list arrays deal with the fact that struct ifreq has unions */ | 
|  |  | 
|  | STRUCT(sockaddr_ifreq, | 
|  | MK_ARRAY(TYPE_CHAR, IFNAMSIZ), MK_STRUCT(STRUCT_sockaddr)) | 
|  |  | 
|  | STRUCT(short_ifreq, | 
|  | MK_ARRAY(TYPE_CHAR, IFNAMSIZ), TYPE_SHORT) | 
|  |  | 
|  | STRUCT(int_ifreq, | 
|  | MK_ARRAY(TYPE_CHAR, IFNAMSIZ), TYPE_INT) | 
|  |  | 
|  | STRUCT(ifmap_ifreq, | 
|  | MK_ARRAY(TYPE_CHAR, IFNAMSIZ), MK_STRUCT(STRUCT_ifmap)) | 
|  |  | 
|  | STRUCT(char_ifreq, | 
|  | MK_ARRAY(TYPE_CHAR, IFNAMSIZ), | 
|  | MK_ARRAY(TYPE_CHAR, IFNAMSIZ)) | 
|  |  | 
|  | STRUCT(ptr_ifreq, | 
|  | MK_ARRAY(TYPE_CHAR, IFNAMSIZ), TYPE_PTRVOID) | 
|  |  | 
|  | STRUCT(ifconf, | 
|  | TYPE_INT, TYPE_PTRVOID) | 
|  |  | 
|  | STRUCT(arpreq, | 
|  | MK_STRUCT(STRUCT_sockaddr), MK_STRUCT(STRUCT_sockaddr), TYPE_INT, MK_STRUCT(STRUCT_sockaddr), | 
|  | MK_ARRAY(TYPE_CHAR, 16)) | 
|  |  | 
|  | STRUCT(arpreq_old, | 
|  | MK_STRUCT(STRUCT_sockaddr), MK_STRUCT(STRUCT_sockaddr), TYPE_INT, MK_STRUCT(STRUCT_sockaddr)) | 
|  |  | 
|  | STRUCT(cdrom_read_audio, | 
|  | TYPE_CHAR, TYPE_CHAR, TYPE_CHAR, TYPE_CHAR, TYPE_CHAR, TYPE_INT, TYPE_PTRVOID, | 
|  | TYPE_NULL) | 
|  |  | 
|  | STRUCT(hd_geometry, | 
|  | TYPE_CHAR, TYPE_CHAR, TYPE_SHORT, TYPE_ULONG) | 
|  |  | 
|  | STRUCT(dirent, | 
|  | TYPE_LONG, TYPE_LONG, TYPE_SHORT, MK_ARRAY(TYPE_CHAR, 256)) | 
|  |  | 
|  | STRUCT(kbentry, | 
|  | TYPE_CHAR, TYPE_CHAR, TYPE_SHORT) | 
|  |  | 
|  | STRUCT(kbsentry, | 
|  | TYPE_CHAR, MK_ARRAY(TYPE_CHAR, 512)) | 
|  |  | 
|  | STRUCT(audio_buf_info, | 
|  | TYPE_INT, TYPE_INT, TYPE_INT, TYPE_INT) | 
|  |  | 
|  | STRUCT(count_info, | 
|  | TYPE_INT, TYPE_INT, TYPE_INT) | 
|  |  | 
|  | STRUCT(buffmem_desc, | 
|  | TYPE_PTRVOID, TYPE_INT) | 
|  |  | 
|  | STRUCT(mixer_info, | 
|  | MK_ARRAY(TYPE_CHAR, 16), MK_ARRAY(TYPE_CHAR, 32), TYPE_INT, MK_ARRAY(TYPE_INT, 10)) | 
|  |  | 
|  | STRUCT(snd_timer_id, | 
|  | TYPE_INT, /* dev_class */ | 
|  | TYPE_INT, /* dev_sclass */ | 
|  | TYPE_INT, /* card */ | 
|  | TYPE_INT, /* device */ | 
|  | TYPE_INT) /* subdevice */ | 
|  |  | 
|  | STRUCT(snd_timer_ginfo, | 
|  | MK_STRUCT(STRUCT_snd_timer_id), /* tid */ | 
|  | TYPE_INT, /* flags */ | 
|  | TYPE_INT, /* card */ | 
|  | MK_ARRAY(TYPE_CHAR, 64), /* id */ | 
|  | MK_ARRAY(TYPE_CHAR, 80), /* name */ | 
|  | TYPE_ULONG, /* reserved0 */ | 
|  | TYPE_ULONG, /* resolution */ | 
|  | TYPE_ULONG, /* resolution_min */ | 
|  | TYPE_ULONG, /* resolution_max */ | 
|  | TYPE_INT, /* clients */ | 
|  | MK_ARRAY(TYPE_CHAR, 32)) /* reserved */ | 
|  |  | 
|  | STRUCT(snd_timer_gparams, | 
|  | MK_STRUCT(STRUCT_snd_timer_id), /* tid */ | 
|  | TYPE_ULONG, /* period_num */ | 
|  | TYPE_ULONG, /* period_den */ | 
|  | MK_ARRAY(TYPE_CHAR, 32)) /* reserved */ | 
|  |  | 
|  | STRUCT(snd_timer_gstatus, | 
|  | MK_STRUCT(STRUCT_snd_timer_id), /* tid */ | 
|  | TYPE_ULONG, /* resolution */ | 
|  | TYPE_ULONG, /* resolution_num */ | 
|  | TYPE_ULONG, /* resolution_den */ | 
|  | MK_ARRAY(TYPE_CHAR, 32)) /* reserved */ | 
|  |  | 
|  | STRUCT(snd_timer_select, | 
|  | MK_STRUCT(STRUCT_snd_timer_id), /* id */ | 
|  | MK_ARRAY(TYPE_CHAR, 32)) /* reserved */ | 
|  |  | 
|  | STRUCT(snd_timer_info, | 
|  | TYPE_INT, /* flags */ | 
|  | TYPE_INT, /* card */ | 
|  | MK_ARRAY(TYPE_CHAR, 64), /* id */ | 
|  | MK_ARRAY(TYPE_CHAR, 80), /* name */ | 
|  | TYPE_ULONG, /* reserved0 */ | 
|  | TYPE_ULONG, /* resolution */ | 
|  | MK_ARRAY(TYPE_CHAR, 64)) /* reserved */ | 
|  |  | 
|  | STRUCT(snd_timer_params, | 
|  | TYPE_INT, /* flags */ | 
|  | TYPE_INT, /* ticks */ | 
|  | TYPE_INT, /* queue_size */ | 
|  | TYPE_INT, /* reserved0 */ | 
|  | TYPE_INT, /* filter */ | 
|  | MK_ARRAY(TYPE_CHAR, 60)) /* reserved */ | 
|  |  | 
|  | #if defined(TARGET_SPARC64) && !defined(TARGET_ABI32) | 
|  | STRUCT(timeval, | 
|  | TYPE_LONG, /* tv_sec */ | 
|  | TYPE_INT) /* tv_usec */ | 
|  |  | 
|  | STRUCT(_kernel_sock_timeval, | 
|  | TYPE_LONG, /* tv_sec */ | 
|  | TYPE_INT) /* tv_usec */ | 
|  | #else | 
|  | STRUCT(timeval, | 
|  | TYPE_LONG, /* tv_sec */ | 
|  | TYPE_LONG) /* tv_usec */ | 
|  |  | 
|  | STRUCT(_kernel_sock_timeval, | 
|  | TYPE_LONGLONG, /* tv_sec */ | 
|  | TYPE_LONGLONG) /* tv_usec */ | 
|  | #endif | 
|  |  | 
|  | STRUCT(timespec, | 
|  | TYPE_LONG, /* tv_sec */ | 
|  | TYPE_LONG) /* tv_nsec */ | 
|  |  | 
|  | STRUCT(_kernel_timespec, | 
|  | TYPE_LONGLONG, /* tv_sec */ | 
|  | TYPE_LONGLONG) /* tv_nsec */ | 
|  |  | 
|  | STRUCT(snd_timer_status, | 
|  | MK_STRUCT(STRUCT_timespec), /* tstamp */ | 
|  | TYPE_INT, /* resolution */ | 
|  | TYPE_INT, /* lost */ | 
|  | TYPE_INT, /* overrun */ | 
|  | TYPE_INT, /* queue */ | 
|  | MK_ARRAY(TYPE_CHAR, 64)) /* reserved */ | 
|  |  | 
|  | /* loop device ioctls */ | 
|  | STRUCT(loop_info, | 
|  | TYPE_INT,                 /* lo_number */ | 
|  | TYPE_OLDDEVT,             /* lo_device */ | 
|  | TYPE_ULONG,               /* lo_inode */ | 
|  | TYPE_OLDDEVT,             /* lo_rdevice */ | 
|  | TYPE_INT,                 /* lo_offset */ | 
|  | TYPE_INT,                 /* lo_encrypt_type */ | 
|  | TYPE_INT,                 /* lo_encrypt_key_size */ | 
|  | TYPE_INT,                 /* lo_flags */ | 
|  | MK_ARRAY(TYPE_CHAR, 64),  /* lo_name */ | 
|  | MK_ARRAY(TYPE_CHAR, 32),  /* lo_encrypt_key */ | 
|  | MK_ARRAY(TYPE_ULONG, 2),  /* lo_init */ | 
|  | MK_ARRAY(TYPE_CHAR, 4))   /* reserved */ | 
|  |  | 
|  | STRUCT(loop_info64, | 
|  | TYPE_ULONGLONG,           /* lo_device */ | 
|  | TYPE_ULONGLONG,           /* lo_inode */ | 
|  | TYPE_ULONGLONG,           /* lo_rdevice */ | 
|  | TYPE_ULONGLONG,           /* lo_offset */ | 
|  | TYPE_ULONGLONG,           /* lo_sizelimit */ | 
|  | TYPE_INT,                 /* lo_number */ | 
|  | TYPE_INT,                 /* lo_encrypt_type */ | 
|  | TYPE_INT,                 /* lo_encrypt_key_size */ | 
|  | TYPE_INT,                 /* lo_flags */ | 
|  | MK_ARRAY(TYPE_CHAR, 64),  /* lo_name */ | 
|  | MK_ARRAY(TYPE_CHAR, 64),  /* lo_crypt_name */ | 
|  | MK_ARRAY(TYPE_CHAR, 32),  /* lo_encrypt_key */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, 2))  /* lo_init */ | 
|  |  | 
|  | STRUCT(loop_config, | 
|  | TYPE_INT,                 /* fd */ | 
|  | TYPE_INT,                 /* block_size */ | 
|  | MK_STRUCT(STRUCT_loop_info64), /* info */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, 8)) /* __reserved */ | 
|  |  | 
|  | /* mag tape ioctls */ | 
|  | STRUCT(mtop, TYPE_SHORT, TYPE_INT) | 
|  | STRUCT(mtget, TYPE_LONG, TYPE_LONG, TYPE_LONG, TYPE_LONG, TYPE_LONG, | 
|  | TYPE_INT, TYPE_INT) | 
|  | STRUCT(mtpos, TYPE_LONG) | 
|  |  | 
|  | STRUCT(fb_fix_screeninfo, | 
|  | MK_ARRAY(TYPE_CHAR, 16), /* id */ | 
|  | TYPE_ULONG, /* smem_start */ | 
|  | TYPE_INT, /* smem_len */ | 
|  | TYPE_INT, /* type */ | 
|  | TYPE_INT, /* type_aux */ | 
|  | TYPE_INT, /* visual */ | 
|  | TYPE_SHORT, /* xpanstep */ | 
|  | TYPE_SHORT, /* ypanstep */ | 
|  | TYPE_SHORT, /* ywrapstep */ | 
|  | TYPE_INT, /* line_length */ | 
|  | TYPE_ULONG, /* mmio_start */ | 
|  | TYPE_INT, /* mmio_len */ | 
|  | TYPE_INT, /* accel */ | 
|  | MK_ARRAY(TYPE_CHAR, 3)) /* reserved */ | 
|  |  | 
|  | STRUCT(fb_var_screeninfo, | 
|  | TYPE_INT, /* xres */ | 
|  | TYPE_INT, /* yres */ | 
|  | TYPE_INT, /* xres_virtual */ | 
|  | TYPE_INT, /* yres_virtual */ | 
|  | TYPE_INT, /* xoffset */ | 
|  | TYPE_INT, /* yoffset */ | 
|  | TYPE_INT, /* bits_per_pixel */ | 
|  | TYPE_INT, /* grayscale */ | 
|  | MK_ARRAY(TYPE_INT, 3), /* red */ | 
|  | MK_ARRAY(TYPE_INT, 3), /* green */ | 
|  | MK_ARRAY(TYPE_INT, 3), /* blue */ | 
|  | MK_ARRAY(TYPE_INT, 3), /* transp */ | 
|  | TYPE_INT, /* nonstd */ | 
|  | TYPE_INT, /* activate */ | 
|  | TYPE_INT, /* height */ | 
|  | TYPE_INT, /* width */ | 
|  | TYPE_INT, /* accel_flags */ | 
|  | TYPE_INT, /* pixclock */ | 
|  | TYPE_INT, /* left_margin */ | 
|  | TYPE_INT, /* right_margin */ | 
|  | TYPE_INT, /* upper_margin */ | 
|  | TYPE_INT, /* lower_margin */ | 
|  | TYPE_INT, /* hsync_len */ | 
|  | TYPE_INT, /* vsync_len */ | 
|  | TYPE_INT, /* sync */ | 
|  | TYPE_INT, /* vmode */ | 
|  | TYPE_INT, /* rotate */ | 
|  | MK_ARRAY(TYPE_INT, 5)) /* reserved */ | 
|  |  | 
|  | STRUCT(fb_cmap, | 
|  | TYPE_INT, /* start  */ | 
|  | TYPE_INT, /* len    */ | 
|  | TYPE_PTRVOID, /* red    */ | 
|  | TYPE_PTRVOID, /* green  */ | 
|  | TYPE_PTRVOID, /* blue   */ | 
|  | TYPE_PTRVOID) /* transp */ | 
|  |  | 
|  | STRUCT(fb_con2fbmap, | 
|  | TYPE_INT, /* console     */ | 
|  | TYPE_INT) /* framebuffer */ | 
|  |  | 
|  |  | 
|  | STRUCT(vt_stat, | 
|  | TYPE_SHORT, /* v_active */ | 
|  | TYPE_SHORT, /* v_signal */ | 
|  | TYPE_SHORT) /* v_state */ | 
|  |  | 
|  | STRUCT(vt_mode, | 
|  | TYPE_CHAR,  /* mode   */ | 
|  | TYPE_CHAR,  /* waitv  */ | 
|  | TYPE_SHORT, /* relsig */ | 
|  | TYPE_SHORT, /* acqsig */ | 
|  | TYPE_SHORT) /* frsig  */ | 
|  |  | 
|  | STRUCT(dm_ioctl, | 
|  | MK_ARRAY(TYPE_INT, 3), /* version */ | 
|  | TYPE_INT, /* data_size */ | 
|  | TYPE_INT, /* data_start */ | 
|  | TYPE_INT, /* target_count*/ | 
|  | TYPE_INT, /* open_count */ | 
|  | TYPE_INT, /* flags */ | 
|  | TYPE_INT, /* event_nr */ | 
|  | TYPE_INT, /* padding */ | 
|  | TYPE_ULONGLONG, /* dev */ | 
|  | MK_ARRAY(TYPE_CHAR, 128), /* name */ | 
|  | MK_ARRAY(TYPE_CHAR, 129), /* uuid */ | 
|  | MK_ARRAY(TYPE_CHAR, 7)) /* data */ | 
|  |  | 
|  | STRUCT(dm_target_spec, | 
|  | TYPE_ULONGLONG, /* sector_start */ | 
|  | TYPE_ULONGLONG, /* length */ | 
|  | TYPE_INT, /* status */ | 
|  | TYPE_INT, /* next */ | 
|  | MK_ARRAY(TYPE_CHAR, 16)) /* target_type */ | 
|  |  | 
|  | STRUCT(dm_target_deps, | 
|  | TYPE_INT, /* count */ | 
|  | TYPE_INT) /* padding */ | 
|  |  | 
|  | STRUCT(dm_name_list, | 
|  | TYPE_ULONGLONG, /* dev */ | 
|  | TYPE_INT) /* next */ | 
|  |  | 
|  | STRUCT(dm_target_versions, | 
|  | TYPE_INT, /* next */ | 
|  | MK_ARRAY(TYPE_INT, 3)) /* version*/ | 
|  |  | 
|  | STRUCT(dm_target_msg, | 
|  | TYPE_ULONGLONG) /* sector */ | 
|  |  | 
|  | STRUCT(drm_version, | 
|  | TYPE_INT, /* version_major */ | 
|  | TYPE_INT, /* version_minor */ | 
|  | TYPE_INT, /* version_patchlevel */ | 
|  | TYPE_ULONG, /* name_len */ | 
|  | TYPE_PTRVOID, /* name */ | 
|  | TYPE_ULONG, /* date_len */ | 
|  | TYPE_PTRVOID, /* date */ | 
|  | TYPE_ULONG, /* desc_len */ | 
|  | TYPE_PTRVOID) /* desc */ | 
|  |  | 
|  | STRUCT(drm_i915_getparam, | 
|  | TYPE_INT, /* param */ | 
|  | TYPE_PTRVOID) /* value */ | 
|  |  | 
|  | STRUCT(file_clone_range, | 
|  | TYPE_LONGLONG, /* src_fd */ | 
|  | TYPE_ULONGLONG, /* src_offset */ | 
|  | TYPE_ULONGLONG, /* src_length */ | 
|  | TYPE_ULONGLONG) /* dest_offset */ | 
|  |  | 
|  | STRUCT(fstrim_range, | 
|  | TYPE_ULONGLONG, /* start */ | 
|  | TYPE_ULONGLONG, /* len */ | 
|  | TYPE_ULONGLONG) /* minlen */ | 
|  |  | 
|  | STRUCT(fiemap_extent, | 
|  | TYPE_ULONGLONG, /* fe_logical */ | 
|  | TYPE_ULONGLONG, /* fe_physical */ | 
|  | TYPE_ULONGLONG, /* fe_length */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, 2), /* fe_reserved64[2] */ | 
|  | TYPE_INT, /* fe_flags */ | 
|  | MK_ARRAY(TYPE_INT, 3)) /* fe_reserved[3] */ | 
|  |  | 
|  | STRUCT(fiemap, | 
|  | TYPE_ULONGLONG, /* fm_start */ | 
|  | TYPE_ULONGLONG, /* fm_length */ | 
|  | TYPE_INT, /* fm_flags */ | 
|  | TYPE_INT, /* fm_mapped_extents */ | 
|  | TYPE_INT, /* fm_extent_count */ | 
|  | TYPE_INT) /* fm_reserved */ | 
|  |  | 
|  | STRUCT(blkpg_partition, | 
|  | TYPE_LONGLONG, /* start */ | 
|  | TYPE_LONGLONG, /* length */ | 
|  | TYPE_INT, /* pno */ | 
|  | MK_ARRAY(TYPE_CHAR, BLKPG_DEVNAMELTH), /* devname */ | 
|  | MK_ARRAY(TYPE_CHAR, BLKPG_VOLNAMELTH)) /* volname */ | 
|  |  | 
|  | #if defined(BTRFS_IOC_SUBVOL_CREATE) || defined(BTRFS_IOC_SNAP_CREATE) || \ | 
|  | defined(BTRFS_IOC_SNAP_DESTROY)  || defined(BTRFS_IOC_SCAN_DEV)  || \ | 
|  | defined(BTRFS_IOC_FORGET_DEV)    || defined(BTRFS_IOC_ADD_DEV) || \ | 
|  | defined(BTRFS_IOC_RM_DEV)        || defined(BTRFS_IOC_DEV_INFO) | 
|  | STRUCT(btrfs_ioctl_vol_args, | 
|  | TYPE_LONGLONG, /* fd */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_PATH_NAME_MAX + 1)) /* name */ | 
|  | #endif | 
|  |  | 
|  | #ifdef BTRFS_IOC_GET_SUBVOL_INFO | 
|  | STRUCT(btrfs_ioctl_timespec, | 
|  | TYPE_ULONGLONG, /* sec */ | 
|  | TYPE_INT) /* nsec */ | 
|  |  | 
|  | STRUCT(btrfs_ioctl_get_subvol_info_args, | 
|  | TYPE_ULONGLONG, /* treeid */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_VOL_NAME_MAX + 1), | 
|  | TYPE_ULONGLONG, /* parentid */ | 
|  | TYPE_ULONGLONG, /* dirid */ | 
|  | TYPE_ULONGLONG, /* generation */ | 
|  | TYPE_ULONGLONG, /* flags */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_UUID_SIZE), /* uuid */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_UUID_SIZE), /* parent_uuid */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_UUID_SIZE), /* received_uuid */ | 
|  | TYPE_ULONGLONG, /* ctransid */ | 
|  | TYPE_ULONGLONG, /* otransid */ | 
|  | TYPE_ULONGLONG, /* stransid */ | 
|  | TYPE_ULONGLONG, /* rtransid */ | 
|  | MK_STRUCT(STRUCT_btrfs_ioctl_timespec), /* ctime */ | 
|  | MK_STRUCT(STRUCT_btrfs_ioctl_timespec), /* otime */ | 
|  | MK_STRUCT(STRUCT_btrfs_ioctl_timespec), /* stime */ | 
|  | MK_STRUCT(STRUCT_btrfs_ioctl_timespec), /* rtime */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, 8)) /* reserved */ | 
|  | #endif | 
|  |  | 
|  | #ifdef BTRFS_IOC_INO_LOOKUP | 
|  | STRUCT(btrfs_ioctl_ino_lookup_args, | 
|  | TYPE_ULONGLONG, /* treeid */ | 
|  | TYPE_ULONGLONG, /* objectid */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_INO_LOOKUP_PATH_MAX)) /* name */ | 
|  | #endif | 
|  |  | 
|  | #ifdef BTRFS_IOC_INO_PATHS | 
|  | STRUCT(btrfs_ioctl_ino_path_args, | 
|  | TYPE_ULONGLONG, /* inum */ | 
|  | TYPE_ULONGLONG, /* size */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, 4), /* reserved */ | 
|  | TYPE_ULONGLONG) /* fspath */ | 
|  | #endif | 
|  |  | 
|  | #if defined(BTRFS_IOC_LOGICAL_INO) || defined(BTRFS_IOC_LOGICAL_INO_V2) | 
|  | STRUCT(btrfs_ioctl_logical_ino_args, | 
|  | TYPE_ULONGLONG, /* logical */ | 
|  | TYPE_ULONGLONG, /* size */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, 3), /* reserved */ | 
|  | TYPE_ULONGLONG, /* flags */ | 
|  | TYPE_ULONGLONG) /* inodes */ | 
|  | #endif | 
|  |  | 
|  | #ifdef BTRFS_IOC_INO_LOOKUP_USER | 
|  | STRUCT(btrfs_ioctl_ino_lookup_user_args, | 
|  | TYPE_ULONGLONG, /* dirid */ | 
|  | TYPE_ULONGLONG, /* treeid */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_VOL_NAME_MAX + 1), /* name */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_INO_LOOKUP_USER_PATH_MAX)) /* path */ | 
|  | #endif | 
|  |  | 
|  | #if defined(BTRFS_IOC_SCRUB) || defined(BTRFS_IOC_SCRUB_PROGRESS) | 
|  | STRUCT(btrfs_scrub_progress, | 
|  | TYPE_ULONGLONG, /* data_extents_scrubbed */ | 
|  | TYPE_ULONGLONG, /* tree_extents_scrubbed */ | 
|  | TYPE_ULONGLONG, /* data_bytes_scrubbed */ | 
|  | TYPE_ULONGLONG, /* tree_bytes_scrubbed */ | 
|  | TYPE_ULONGLONG, /* read_errors */ | 
|  | TYPE_ULONGLONG, /* csum_errors */ | 
|  | TYPE_ULONGLONG, /* verify_errors */ | 
|  | TYPE_ULONGLONG, /* no_csum */ | 
|  | TYPE_ULONGLONG, /* csum_discards */ | 
|  | TYPE_ULONGLONG, /* super_errors */ | 
|  | TYPE_ULONGLONG, /* malloc_errors */ | 
|  | TYPE_ULONGLONG, /* uncorrectable_errors */ | 
|  | TYPE_ULONGLONG, /* corrected_er */ | 
|  | TYPE_ULONGLONG, /* last_physical */ | 
|  | TYPE_ULONGLONG) /* unverified_errors */ | 
|  |  | 
|  | STRUCT(btrfs_ioctl_scrub_args, | 
|  | TYPE_ULONGLONG, /* devid */ | 
|  | TYPE_ULONGLONG, /* start */ | 
|  | TYPE_ULONGLONG, /* end */ | 
|  | TYPE_ULONGLONG, /* flags */ | 
|  | MK_STRUCT(STRUCT_btrfs_scrub_progress), /* progress */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, | 
|  | (1024 - 32 - | 
|  | sizeof(struct btrfs_scrub_progress)) / 8)) /* unused */ | 
|  | #endif | 
|  |  | 
|  | #ifdef BTRFS_IOC_DEV_INFO | 
|  | STRUCT(btrfs_ioctl_dev_info_args, | 
|  | TYPE_ULONGLONG, /* devid */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_UUID_SIZE), /* uuid */ | 
|  | TYPE_ULONGLONG, /* bytes_used */ | 
|  | TYPE_ULONGLONG, /* total_bytes */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, 379), /* unused */ | 
|  | MK_ARRAY(TYPE_CHAR, BTRFS_DEVICE_PATH_NAME_MAX)) /* path */ | 
|  | #endif | 
|  |  | 
|  | #ifdef BTRFS_IOC_GET_SUBVOL_ROOTREF | 
|  | STRUCT(rootref, | 
|  | TYPE_ULONGLONG, /* treeid */ | 
|  | TYPE_ULONGLONG) /* dirid */ | 
|  |  | 
|  | STRUCT(btrfs_ioctl_get_subvol_rootref_args, | 
|  | TYPE_ULONGLONG, /* min_treeid */ | 
|  | MK_ARRAY(MK_STRUCT(STRUCT_rootref), | 
|  | BTRFS_MAX_ROOTREF_BUFFER_NUM), /* rootref */ | 
|  | TYPE_CHAR, /* num_items */ | 
|  | MK_ARRAY(TYPE_CHAR, 7)) /* align */ | 
|  | #endif | 
|  |  | 
|  | #ifdef BTRFS_IOC_GET_DEV_STATS | 
|  | STRUCT(btrfs_ioctl_get_dev_stats, | 
|  | TYPE_ULONGLONG, /* devid */ | 
|  | TYPE_ULONGLONG, /* nr_items */ | 
|  | TYPE_ULONGLONG, /* flags */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, BTRFS_DEV_STAT_VALUES_MAX), /* values */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, | 
|  | 128 - 2 - BTRFS_DEV_STAT_VALUES_MAX)) /* unused */ | 
|  | #endif | 
|  |  | 
|  | STRUCT(btrfs_ioctl_quota_ctl_args, | 
|  | TYPE_ULONGLONG, /* cmd */ | 
|  | TYPE_ULONGLONG) /* status */ | 
|  |  | 
|  | STRUCT(btrfs_ioctl_quota_rescan_args, | 
|  | TYPE_ULONGLONG, /* flags */ | 
|  | TYPE_ULONGLONG, /* progress */ | 
|  | MK_ARRAY(TYPE_ULONGLONG, 6)) /* reserved */ | 
|  |  | 
|  | STRUCT(btrfs_ioctl_qgroup_assign_args, | 
|  | TYPE_ULONGLONG, /* assign */ | 
|  | TYPE_ULONGLONG, /* src */ | 
|  | TYPE_ULONGLONG) /* dst */ | 
|  |  | 
|  | STRUCT(btrfs_ioctl_qgroup_create_args, | 
|  | TYPE_ULONGLONG, /* create */ | 
|  | TYPE_ULONGLONG) /* qgroupid */ | 
|  |  | 
|  | STRUCT(btrfs_qgroup_limit, | 
|  | TYPE_ULONGLONG, /* flags */ | 
|  | TYPE_ULONGLONG, /* max_rfer */ | 
|  | TYPE_ULONGLONG, /* max_excl */ | 
|  | TYPE_ULONGLONG, /* rsv_rfer */ | 
|  | TYPE_ULONGLONG) /* rsv_excl */ | 
|  |  | 
|  | STRUCT(btrfs_ioctl_qgroup_limit_args, | 
|  | TYPE_ULONGLONG, /* qgroupid */ | 
|  | MK_STRUCT(STRUCT_btrfs_qgroup_limit)) /* lim */ | 
|  |  | 
|  | STRUCT(btrfs_ioctl_feature_flags, | 
|  | TYPE_ULONGLONG, /* compat_flags */ | 
|  | TYPE_ULONGLONG, /* compat_ro_flags */ | 
|  | TYPE_ULONGLONG) /* incompat_flags */ | 
|  |  | 
|  | STRUCT(rtc_time, | 
|  | TYPE_INT, /* tm_sec */ | 
|  | TYPE_INT, /* tm_min */ | 
|  | TYPE_INT, /* tm_hour */ | 
|  | TYPE_INT, /* tm_mday */ | 
|  | TYPE_INT, /* tm_mon */ | 
|  | TYPE_INT, /* tm_year */ | 
|  | TYPE_INT, /* tm_wday */ | 
|  | TYPE_INT, /* tm_yday */ | 
|  | TYPE_INT) /* tm_isdst */ | 
|  |  | 
|  | STRUCT(rtc_wkalrm, | 
|  | TYPE_CHAR, /* enabled */ | 
|  | TYPE_CHAR, /* pending */ | 
|  | MK_STRUCT(STRUCT_rtc_time)) /* time */ | 
|  |  | 
|  | STRUCT(rtc_pll_info, | 
|  | TYPE_INT, /* pll_ctrl */ | 
|  | TYPE_INT, /* pll_value */ | 
|  | TYPE_INT, /* pll_max */ | 
|  | TYPE_INT, /* pll_min */ | 
|  | TYPE_INT, /* pll_posmult */ | 
|  | TYPE_INT, /* pll_negmult */ | 
|  | TYPE_LONG) /* pll_clock */ | 
|  |  | 
|  | STRUCT(blkpg_ioctl_arg, | 
|  | TYPE_INT, /* op */ | 
|  | TYPE_INT, /* flags */ | 
|  | TYPE_INT, /* datalen */ | 
|  | TYPE_PTRVOID) /* data */ | 
|  |  | 
|  | STRUCT(format_descr, | 
|  | TYPE_INT,     /* device */ | 
|  | TYPE_INT,     /* head */ | 
|  | TYPE_INT)     /* track */ | 
|  |  | 
|  | STRUCT(floppy_max_errors, | 
|  | TYPE_INT, /* abort */ | 
|  | TYPE_INT, /* read_track */ | 
|  | TYPE_INT, /* reset */ | 
|  | TYPE_INT, /* recal */ | 
|  | TYPE_INT) /* reporting */ | 
|  |  | 
|  | #if defined(CONFIG_USBFS) | 
|  | /* usb device ioctls */ | 
|  | STRUCT(usbdevfs_ctrltransfer, | 
|  | TYPE_CHAR, /* bRequestType */ | 
|  | TYPE_CHAR, /* bRequest */ | 
|  | TYPE_SHORT, /* wValue */ | 
|  | TYPE_SHORT, /* wIndex */ | 
|  | TYPE_SHORT, /* wLength */ | 
|  | TYPE_INT, /* timeout */ | 
|  | TYPE_PTRVOID) /* data */ | 
|  |  | 
|  | STRUCT(usbdevfs_bulktransfer, | 
|  | TYPE_INT, /* ep */ | 
|  | TYPE_INT, /* len */ | 
|  | TYPE_INT, /* timeout */ | 
|  | TYPE_PTRVOID) /* data */ | 
|  |  | 
|  | STRUCT(usbdevfs_setinterface, | 
|  | TYPE_INT, /* interface */ | 
|  | TYPE_INT) /* altsetting */ | 
|  |  | 
|  | STRUCT(usbdevfs_disconnectsignal, | 
|  | TYPE_INT, /* signr */ | 
|  | TYPE_PTRVOID) /* context */ | 
|  |  | 
|  | STRUCT(usbdevfs_getdriver, | 
|  | TYPE_INT, /* interface */ | 
|  | MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */ | 
|  |  | 
|  | STRUCT(usbdevfs_connectinfo, | 
|  | TYPE_INT, /* devnum */ | 
|  | TYPE_CHAR) /* slow */ | 
|  |  | 
|  | STRUCT(usbdevfs_iso_packet_desc, | 
|  | TYPE_INT, /* length */ | 
|  | TYPE_INT, /* actual_length */ | 
|  | TYPE_INT) /* status */ | 
|  |  | 
|  | STRUCT(usbdevfs_urb, | 
|  | TYPE_CHAR, /* type */ | 
|  | TYPE_CHAR, /* endpoint */ | 
|  | TYPE_INT, /* status */ | 
|  | TYPE_INT, /* flags */ | 
|  | TYPE_PTRVOID, /* buffer */ | 
|  | TYPE_INT, /* buffer_length */ | 
|  | TYPE_INT, /* actual_length */ | 
|  | TYPE_INT, /* start_frame */ | 
|  | TYPE_INT, /* union number_of_packets stream_id */ | 
|  | TYPE_INT, /* error_count */ | 
|  | TYPE_INT, /* signr */ | 
|  | TYPE_PTRVOID, /* usercontext */ | 
|  | MK_ARRAY(MK_STRUCT(STRUCT_usbdevfs_iso_packet_desc), 0)) /* desc */ | 
|  |  | 
|  | STRUCT(usbdevfs_ioctl, | 
|  | TYPE_INT, /* ifno */ | 
|  | TYPE_INT, /* ioctl_code */ | 
|  | TYPE_PTRVOID) /* data */ | 
|  |  | 
|  | STRUCT(usbdevfs_hub_portinfo, | 
|  | TYPE_CHAR, /* nports */ | 
|  | MK_ARRAY(TYPE_CHAR, 127)) /* port */ | 
|  |  | 
|  | STRUCT(usbdevfs_disconnect_claim, | 
|  | TYPE_INT, /* interface */ | 
|  | TYPE_INT, /* flags */ | 
|  | MK_ARRAY(TYPE_CHAR, USBDEVFS_MAXDRIVERNAME + 1)) /* driver */ | 
|  | #endif /* CONFIG_USBFS */ |