start work on nihed-cros-libva
[nihav-player.git] / nihed-cros-libva / src / bindings / va.rs
diff --git a/nihed-cros-libva/src/bindings/va.rs b/nihed-cros-libva/src/bindings/va.rs
new file mode 100644 (file)
index 0000000..42bbd82
--- /dev/null
@@ -0,0 +1,8131 @@
+/* automatically generated by tools/bindgen-all-the-things */
+
+#![allow(clippy::missing_safety_doc)]
+#![allow(clippy::upper_case_acronyms)]
+#![allow(non_upper_case_globals)]
+#![allow(non_camel_case_types)]
+#![allow(non_snake_case)]
+#![allow(dead_code)]
+
+pub mod constants;
+
+#[repr(C)]
+#[derive(Copy, Clone, Debug, Default, Eq, Hash, Ord, PartialEq, PartialOrd)]
+pub struct __BindgenBitfieldUnit<Storage> {
+    storage: Storage,
+}
+impl<Storage> __BindgenBitfieldUnit<Storage> {
+    #[inline]
+    pub const fn new(storage: Storage) -> Self {
+        Self { storage }
+    }
+}
+impl<Storage> __BindgenBitfieldUnit<Storage>
+where
+    Storage: AsRef<[u8]> + AsMut<[u8]>,
+{
+    #[inline]
+    pub fn get_bit(&self, index: usize) -> bool {
+        debug_assert!(index / 8 < self.storage.as_ref().len());
+        let byte_index = index / 8;
+        let byte = self.storage.as_ref()[byte_index];
+        let bit_index = if cfg!(target_endian = "big") {
+            7 - (index % 8)
+        } else {
+            index % 8
+        };
+        let mask = 1 << bit_index;
+        byte & mask == mask
+    }
+    #[inline]
+    pub fn set_bit(&mut self, index: usize, val: bool) {
+        debug_assert!(index / 8 < self.storage.as_ref().len());
+        let byte_index = index / 8;
+        let byte = &mut self.storage.as_mut()[byte_index];
+        let bit_index = if cfg!(target_endian = "big") {
+            7 - (index % 8)
+        } else {
+            index % 8
+        };
+        let mask = 1 << bit_index;
+        if val {
+            *byte |= mask;
+        } else {
+            *byte &= !mask;
+        }
+    }
+    #[inline]
+    pub fn get(&self, bit_offset: usize, bit_width: u8) -> u64 {
+        debug_assert!(bit_width <= 64);
+        debug_assert!(bit_offset / 8 < self.storage.as_ref().len());
+        debug_assert!((bit_offset + (bit_width as usize)) / 8 <= self.storage.as_ref().len());
+        let mut val = 0;
+        for i in 0..(bit_width as usize) {
+            if self.get_bit(i + bit_offset) {
+                let index = if cfg!(target_endian = "big") {
+                    bit_width as usize - 1 - i
+                } else {
+                    i
+                };
+                val |= 1 << index;
+            }
+        }
+        val
+    }
+    #[inline]
+    pub fn set(&mut self, bit_offset: usize, bit_width: u8, val: u64) {
+        debug_assert!(bit_width <= 64);
+        debug_assert!(bit_offset / 8 < self.storage.as_ref().len());
+        debug_assert!((bit_offset + (bit_width as usize)) / 8 <= self.storage.as_ref().len());
+        for i in 0..(bit_width as usize) {
+            let mask = 1 << i;
+            let val_bit_is_set = val & mask == mask;
+            let index = if cfg!(target_endian = "big") {
+                bit_width as usize - 1 - i
+            } else {
+                i
+            };
+            self.set_bit(index + bit_offset, val_bit_is_set);
+        }
+    }
+}
+pub type __int8_t = ::std::os::raw::c_schar;
+pub type __uint8_t = ::std::os::raw::c_uchar;
+pub type __int16_t = ::std::os::raw::c_short;
+pub type __uint16_t = ::std::os::raw::c_ushort;
+pub type __int32_t = ::std::os::raw::c_int;
+pub type __uint32_t = ::std::os::raw::c_uint;
+pub type __uint64_t = ::std::os::raw::c_ulong;
+pub type VADisplay = *mut ::std::os::raw::c_void;
+pub type VAStatus = ::std::os::raw::c_int;
+extern "C" {
+    pub fn vaErrorStr(error_status: VAStatus) -> *const ::std::os::raw::c_char;
+}
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAMotionVector {
+    pub mv0: [i16; 2usize],
+    pub mv1: [i16; 2usize],
+}
+pub type VAMotionVector = _VAMotionVector;
+pub type VAMessageCallback = ::std::option::Option<
+    unsafe extern "C" fn(
+        user_context: *mut ::std::os::raw::c_void,
+        message: *const ::std::os::raw::c_char,
+    ),
+>;
+extern "C" {
+    pub fn vaSetErrorCallback(
+        dpy: VADisplay,
+        callback: VAMessageCallback,
+        user_context: *mut ::std::os::raw::c_void,
+    ) -> VAMessageCallback;
+}
+extern "C" {
+    pub fn vaSetInfoCallback(
+        dpy: VADisplay,
+        callback: VAMessageCallback,
+        user_context: *mut ::std::os::raw::c_void,
+    ) -> VAMessageCallback;
+}
+extern "C" {
+    pub fn vaDisplayIsValid(dpy: VADisplay) -> ::std::os::raw::c_int;
+}
+extern "C" {
+    pub fn vaSetDriverName(dpy: VADisplay, driver_name: *mut ::std::os::raw::c_char) -> VAStatus;
+}
+extern "C" {
+    pub fn vaInitialize(
+        dpy: VADisplay,
+        major_version: *mut ::std::os::raw::c_int,
+        minor_version: *mut ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaTerminate(dpy: VADisplay) -> VAStatus;
+}
+extern "C" {
+    pub fn vaQueryVendorString(dpy: VADisplay) -> *const ::std::os::raw::c_char;
+}
+pub type VAPrivFunc = ::std::option::Option<unsafe extern "C" fn() -> ::std::os::raw::c_int>;
+extern "C" {
+    pub fn vaGetLibFunc(dpy: VADisplay, func: *const ::std::os::raw::c_char) -> VAPrivFunc;
+}
+pub mod VAProfile {
+    pub type Type = ::std::os::raw::c_int;
+    pub const VAProfileNone: Type = -1;
+    pub const VAProfileMPEG2Simple: Type = 0;
+    pub const VAProfileMPEG2Main: Type = 1;
+    pub const VAProfileMPEG4Simple: Type = 2;
+    pub const VAProfileMPEG4AdvancedSimple: Type = 3;
+    pub const VAProfileMPEG4Main: Type = 4;
+    pub const VAProfileH264Baseline: Type = 5;
+    pub const VAProfileH264Main: Type = 6;
+    pub const VAProfileH264High: Type = 7;
+    pub const VAProfileVC1Simple: Type = 8;
+    pub const VAProfileVC1Main: Type = 9;
+    pub const VAProfileVC1Advanced: Type = 10;
+    pub const VAProfileH263Baseline: Type = 11;
+    pub const VAProfileJPEGBaseline: Type = 12;
+    pub const VAProfileH264ConstrainedBaseline: Type = 13;
+    pub const VAProfileVP8Version0_3: Type = 14;
+    pub const VAProfileH264MultiviewHigh: Type = 15;
+    pub const VAProfileH264StereoHigh: Type = 16;
+    pub const VAProfileHEVCMain: Type = 17;
+    pub const VAProfileHEVCMain10: Type = 18;
+    pub const VAProfileVP9Profile0: Type = 19;
+    pub const VAProfileVP9Profile1: Type = 20;
+    pub const VAProfileVP9Profile2: Type = 21;
+    pub const VAProfileVP9Profile3: Type = 22;
+    pub const VAProfileHEVCMain12: Type = 23;
+    pub const VAProfileHEVCMain422_10: Type = 24;
+    pub const VAProfileHEVCMain422_12: Type = 25;
+    pub const VAProfileHEVCMain444: Type = 26;
+    pub const VAProfileHEVCMain444_10: Type = 27;
+    pub const VAProfileHEVCMain444_12: Type = 28;
+    pub const VAProfileHEVCSccMain: Type = 29;
+    pub const VAProfileHEVCSccMain10: Type = 30;
+    pub const VAProfileHEVCSccMain444: Type = 31;
+    pub const VAProfileAV1Profile0: Type = 32;
+    pub const VAProfileAV1Profile1: Type = 33;
+    pub const VAProfileHEVCSccMain444_10: Type = 34;
+    pub const VAProfileProtected: Type = 35;
+}
+pub mod VAEntrypoint {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VAEntrypointVLD: Type = 1;
+    pub const VAEntrypointIZZ: Type = 2;
+    pub const VAEntrypointIDCT: Type = 3;
+    pub const VAEntrypointMoComp: Type = 4;
+    pub const VAEntrypointDeblocking: Type = 5;
+    pub const VAEntrypointEncSlice: Type = 6;
+    pub const VAEntrypointEncPicture: Type = 7;
+    pub const VAEntrypointEncSliceLP: Type = 8;
+    pub const VAEntrypointVideoProc: Type = 10;
+    pub const VAEntrypointFEI: Type = 11;
+    pub const VAEntrypointStats: Type = 12;
+    pub const VAEntrypointProtectedTEEComm: Type = 13;
+    pub const VAEntrypointProtectedContent: Type = 14;
+}
+pub mod VAConfigAttribType {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VAConfigAttribRTFormat: Type = 0;
+    pub const VAConfigAttribSpatialResidual: Type = 1;
+    pub const VAConfigAttribSpatialClipping: Type = 2;
+    pub const VAConfigAttribIntraResidual: Type = 3;
+    pub const VAConfigAttribEncryption: Type = 4;
+    pub const VAConfigAttribRateControl: Type = 5;
+    pub const VAConfigAttribDecSliceMode: Type = 6;
+    pub const VAConfigAttribDecJPEG: Type = 7;
+    pub const VAConfigAttribDecProcessing: Type = 8;
+    pub const VAConfigAttribEncPackedHeaders: Type = 10;
+    pub const VAConfigAttribEncInterlaced: Type = 11;
+    pub const VAConfigAttribEncMaxRefFrames: Type = 13;
+    pub const VAConfigAttribEncMaxSlices: Type = 14;
+    pub const VAConfigAttribEncSliceStructure: Type = 15;
+    pub const VAConfigAttribEncMacroblockInfo: Type = 16;
+    pub const VAConfigAttribMaxPictureWidth: Type = 18;
+    pub const VAConfigAttribMaxPictureHeight: Type = 19;
+    pub const VAConfigAttribEncJPEG: Type = 20;
+    pub const VAConfigAttribEncQualityRange: Type = 21;
+    pub const VAConfigAttribEncQuantization: Type = 22;
+    pub const VAConfigAttribEncIntraRefresh: Type = 23;
+    pub const VAConfigAttribEncSkipFrame: Type = 24;
+    pub const VAConfigAttribEncROI: Type = 25;
+    pub const VAConfigAttribEncRateControlExt: Type = 26;
+    pub const VAConfigAttribProcessingRate: Type = 27;
+    pub const VAConfigAttribEncDirtyRect: Type = 28;
+    pub const VAConfigAttribEncParallelRateControl: Type = 29;
+    pub const VAConfigAttribEncDynamicScaling: Type = 30;
+    pub const VAConfigAttribFrameSizeToleranceSupport: Type = 31;
+    pub const VAConfigAttribFEIFunctionType: Type = 32;
+    pub const VAConfigAttribFEIMVPredictors: Type = 33;
+    pub const VAConfigAttribStats: Type = 34;
+    pub const VAConfigAttribEncTileSupport: Type = 35;
+    pub const VAConfigAttribCustomRoundingControl: Type = 36;
+    pub const VAConfigAttribQPBlockSize: Type = 37;
+    pub const VAConfigAttribMaxFrameSize: Type = 38;
+    pub const VAConfigAttribPredictionDirection: Type = 39;
+    pub const VAConfigAttribMultipleFrame: Type = 40;
+    pub const VAConfigAttribContextPriority: Type = 41;
+    pub const VAConfigAttribDecAV1Features: Type = 42;
+    pub const VAConfigAttribTEEType: Type = 43;
+    pub const VAConfigAttribTEETypeClient: Type = 44;
+    pub const VAConfigAttribProtectedContentCipherAlgorithm: Type = 45;
+    pub const VAConfigAttribProtectedContentCipherBlockSize: Type = 46;
+    pub const VAConfigAttribProtectedContentCipherMode: Type = 47;
+    pub const VAConfigAttribProtectedContentCipherSampleType: Type = 48;
+    pub const VAConfigAttribProtectedContentUsage: Type = 49;
+    pub const VAConfigAttribEncHEVCFeatures: Type = 50;
+    pub const VAConfigAttribEncHEVCBlockSizes: Type = 51;
+    pub const VAConfigAttribEncAV1: Type = 52;
+    pub const VAConfigAttribEncAV1Ext1: Type = 53;
+    pub const VAConfigAttribEncAV1Ext2: Type = 54;
+    pub const VAConfigAttribEncPerBlockControl: Type = 55;
+    pub const VAConfigAttribTypeMax: Type = 56;
+}
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VAConfigAttrib {
+    pub type_: VAConfigAttribType::Type,
+    pub value: u32,
+}
+impl Default for _VAConfigAttrib {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAConfigAttrib = _VAConfigAttrib;
+extern "C" {
+    pub fn vaMaxNumProfiles(dpy: VADisplay) -> ::std::os::raw::c_int;
+}
+extern "C" {
+    pub fn vaMaxNumEntrypoints(dpy: VADisplay) -> ::std::os::raw::c_int;
+}
+extern "C" {
+    pub fn vaMaxNumConfigAttributes(dpy: VADisplay) -> ::std::os::raw::c_int;
+}
+extern "C" {
+    pub fn vaQueryConfigProfiles(
+        dpy: VADisplay,
+        profile_list: *mut VAProfile::Type,
+        num_profiles: *mut ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaQueryConfigEntrypoints(
+        dpy: VADisplay,
+        profile: VAProfile::Type,
+        entrypoint_list: *mut VAEntrypoint::Type,
+        num_entrypoints: *mut ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaGetConfigAttributes(
+        dpy: VADisplay,
+        profile: VAProfile::Type,
+        entrypoint: VAEntrypoint::Type,
+        attrib_list: *mut VAConfigAttrib,
+        num_attribs: ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+pub type VAGenericID = ::std::os::raw::c_uint;
+pub type VAConfigID = VAGenericID;
+extern "C" {
+    pub fn vaCreateConfig(
+        dpy: VADisplay,
+        profile: VAProfile::Type,
+        entrypoint: VAEntrypoint::Type,
+        attrib_list: *mut VAConfigAttrib,
+        num_attribs: ::std::os::raw::c_int,
+        config_id: *mut VAConfigID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDestroyConfig(dpy: VADisplay, config_id: VAConfigID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaQueryConfigAttributes(
+        dpy: VADisplay,
+        config_id: VAConfigID,
+        profile: *mut VAProfile::Type,
+        entrypoint: *mut VAEntrypoint::Type,
+        attrib_list: *mut VAConfigAttrib,
+        num_attribs: *mut ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+pub type VAContextID = VAGenericID;
+pub type VASurfaceID = VAGenericID;
+pub mod VAGenericValueType {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VAGenericValueTypeInteger: Type = 1;
+    pub const VAGenericValueTypeFloat: Type = 2;
+    pub const VAGenericValueTypePointer: Type = 3;
+    pub const VAGenericValueTypeFunc: Type = 4;
+}
+pub type VAGenericFunc = ::std::option::Option<unsafe extern "C" fn()>;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAGenericValue {
+    pub type_: VAGenericValueType::Type,
+    pub value: _VAGenericValue__bindgen_ty_1,
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAGenericValue__bindgen_ty_1 {
+    pub i: i32,
+    pub f: f32,
+    pub p: *mut ::std::os::raw::c_void,
+    pub fn_: VAGenericFunc,
+}
+impl Default for _VAGenericValue__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAGenericValue {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAGenericValue = _VAGenericValue;
+pub mod VASurfaceAttribType {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VASurfaceAttribNone: Type = 0;
+    pub const VASurfaceAttribPixelFormat: Type = 1;
+    pub const VASurfaceAttribMinWidth: Type = 2;
+    pub const VASurfaceAttribMaxWidth: Type = 3;
+    pub const VASurfaceAttribMinHeight: Type = 4;
+    pub const VASurfaceAttribMaxHeight: Type = 5;
+    pub const VASurfaceAttribMemoryType: Type = 6;
+    pub const VASurfaceAttribExternalBufferDescriptor: Type = 7;
+    pub const VASurfaceAttribUsageHint: Type = 8;
+    pub const VASurfaceAttribDRMFormatModifiers: Type = 9;
+    pub const VASurfaceAttribCount: Type = 10;
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VASurfaceAttrib {
+    pub type_: VASurfaceAttribType::Type,
+    pub flags: u32,
+    pub value: VAGenericValue,
+}
+impl Default for _VASurfaceAttrib {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VASurfaceAttrib = _VASurfaceAttrib;
+extern "C" {
+    pub fn vaQuerySurfaceAttributes(
+        dpy: VADisplay,
+        config: VAConfigID,
+        attrib_list: *mut VASurfaceAttrib,
+        num_attribs: *mut ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaCreateSurfaces(
+        dpy: VADisplay,
+        format: ::std::os::raw::c_uint,
+        width: ::std::os::raw::c_uint,
+        height: ::std::os::raw::c_uint,
+        surfaces: *mut VASurfaceID,
+        num_surfaces: ::std::os::raw::c_uint,
+        attrib_list: *mut VASurfaceAttrib,
+        num_attribs: ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDestroySurfaces(
+        dpy: VADisplay,
+        surfaces: *mut VASurfaceID,
+        num_surfaces: ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaCreateContext(
+        dpy: VADisplay,
+        config_id: VAConfigID,
+        picture_width: ::std::os::raw::c_int,
+        picture_height: ::std::os::raw::c_int,
+        flag: ::std::os::raw::c_int,
+        render_targets: *mut VASurfaceID,
+        num_render_targets: ::std::os::raw::c_int,
+        context: *mut VAContextID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDestroyContext(dpy: VADisplay, context: VAContextID) -> VAStatus;
+}
+pub type VAMFContextID = VAGenericID;
+extern "C" {
+    pub fn vaCreateMFContext(dpy: VADisplay, mf_context: *mut VAMFContextID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaMFAddContext(
+        dpy: VADisplay,
+        mf_context: VAMFContextID,
+        context: VAContextID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaMFReleaseContext(
+        dpy: VADisplay,
+        mf_context: VAMFContextID,
+        context: VAContextID,
+    ) -> VAStatus;
+}
+pub type VABufferID = VAGenericID;
+pub mod VABufferType {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VAPictureParameterBufferType: Type = 0;
+    pub const VAIQMatrixBufferType: Type = 1;
+    pub const VABitPlaneBufferType: Type = 2;
+    pub const VASliceGroupMapBufferType: Type = 3;
+    pub const VASliceParameterBufferType: Type = 4;
+    pub const VASliceDataBufferType: Type = 5;
+    pub const VAMacroblockParameterBufferType: Type = 6;
+    pub const VAResidualDataBufferType: Type = 7;
+    pub const VADeblockingParameterBufferType: Type = 8;
+    pub const VAImageBufferType: Type = 9;
+    pub const VAProtectedSliceDataBufferType: Type = 10;
+    pub const VAQMatrixBufferType: Type = 11;
+    pub const VAHuffmanTableBufferType: Type = 12;
+    pub const VAProbabilityBufferType: Type = 13;
+    pub const VAEncCodedBufferType: Type = 21;
+    pub const VAEncSequenceParameterBufferType: Type = 22;
+    pub const VAEncPictureParameterBufferType: Type = 23;
+    pub const VAEncSliceParameterBufferType: Type = 24;
+    pub const VAEncPackedHeaderParameterBufferType: Type = 25;
+    pub const VAEncPackedHeaderDataBufferType: Type = 26;
+    pub const VAEncMiscParameterBufferType: Type = 27;
+    pub const VAEncMacroblockParameterBufferType: Type = 28;
+    pub const VAEncMacroblockMapBufferType: Type = 29;
+    pub const VAEncQPBufferType: Type = 30;
+    pub const VAProcPipelineParameterBufferType: Type = 41;
+    pub const VAProcFilterParameterBufferType: Type = 42;
+    pub const VAEncFEIMVBufferType: Type = 43;
+    pub const VAEncFEIMBCodeBufferType: Type = 44;
+    pub const VAEncFEIDistortionBufferType: Type = 45;
+    pub const VAEncFEIMBControlBufferType: Type = 46;
+    pub const VAEncFEIMVPredictorBufferType: Type = 47;
+    pub const VAStatsStatisticsParameterBufferType: Type = 48;
+    pub const VAStatsStatisticsBufferType: Type = 49;
+    pub const VAStatsStatisticsBottomFieldBufferType: Type = 50;
+    pub const VAStatsMVBufferType: Type = 51;
+    pub const VAStatsMVPredictorBufferType: Type = 52;
+    pub const VAEncMacroblockDisableSkipMapBufferType: Type = 53;
+    pub const VAEncFEICTBCmdBufferType: Type = 54;
+    pub const VAEncFEICURecordBufferType: Type = 55;
+    pub const VADecodeStreamoutBufferType: Type = 56;
+    pub const VASubsetsParameterBufferType: Type = 57;
+    pub const VAContextParameterUpdateBufferType: Type = 58;
+    pub const VAProtectedSessionExecuteBufferType: Type = 59;
+    pub const VAEncryptionParameterBufferType: Type = 60;
+    pub const VAEncDeltaQpPerBlockBufferType: Type = 61;
+    pub const VABufferTypeMax: Type = 62;
+}
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAProcessingRateParameterEnc {
+    pub level_idc: u8,
+    pub reserved: [u8; 3usize],
+    pub quality_level: u32,
+    pub intra_period: u32,
+    pub ip_period: u32,
+}
+pub type VAProcessingRateParameterEnc = _VAProcessingRateParameterEnc;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAProcessingRateParameterDec {
+    pub level_idc: u8,
+    pub reserved0: [u8; 3usize],
+    pub reserved: u32,
+}
+pub type VAProcessingRateParameterDec = _VAProcessingRateParameterDec;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAProcessingRateParameter {
+    pub __bindgen_anon_1: _VAProcessingRateParameter__bindgen_ty_1,
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAProcessingRateParameter__bindgen_ty_1 {
+    pub proc_buf_enc: VAProcessingRateParameterEnc,
+    pub proc_buf_dec: VAProcessingRateParameterDec,
+}
+impl Default for _VAProcessingRateParameter__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAProcessingRateParameter {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAProcessingRateParameter = _VAProcessingRateParameter;
+extern "C" {
+    pub fn vaQueryProcessingRate(
+        dpy: VADisplay,
+        config: VAConfigID,
+        proc_buf: *mut VAProcessingRateParameter,
+        processing_rate: *mut ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAPictureParameterBufferMPEG2 {
+    pub horizontal_size: u16,
+    pub vertical_size: u16,
+    pub forward_reference_picture: VASurfaceID,
+    pub backward_reference_picture: VASurfaceID,
+    pub picture_coding_type: i32,
+    pub f_code: i32,
+    pub picture_coding_extension: _VAPictureParameterBufferMPEG2__bindgen_ty_1,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAPictureParameterBufferMPEG2__bindgen_ty_1 {
+    pub bits: _VAPictureParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAPictureParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 2usize]>,
+    pub __bindgen_padding_0: u16,
+}
+impl _VAPictureParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn intra_dc_precision(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_dc_precision(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn picture_structure(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_picture_structure(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn top_field_first(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_top_field_first(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_pred_frame_dct(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_pred_frame_dct(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn concealment_motion_vectors(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_concealment_motion_vectors(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn q_scale_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_q_scale_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_vlc_format(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_vlc_format(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn alternate_scan(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(9usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_alternate_scan(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(9usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn repeat_first_field(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(10usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_repeat_first_field(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(10usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn progressive_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_progressive_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn is_first_field(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_is_first_field(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        intra_dc_precision: u32,
+        picture_structure: u32,
+        top_field_first: u32,
+        frame_pred_frame_dct: u32,
+        concealment_motion_vectors: u32,
+        q_scale_type: u32,
+        intra_vlc_format: u32,
+        alternate_scan: u32,
+        repeat_first_field: u32,
+        progressive_frame: u32,
+        is_first_field: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 2usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 2usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 2u8, {
+            let intra_dc_precision: u32 = unsafe { ::std::mem::transmute(intra_dc_precision) };
+            intra_dc_precision as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 2u8, {
+            let picture_structure: u32 = unsafe { ::std::mem::transmute(picture_structure) };
+            picture_structure as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let top_field_first: u32 = unsafe { ::std::mem::transmute(top_field_first) };
+            top_field_first as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let frame_pred_frame_dct: u32 = unsafe { ::std::mem::transmute(frame_pred_frame_dct) };
+            frame_pred_frame_dct as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 1u8, {
+            let concealment_motion_vectors: u32 =
+                unsafe { ::std::mem::transmute(concealment_motion_vectors) };
+            concealment_motion_vectors as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 1u8, {
+            let q_scale_type: u32 = unsafe { ::std::mem::transmute(q_scale_type) };
+            q_scale_type as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 1u8, {
+            let intra_vlc_format: u32 = unsafe { ::std::mem::transmute(intra_vlc_format) };
+            intra_vlc_format as u64
+        });
+        __bindgen_bitfield_unit.set(9usize, 1u8, {
+            let alternate_scan: u32 = unsafe { ::std::mem::transmute(alternate_scan) };
+            alternate_scan as u64
+        });
+        __bindgen_bitfield_unit.set(10usize, 1u8, {
+            let repeat_first_field: u32 = unsafe { ::std::mem::transmute(repeat_first_field) };
+            repeat_first_field as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 1u8, {
+            let progressive_frame: u32 = unsafe { ::std::mem::transmute(progressive_frame) };
+            progressive_frame as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 1u8, {
+            let is_first_field: u32 = unsafe { ::std::mem::transmute(is_first_field) };
+            is_first_field as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAPictureParameterBufferMPEG2__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAPictureParameterBufferMPEG2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAPictureParameterBufferMPEG2 = _VAPictureParameterBufferMPEG2;
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VAIQMatrixBufferMPEG2 {
+    pub load_intra_quantiser_matrix: i32,
+    pub load_non_intra_quantiser_matrix: i32,
+    pub load_chroma_intra_quantiser_matrix: i32,
+    pub load_chroma_non_intra_quantiser_matrix: i32,
+    pub intra_quantiser_matrix: [u8; 64usize],
+    pub non_intra_quantiser_matrix: [u8; 64usize],
+    pub chroma_intra_quantiser_matrix: [u8; 64usize],
+    pub chroma_non_intra_quantiser_matrix: [u8; 64usize],
+    pub va_reserved: [u32; 4usize],
+}
+impl Default for _VAIQMatrixBufferMPEG2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAIQMatrixBufferMPEG2 = _VAIQMatrixBufferMPEG2;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VASliceParameterBufferMPEG2 {
+    pub slice_data_size: u32,
+    pub slice_data_offset: u32,
+    pub slice_data_flag: u32,
+    pub macroblock_offset: u32,
+    pub slice_horizontal_position: u32,
+    pub slice_vertical_position: u32,
+    pub quantiser_scale_code: i32,
+    pub intra_slice_flag: i32,
+    pub va_reserved: [u32; 4usize],
+}
+pub type VASliceParameterBufferMPEG2 = _VASliceParameterBufferMPEG2;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAMacroblockParameterBufferMPEG2 {
+    pub macroblock_address: u16,
+    pub macroblock_type: u8,
+    pub macroblock_modes: _VAMacroblockParameterBufferMPEG2__bindgen_ty_1,
+    pub motion_vertical_field_select: u8,
+    pub PMV: [[[i16; 2usize]; 2usize]; 2usize],
+    pub coded_block_pattern: u16,
+    pub num_skipped_macroblocks: u16,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAMacroblockParameterBufferMPEG2__bindgen_ty_1 {
+    pub bits: _VAMacroblockParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAMacroblockParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
+    pub __bindgen_padding_0: [u8; 3usize],
+}
+impl _VAMacroblockParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn frame_motion_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_motion_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn field_motion_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_field_motion_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn dct_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_dct_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        frame_motion_type: u32,
+        field_motion_type: u32,
+        dct_type: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 2u8, {
+            let frame_motion_type: u32 = unsafe { ::std::mem::transmute(frame_motion_type) };
+            frame_motion_type as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 2u8, {
+            let field_motion_type: u32 = unsafe { ::std::mem::transmute(field_motion_type) };
+            field_motion_type as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let dct_type: u32 = unsafe { ::std::mem::transmute(dct_type) };
+            dct_type as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAMacroblockParameterBufferMPEG2__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAMacroblockParameterBufferMPEG2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAMacroblockParameterBufferMPEG2 = _VAMacroblockParameterBufferMPEG2;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAPictureH264 {
+    pub picture_id: VASurfaceID,
+    pub frame_idx: u32,
+    pub flags: u32,
+    pub TopFieldOrderCnt: i32,
+    pub BottomFieldOrderCnt: i32,
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAPictureH264 = _VAPictureH264;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAPictureParameterBufferH264 {
+    pub CurrPic: VAPictureH264,
+    pub ReferenceFrames: [VAPictureH264; 16usize],
+    pub picture_width_in_mbs_minus1: u16,
+    pub picture_height_in_mbs_minus1: u16,
+    pub bit_depth_luma_minus8: u8,
+    pub bit_depth_chroma_minus8: u8,
+    pub num_ref_frames: u8,
+    pub seq_fields: _VAPictureParameterBufferH264__bindgen_ty_1,
+    pub num_slice_groups_minus1: u8,
+    pub slice_group_map_type: u8,
+    pub slice_group_change_rate_minus1: u16,
+    pub pic_init_qp_minus26: i8,
+    pub pic_init_qs_minus26: i8,
+    pub chroma_qp_index_offset: i8,
+    pub second_chroma_qp_index_offset: i8,
+    pub pic_fields: _VAPictureParameterBufferH264__bindgen_ty_2,
+    pub frame_num: u16,
+    pub va_reserved: [u32; 8usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAPictureParameterBufferH264__bindgen_ty_1 {
+    pub bits: _VAPictureParameterBufferH264__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAPictureParameterBufferH264__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 3usize]>,
+    pub __bindgen_padding_0: u8,
+}
+impl _VAPictureParameterBufferH264__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn chroma_format_idc(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_chroma_format_idc(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn residual_colour_transform_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_residual_colour_transform_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn gaps_in_frame_num_value_allowed_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_gaps_in_frame_num_value_allowed_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_mbs_only_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_mbs_only_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_adaptive_frame_field_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_adaptive_frame_field_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn direct_8x8_inference_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_direct_8x8_inference_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn MinLumaBiPredSize8x8(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_MinLumaBiPredSize8x8(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn log2_max_frame_num_minus4(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_log2_max_frame_num_minus4(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn pic_order_cnt_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_pic_order_cnt_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn log2_max_pic_order_cnt_lsb_minus4(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_log2_max_pic_order_cnt_lsb_minus4(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn delta_pic_order_always_zero_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(18usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_delta_pic_order_always_zero_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(18usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        chroma_format_idc: u32,
+        residual_colour_transform_flag: u32,
+        gaps_in_frame_num_value_allowed_flag: u32,
+        frame_mbs_only_flag: u32,
+        mb_adaptive_frame_field_flag: u32,
+        direct_8x8_inference_flag: u32,
+        MinLumaBiPredSize8x8: u32,
+        log2_max_frame_num_minus4: u32,
+        pic_order_cnt_type: u32,
+        log2_max_pic_order_cnt_lsb_minus4: u32,
+        delta_pic_order_always_zero_flag: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 3usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 3usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 2u8, {
+            let chroma_format_idc: u32 = unsafe { ::std::mem::transmute(chroma_format_idc) };
+            chroma_format_idc as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let residual_colour_transform_flag: u32 =
+                unsafe { ::std::mem::transmute(residual_colour_transform_flag) };
+            residual_colour_transform_flag as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let gaps_in_frame_num_value_allowed_flag: u32 =
+                unsafe { ::std::mem::transmute(gaps_in_frame_num_value_allowed_flag) };
+            gaps_in_frame_num_value_allowed_flag as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let frame_mbs_only_flag: u32 = unsafe { ::std::mem::transmute(frame_mbs_only_flag) };
+            frame_mbs_only_flag as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let mb_adaptive_frame_field_flag: u32 =
+                unsafe { ::std::mem::transmute(mb_adaptive_frame_field_flag) };
+            mb_adaptive_frame_field_flag as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 1u8, {
+            let direct_8x8_inference_flag: u32 =
+                unsafe { ::std::mem::transmute(direct_8x8_inference_flag) };
+            direct_8x8_inference_flag as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 1u8, {
+            let MinLumaBiPredSize8x8: u32 = unsafe { ::std::mem::transmute(MinLumaBiPredSize8x8) };
+            MinLumaBiPredSize8x8 as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 4u8, {
+            let log2_max_frame_num_minus4: u32 =
+                unsafe { ::std::mem::transmute(log2_max_frame_num_minus4) };
+            log2_max_frame_num_minus4 as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 2u8, {
+            let pic_order_cnt_type: u32 = unsafe { ::std::mem::transmute(pic_order_cnt_type) };
+            pic_order_cnt_type as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 4u8, {
+            let log2_max_pic_order_cnt_lsb_minus4: u32 =
+                unsafe { ::std::mem::transmute(log2_max_pic_order_cnt_lsb_minus4) };
+            log2_max_pic_order_cnt_lsb_minus4 as u64
+        });
+        __bindgen_bitfield_unit.set(18usize, 1u8, {
+            let delta_pic_order_always_zero_flag: u32 =
+                unsafe { ::std::mem::transmute(delta_pic_order_always_zero_flag) };
+            delta_pic_order_always_zero_flag as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAPictureParameterBufferH264__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAPictureParameterBufferH264__bindgen_ty_2 {
+    pub bits: _VAPictureParameterBufferH264__bindgen_ty_2__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAPictureParameterBufferH264__bindgen_ty_2__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 2usize]>,
+    pub __bindgen_padding_0: u16,
+}
+impl _VAPictureParameterBufferH264__bindgen_ty_2__bindgen_ty_1 {
+    #[inline]
+    pub fn entropy_coding_mode_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_entropy_coding_mode_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn weighted_pred_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_weighted_pred_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn weighted_bipred_idc(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_weighted_bipred_idc(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn transform_8x8_mode_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_transform_8x8_mode_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn field_pic_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_field_pic_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn constrained_intra_pred_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_constrained_intra_pred_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn pic_order_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_pic_order_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn deblocking_filter_control_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_deblocking_filter_control_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn redundant_pic_cnt_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(9usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_redundant_pic_cnt_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(9usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reference_pic_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(10usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reference_pic_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(10usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        entropy_coding_mode_flag: u32,
+        weighted_pred_flag: u32,
+        weighted_bipred_idc: u32,
+        transform_8x8_mode_flag: u32,
+        field_pic_flag: u32,
+        constrained_intra_pred_flag: u32,
+        pic_order_present_flag: u32,
+        deblocking_filter_control_present_flag: u32,
+        redundant_pic_cnt_present_flag: u32,
+        reference_pic_flag: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 2usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 2usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let entropy_coding_mode_flag: u32 =
+                unsafe { ::std::mem::transmute(entropy_coding_mode_flag) };
+            entropy_coding_mode_flag as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 1u8, {
+            let weighted_pred_flag: u32 = unsafe { ::std::mem::transmute(weighted_pred_flag) };
+            weighted_pred_flag as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 2u8, {
+            let weighted_bipred_idc: u32 = unsafe { ::std::mem::transmute(weighted_bipred_idc) };
+            weighted_bipred_idc as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let transform_8x8_mode_flag: u32 =
+                unsafe { ::std::mem::transmute(transform_8x8_mode_flag) };
+            transform_8x8_mode_flag as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let field_pic_flag: u32 = unsafe { ::std::mem::transmute(field_pic_flag) };
+            field_pic_flag as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 1u8, {
+            let constrained_intra_pred_flag: u32 =
+                unsafe { ::std::mem::transmute(constrained_intra_pred_flag) };
+            constrained_intra_pred_flag as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 1u8, {
+            let pic_order_present_flag: u32 =
+                unsafe { ::std::mem::transmute(pic_order_present_flag) };
+            pic_order_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 1u8, {
+            let deblocking_filter_control_present_flag: u32 =
+                unsafe { ::std::mem::transmute(deblocking_filter_control_present_flag) };
+            deblocking_filter_control_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(9usize, 1u8, {
+            let redundant_pic_cnt_present_flag: u32 =
+                unsafe { ::std::mem::transmute(redundant_pic_cnt_present_flag) };
+            redundant_pic_cnt_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(10usize, 1u8, {
+            let reference_pic_flag: u32 = unsafe { ::std::mem::transmute(reference_pic_flag) };
+            reference_pic_flag as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAPictureParameterBufferH264__bindgen_ty_2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAPictureParameterBufferH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAPictureParameterBufferH264 = _VAPictureParameterBufferH264;
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VAIQMatrixBufferH264 {
+    pub ScalingList4x4: [[u8; 16usize]; 6usize],
+    pub ScalingList8x8: [[u8; 64usize]; 2usize],
+    pub va_reserved: [u32; 4usize],
+}
+impl Default for _VAIQMatrixBufferH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAIQMatrixBufferH264 = _VAIQMatrixBufferH264;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VASliceParameterBufferH264 {
+    pub slice_data_size: u32,
+    pub slice_data_offset: u32,
+    pub slice_data_flag: u32,
+    pub slice_data_bit_offset: u16,
+    pub first_mb_in_slice: u16,
+    pub slice_type: u8,
+    pub direct_spatial_mv_pred_flag: u8,
+    pub num_ref_idx_l0_active_minus1: u8,
+    pub num_ref_idx_l1_active_minus1: u8,
+    pub cabac_init_idc: u8,
+    pub slice_qp_delta: i8,
+    pub disable_deblocking_filter_idc: u8,
+    pub slice_alpha_c0_offset_div2: i8,
+    pub slice_beta_offset_div2: i8,
+    pub RefPicList0: [VAPictureH264; 32usize],
+    pub RefPicList1: [VAPictureH264; 32usize],
+    pub luma_log2_weight_denom: u8,
+    pub chroma_log2_weight_denom: u8,
+    pub luma_weight_l0_flag: u8,
+    pub luma_weight_l0: [i16; 32usize],
+    pub luma_offset_l0: [i16; 32usize],
+    pub chroma_weight_l0_flag: u8,
+    pub chroma_weight_l0: [[i16; 2usize]; 32usize],
+    pub chroma_offset_l0: [[i16; 2usize]; 32usize],
+    pub luma_weight_l1_flag: u8,
+    pub luma_weight_l1: [i16; 32usize],
+    pub luma_offset_l1: [i16; 32usize],
+    pub chroma_weight_l1_flag: u8,
+    pub chroma_weight_l1: [[i16; 2usize]; 32usize],
+    pub chroma_offset_l1: [[i16; 2usize]; 32usize],
+    pub va_reserved: [u32; 4usize],
+}
+pub type VASliceParameterBufferH264 = _VASliceParameterBufferH264;
+pub mod VAEncPictureType {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VAEncPictureTypeIntra: Type = 0;
+    pub const VAEncPictureTypePredictive: Type = 1;
+    pub const VAEncPictureTypeBidirectional: Type = 2;
+}
+extern "C" {
+    pub fn vaCreateBuffer(
+        dpy: VADisplay,
+        context: VAContextID,
+        type_: VABufferType::Type,
+        size: ::std::os::raw::c_uint,
+        num_elements: ::std::os::raw::c_uint,
+        data: *mut ::std::os::raw::c_void,
+        buf_id: *mut VABufferID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaCreateBuffer2(
+        dpy: VADisplay,
+        context: VAContextID,
+        type_: VABufferType::Type,
+        width: ::std::os::raw::c_uint,
+        height: ::std::os::raw::c_uint,
+        unit_size: *mut ::std::os::raw::c_uint,
+        pitch: *mut ::std::os::raw::c_uint,
+        buf_id: *mut VABufferID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaBufferSetNumElements(
+        dpy: VADisplay,
+        buf_id: VABufferID,
+        num_elements: ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaMapBuffer(
+        dpy: VADisplay,
+        buf_id: VABufferID,
+        pbuf: *mut *mut ::std::os::raw::c_void,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaUnmapBuffer(dpy: VADisplay, buf_id: VABufferID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDestroyBuffer(dpy: VADisplay, buffer_id: VABufferID) -> VAStatus;
+}
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct VABufferInfo {
+    pub handle: usize,
+    pub type_: u32,
+    pub mem_type: u32,
+    pub mem_size: usize,
+    pub va_reserved: [u32; 4usize],
+}
+extern "C" {
+    pub fn vaAcquireBufferHandle(
+        dpy: VADisplay,
+        buf_id: VABufferID,
+        buf_info: *mut VABufferInfo,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaReleaseBufferHandle(dpy: VADisplay, buf_id: VABufferID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaExportSurfaceHandle(
+        dpy: VADisplay,
+        surface_id: VASurfaceID,
+        mem_type: u32,
+        flags: u32,
+        descriptor: *mut ::std::os::raw::c_void,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaBeginPicture(
+        dpy: VADisplay,
+        context: VAContextID,
+        render_target: VASurfaceID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaRenderPicture(
+        dpy: VADisplay,
+        context: VAContextID,
+        buffers: *mut VABufferID,
+        num_buffers: ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaEndPicture(dpy: VADisplay, context: VAContextID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaMFSubmit(
+        dpy: VADisplay,
+        mf_context: VAMFContextID,
+        contexts: *mut VAContextID,
+        num_contexts: ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaSyncSurface(dpy: VADisplay, render_target: VASurfaceID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaSyncSurface2(dpy: VADisplay, surface: VASurfaceID, timeout_ns: u64) -> VAStatus;
+}
+pub mod VASurfaceStatus {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VASurfaceRendering: Type = 1;
+    pub const VASurfaceDisplaying: Type = 2;
+    pub const VASurfaceReady: Type = 4;
+    pub const VASurfaceSkipped: Type = 8;
+}
+extern "C" {
+    pub fn vaQuerySurfaceStatus(
+        dpy: VADisplay,
+        render_target: VASurfaceID,
+        status: *mut VASurfaceStatus::Type,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaQuerySurfaceError(
+        dpy: VADisplay,
+        surface: VASurfaceID,
+        error_status: VAStatus,
+        error_info: *mut *mut ::std::os::raw::c_void,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaSyncBuffer(dpy: VADisplay, buf_id: VABufferID, timeout_ns: u64) -> VAStatus;
+}
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAImageFormat {
+    pub fourcc: u32,
+    pub byte_order: u32,
+    pub bits_per_pixel: u32,
+    pub depth: u32,
+    pub red_mask: u32,
+    pub green_mask: u32,
+    pub blue_mask: u32,
+    pub alpha_mask: u32,
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAImageFormat = _VAImageFormat;
+pub type VAImageID = VAGenericID;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAImage {
+    pub image_id: VAImageID,
+    pub format: VAImageFormat,
+    pub buf: VABufferID,
+    pub width: u16,
+    pub height: u16,
+    pub data_size: u32,
+    pub num_planes: u32,
+    pub pitches: [u32; 3usize],
+    pub offsets: [u32; 3usize],
+    pub num_palette_entries: i32,
+    pub entry_bytes: i32,
+    pub component_order: [i8; 4usize],
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAImage = _VAImage;
+extern "C" {
+    pub fn vaMaxNumImageFormats(dpy: VADisplay) -> ::std::os::raw::c_int;
+}
+extern "C" {
+    pub fn vaQueryImageFormats(
+        dpy: VADisplay,
+        format_list: *mut VAImageFormat,
+        num_formats: *mut ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaCreateImage(
+        dpy: VADisplay,
+        format: *mut VAImageFormat,
+        width: ::std::os::raw::c_int,
+        height: ::std::os::raw::c_int,
+        image: *mut VAImage,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDestroyImage(dpy: VADisplay, image: VAImageID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaSetImagePalette(
+        dpy: VADisplay,
+        image: VAImageID,
+        palette: *mut ::std::os::raw::c_uchar,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaGetImage(
+        dpy: VADisplay,
+        surface: VASurfaceID,
+        x: ::std::os::raw::c_int,
+        y: ::std::os::raw::c_int,
+        width: ::std::os::raw::c_uint,
+        height: ::std::os::raw::c_uint,
+        image: VAImageID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaPutImage(
+        dpy: VADisplay,
+        surface: VASurfaceID,
+        image: VAImageID,
+        src_x: ::std::os::raw::c_int,
+        src_y: ::std::os::raw::c_int,
+        src_width: ::std::os::raw::c_uint,
+        src_height: ::std::os::raw::c_uint,
+        dest_x: ::std::os::raw::c_int,
+        dest_y: ::std::os::raw::c_int,
+        dest_width: ::std::os::raw::c_uint,
+        dest_height: ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDeriveImage(dpy: VADisplay, surface: VASurfaceID, image: *mut VAImage) -> VAStatus;
+}
+pub type VASubpictureID = VAGenericID;
+extern "C" {
+    pub fn vaMaxNumSubpictureFormats(dpy: VADisplay) -> ::std::os::raw::c_int;
+}
+extern "C" {
+    pub fn vaQuerySubpictureFormats(
+        dpy: VADisplay,
+        format_list: *mut VAImageFormat,
+        flags: *mut ::std::os::raw::c_uint,
+        num_formats: *mut ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaCreateSubpicture(
+        dpy: VADisplay,
+        image: VAImageID,
+        subpicture: *mut VASubpictureID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDestroySubpicture(dpy: VADisplay, subpicture: VASubpictureID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaSetSubpictureImage(
+        dpy: VADisplay,
+        subpicture: VASubpictureID,
+        image: VAImageID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaSetSubpictureChromakey(
+        dpy: VADisplay,
+        subpicture: VASubpictureID,
+        chromakey_min: ::std::os::raw::c_uint,
+        chromakey_max: ::std::os::raw::c_uint,
+        chromakey_mask: ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaSetSubpictureGlobalAlpha(
+        dpy: VADisplay,
+        subpicture: VASubpictureID,
+        global_alpha: f32,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaAssociateSubpicture(
+        dpy: VADisplay,
+        subpicture: VASubpictureID,
+        target_surfaces: *mut VASurfaceID,
+        num_surfaces: ::std::os::raw::c_int,
+        src_x: i16,
+        src_y: i16,
+        src_width: u16,
+        src_height: u16,
+        dest_x: i16,
+        dest_y: i16,
+        dest_width: u16,
+        dest_height: u16,
+        flags: u32,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDeassociateSubpicture(
+        dpy: VADisplay,
+        subpicture: VASubpictureID,
+        target_surfaces: *mut VASurfaceID,
+        num_surfaces: ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+pub mod VADisplayAttribType {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VADisplayAttribBrightness: Type = 0;
+    pub const VADisplayAttribContrast: Type = 1;
+    pub const VADisplayAttribHue: Type = 2;
+    pub const VADisplayAttribSaturation: Type = 3;
+    pub const VADisplayAttribBackgroundColor: Type = 4;
+    pub const VADisplayAttribDirectSurface: Type = 5;
+    pub const VADisplayAttribRotation: Type = 6;
+    pub const VADisplayAttribOutofLoopDeblock: Type = 7;
+    pub const VADisplayAttribBLEBlackMode: Type = 8;
+    pub const VADisplayAttribBLEWhiteMode: Type = 9;
+    pub const VADisplayAttribBlueStretch: Type = 10;
+    pub const VADisplayAttribSkinColorCorrection: Type = 11;
+    pub const VADisplayAttribCSCMatrix: Type = 12;
+    pub const VADisplayAttribBlendColor: Type = 13;
+    pub const VADisplayAttribOverlayAutoPaintColorKey: Type = 14;
+    pub const VADisplayAttribOverlayColorKey: Type = 15;
+    pub const VADisplayAttribRenderMode: Type = 16;
+    pub const VADisplayAttribRenderDevice: Type = 17;
+    pub const VADisplayAttribRenderRect: Type = 18;
+    pub const VADisplayAttribSubDevice: Type = 19;
+    pub const VADisplayAttribCopy: Type = 20;
+    pub const VADisplayPCIID: Type = 21;
+}
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VADisplayAttribute {
+    pub type_: VADisplayAttribType::Type,
+    pub min_value: i32,
+    pub max_value: i32,
+    pub value: i32,
+    pub flags: u32,
+    pub va_reserved: [u32; 4usize],
+}
+impl Default for _VADisplayAttribute {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VADisplayAttribute = _VADisplayAttribute;
+extern "C" {
+    pub fn vaMaxNumDisplayAttributes(dpy: VADisplay) -> ::std::os::raw::c_int;
+}
+extern "C" {
+    pub fn vaQueryDisplayAttributes(
+        dpy: VADisplay,
+        attr_list: *mut VADisplayAttribute,
+        num_attributes: *mut ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaGetDisplayAttributes(
+        dpy: VADisplay,
+        attr_list: *mut VADisplayAttribute,
+        num_attributes: ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaSetDisplayAttributes(
+        dpy: VADisplay,
+        attr_list: *mut VADisplayAttribute,
+        num_attributes: ::std::os::raw::c_int,
+    ) -> VAStatus;
+}
+pub mod VACopyObjectType {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VACopyObjectSurface: Type = 0;
+    pub const VACopyObjectBuffer: Type = 1;
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VACopyObject {
+    pub obj_type: VACopyObjectType::Type,
+    pub object: _VACopyObject__bindgen_ty_1,
+    pub va_reserved: [u32; 8usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VACopyObject__bindgen_ty_1 {
+    pub surface_id: VASurfaceID,
+    pub buffer_id: VABufferID,
+}
+impl Default for _VACopyObject__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VACopyObject {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VACopyObject = _VACopyObject;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VACopyOption {
+    pub bits: _VACopyOption__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VACopyOption__bindgen_ty_1 {
+    pub _bitfield_align_1: [u32; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VACopyOption__bindgen_ty_1 {
+    #[inline]
+    pub fn va_copy_sync(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_va_copy_sync(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn va_copy_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_va_copy_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 26u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 26u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        va_copy_sync: u32,
+        va_copy_mode: u32,
+        reserved: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 2u8, {
+            let va_copy_sync: u32 = unsafe { ::std::mem::transmute(va_copy_sync) };
+            va_copy_sync as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 4u8, {
+            let va_copy_mode: u32 = unsafe { ::std::mem::transmute(va_copy_mode) };
+            va_copy_mode as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 26u8, {
+            let reserved: u32 = unsafe { ::std::mem::transmute(reserved) };
+            reserved as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VACopyOption {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VACopyOption = _VACopyOption;
+extern "C" {
+    pub fn vaCopy(
+        dpy: VADisplay,
+        dst: *mut VACopyObject,
+        src: *mut VACopyObject,
+        option: VACopyOption,
+    ) -> VAStatus;
+}
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VABoolCoderContextVPX {
+    pub range: u8,
+    pub value: u8,
+    pub count: u8,
+}
+pub type VABoolCoderContextVPX = _VABoolCoderContextVPX;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAPictureParameterBufferVP8 {
+    pub frame_width: u32,
+    pub frame_height: u32,
+    pub last_ref_frame: VASurfaceID,
+    pub golden_ref_frame: VASurfaceID,
+    pub alt_ref_frame: VASurfaceID,
+    pub out_of_loop_frame: VASurfaceID,
+    pub pic_fields: _VAPictureParameterBufferVP8__bindgen_ty_1,
+    pub mb_segment_tree_probs: [u8; 3usize],
+    pub loop_filter_level: [u8; 4usize],
+    pub loop_filter_deltas_ref_frame: [i8; 4usize],
+    pub loop_filter_deltas_mode: [i8; 4usize],
+    pub prob_skip_false: u8,
+    pub prob_intra: u8,
+    pub prob_last: u8,
+    pub prob_gf: u8,
+    pub y_mode_probs: [u8; 4usize],
+    pub uv_mode_probs: [u8; 3usize],
+    pub mv_probs: [[u8; 19usize]; 2usize],
+    pub bool_coder_ctx: VABoolCoderContextVPX,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAPictureParameterBufferVP8__bindgen_ty_1 {
+    pub bits: _VAPictureParameterBufferVP8__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAPictureParameterBufferVP8__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 3usize]>,
+    pub __bindgen_padding_0: u8,
+}
+impl _VAPictureParameterBufferVP8__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn key_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_key_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn version(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_version(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segmentation_enabled(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_segmentation_enabled(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn update_mb_segmentation_map(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_update_mb_segmentation_map(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn update_segment_feature_data(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_update_segment_feature_data(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn filter_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_filter_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sharpness_level(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sharpness_level(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn loop_filter_adj_enable(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_loop_filter_adj_enable(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mode_ref_lf_delta_update(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mode_ref_lf_delta_update(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sign_bias_golden(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(13usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sign_bias_golden(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(13usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sign_bias_alternate(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sign_bias_alternate(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_no_coeff_skip(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(15usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_no_coeff_skip(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(15usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn loop_filter_disable(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_loop_filter_disable(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        key_frame: u32,
+        version: u32,
+        segmentation_enabled: u32,
+        update_mb_segmentation_map: u32,
+        update_segment_feature_data: u32,
+        filter_type: u32,
+        sharpness_level: u32,
+        loop_filter_adj_enable: u32,
+        mode_ref_lf_delta_update: u32,
+        sign_bias_golden: u32,
+        sign_bias_alternate: u32,
+        mb_no_coeff_skip: u32,
+        loop_filter_disable: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 3usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 3usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let key_frame: u32 = unsafe { ::std::mem::transmute(key_frame) };
+            key_frame as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 3u8, {
+            let version: u32 = unsafe { ::std::mem::transmute(version) };
+            version as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let segmentation_enabled: u32 = unsafe { ::std::mem::transmute(segmentation_enabled) };
+            segmentation_enabled as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let update_mb_segmentation_map: u32 =
+                unsafe { ::std::mem::transmute(update_mb_segmentation_map) };
+            update_mb_segmentation_map as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 1u8, {
+            let update_segment_feature_data: u32 =
+                unsafe { ::std::mem::transmute(update_segment_feature_data) };
+            update_segment_feature_data as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 1u8, {
+            let filter_type: u32 = unsafe { ::std::mem::transmute(filter_type) };
+            filter_type as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 3u8, {
+            let sharpness_level: u32 = unsafe { ::std::mem::transmute(sharpness_level) };
+            sharpness_level as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 1u8, {
+            let loop_filter_adj_enable: u32 =
+                unsafe { ::std::mem::transmute(loop_filter_adj_enable) };
+            loop_filter_adj_enable as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 1u8, {
+            let mode_ref_lf_delta_update: u32 =
+                unsafe { ::std::mem::transmute(mode_ref_lf_delta_update) };
+            mode_ref_lf_delta_update as u64
+        });
+        __bindgen_bitfield_unit.set(13usize, 1u8, {
+            let sign_bias_golden: u32 = unsafe { ::std::mem::transmute(sign_bias_golden) };
+            sign_bias_golden as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 1u8, {
+            let sign_bias_alternate: u32 = unsafe { ::std::mem::transmute(sign_bias_alternate) };
+            sign_bias_alternate as u64
+        });
+        __bindgen_bitfield_unit.set(15usize, 1u8, {
+            let mb_no_coeff_skip: u32 = unsafe { ::std::mem::transmute(mb_no_coeff_skip) };
+            mb_no_coeff_skip as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 1u8, {
+            let loop_filter_disable: u32 = unsafe { ::std::mem::transmute(loop_filter_disable) };
+            loop_filter_disable as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAPictureParameterBufferVP8__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAPictureParameterBufferVP8 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAPictureParameterBufferVP8 = _VAPictureParameterBufferVP8;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VASliceParameterBufferVP8 {
+    pub slice_data_size: u32,
+    pub slice_data_offset: u32,
+    pub slice_data_flag: u32,
+    pub macroblock_offset: u32,
+    pub num_of_partitions: u8,
+    pub partition_size: [u32; 9usize],
+    pub va_reserved: [u32; 4usize],
+}
+pub type VASliceParameterBufferVP8 = _VASliceParameterBufferVP8;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAProbabilityDataBufferVP8 {
+    pub dct_coeff_probs: [[[[u8; 11usize]; 3usize]; 8usize]; 4usize],
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAProbabilityDataBufferVP8 = _VAProbabilityDataBufferVP8;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAIQMatrixBufferVP8 {
+    pub quantization_index: [[u16; 6usize]; 4usize],
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAIQMatrixBufferVP8 = _VAIQMatrixBufferVP8;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VADecPictureParameterBufferVP9 {
+    pub frame_width: u16,
+    pub frame_height: u16,
+    pub reference_frames: [VASurfaceID; 8usize],
+    pub pic_fields: _VADecPictureParameterBufferVP9__bindgen_ty_1,
+    pub filter_level: u8,
+    pub sharpness_level: u8,
+    pub log2_tile_rows: u8,
+    pub log2_tile_columns: u8,
+    pub frame_header_length_in_bytes: u8,
+    pub first_partition_size: u16,
+    pub mb_segment_tree_probs: [u8; 7usize],
+    pub segment_pred_probs: [u8; 3usize],
+    pub profile: u8,
+    pub bit_depth: u8,
+    pub va_reserved: [u32; 8usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VADecPictureParameterBufferVP9__bindgen_ty_1 {
+    pub bits: _VADecPictureParameterBufferVP9__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VADecPictureParameterBufferVP9__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VADecPictureParameterBufferVP9__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn subsampling_x(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_subsampling_x(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn subsampling_y(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_subsampling_y(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn show_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_show_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn error_resilient_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_error_resilient_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_only(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_only(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn allow_high_precision_mv(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_allow_high_precision_mv(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mcomp_filter_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mcomp_filter_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_parallel_decoding_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(10usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_parallel_decoding_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(10usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reset_frame_context(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reset_frame_context(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn refresh_frame_context(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(13usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_refresh_frame_context(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(13usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_context_idx(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_context_idx(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segmentation_enabled(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_segmentation_enabled(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segmentation_temporal_update(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(17usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_segmentation_temporal_update(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(17usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segmentation_update_map(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(18usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_segmentation_update_map(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(18usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn last_ref_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(19usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_last_ref_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(19usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn last_ref_frame_sign_bias(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(22usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_last_ref_frame_sign_bias(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(22usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn golden_ref_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(23usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_golden_ref_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(23usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn golden_ref_frame_sign_bias(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(26usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_golden_ref_frame_sign_bias(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(26usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn alt_ref_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(27usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_alt_ref_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(27usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn alt_ref_frame_sign_bias(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(30usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_alt_ref_frame_sign_bias(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(30usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn lossless_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(31usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_lossless_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(31usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        subsampling_x: u32,
+        subsampling_y: u32,
+        frame_type: u32,
+        show_frame: u32,
+        error_resilient_mode: u32,
+        intra_only: u32,
+        allow_high_precision_mv: u32,
+        mcomp_filter_type: u32,
+        frame_parallel_decoding_mode: u32,
+        reset_frame_context: u32,
+        refresh_frame_context: u32,
+        frame_context_idx: u32,
+        segmentation_enabled: u32,
+        segmentation_temporal_update: u32,
+        segmentation_update_map: u32,
+        last_ref_frame: u32,
+        last_ref_frame_sign_bias: u32,
+        golden_ref_frame: u32,
+        golden_ref_frame_sign_bias: u32,
+        alt_ref_frame: u32,
+        alt_ref_frame_sign_bias: u32,
+        lossless_flag: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let subsampling_x: u32 = unsafe { ::std::mem::transmute(subsampling_x) };
+            subsampling_x as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 1u8, {
+            let subsampling_y: u32 = unsafe { ::std::mem::transmute(subsampling_y) };
+            subsampling_y as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let frame_type: u32 = unsafe { ::std::mem::transmute(frame_type) };
+            frame_type as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let show_frame: u32 = unsafe { ::std::mem::transmute(show_frame) };
+            show_frame as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let error_resilient_mode: u32 = unsafe { ::std::mem::transmute(error_resilient_mode) };
+            error_resilient_mode as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let intra_only: u32 = unsafe { ::std::mem::transmute(intra_only) };
+            intra_only as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 1u8, {
+            let allow_high_precision_mv: u32 =
+                unsafe { ::std::mem::transmute(allow_high_precision_mv) };
+            allow_high_precision_mv as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 3u8, {
+            let mcomp_filter_type: u32 = unsafe { ::std::mem::transmute(mcomp_filter_type) };
+            mcomp_filter_type as u64
+        });
+        __bindgen_bitfield_unit.set(10usize, 1u8, {
+            let frame_parallel_decoding_mode: u32 =
+                unsafe { ::std::mem::transmute(frame_parallel_decoding_mode) };
+            frame_parallel_decoding_mode as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 2u8, {
+            let reset_frame_context: u32 = unsafe { ::std::mem::transmute(reset_frame_context) };
+            reset_frame_context as u64
+        });
+        __bindgen_bitfield_unit.set(13usize, 1u8, {
+            let refresh_frame_context: u32 =
+                unsafe { ::std::mem::transmute(refresh_frame_context) };
+            refresh_frame_context as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 2u8, {
+            let frame_context_idx: u32 = unsafe { ::std::mem::transmute(frame_context_idx) };
+            frame_context_idx as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 1u8, {
+            let segmentation_enabled: u32 = unsafe { ::std::mem::transmute(segmentation_enabled) };
+            segmentation_enabled as u64
+        });
+        __bindgen_bitfield_unit.set(17usize, 1u8, {
+            let segmentation_temporal_update: u32 =
+                unsafe { ::std::mem::transmute(segmentation_temporal_update) };
+            segmentation_temporal_update as u64
+        });
+        __bindgen_bitfield_unit.set(18usize, 1u8, {
+            let segmentation_update_map: u32 =
+                unsafe { ::std::mem::transmute(segmentation_update_map) };
+            segmentation_update_map as u64
+        });
+        __bindgen_bitfield_unit.set(19usize, 3u8, {
+            let last_ref_frame: u32 = unsafe { ::std::mem::transmute(last_ref_frame) };
+            last_ref_frame as u64
+        });
+        __bindgen_bitfield_unit.set(22usize, 1u8, {
+            let last_ref_frame_sign_bias: u32 =
+                unsafe { ::std::mem::transmute(last_ref_frame_sign_bias) };
+            last_ref_frame_sign_bias as u64
+        });
+        __bindgen_bitfield_unit.set(23usize, 3u8, {
+            let golden_ref_frame: u32 = unsafe { ::std::mem::transmute(golden_ref_frame) };
+            golden_ref_frame as u64
+        });
+        __bindgen_bitfield_unit.set(26usize, 1u8, {
+            let golden_ref_frame_sign_bias: u32 =
+                unsafe { ::std::mem::transmute(golden_ref_frame_sign_bias) };
+            golden_ref_frame_sign_bias as u64
+        });
+        __bindgen_bitfield_unit.set(27usize, 3u8, {
+            let alt_ref_frame: u32 = unsafe { ::std::mem::transmute(alt_ref_frame) };
+            alt_ref_frame as u64
+        });
+        __bindgen_bitfield_unit.set(30usize, 1u8, {
+            let alt_ref_frame_sign_bias: u32 =
+                unsafe { ::std::mem::transmute(alt_ref_frame_sign_bias) };
+            alt_ref_frame_sign_bias as u64
+        });
+        __bindgen_bitfield_unit.set(31usize, 1u8, {
+            let lossless_flag: u32 = unsafe { ::std::mem::transmute(lossless_flag) };
+            lossless_flag as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VADecPictureParameterBufferVP9__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VADecPictureParameterBufferVP9 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VADecPictureParameterBufferVP9 = _VADecPictureParameterBufferVP9;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VASegmentParameterVP9 {
+    pub segment_flags: _VASegmentParameterVP9__bindgen_ty_1,
+    pub filter_level: [[u8; 2usize]; 4usize],
+    pub luma_ac_quant_scale: i16,
+    pub luma_dc_quant_scale: i16,
+    pub chroma_ac_quant_scale: i16,
+    pub chroma_dc_quant_scale: i16,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VASegmentParameterVP9__bindgen_ty_1 {
+    pub fields: _VASegmentParameterVP9__bindgen_ty_1__bindgen_ty_1,
+    pub value: u16,
+}
+#[repr(C)]
+#[repr(align(2))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VASegmentParameterVP9__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
+    pub __bindgen_padding_0: u8,
+}
+impl _VASegmentParameterVP9__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn segment_reference_enabled(&self) -> u16 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u16) }
+    }
+    #[inline]
+    pub fn set_segment_reference_enabled(&mut self, val: u16) {
+        unsafe {
+            let val: u16 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segment_reference(&self) -> u16 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 2u8) as u16) }
+    }
+    #[inline]
+    pub fn set_segment_reference(&mut self, val: u16) {
+        unsafe {
+            let val: u16 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segment_reference_skipped(&self) -> u16 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u16) }
+    }
+    #[inline]
+    pub fn set_segment_reference_skipped(&mut self, val: u16) {
+        unsafe {
+            let val: u16 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        segment_reference_enabled: u16,
+        segment_reference: u16,
+        segment_reference_skipped: u16,
+    ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let segment_reference_enabled: u16 =
+                unsafe { ::std::mem::transmute(segment_reference_enabled) };
+            segment_reference_enabled as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 2u8, {
+            let segment_reference: u16 = unsafe { ::std::mem::transmute(segment_reference) };
+            segment_reference as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let segment_reference_skipped: u16 =
+                unsafe { ::std::mem::transmute(segment_reference_skipped) };
+            segment_reference_skipped as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VASegmentParameterVP9__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VASegmentParameterVP9 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VASegmentParameterVP9 = _VASegmentParameterVP9;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VASliceParameterBufferVP9 {
+    pub slice_data_size: u32,
+    pub slice_data_offset: u32,
+    pub slice_data_flag: u32,
+    pub seg_param: [VASegmentParameterVP9; 8usize],
+    pub va_reserved: [u32; 4usize],
+}
+impl Default for _VASliceParameterBufferVP9 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VASliceParameterBufferVP9 = _VASliceParameterBufferVP9;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAPictureStats {
+    pub picture_id: VASurfaceID,
+    pub flags: u32,
+}
+pub type VAPictureStats = _VAPictureStats;
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VAStatsStatisticsParameter {
+    pub input: VAPictureStats,
+    pub past_references: *mut VAPictureStats,
+    pub num_past_references: u32,
+    pub past_ref_stat_buf: *mut VABufferID,
+    pub future_references: *mut VAPictureStats,
+    pub num_future_references: u32,
+    pub future_ref_stat_buf: *mut VABufferID,
+    pub outputs: *mut VABufferID,
+    pub mv_predictor: VABufferID,
+    pub qp: VABufferID,
+}
+impl Default for _VAStatsStatisticsParameter {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAStatsStatisticsParameter = _VAStatsStatisticsParameter;
+pub mod VAEncPackedHeaderTypeH264 {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VAEncPackedHeaderH264_SPS: Type = 1;
+    pub const VAEncPackedHeaderH264_PPS: Type = 2;
+    pub const VAEncPackedHeaderH264_Slice: Type = 3;
+    pub const VAEncPackedHeaderH264_SEI: Type = 2147483649;
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncSequenceParameterBufferH264 {
+    pub seq_parameter_set_id: u8,
+    pub level_idc: u8,
+    pub intra_period: u32,
+    pub intra_idr_period: u32,
+    pub ip_period: u32,
+    pub bits_per_second: u32,
+    pub max_num_ref_frames: u32,
+    pub picture_width_in_mbs: u16,
+    pub picture_height_in_mbs: u16,
+    pub seq_fields: _VAEncSequenceParameterBufferH264__bindgen_ty_1,
+    pub bit_depth_luma_minus8: u8,
+    pub bit_depth_chroma_minus8: u8,
+    pub num_ref_frames_in_pic_order_cnt_cycle: u8,
+    pub offset_for_non_ref_pic: i32,
+    pub offset_for_top_to_bottom_field: i32,
+    pub offset_for_ref_frame: [i32; 256usize],
+    pub frame_cropping_flag: u8,
+    pub frame_crop_left_offset: u32,
+    pub frame_crop_right_offset: u32,
+    pub frame_crop_top_offset: u32,
+    pub frame_crop_bottom_offset: u32,
+    pub vui_parameters_present_flag: u8,
+    pub vui_fields: _VAEncSequenceParameterBufferH264__bindgen_ty_2,
+    pub aspect_ratio_idc: u8,
+    pub sar_width: u32,
+    pub sar_height: u32,
+    pub num_units_in_tick: u32,
+    pub time_scale: u32,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncSequenceParameterBufferH264__bindgen_ty_1 {
+    pub bits: _VAEncSequenceParameterBufferH264__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSequenceParameterBufferH264__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 3usize]>,
+    pub __bindgen_padding_0: u8,
+}
+impl _VAEncSequenceParameterBufferH264__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn chroma_format_idc(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_chroma_format_idc(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_mbs_only_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_mbs_only_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_adaptive_frame_field_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_adaptive_frame_field_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn seq_scaling_matrix_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_seq_scaling_matrix_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn direct_8x8_inference_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_direct_8x8_inference_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn log2_max_frame_num_minus4(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_log2_max_frame_num_minus4(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn pic_order_cnt_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(10usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_pic_order_cnt_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(10usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn log2_max_pic_order_cnt_lsb_minus4(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_log2_max_pic_order_cnt_lsb_minus4(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn delta_pic_order_always_zero_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_delta_pic_order_always_zero_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        chroma_format_idc: u32,
+        frame_mbs_only_flag: u32,
+        mb_adaptive_frame_field_flag: u32,
+        seq_scaling_matrix_present_flag: u32,
+        direct_8x8_inference_flag: u32,
+        log2_max_frame_num_minus4: u32,
+        pic_order_cnt_type: u32,
+        log2_max_pic_order_cnt_lsb_minus4: u32,
+        delta_pic_order_always_zero_flag: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 3usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 3usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 2u8, {
+            let chroma_format_idc: u32 = unsafe { ::std::mem::transmute(chroma_format_idc) };
+            chroma_format_idc as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let frame_mbs_only_flag: u32 = unsafe { ::std::mem::transmute(frame_mbs_only_flag) };
+            frame_mbs_only_flag as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let mb_adaptive_frame_field_flag: u32 =
+                unsafe { ::std::mem::transmute(mb_adaptive_frame_field_flag) };
+            mb_adaptive_frame_field_flag as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let seq_scaling_matrix_present_flag: u32 =
+                unsafe { ::std::mem::transmute(seq_scaling_matrix_present_flag) };
+            seq_scaling_matrix_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let direct_8x8_inference_flag: u32 =
+                unsafe { ::std::mem::transmute(direct_8x8_inference_flag) };
+            direct_8x8_inference_flag as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 4u8, {
+            let log2_max_frame_num_minus4: u32 =
+                unsafe { ::std::mem::transmute(log2_max_frame_num_minus4) };
+            log2_max_frame_num_minus4 as u64
+        });
+        __bindgen_bitfield_unit.set(10usize, 2u8, {
+            let pic_order_cnt_type: u32 = unsafe { ::std::mem::transmute(pic_order_cnt_type) };
+            pic_order_cnt_type as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 4u8, {
+            let log2_max_pic_order_cnt_lsb_minus4: u32 =
+                unsafe { ::std::mem::transmute(log2_max_pic_order_cnt_lsb_minus4) };
+            log2_max_pic_order_cnt_lsb_minus4 as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 1u8, {
+            let delta_pic_order_always_zero_flag: u32 =
+                unsafe { ::std::mem::transmute(delta_pic_order_always_zero_flag) };
+            delta_pic_order_always_zero_flag as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncSequenceParameterBufferH264__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncSequenceParameterBufferH264__bindgen_ty_2 {
+    pub bits: _VAEncSequenceParameterBufferH264__bindgen_ty_2__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSequenceParameterBufferH264__bindgen_ty_2__bindgen_ty_1 {
+    pub _bitfield_align_1: [u16; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VAEncSequenceParameterBufferH264__bindgen_ty_2__bindgen_ty_1 {
+    #[inline]
+    pub fn aspect_ratio_info_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_aspect_ratio_info_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn timing_info_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_timing_info_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn bitstream_restriction_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_bitstream_restriction_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn log2_max_mv_length_horizontal(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 5u8) as u32) }
+    }
+    #[inline]
+    pub fn set_log2_max_mv_length_horizontal(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 5u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn log2_max_mv_length_vertical(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 5u8) as u32) }
+    }
+    #[inline]
+    pub fn set_log2_max_mv_length_vertical(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 5u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn fixed_frame_rate_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(13usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_fixed_frame_rate_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(13usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn low_delay_hrd_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_low_delay_hrd_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn motion_vectors_over_pic_boundaries_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(15usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_motion_vectors_over_pic_boundaries_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(15usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        aspect_ratio_info_present_flag: u32,
+        timing_info_present_flag: u32,
+        bitstream_restriction_flag: u32,
+        log2_max_mv_length_horizontal: u32,
+        log2_max_mv_length_vertical: u32,
+        fixed_frame_rate_flag: u32,
+        low_delay_hrd_flag: u32,
+        motion_vectors_over_pic_boundaries_flag: u32,
+        reserved: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let aspect_ratio_info_present_flag: u32 =
+                unsafe { ::std::mem::transmute(aspect_ratio_info_present_flag) };
+            aspect_ratio_info_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 1u8, {
+            let timing_info_present_flag: u32 =
+                unsafe { ::std::mem::transmute(timing_info_present_flag) };
+            timing_info_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let bitstream_restriction_flag: u32 =
+                unsafe { ::std::mem::transmute(bitstream_restriction_flag) };
+            bitstream_restriction_flag as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 5u8, {
+            let log2_max_mv_length_horizontal: u32 =
+                unsafe { ::std::mem::transmute(log2_max_mv_length_horizontal) };
+            log2_max_mv_length_horizontal as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 5u8, {
+            let log2_max_mv_length_vertical: u32 =
+                unsafe { ::std::mem::transmute(log2_max_mv_length_vertical) };
+            log2_max_mv_length_vertical as u64
+        });
+        __bindgen_bitfield_unit.set(13usize, 1u8, {
+            let fixed_frame_rate_flag: u32 =
+                unsafe { ::std::mem::transmute(fixed_frame_rate_flag) };
+            fixed_frame_rate_flag as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 1u8, {
+            let low_delay_hrd_flag: u32 = unsafe { ::std::mem::transmute(low_delay_hrd_flag) };
+            low_delay_hrd_flag as u64
+        });
+        __bindgen_bitfield_unit.set(15usize, 1u8, {
+            let motion_vectors_over_pic_boundaries_flag: u32 =
+                unsafe { ::std::mem::transmute(motion_vectors_over_pic_boundaries_flag) };
+            motion_vectors_over_pic_boundaries_flag as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 16u8, {
+            let reserved: u32 = unsafe { ::std::mem::transmute(reserved) };
+            reserved as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncSequenceParameterBufferH264__bindgen_ty_2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncSequenceParameterBufferH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncSequenceParameterBufferH264 = _VAEncSequenceParameterBufferH264;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncPictureParameterBufferH264 {
+    pub CurrPic: VAPictureH264,
+    pub ReferenceFrames: [VAPictureH264; 16usize],
+    pub coded_buf: VABufferID,
+    pub pic_parameter_set_id: u8,
+    pub seq_parameter_set_id: u8,
+    pub last_picture: u8,
+    pub frame_num: u16,
+    pub pic_init_qp: u8,
+    pub num_ref_idx_l0_active_minus1: u8,
+    pub num_ref_idx_l1_active_minus1: u8,
+    pub chroma_qp_index_offset: i8,
+    pub second_chroma_qp_index_offset: i8,
+    pub pic_fields: _VAEncPictureParameterBufferH264__bindgen_ty_1,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncPictureParameterBufferH264__bindgen_ty_1 {
+    pub bits: _VAEncPictureParameterBufferH264__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncPictureParameterBufferH264__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 2usize]>,
+    pub __bindgen_padding_0: u16,
+}
+impl _VAEncPictureParameterBufferH264__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn idr_pic_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_idr_pic_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reference_pic_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reference_pic_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn entropy_coding_mode_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_entropy_coding_mode_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn weighted_pred_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_weighted_pred_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn weighted_bipred_idc(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_weighted_bipred_idc(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn constrained_intra_pred_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_constrained_intra_pred_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn transform_8x8_mode_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_transform_8x8_mode_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn deblocking_filter_control_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(9usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_deblocking_filter_control_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(9usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn redundant_pic_cnt_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(10usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_redundant_pic_cnt_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(10usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn pic_order_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_pic_order_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn pic_scaling_matrix_present_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_pic_scaling_matrix_present_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        idr_pic_flag: u32,
+        reference_pic_flag: u32,
+        entropy_coding_mode_flag: u32,
+        weighted_pred_flag: u32,
+        weighted_bipred_idc: u32,
+        constrained_intra_pred_flag: u32,
+        transform_8x8_mode_flag: u32,
+        deblocking_filter_control_present_flag: u32,
+        redundant_pic_cnt_present_flag: u32,
+        pic_order_present_flag: u32,
+        pic_scaling_matrix_present_flag: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 2usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 2usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let idr_pic_flag: u32 = unsafe { ::std::mem::transmute(idr_pic_flag) };
+            idr_pic_flag as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 2u8, {
+            let reference_pic_flag: u32 = unsafe { ::std::mem::transmute(reference_pic_flag) };
+            reference_pic_flag as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let entropy_coding_mode_flag: u32 =
+                unsafe { ::std::mem::transmute(entropy_coding_mode_flag) };
+            entropy_coding_mode_flag as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let weighted_pred_flag: u32 = unsafe { ::std::mem::transmute(weighted_pred_flag) };
+            weighted_pred_flag as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 2u8, {
+            let weighted_bipred_idc: u32 = unsafe { ::std::mem::transmute(weighted_bipred_idc) };
+            weighted_bipred_idc as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 1u8, {
+            let constrained_intra_pred_flag: u32 =
+                unsafe { ::std::mem::transmute(constrained_intra_pred_flag) };
+            constrained_intra_pred_flag as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 1u8, {
+            let transform_8x8_mode_flag: u32 =
+                unsafe { ::std::mem::transmute(transform_8x8_mode_flag) };
+            transform_8x8_mode_flag as u64
+        });
+        __bindgen_bitfield_unit.set(9usize, 1u8, {
+            let deblocking_filter_control_present_flag: u32 =
+                unsafe { ::std::mem::transmute(deblocking_filter_control_present_flag) };
+            deblocking_filter_control_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(10usize, 1u8, {
+            let redundant_pic_cnt_present_flag: u32 =
+                unsafe { ::std::mem::transmute(redundant_pic_cnt_present_flag) };
+            redundant_pic_cnt_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 1u8, {
+            let pic_order_present_flag: u32 =
+                unsafe { ::std::mem::transmute(pic_order_present_flag) };
+            pic_order_present_flag as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 1u8, {
+            let pic_scaling_matrix_present_flag: u32 =
+                unsafe { ::std::mem::transmute(pic_scaling_matrix_present_flag) };
+            pic_scaling_matrix_present_flag as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncPictureParameterBufferH264__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncPictureParameterBufferH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncPictureParameterBufferH264 = _VAEncPictureParameterBufferH264;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncQPBufferH264 {
+    pub qp: u8,
+}
+pub type VAEncQPBufferH264 = _VAEncQPBufferH264;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSliceParameterBufferH264 {
+    pub macroblock_address: u32,
+    pub num_macroblocks: u32,
+    pub macroblock_info: VABufferID,
+    pub slice_type: u8,
+    pub pic_parameter_set_id: u8,
+    pub idr_pic_id: u16,
+    pub pic_order_cnt_lsb: u16,
+    pub delta_pic_order_cnt_bottom: i32,
+    pub delta_pic_order_cnt: [i32; 2usize],
+    pub direct_spatial_mv_pred_flag: u8,
+    pub num_ref_idx_active_override_flag: u8,
+    pub num_ref_idx_l0_active_minus1: u8,
+    pub num_ref_idx_l1_active_minus1: u8,
+    pub RefPicList0: [VAPictureH264; 32usize],
+    pub RefPicList1: [VAPictureH264; 32usize],
+    pub luma_log2_weight_denom: u8,
+    pub chroma_log2_weight_denom: u8,
+    pub luma_weight_l0_flag: u8,
+    pub luma_weight_l0: [::std::os::raw::c_short; 32usize],
+    pub luma_offset_l0: [::std::os::raw::c_short; 32usize],
+    pub chroma_weight_l0_flag: u8,
+    pub chroma_weight_l0: [[::std::os::raw::c_short; 2usize]; 32usize],
+    pub chroma_offset_l0: [[::std::os::raw::c_short; 2usize]; 32usize],
+    pub luma_weight_l1_flag: u8,
+    pub luma_weight_l1: [::std::os::raw::c_short; 32usize],
+    pub luma_offset_l1: [::std::os::raw::c_short; 32usize],
+    pub chroma_weight_l1_flag: u8,
+    pub chroma_weight_l1: [[::std::os::raw::c_short; 2usize]; 32usize],
+    pub chroma_offset_l1: [[::std::os::raw::c_short; 2usize]; 32usize],
+    pub cabac_init_idc: u8,
+    pub slice_qp_delta: i8,
+    pub disable_deblocking_filter_idc: u8,
+    pub slice_alpha_c0_offset_div2: i8,
+    pub slice_beta_offset_div2: i8,
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAEncSliceParameterBufferH264 = _VAEncSliceParameterBufferH264;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncMacroblockParameterBufferH264 {
+    pub qp: u8,
+    pub info: _VAEncMacroblockParameterBufferH264__bindgen_ty_1,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncMacroblockParameterBufferH264__bindgen_ty_1 {
+    pub intra_fields: _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_1,
+    pub inter_fields: _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_2,
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_1 {
+    pub bits: _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 2usize]>,
+    pub __bindgen_padding_0: u16,
+}
+impl _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn pred_avail_override_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_pred_avail_override_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn pred_avail_flags(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_pred_avail_flags(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        pred_avail_override_flag: u32,
+        pred_avail_flags: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 2usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 2usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let pred_avail_override_flag: u32 =
+                unsafe { ::std::mem::transmute(pred_avail_override_flag) };
+            pred_avail_override_flag as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 8u8, {
+            let pred_avail_flags: u32 = unsafe { ::std::mem::transmute(pred_avail_flags) };
+            pred_avail_flags as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_2 {
+    pub bits: _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_2__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_2__bindgen_ty_1 {
+    pub reserved: u32,
+}
+impl Default for _VAEncMacroblockParameterBufferH264__bindgen_ty_1__bindgen_ty_2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncMacroblockParameterBufferH264__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncMacroblockParameterBufferH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncMacroblockParameterBufferH264 = _VAEncMacroblockParameterBufferH264;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncMiscParameterSubMbPartPelH264 {
+    pub disable_inter_sub_mb_partition: u32,
+    pub inter_sub_mb_partition_mask: _VAEncMiscParameterSubMbPartPelH264__bindgen_ty_1,
+    pub enable_sub_pel_mode: u32,
+    pub sub_pel_mode: u8,
+    pub reserved: [u8; 3usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncMiscParameterSubMbPartPelH264__bindgen_ty_1 {
+    pub bits: _VAEncMiscParameterSubMbPartPelH264__bindgen_ty_1__bindgen_ty_1,
+    pub value: u8,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncMiscParameterSubMbPartPelH264__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
+    pub __bindgen_padding_0: [u8; 3usize],
+}
+impl _VAEncMiscParameterSubMbPartPelH264__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn disable_16x16_inter_mb_partition(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_16x16_inter_mb_partition(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn disable_16x8_inter_mb_partition(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_16x8_inter_mb_partition(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn disable_8x16_inter_mb_partition(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_8x16_inter_mb_partition(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn disable_8x8_inter_mb_partition(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_8x8_inter_mb_partition(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn disable_8x4_inter_mb_partition(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_8x4_inter_mb_partition(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn disable_4x8_inter_mb_partition(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_4x8_inter_mb_partition(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn disable_4x4_inter_mb_partition(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_4x4_inter_mb_partition(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        disable_16x16_inter_mb_partition: u32,
+        disable_16x8_inter_mb_partition: u32,
+        disable_8x16_inter_mb_partition: u32,
+        disable_8x8_inter_mb_partition: u32,
+        disable_8x4_inter_mb_partition: u32,
+        disable_4x8_inter_mb_partition: u32,
+        disable_4x4_inter_mb_partition: u32,
+        reserved: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let disable_16x16_inter_mb_partition: u32 =
+                unsafe { ::std::mem::transmute(disable_16x16_inter_mb_partition) };
+            disable_16x16_inter_mb_partition as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 1u8, {
+            let disable_16x8_inter_mb_partition: u32 =
+                unsafe { ::std::mem::transmute(disable_16x8_inter_mb_partition) };
+            disable_16x8_inter_mb_partition as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let disable_8x16_inter_mb_partition: u32 =
+                unsafe { ::std::mem::transmute(disable_8x16_inter_mb_partition) };
+            disable_8x16_inter_mb_partition as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let disable_8x8_inter_mb_partition: u32 =
+                unsafe { ::std::mem::transmute(disable_8x8_inter_mb_partition) };
+            disable_8x8_inter_mb_partition as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let disable_8x4_inter_mb_partition: u32 =
+                unsafe { ::std::mem::transmute(disable_8x4_inter_mb_partition) };
+            disable_8x4_inter_mb_partition as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let disable_4x8_inter_mb_partition: u32 =
+                unsafe { ::std::mem::transmute(disable_4x8_inter_mb_partition) };
+            disable_4x8_inter_mb_partition as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 1u8, {
+            let disable_4x4_inter_mb_partition: u32 =
+                unsafe { ::std::mem::transmute(disable_4x4_inter_mb_partition) };
+            disable_4x4_inter_mb_partition as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 1u8, {
+            let reserved: u32 = unsafe { ::std::mem::transmute(reserved) };
+            reserved as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncMiscParameterSubMbPartPelH264__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncMiscParameterSubMbPartPelH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncMiscParameterSubMbPartPelH264 = _VAEncMiscParameterSubMbPartPelH264;
+pub type VAQMatrixBufferMPEG2 = VAIQMatrixBufferMPEG2;
+pub mod VAEncPackedHeaderTypeMPEG2 {
+    pub type Type = ::std::os::raw::c_uint;
+    pub const VAEncPackedHeaderMPEG2_SPS: Type = 1;
+    pub const VAEncPackedHeaderMPEG2_PPS: Type = 2;
+    pub const VAEncPackedHeaderMPEG2_Slice: Type = 3;
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncSequenceParameterBufferMPEG2 {
+    pub intra_period: u32,
+    pub ip_period: u32,
+    pub picture_width: u16,
+    pub picture_height: u16,
+    pub bits_per_second: u32,
+    pub frame_rate: f32,
+    pub aspect_ratio_information: u16,
+    pub vbv_buffer_size: u32,
+    pub sequence_extension: _VAEncSequenceParameterBufferMPEG2__bindgen_ty_1,
+    pub new_gop_header: u32,
+    pub gop_header: _VAEncSequenceParameterBufferMPEG2__bindgen_ty_2,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncSequenceParameterBufferMPEG2__bindgen_ty_1 {
+    pub bits: _VAEncSequenceParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSequenceParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 3usize]>,
+    pub __bindgen_padding_0: u8,
+}
+impl _VAEncSequenceParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn profile_and_level_indication(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_profile_and_level_indication(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn progressive_sequence(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_progressive_sequence(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn chroma_format(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(9usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_chroma_format(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(9usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn low_delay(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_low_delay(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_rate_extension_n(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_rate_extension_n(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_rate_extension_d(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 5u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_rate_extension_d(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 5u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        profile_and_level_indication: u32,
+        progressive_sequence: u32,
+        chroma_format: u32,
+        low_delay: u32,
+        frame_rate_extension_n: u32,
+        frame_rate_extension_d: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 3usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 3usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 8u8, {
+            let profile_and_level_indication: u32 =
+                unsafe { ::std::mem::transmute(profile_and_level_indication) };
+            profile_and_level_indication as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 1u8, {
+            let progressive_sequence: u32 = unsafe { ::std::mem::transmute(progressive_sequence) };
+            progressive_sequence as u64
+        });
+        __bindgen_bitfield_unit.set(9usize, 2u8, {
+            let chroma_format: u32 = unsafe { ::std::mem::transmute(chroma_format) };
+            chroma_format as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 1u8, {
+            let low_delay: u32 = unsafe { ::std::mem::transmute(low_delay) };
+            low_delay as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 2u8, {
+            let frame_rate_extension_n: u32 =
+                unsafe { ::std::mem::transmute(frame_rate_extension_n) };
+            frame_rate_extension_n as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 5u8, {
+            let frame_rate_extension_d: u32 =
+                unsafe { ::std::mem::transmute(frame_rate_extension_d) };
+            frame_rate_extension_d as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncSequenceParameterBufferMPEG2__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncSequenceParameterBufferMPEG2__bindgen_ty_2 {
+    pub bits: _VAEncSequenceParameterBufferMPEG2__bindgen_ty_2__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSequenceParameterBufferMPEG2__bindgen_ty_2__bindgen_ty_1 {
+    pub _bitfield_align_1: [u32; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VAEncSequenceParameterBufferMPEG2__bindgen_ty_2__bindgen_ty_1 {
+    #[inline]
+    pub fn time_code(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 25u8) as u32) }
+    }
+    #[inline]
+    pub fn set_time_code(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 25u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn closed_gop(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(25usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_closed_gop(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(25usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn broken_link(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(26usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_broken_link(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(26usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        time_code: u32,
+        closed_gop: u32,
+        broken_link: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 25u8, {
+            let time_code: u32 = unsafe { ::std::mem::transmute(time_code) };
+            time_code as u64
+        });
+        __bindgen_bitfield_unit.set(25usize, 1u8, {
+            let closed_gop: u32 = unsafe { ::std::mem::transmute(closed_gop) };
+            closed_gop as u64
+        });
+        __bindgen_bitfield_unit.set(26usize, 1u8, {
+            let broken_link: u32 = unsafe { ::std::mem::transmute(broken_link) };
+            broken_link as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncSequenceParameterBufferMPEG2__bindgen_ty_2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncSequenceParameterBufferMPEG2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncSequenceParameterBufferMPEG2 = _VAEncSequenceParameterBufferMPEG2;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncPictureParameterBufferMPEG2 {
+    pub forward_reference_picture: VASurfaceID,
+    pub backward_reference_picture: VASurfaceID,
+    pub reconstructed_picture: VASurfaceID,
+    pub coded_buf: VABufferID,
+    pub last_picture: u8,
+    pub picture_type: VAEncPictureType::Type,
+    pub temporal_reference: u32,
+    pub vbv_delay: u32,
+    pub f_code: [[u8; 2usize]; 2usize],
+    pub picture_coding_extension: _VAEncPictureParameterBufferMPEG2__bindgen_ty_1,
+    pub composite_display: _VAEncPictureParameterBufferMPEG2__bindgen_ty_2,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncPictureParameterBufferMPEG2__bindgen_ty_1 {
+    pub bits: _VAEncPictureParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncPictureParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 2usize]>,
+    pub __bindgen_padding_0: u16,
+}
+impl _VAEncPictureParameterBufferMPEG2__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn intra_dc_precision(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_dc_precision(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn picture_structure(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_picture_structure(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn top_field_first(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_top_field_first(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_pred_frame_dct(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_pred_frame_dct(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn concealment_motion_vectors(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_concealment_motion_vectors(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn q_scale_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_q_scale_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_vlc_format(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_vlc_format(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn alternate_scan(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(9usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_alternate_scan(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(9usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn repeat_first_field(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(10usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_repeat_first_field(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(10usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn progressive_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_progressive_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn composite_display_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_composite_display_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        intra_dc_precision: u32,
+        picture_structure: u32,
+        top_field_first: u32,
+        frame_pred_frame_dct: u32,
+        concealment_motion_vectors: u32,
+        q_scale_type: u32,
+        intra_vlc_format: u32,
+        alternate_scan: u32,
+        repeat_first_field: u32,
+        progressive_frame: u32,
+        composite_display_flag: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 2usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 2usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 2u8, {
+            let intra_dc_precision: u32 = unsafe { ::std::mem::transmute(intra_dc_precision) };
+            intra_dc_precision as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 2u8, {
+            let picture_structure: u32 = unsafe { ::std::mem::transmute(picture_structure) };
+            picture_structure as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let top_field_first: u32 = unsafe { ::std::mem::transmute(top_field_first) };
+            top_field_first as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let frame_pred_frame_dct: u32 = unsafe { ::std::mem::transmute(frame_pred_frame_dct) };
+            frame_pred_frame_dct as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 1u8, {
+            let concealment_motion_vectors: u32 =
+                unsafe { ::std::mem::transmute(concealment_motion_vectors) };
+            concealment_motion_vectors as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 1u8, {
+            let q_scale_type: u32 = unsafe { ::std::mem::transmute(q_scale_type) };
+            q_scale_type as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 1u8, {
+            let intra_vlc_format: u32 = unsafe { ::std::mem::transmute(intra_vlc_format) };
+            intra_vlc_format as u64
+        });
+        __bindgen_bitfield_unit.set(9usize, 1u8, {
+            let alternate_scan: u32 = unsafe { ::std::mem::transmute(alternate_scan) };
+            alternate_scan as u64
+        });
+        __bindgen_bitfield_unit.set(10usize, 1u8, {
+            let repeat_first_field: u32 = unsafe { ::std::mem::transmute(repeat_first_field) };
+            repeat_first_field as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 1u8, {
+            let progressive_frame: u32 = unsafe { ::std::mem::transmute(progressive_frame) };
+            progressive_frame as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 1u8, {
+            let composite_display_flag: u32 =
+                unsafe { ::std::mem::transmute(composite_display_flag) };
+            composite_display_flag as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncPictureParameterBufferMPEG2__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncPictureParameterBufferMPEG2__bindgen_ty_2 {
+    pub bits: _VAEncPictureParameterBufferMPEG2__bindgen_ty_2__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncPictureParameterBufferMPEG2__bindgen_ty_2__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 3usize]>,
+    pub __bindgen_padding_0: u8,
+}
+impl _VAEncPictureParameterBufferMPEG2__bindgen_ty_2__bindgen_ty_1 {
+    #[inline]
+    pub fn v_axis(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_v_axis(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn field_sequence(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_field_sequence(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sub_carrier(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sub_carrier(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn burst_amplitude(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 7u8) as u32) }
+    }
+    #[inline]
+    pub fn set_burst_amplitude(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 7u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sub_carrier_phase(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sub_carrier_phase(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        v_axis: u32,
+        field_sequence: u32,
+        sub_carrier: u32,
+        burst_amplitude: u32,
+        sub_carrier_phase: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 3usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 3usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let v_axis: u32 = unsafe { ::std::mem::transmute(v_axis) };
+            v_axis as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 3u8, {
+            let field_sequence: u32 = unsafe { ::std::mem::transmute(field_sequence) };
+            field_sequence as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let sub_carrier: u32 = unsafe { ::std::mem::transmute(sub_carrier) };
+            sub_carrier as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 7u8, {
+            let burst_amplitude: u32 = unsafe { ::std::mem::transmute(burst_amplitude) };
+            burst_amplitude as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 8u8, {
+            let sub_carrier_phase: u32 = unsafe { ::std::mem::transmute(sub_carrier_phase) };
+            sub_carrier_phase as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncPictureParameterBufferMPEG2__bindgen_ty_2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncPictureParameterBufferMPEG2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncPictureParameterBufferMPEG2 = _VAEncPictureParameterBufferMPEG2;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSliceParameterBufferMPEG2 {
+    pub macroblock_address: u32,
+    pub num_macroblocks: u32,
+    pub quantiser_scale_code: i32,
+    pub is_intra_slice: i32,
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAEncSliceParameterBufferMPEG2 = _VAEncSliceParameterBufferMPEG2;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncMiscParameterExtensionDataSeqDisplayMPEG2 {
+    pub extension_start_code_identifier: u8,
+    pub video_format: u8,
+    pub colour_description: u8,
+    pub colour_primaries: u8,
+    pub transfer_characteristics: u8,
+    pub matrix_coefficients: u8,
+    pub display_horizontal_size: u16,
+    pub display_vertical_size: u16,
+}
+pub type VAEncMiscParameterExtensionDataSeqDisplayMPEG2 =
+    _VAEncMiscParameterExtensionDataSeqDisplayMPEG2;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSequenceParameterBufferVP8 {
+    pub frame_width: u32,
+    pub frame_height: u32,
+    pub frame_width_scale: u32,
+    pub frame_height_scale: u32,
+    pub error_resilient: u32,
+    pub kf_auto: u32,
+    pub kf_min_dist: u32,
+    pub kf_max_dist: u32,
+    pub bits_per_second: u32,
+    pub intra_period: u32,
+    pub reference_frames: [VASurfaceID; 4usize],
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAEncSequenceParameterBufferVP8 = _VAEncSequenceParameterBufferVP8;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncPictureParameterBufferVP8 {
+    pub reconstructed_frame: VASurfaceID,
+    pub ref_last_frame: VASurfaceID,
+    pub ref_gf_frame: VASurfaceID,
+    pub ref_arf_frame: VASurfaceID,
+    pub coded_buf: VABufferID,
+    pub ref_flags: _VAEncPictureParameterBufferVP8__bindgen_ty_1,
+    pub pic_flags: _VAEncPictureParameterBufferVP8__bindgen_ty_2,
+    pub loop_filter_level: [i8; 4usize],
+    pub ref_lf_delta: [i8; 4usize],
+    pub mode_lf_delta: [i8; 4usize],
+    pub sharpness_level: u8,
+    pub clamp_qindex_high: u8,
+    pub clamp_qindex_low: u8,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncPictureParameterBufferVP8__bindgen_ty_1 {
+    pub bits: _VAEncPictureParameterBufferVP8__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncPictureParameterBufferVP8__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u16; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VAEncPictureParameterBufferVP8__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn force_kf(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_force_kf(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn no_ref_last(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_no_ref_last(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn no_ref_gf(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_no_ref_gf(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn no_ref_arf(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_no_ref_arf(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn temporal_id(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_temporal_id(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn first_ref(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_first_ref(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn second_ref(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_second_ref(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        force_kf: u32,
+        no_ref_last: u32,
+        no_ref_gf: u32,
+        no_ref_arf: u32,
+        temporal_id: u32,
+        first_ref: u32,
+        second_ref: u32,
+        reserved: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let force_kf: u32 = unsafe { ::std::mem::transmute(force_kf) };
+            force_kf as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 1u8, {
+            let no_ref_last: u32 = unsafe { ::std::mem::transmute(no_ref_last) };
+            no_ref_last as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let no_ref_gf: u32 = unsafe { ::std::mem::transmute(no_ref_gf) };
+            no_ref_gf as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let no_ref_arf: u32 = unsafe { ::std::mem::transmute(no_ref_arf) };
+            no_ref_arf as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 8u8, {
+            let temporal_id: u32 = unsafe { ::std::mem::transmute(temporal_id) };
+            temporal_id as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 2u8, {
+            let first_ref: u32 = unsafe { ::std::mem::transmute(first_ref) };
+            first_ref as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 2u8, {
+            let second_ref: u32 = unsafe { ::std::mem::transmute(second_ref) };
+            second_ref as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 16u8, {
+            let reserved: u32 = unsafe { ::std::mem::transmute(reserved) };
+            reserved as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncPictureParameterBufferVP8__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncPictureParameterBufferVP8__bindgen_ty_2 {
+    pub bits: _VAEncPictureParameterBufferVP8__bindgen_ty_2__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncPictureParameterBufferVP8__bindgen_ty_2__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VAEncPictureParameterBufferVP8__bindgen_ty_2__bindgen_ty_1 {
+    #[inline]
+    pub fn frame_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn version(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_version(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn show_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_show_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn color_space(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_color_space(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn recon_filter_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_recon_filter_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn loop_filter_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_loop_filter_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn auto_partitions(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(10usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_auto_partitions(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(10usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn num_token_partitions(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_num_token_partitions(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn clamping_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(13usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_clamping_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(13usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segmentation_enabled(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_segmentation_enabled(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn update_mb_segmentation_map(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(15usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_update_mb_segmentation_map(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(15usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn update_segment_feature_data(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_update_segment_feature_data(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn loop_filter_adj_enable(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(17usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_loop_filter_adj_enable(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(17usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn refresh_entropy_probs(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(18usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_refresh_entropy_probs(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(18usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn refresh_golden_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(19usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_refresh_golden_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(19usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn refresh_alternate_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(20usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_refresh_alternate_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(20usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn refresh_last(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(21usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_refresh_last(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(21usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn copy_buffer_to_golden(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(22usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_copy_buffer_to_golden(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(22usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn copy_buffer_to_alternate(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(24usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_copy_buffer_to_alternate(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(24usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sign_bias_golden(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(26usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sign_bias_golden(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(26usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sign_bias_alternate(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(27usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sign_bias_alternate(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(27usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_no_coeff_skip(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(28usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_no_coeff_skip(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(28usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn forced_lf_adjustment(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(29usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_forced_lf_adjustment(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(29usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(30usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(30usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        frame_type: u32,
+        version: u32,
+        show_frame: u32,
+        color_space: u32,
+        recon_filter_type: u32,
+        loop_filter_type: u32,
+        auto_partitions: u32,
+        num_token_partitions: u32,
+        clamping_type: u32,
+        segmentation_enabled: u32,
+        update_mb_segmentation_map: u32,
+        update_segment_feature_data: u32,
+        loop_filter_adj_enable: u32,
+        refresh_entropy_probs: u32,
+        refresh_golden_frame: u32,
+        refresh_alternate_frame: u32,
+        refresh_last: u32,
+        copy_buffer_to_golden: u32,
+        copy_buffer_to_alternate: u32,
+        sign_bias_golden: u32,
+        sign_bias_alternate: u32,
+        mb_no_coeff_skip: u32,
+        forced_lf_adjustment: u32,
+        reserved: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let frame_type: u32 = unsafe { ::std::mem::transmute(frame_type) };
+            frame_type as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 3u8, {
+            let version: u32 = unsafe { ::std::mem::transmute(version) };
+            version as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let show_frame: u32 = unsafe { ::std::mem::transmute(show_frame) };
+            show_frame as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 1u8, {
+            let color_space: u32 = unsafe { ::std::mem::transmute(color_space) };
+            color_space as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 2u8, {
+            let recon_filter_type: u32 = unsafe { ::std::mem::transmute(recon_filter_type) };
+            recon_filter_type as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 2u8, {
+            let loop_filter_type: u32 = unsafe { ::std::mem::transmute(loop_filter_type) };
+            loop_filter_type as u64
+        });
+        __bindgen_bitfield_unit.set(10usize, 1u8, {
+            let auto_partitions: u32 = unsafe { ::std::mem::transmute(auto_partitions) };
+            auto_partitions as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 2u8, {
+            let num_token_partitions: u32 = unsafe { ::std::mem::transmute(num_token_partitions) };
+            num_token_partitions as u64
+        });
+        __bindgen_bitfield_unit.set(13usize, 1u8, {
+            let clamping_type: u32 = unsafe { ::std::mem::transmute(clamping_type) };
+            clamping_type as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 1u8, {
+            let segmentation_enabled: u32 = unsafe { ::std::mem::transmute(segmentation_enabled) };
+            segmentation_enabled as u64
+        });
+        __bindgen_bitfield_unit.set(15usize, 1u8, {
+            let update_mb_segmentation_map: u32 =
+                unsafe { ::std::mem::transmute(update_mb_segmentation_map) };
+            update_mb_segmentation_map as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 1u8, {
+            let update_segment_feature_data: u32 =
+                unsafe { ::std::mem::transmute(update_segment_feature_data) };
+            update_segment_feature_data as u64
+        });
+        __bindgen_bitfield_unit.set(17usize, 1u8, {
+            let loop_filter_adj_enable: u32 =
+                unsafe { ::std::mem::transmute(loop_filter_adj_enable) };
+            loop_filter_adj_enable as u64
+        });
+        __bindgen_bitfield_unit.set(18usize, 1u8, {
+            let refresh_entropy_probs: u32 =
+                unsafe { ::std::mem::transmute(refresh_entropy_probs) };
+            refresh_entropy_probs as u64
+        });
+        __bindgen_bitfield_unit.set(19usize, 1u8, {
+            let refresh_golden_frame: u32 = unsafe { ::std::mem::transmute(refresh_golden_frame) };
+            refresh_golden_frame as u64
+        });
+        __bindgen_bitfield_unit.set(20usize, 1u8, {
+            let refresh_alternate_frame: u32 =
+                unsafe { ::std::mem::transmute(refresh_alternate_frame) };
+            refresh_alternate_frame as u64
+        });
+        __bindgen_bitfield_unit.set(21usize, 1u8, {
+            let refresh_last: u32 = unsafe { ::std::mem::transmute(refresh_last) };
+            refresh_last as u64
+        });
+        __bindgen_bitfield_unit.set(22usize, 2u8, {
+            let copy_buffer_to_golden: u32 =
+                unsafe { ::std::mem::transmute(copy_buffer_to_golden) };
+            copy_buffer_to_golden as u64
+        });
+        __bindgen_bitfield_unit.set(24usize, 2u8, {
+            let copy_buffer_to_alternate: u32 =
+                unsafe { ::std::mem::transmute(copy_buffer_to_alternate) };
+            copy_buffer_to_alternate as u64
+        });
+        __bindgen_bitfield_unit.set(26usize, 1u8, {
+            let sign_bias_golden: u32 = unsafe { ::std::mem::transmute(sign_bias_golden) };
+            sign_bias_golden as u64
+        });
+        __bindgen_bitfield_unit.set(27usize, 1u8, {
+            let sign_bias_alternate: u32 = unsafe { ::std::mem::transmute(sign_bias_alternate) };
+            sign_bias_alternate as u64
+        });
+        __bindgen_bitfield_unit.set(28usize, 1u8, {
+            let mb_no_coeff_skip: u32 = unsafe { ::std::mem::transmute(mb_no_coeff_skip) };
+            mb_no_coeff_skip as u64
+        });
+        __bindgen_bitfield_unit.set(29usize, 1u8, {
+            let forced_lf_adjustment: u32 = unsafe { ::std::mem::transmute(forced_lf_adjustment) };
+            forced_lf_adjustment as u64
+        });
+        __bindgen_bitfield_unit.set(30usize, 2u8, {
+            let reserved: u32 = unsafe { ::std::mem::transmute(reserved) };
+            reserved as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncPictureParameterBufferVP8__bindgen_ty_2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncPictureParameterBufferVP8 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncPictureParameterBufferVP8 = _VAEncPictureParameterBufferVP8;
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncMBMapBufferVP8 {
+    pub num_mbs: u32,
+    pub mb_segment_id: *mut u8,
+    pub va_reserved: [u32; 4usize],
+}
+impl Default for _VAEncMBMapBufferVP8 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncMBMapBufferVP8 = _VAEncMBMapBufferVP8;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAQMatrixBufferVP8 {
+    pub quantization_index: [u16; 4usize],
+    pub quantization_index_delta: [i16; 5usize],
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAQMatrixBufferVP8 = _VAQMatrixBufferVP8;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VACodedBufferVP9Status {
+    pub base_qp_index: u16,
+    pub loop_filter_level: u8,
+    pub long_term_indication: u8,
+    pub next_frame_width: u16,
+    pub next_frame_height: u16,
+    pub va_reserved: [u32; 4usize],
+}
+pub type VACodedBufferVP9Status = _VACodedBufferVP9Status;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSequenceParameterBufferVP9 {
+    pub max_frame_width: u32,
+    pub max_frame_height: u32,
+    pub kf_auto: u32,
+    pub kf_min_dist: u32,
+    pub kf_max_dist: u32,
+    pub bits_per_second: u32,
+    pub intra_period: u32,
+    pub va_reserved: [u32; 4usize],
+}
+pub type VAEncSequenceParameterBufferVP9 = _VAEncSequenceParameterBufferVP9;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncPictureParameterBufferVP9 {
+    pub frame_width_src: u32,
+    pub frame_height_src: u32,
+    pub frame_width_dst: u32,
+    pub frame_height_dst: u32,
+    pub reconstructed_frame: VASurfaceID,
+    pub reference_frames: [VASurfaceID; 8usize],
+    pub coded_buf: VABufferID,
+    pub ref_flags: _VAEncPictureParameterBufferVP9__bindgen_ty_1,
+    pub pic_flags: _VAEncPictureParameterBufferVP9__bindgen_ty_2,
+    pub refresh_frame_flags: u8,
+    pub luma_ac_qindex: u8,
+    pub luma_dc_qindex_delta: i8,
+    pub chroma_ac_qindex_delta: i8,
+    pub chroma_dc_qindex_delta: i8,
+    pub filter_level: u8,
+    pub sharpness_level: u8,
+    pub ref_lf_delta: [i8; 4usize],
+    pub mode_lf_delta: [i8; 2usize],
+    pub bit_offset_ref_lf_delta: u16,
+    pub bit_offset_mode_lf_delta: u16,
+    pub bit_offset_lf_level: u16,
+    pub bit_offset_qindex: u16,
+    pub bit_offset_first_partition_size: u16,
+    pub bit_offset_segmentation: u16,
+    pub bit_size_segmentation: u16,
+    pub log2_tile_rows: u8,
+    pub log2_tile_columns: u8,
+    pub skip_frame_flag: u8,
+    pub number_skip_frames: u8,
+    pub skip_frames_size: u32,
+    pub va_reserved: [u32; 8usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncPictureParameterBufferVP9__bindgen_ty_1 {
+    pub bits: _VAEncPictureParameterBufferVP9__bindgen_ty_1__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncPictureParameterBufferVP9__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VAEncPictureParameterBufferVP9__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn force_kf(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_force_kf(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_frame_ctrl_l0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_frame_ctrl_l0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_frame_ctrl_l1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_frame_ctrl_l1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_last_idx(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_last_idx(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_last_sign_bias(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(10usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_last_sign_bias(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(10usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_gf_idx(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_gf_idx(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_gf_sign_bias(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_gf_sign_bias(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_arf_idx(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(15usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_arf_idx(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(15usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_arf_sign_bias(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(18usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_arf_sign_bias(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(18usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn temporal_id(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(19usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_temporal_id(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(19usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(27usize, 5u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(27usize, 5u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        force_kf: u32,
+        ref_frame_ctrl_l0: u32,
+        ref_frame_ctrl_l1: u32,
+        ref_last_idx: u32,
+        ref_last_sign_bias: u32,
+        ref_gf_idx: u32,
+        ref_gf_sign_bias: u32,
+        ref_arf_idx: u32,
+        ref_arf_sign_bias: u32,
+        temporal_id: u32,
+        reserved: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let force_kf: u32 = unsafe { ::std::mem::transmute(force_kf) };
+            force_kf as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 3u8, {
+            let ref_frame_ctrl_l0: u32 = unsafe { ::std::mem::transmute(ref_frame_ctrl_l0) };
+            ref_frame_ctrl_l0 as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 3u8, {
+            let ref_frame_ctrl_l1: u32 = unsafe { ::std::mem::transmute(ref_frame_ctrl_l1) };
+            ref_frame_ctrl_l1 as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 3u8, {
+            let ref_last_idx: u32 = unsafe { ::std::mem::transmute(ref_last_idx) };
+            ref_last_idx as u64
+        });
+        __bindgen_bitfield_unit.set(10usize, 1u8, {
+            let ref_last_sign_bias: u32 = unsafe { ::std::mem::transmute(ref_last_sign_bias) };
+            ref_last_sign_bias as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 3u8, {
+            let ref_gf_idx: u32 = unsafe { ::std::mem::transmute(ref_gf_idx) };
+            ref_gf_idx as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 1u8, {
+            let ref_gf_sign_bias: u32 = unsafe { ::std::mem::transmute(ref_gf_sign_bias) };
+            ref_gf_sign_bias as u64
+        });
+        __bindgen_bitfield_unit.set(15usize, 3u8, {
+            let ref_arf_idx: u32 = unsafe { ::std::mem::transmute(ref_arf_idx) };
+            ref_arf_idx as u64
+        });
+        __bindgen_bitfield_unit.set(18usize, 1u8, {
+            let ref_arf_sign_bias: u32 = unsafe { ::std::mem::transmute(ref_arf_sign_bias) };
+            ref_arf_sign_bias as u64
+        });
+        __bindgen_bitfield_unit.set(19usize, 8u8, {
+            let temporal_id: u32 = unsafe { ::std::mem::transmute(temporal_id) };
+            temporal_id as u64
+        });
+        __bindgen_bitfield_unit.set(27usize, 5u8, {
+            let reserved: u32 = unsafe { ::std::mem::transmute(reserved) };
+            reserved as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncPictureParameterBufferVP9__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncPictureParameterBufferVP9__bindgen_ty_2 {
+    pub bits: _VAEncPictureParameterBufferVP9__bindgen_ty_2__bindgen_ty_1,
+    pub value: u32,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncPictureParameterBufferVP9__bindgen_ty_2__bindgen_ty_1 {
+    pub _bitfield_align_1: [u16; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VAEncPictureParameterBufferVP9__bindgen_ty_2__bindgen_ty_1 {
+    #[inline]
+    pub fn frame_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn show_frame(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_show_frame(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn error_resilient_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_error_resilient_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_only(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_only(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn allow_high_precision_mv(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_allow_high_precision_mv(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mcomp_filter_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mcomp_filter_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_parallel_decoding_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_parallel_decoding_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reset_frame_context(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(9usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reset_frame_context(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(9usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn refresh_frame_context(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(11usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_refresh_frame_context(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(11usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn frame_context_idx(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(12usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_context_idx(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(12usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segmentation_enabled(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_segmentation_enabled(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segmentation_temporal_update(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(15usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_segmentation_temporal_update(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(15usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segmentation_update_map(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_segmentation_update_map(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn lossless_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(17usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_lossless_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(17usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn comp_prediction_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(18usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_comp_prediction_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(18usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn auto_segmentation(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(20usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_auto_segmentation(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(20usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn super_frame_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(21usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_super_frame_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(21usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(22usize, 10u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(22usize, 10u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        frame_type: u32,
+        show_frame: u32,
+        error_resilient_mode: u32,
+        intra_only: u32,
+        allow_high_precision_mv: u32,
+        mcomp_filter_type: u32,
+        frame_parallel_decoding_mode: u32,
+        reset_frame_context: u32,
+        refresh_frame_context: u32,
+        frame_context_idx: u32,
+        segmentation_enabled: u32,
+        segmentation_temporal_update: u32,
+        segmentation_update_map: u32,
+        lossless_mode: u32,
+        comp_prediction_mode: u32,
+        auto_segmentation: u32,
+        super_frame_flag: u32,
+        reserved: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let frame_type: u32 = unsafe { ::std::mem::transmute(frame_type) };
+            frame_type as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 1u8, {
+            let show_frame: u32 = unsafe { ::std::mem::transmute(show_frame) };
+            show_frame as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let error_resilient_mode: u32 = unsafe { ::std::mem::transmute(error_resilient_mode) };
+            error_resilient_mode as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let intra_only: u32 = unsafe { ::std::mem::transmute(intra_only) };
+            intra_only as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let allow_high_precision_mv: u32 =
+                unsafe { ::std::mem::transmute(allow_high_precision_mv) };
+            allow_high_precision_mv as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 3u8, {
+            let mcomp_filter_type: u32 = unsafe { ::std::mem::transmute(mcomp_filter_type) };
+            mcomp_filter_type as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 1u8, {
+            let frame_parallel_decoding_mode: u32 =
+                unsafe { ::std::mem::transmute(frame_parallel_decoding_mode) };
+            frame_parallel_decoding_mode as u64
+        });
+        __bindgen_bitfield_unit.set(9usize, 2u8, {
+            let reset_frame_context: u32 = unsafe { ::std::mem::transmute(reset_frame_context) };
+            reset_frame_context as u64
+        });
+        __bindgen_bitfield_unit.set(11usize, 1u8, {
+            let refresh_frame_context: u32 =
+                unsafe { ::std::mem::transmute(refresh_frame_context) };
+            refresh_frame_context as u64
+        });
+        __bindgen_bitfield_unit.set(12usize, 2u8, {
+            let frame_context_idx: u32 = unsafe { ::std::mem::transmute(frame_context_idx) };
+            frame_context_idx as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 1u8, {
+            let segmentation_enabled: u32 = unsafe { ::std::mem::transmute(segmentation_enabled) };
+            segmentation_enabled as u64
+        });
+        __bindgen_bitfield_unit.set(15usize, 1u8, {
+            let segmentation_temporal_update: u32 =
+                unsafe { ::std::mem::transmute(segmentation_temporal_update) };
+            segmentation_temporal_update as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 1u8, {
+            let segmentation_update_map: u32 =
+                unsafe { ::std::mem::transmute(segmentation_update_map) };
+            segmentation_update_map as u64
+        });
+        __bindgen_bitfield_unit.set(17usize, 1u8, {
+            let lossless_mode: u32 = unsafe { ::std::mem::transmute(lossless_mode) };
+            lossless_mode as u64
+        });
+        __bindgen_bitfield_unit.set(18usize, 2u8, {
+            let comp_prediction_mode: u32 = unsafe { ::std::mem::transmute(comp_prediction_mode) };
+            comp_prediction_mode as u64
+        });
+        __bindgen_bitfield_unit.set(20usize, 1u8, {
+            let auto_segmentation: u32 = unsafe { ::std::mem::transmute(auto_segmentation) };
+            auto_segmentation as u64
+        });
+        __bindgen_bitfield_unit.set(21usize, 1u8, {
+            let super_frame_flag: u32 = unsafe { ::std::mem::transmute(super_frame_flag) };
+            super_frame_flag as u64
+        });
+        __bindgen_bitfield_unit.set(22usize, 10u8, {
+            let reserved: u32 = unsafe { ::std::mem::transmute(reserved) };
+            reserved as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncPictureParameterBufferVP9__bindgen_ty_2 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncPictureParameterBufferVP9 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncPictureParameterBufferVP9 = _VAEncPictureParameterBufferVP9;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncSegParamVP9 {
+    pub seg_flags: _VAEncSegParamVP9__bindgen_ty_1,
+    pub segment_lf_level_delta: i8,
+    pub segment_qindex_delta: i16,
+    pub va_reserved: [u32; 4usize],
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncSegParamVP9__bindgen_ty_1 {
+    pub bits: _VAEncSegParamVP9__bindgen_ty_1__bindgen_ty_1,
+    pub value: u8,
+}
+#[repr(C, packed)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncSegParamVP9__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
+}
+impl _VAEncSegParamVP9__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn segment_reference_enabled(&self) -> u8 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u8) }
+    }
+    #[inline]
+    pub fn set_segment_reference_enabled(&mut self, val: u8) {
+        unsafe {
+            let val: u8 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segment_reference(&self) -> u8 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 2u8) as u8) }
+    }
+    #[inline]
+    pub fn set_segment_reference(&mut self, val: u8) {
+        unsafe {
+            let val: u8 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn segment_reference_skipped(&self) -> u8 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u8) }
+    }
+    #[inline]
+    pub fn set_segment_reference_skipped(&mut self, val: u8) {
+        unsafe {
+            let val: u8 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved(&self) -> u8 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 4u8) as u8) }
+    }
+    #[inline]
+    pub fn set_reserved(&mut self, val: u8) {
+        unsafe {
+            let val: u8 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        segment_reference_enabled: u8,
+        segment_reference: u8,
+        segment_reference_skipped: u8,
+        reserved: u8,
+    ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let segment_reference_enabled: u8 =
+                unsafe { ::std::mem::transmute(segment_reference_enabled) };
+            segment_reference_enabled as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 2u8, {
+            let segment_reference: u8 = unsafe { ::std::mem::transmute(segment_reference) };
+            segment_reference as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let segment_reference_skipped: u8 =
+                unsafe { ::std::mem::transmute(segment_reference_skipped) };
+            segment_reference_skipped as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 4u8, {
+            let reserved: u8 = unsafe { ::std::mem::transmute(reserved) };
+            reserved as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncSegParamVP9__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncSegParamVP9 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncSegParamVP9 = _VAEncSegParamVP9;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncMiscParameterTypeVP9PerSegmantParam {
+    pub seg_data: [VAEncSegParamVP9; 8usize],
+    pub va_reserved: [u32; 4usize],
+}
+impl Default for _VAEncMiscParameterTypeVP9PerSegmantParam {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAEncMiscParameterTypeVP9PerSegmantParam = _VAEncMiscParameterTypeVP9PerSegmantParam;
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncMiscParameterFEIFrameControlH264 {
+    pub function: u32,
+    pub mb_ctrl: VABufferID,
+    pub distortion: VABufferID,
+    pub mv_data: VABufferID,
+    pub mb_code_data: VABufferID,
+    pub qp: VABufferID,
+    pub mv_predictor: VABufferID,
+    pub _bitfield_align_1: [u16; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 16usize]>,
+    pub max_frame_size: u32,
+    pub num_passes: u32,
+    pub delta_qp: *mut u8,
+    pub reserved3: [u32; 4usize],
+}
+impl Default for _VAEncMiscParameterFEIFrameControlH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl _VAEncMiscParameterFEIFrameControlH264 {
+    #[inline]
+    pub fn num_mv_predictors_l0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_num_mv_predictors_l0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn num_mv_predictors_l1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_num_mv_predictors_l1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn search_path(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(32usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_search_path(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(32usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn len_sp(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(40usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_len_sp(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(40usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(48usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(48usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sub_mb_part_mask(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(64usize, 7u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sub_mb_part_mask(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(64usize, 7u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_part_mask(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(71usize, 5u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_part_mask(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(71usize, 5u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn multi_pred_l0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(76usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_multi_pred_l0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(76usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn multi_pred_l1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(77usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_multi_pred_l1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(77usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sub_pel_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(78usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sub_pel_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(78usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn inter_sad(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(80usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_inter_sad(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(80usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_sad(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(82usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_sad(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(82usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn distortion_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(84usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_distortion_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(84usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn repartition_check_enable(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(85usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_repartition_check_enable(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(85usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn adaptive_search(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(86usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_adaptive_search(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(86usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mv_predictor_enable(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(87usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mv_predictor_enable(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(87usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_qp(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(88usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_qp(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(88usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_input(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(89usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_input(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(89usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_size_ctrl(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(90usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_size_ctrl(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(90usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn colocated_mb_distortion(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(91usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_colocated_mb_distortion(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(91usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(92usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(92usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_width(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(96usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_width(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(96usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_height(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(104usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_height(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(104usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn search_window(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(112usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_search_window(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(112usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved2(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(116usize, 12u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved2(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(116usize, 12u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        num_mv_predictors_l0: u32,
+        num_mv_predictors_l1: u32,
+        search_path: u32,
+        len_sp: u32,
+        reserved0: u32,
+        sub_mb_part_mask: u32,
+        intra_part_mask: u32,
+        multi_pred_l0: u32,
+        multi_pred_l1: u32,
+        sub_pel_mode: u32,
+        inter_sad: u32,
+        intra_sad: u32,
+        distortion_type: u32,
+        repartition_check_enable: u32,
+        adaptive_search: u32,
+        mv_predictor_enable: u32,
+        mb_qp: u32,
+        mb_input: u32,
+        mb_size_ctrl: u32,
+        colocated_mb_distortion: u32,
+        reserved1: u32,
+        ref_width: u32,
+        ref_height: u32,
+        search_window: u32,
+        reserved2: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 16usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 16usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 16u8, {
+            let num_mv_predictors_l0: u32 = unsafe { ::std::mem::transmute(num_mv_predictors_l0) };
+            num_mv_predictors_l0 as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 16u8, {
+            let num_mv_predictors_l1: u32 = unsafe { ::std::mem::transmute(num_mv_predictors_l1) };
+            num_mv_predictors_l1 as u64
+        });
+        __bindgen_bitfield_unit.set(32usize, 8u8, {
+            let search_path: u32 = unsafe { ::std::mem::transmute(search_path) };
+            search_path as u64
+        });
+        __bindgen_bitfield_unit.set(40usize, 8u8, {
+            let len_sp: u32 = unsafe { ::std::mem::transmute(len_sp) };
+            len_sp as u64
+        });
+        __bindgen_bitfield_unit.set(48usize, 16u8, {
+            let reserved0: u32 = unsafe { ::std::mem::transmute(reserved0) };
+            reserved0 as u64
+        });
+        __bindgen_bitfield_unit.set(64usize, 7u8, {
+            let sub_mb_part_mask: u32 = unsafe { ::std::mem::transmute(sub_mb_part_mask) };
+            sub_mb_part_mask as u64
+        });
+        __bindgen_bitfield_unit.set(71usize, 5u8, {
+            let intra_part_mask: u32 = unsafe { ::std::mem::transmute(intra_part_mask) };
+            intra_part_mask as u64
+        });
+        __bindgen_bitfield_unit.set(76usize, 1u8, {
+            let multi_pred_l0: u32 = unsafe { ::std::mem::transmute(multi_pred_l0) };
+            multi_pred_l0 as u64
+        });
+        __bindgen_bitfield_unit.set(77usize, 1u8, {
+            let multi_pred_l1: u32 = unsafe { ::std::mem::transmute(multi_pred_l1) };
+            multi_pred_l1 as u64
+        });
+        __bindgen_bitfield_unit.set(78usize, 2u8, {
+            let sub_pel_mode: u32 = unsafe { ::std::mem::transmute(sub_pel_mode) };
+            sub_pel_mode as u64
+        });
+        __bindgen_bitfield_unit.set(80usize, 2u8, {
+            let inter_sad: u32 = unsafe { ::std::mem::transmute(inter_sad) };
+            inter_sad as u64
+        });
+        __bindgen_bitfield_unit.set(82usize, 2u8, {
+            let intra_sad: u32 = unsafe { ::std::mem::transmute(intra_sad) };
+            intra_sad as u64
+        });
+        __bindgen_bitfield_unit.set(84usize, 1u8, {
+            let distortion_type: u32 = unsafe { ::std::mem::transmute(distortion_type) };
+            distortion_type as u64
+        });
+        __bindgen_bitfield_unit.set(85usize, 1u8, {
+            let repartition_check_enable: u32 =
+                unsafe { ::std::mem::transmute(repartition_check_enable) };
+            repartition_check_enable as u64
+        });
+        __bindgen_bitfield_unit.set(86usize, 1u8, {
+            let adaptive_search: u32 = unsafe { ::std::mem::transmute(adaptive_search) };
+            adaptive_search as u64
+        });
+        __bindgen_bitfield_unit.set(87usize, 1u8, {
+            let mv_predictor_enable: u32 = unsafe { ::std::mem::transmute(mv_predictor_enable) };
+            mv_predictor_enable as u64
+        });
+        __bindgen_bitfield_unit.set(88usize, 1u8, {
+            let mb_qp: u32 = unsafe { ::std::mem::transmute(mb_qp) };
+            mb_qp as u64
+        });
+        __bindgen_bitfield_unit.set(89usize, 1u8, {
+            let mb_input: u32 = unsafe { ::std::mem::transmute(mb_input) };
+            mb_input as u64
+        });
+        __bindgen_bitfield_unit.set(90usize, 1u8, {
+            let mb_size_ctrl: u32 = unsafe { ::std::mem::transmute(mb_size_ctrl) };
+            mb_size_ctrl as u64
+        });
+        __bindgen_bitfield_unit.set(91usize, 1u8, {
+            let colocated_mb_distortion: u32 =
+                unsafe { ::std::mem::transmute(colocated_mb_distortion) };
+            colocated_mb_distortion as u64
+        });
+        __bindgen_bitfield_unit.set(92usize, 4u8, {
+            let reserved1: u32 = unsafe { ::std::mem::transmute(reserved1) };
+            reserved1 as u64
+        });
+        __bindgen_bitfield_unit.set(96usize, 8u8, {
+            let ref_width: u32 = unsafe { ::std::mem::transmute(ref_width) };
+            ref_width as u64
+        });
+        __bindgen_bitfield_unit.set(104usize, 8u8, {
+            let ref_height: u32 = unsafe { ::std::mem::transmute(ref_height) };
+            ref_height as u64
+        });
+        __bindgen_bitfield_unit.set(112usize, 4u8, {
+            let search_window: u32 = unsafe { ::std::mem::transmute(search_window) };
+            search_window as u64
+        });
+        __bindgen_bitfield_unit.set(116usize, 12u8, {
+            let reserved2: u32 = unsafe { ::std::mem::transmute(reserved2) };
+            reserved2 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+pub type VAEncMiscParameterFEIFrameControlH264 = _VAEncMiscParameterFEIFrameControlH264;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncFEIMBControlH264 {
+    pub _bitfield_align_1: [u32; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 4usize]>,
+    pub reserved1: u32,
+    pub reserved2: u32,
+    pub _bitfield_align_2: [u16; 0],
+    pub _bitfield_2: __BindgenBitfieldUnit<[u8; 4usize]>,
+}
+impl _VAEncFEIMBControlH264 {
+    #[inline]
+    pub fn force_to_intra(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_force_to_intra(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn force_to_skip(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_force_to_skip(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(1usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn force_to_nonskip(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_force_to_nonskip(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn enable_direct_bias_adjustment(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_enable_direct_bias_adjustment(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn enable_motion_bias_adjustment(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_enable_motion_bias_adjustment(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ext_mv_cost_scaling_factor(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ext_mv_cost_scaling_factor(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(5usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 24u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 24u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        force_to_intra: u32,
+        force_to_skip: u32,
+        force_to_nonskip: u32,
+        enable_direct_bias_adjustment: u32,
+        enable_motion_bias_adjustment: u32,
+        ext_mv_cost_scaling_factor: u32,
+        reserved0: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let force_to_intra: u32 = unsafe { ::std::mem::transmute(force_to_intra) };
+            force_to_intra as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 1u8, {
+            let force_to_skip: u32 = unsafe { ::std::mem::transmute(force_to_skip) };
+            force_to_skip as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let force_to_nonskip: u32 = unsafe { ::std::mem::transmute(force_to_nonskip) };
+            force_to_nonskip as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let enable_direct_bias_adjustment: u32 =
+                unsafe { ::std::mem::transmute(enable_direct_bias_adjustment) };
+            enable_direct_bias_adjustment as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 1u8, {
+            let enable_motion_bias_adjustment: u32 =
+                unsafe { ::std::mem::transmute(enable_motion_bias_adjustment) };
+            enable_motion_bias_adjustment as u64
+        });
+        __bindgen_bitfield_unit.set(5usize, 3u8, {
+            let ext_mv_cost_scaling_factor: u32 =
+                unsafe { ::std::mem::transmute(ext_mv_cost_scaling_factor) };
+            ext_mv_cost_scaling_factor as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 24u8, {
+            let reserved0: u32 = unsafe { ::std::mem::transmute(reserved0) };
+            reserved0 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+    #[inline]
+    pub fn reserved3(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_2.get(0usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved3(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_2.set(0usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn target_size_in_word(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_2.get(16usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_target_size_in_word(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_2.set(16usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn max_size_in_word(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_2.get(24usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_max_size_in_word(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_2.set(24usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_2(
+        reserved3: u32,
+        target_size_in_word: u32,
+        max_size_in_word: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 16u8, {
+            let reserved3: u32 = unsafe { ::std::mem::transmute(reserved3) };
+            reserved3 as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 8u8, {
+            let target_size_in_word: u32 = unsafe { ::std::mem::transmute(target_size_in_word) };
+            target_size_in_word as u64
+        });
+        __bindgen_bitfield_unit.set(24usize, 8u8, {
+            let max_size_in_word: u32 = unsafe { ::std::mem::transmute(max_size_in_word) };
+            max_size_in_word as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+pub type VAEncFEIMBControlH264 = _VAEncFEIMBControlH264;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncFEIMVPredictorH264 {
+    pub ref_idx: [_VAEncFEIMVPredictorH264__bindgen_ty_1; 4usize],
+    pub reserved: u32,
+    pub mv: [VAMotionVector; 4usize],
+}
+#[repr(C, packed)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncFEIMVPredictorH264__bindgen_ty_1 {
+    pub _bitfield_align_1: [u8; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
+}
+impl _VAEncFEIMVPredictorH264__bindgen_ty_1 {
+    #[inline]
+    pub fn ref_idx_l0(&self) -> u8 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 4u8) as u8) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l0(&mut self, val: u8) {
+        unsafe {
+            let val: u8 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l1(&self) -> u8 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 4u8) as u8) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l1(&mut self, val: u8) {
+        unsafe {
+            let val: u8 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(ref_idx_l0: u8, ref_idx_l1: u8) -> __BindgenBitfieldUnit<[u8; 1usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 4u8, {
+            let ref_idx_l0: u8 = unsafe { ::std::mem::transmute(ref_idx_l0) };
+            ref_idx_l0 as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 4u8, {
+            let ref_idx_l1: u8 = unsafe { ::std::mem::transmute(ref_idx_l1) };
+            ref_idx_l1 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+pub type VAEncFEIMVPredictorH264 = _VAEncFEIMVPredictorH264;
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub struct _VAEncFEIMBCodeH264 {
+    pub reserved0: [u32; 3usize],
+    pub _bitfield_align_1: [u32; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 16usize]>,
+    pub mb_mode: _VAEncFEIMBCodeH264__bindgen_ty_1,
+    pub _bitfield_align_2: [u16; 0],
+    pub _bitfield_2: __BindgenBitfieldUnit<[u8; 4usize]>,
+    pub reserved9: [u32; 4usize],
+    pub reserved10: u32,
+}
+#[repr(C)]
+#[derive(Copy, Clone)]
+pub union _VAEncFEIMBCodeH264__bindgen_ty_1 {
+    pub intra_mb: _VAEncFEIMBCodeH264__bindgen_ty_1__bindgen_ty_1,
+    pub inter_mb: _VAEncFEIMBCodeH264__bindgen_ty_1__bindgen_ty_2,
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncFEIMBCodeH264__bindgen_ty_1__bindgen_ty_1 {
+    pub _bitfield_align_1: [u32; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 12usize]>,
+}
+impl _VAEncFEIMBCodeH264__bindgen_ty_1__bindgen_ty_1 {
+    #[inline]
+    pub fn luma_intra_pred_modes0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_luma_intra_pred_modes0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn luma_intra_pred_modes1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_luma_intra_pred_modes1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn luma_intra_pred_modes2(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(32usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_luma_intra_pred_modes2(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(32usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn luma_intra_pred_modes3(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(48usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_luma_intra_pred_modes3(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(48usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn chroma_intra_pred_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(64usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_chroma_intra_pred_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(64usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_pred_avail_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(66usize, 5u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_pred_avail_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(66usize, 5u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_pred_avail_flagF(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(71usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_pred_avail_flagF(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(71usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved6(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(72usize, 24u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved6(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(72usize, 24u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        luma_intra_pred_modes0: u32,
+        luma_intra_pred_modes1: u32,
+        luma_intra_pred_modes2: u32,
+        luma_intra_pred_modes3: u32,
+        chroma_intra_pred_mode: u32,
+        intra_pred_avail_flag: u32,
+        intra_pred_avail_flagF: u32,
+        reserved6: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 12usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 12usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 16u8, {
+            let luma_intra_pred_modes0: u32 =
+                unsafe { ::std::mem::transmute(luma_intra_pred_modes0) };
+            luma_intra_pred_modes0 as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 16u8, {
+            let luma_intra_pred_modes1: u32 =
+                unsafe { ::std::mem::transmute(luma_intra_pred_modes1) };
+            luma_intra_pred_modes1 as u64
+        });
+        __bindgen_bitfield_unit.set(32usize, 16u8, {
+            let luma_intra_pred_modes2: u32 =
+                unsafe { ::std::mem::transmute(luma_intra_pred_modes2) };
+            luma_intra_pred_modes2 as u64
+        });
+        __bindgen_bitfield_unit.set(48usize, 16u8, {
+            let luma_intra_pred_modes3: u32 =
+                unsafe { ::std::mem::transmute(luma_intra_pred_modes3) };
+            luma_intra_pred_modes3 as u64
+        });
+        __bindgen_bitfield_unit.set(64usize, 2u8, {
+            let chroma_intra_pred_mode: u32 =
+                unsafe { ::std::mem::transmute(chroma_intra_pred_mode) };
+            chroma_intra_pred_mode as u64
+        });
+        __bindgen_bitfield_unit.set(66usize, 5u8, {
+            let intra_pred_avail_flag: u32 =
+                unsafe { ::std::mem::transmute(intra_pred_avail_flag) };
+            intra_pred_avail_flag as u64
+        });
+        __bindgen_bitfield_unit.set(71usize, 1u8, {
+            let intra_pred_avail_flagF: u32 =
+                unsafe { ::std::mem::transmute(intra_pred_avail_flagF) };
+            intra_pred_avail_flagF as u64
+        });
+        __bindgen_bitfield_unit.set(72usize, 24u8, {
+            let reserved6: u32 = unsafe { ::std::mem::transmute(reserved6) };
+            reserved6 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+#[repr(C)]
+#[repr(align(4))]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncFEIMBCodeH264__bindgen_ty_1__bindgen_ty_2 {
+    pub _bitfield_align_1: [u16; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 12usize]>,
+}
+impl _VAEncFEIMBCodeH264__bindgen_ty_1__bindgen_ty_2 {
+    #[inline]
+    pub fn sub_mb_shapes(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sub_mb_shapes(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sub_mb_pred_modes(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sub_mb_pred_modes(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved7(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved7(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l0_0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(32usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l0_0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(32usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l0_1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(40usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l0_1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(40usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l0_2(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(48usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l0_2(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(48usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l0_3(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(56usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l0_3(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(56usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l1_0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(64usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l1_0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(64usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l1_1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(72usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l1_1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(72usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l1_2(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(80usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l1_2(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(80usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_idx_l1_3(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(88usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_idx_l1_3(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(88usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        sub_mb_shapes: u32,
+        sub_mb_pred_modes: u32,
+        reserved7: u32,
+        ref_idx_l0_0: u32,
+        ref_idx_l0_1: u32,
+        ref_idx_l0_2: u32,
+        ref_idx_l0_3: u32,
+        ref_idx_l1_0: u32,
+        ref_idx_l1_1: u32,
+        ref_idx_l1_2: u32,
+        ref_idx_l1_3: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 12usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 12usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 8u8, {
+            let sub_mb_shapes: u32 = unsafe { ::std::mem::transmute(sub_mb_shapes) };
+            sub_mb_shapes as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 8u8, {
+            let sub_mb_pred_modes: u32 = unsafe { ::std::mem::transmute(sub_mb_pred_modes) };
+            sub_mb_pred_modes as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 16u8, {
+            let reserved7: u32 = unsafe { ::std::mem::transmute(reserved7) };
+            reserved7 as u64
+        });
+        __bindgen_bitfield_unit.set(32usize, 8u8, {
+            let ref_idx_l0_0: u32 = unsafe { ::std::mem::transmute(ref_idx_l0_0) };
+            ref_idx_l0_0 as u64
+        });
+        __bindgen_bitfield_unit.set(40usize, 8u8, {
+            let ref_idx_l0_1: u32 = unsafe { ::std::mem::transmute(ref_idx_l0_1) };
+            ref_idx_l0_1 as u64
+        });
+        __bindgen_bitfield_unit.set(48usize, 8u8, {
+            let ref_idx_l0_2: u32 = unsafe { ::std::mem::transmute(ref_idx_l0_2) };
+            ref_idx_l0_2 as u64
+        });
+        __bindgen_bitfield_unit.set(56usize, 8u8, {
+            let ref_idx_l0_3: u32 = unsafe { ::std::mem::transmute(ref_idx_l0_3) };
+            ref_idx_l0_3 as u64
+        });
+        __bindgen_bitfield_unit.set(64usize, 8u8, {
+            let ref_idx_l1_0: u32 = unsafe { ::std::mem::transmute(ref_idx_l1_0) };
+            ref_idx_l1_0 as u64
+        });
+        __bindgen_bitfield_unit.set(72usize, 8u8, {
+            let ref_idx_l1_1: u32 = unsafe { ::std::mem::transmute(ref_idx_l1_1) };
+            ref_idx_l1_1 as u64
+        });
+        __bindgen_bitfield_unit.set(80usize, 8u8, {
+            let ref_idx_l1_2: u32 = unsafe { ::std::mem::transmute(ref_idx_l1_2) };
+            ref_idx_l1_2 as u64
+        });
+        __bindgen_bitfield_unit.set(88usize, 8u8, {
+            let ref_idx_l1_3: u32 = unsafe { ::std::mem::transmute(ref_idx_l1_3) };
+            ref_idx_l1_3 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+impl Default for _VAEncFEIMBCodeH264__bindgen_ty_1 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl Default for _VAEncFEIMBCodeH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl _VAEncFEIMBCodeH264 {
+    #[inline]
+    pub fn inter_mb_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_inter_mb_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_skip_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_skip_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(2usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(3usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_mb_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_mb_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(4usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved2(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved2(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(6usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn field_mb_polarity_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_field_mb_polarity_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(7usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_type(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 5u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_type(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 5u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_mb_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(13usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_mb_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(13usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn field_mb_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(14usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_field_mb_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(14usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn transform8x8_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(15usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_transform8x8_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(15usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved3(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved3(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn dc_block_coded_cr_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(17usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_dc_block_coded_cr_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(17usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn dc_block_coded_cb_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(18usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_dc_block_coded_cb_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(18usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn dc_block_coded_y_flag(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(19usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_dc_block_coded_y_flag(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(19usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved4(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(20usize, 12u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved4(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(20usize, 12u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn horz_origin(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(32usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_horz_origin(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(32usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn vert_origin(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(40usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_vert_origin(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(40usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn cbp_y(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(48usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_cbp_y(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(48usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn cbp_cb(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(64usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_cbp_cb(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(64usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn cbp_cr(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(80usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_cbp_cr(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(80usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn qp_prime_y(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(96usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_qp_prime_y(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(96usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved5(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(104usize, 17u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved5(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(104usize, 17u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_skip_conv_disable(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(121usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_skip_conv_disable(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(121usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn is_last_mb(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(122usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_is_last_mb(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(122usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn enable_coefficient_clamp(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(123usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_enable_coefficient_clamp(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(123usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn direct8x8_pattern(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(124usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_direct8x8_pattern(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(124usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        inter_mb_mode: u32,
+        mb_skip_flag: u32,
+        reserved1: u32,
+        intra_mb_mode: u32,
+        reserved2: u32,
+        field_mb_polarity_flag: u32,
+        mb_type: u32,
+        intra_mb_flag: u32,
+        field_mb_flag: u32,
+        transform8x8_flag: u32,
+        reserved3: u32,
+        dc_block_coded_cr_flag: u32,
+        dc_block_coded_cb_flag: u32,
+        dc_block_coded_y_flag: u32,
+        reserved4: u32,
+        horz_origin: u32,
+        vert_origin: u32,
+        cbp_y: u32,
+        cbp_cb: u32,
+        cbp_cr: u32,
+        qp_prime_y: u32,
+        reserved5: u32,
+        mb_skip_conv_disable: u32,
+        is_last_mb: u32,
+        enable_coefficient_clamp: u32,
+        direct8x8_pattern: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 16usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 16usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 2u8, {
+            let inter_mb_mode: u32 = unsafe { ::std::mem::transmute(inter_mb_mode) };
+            inter_mb_mode as u64
+        });
+        __bindgen_bitfield_unit.set(2usize, 1u8, {
+            let mb_skip_flag: u32 = unsafe { ::std::mem::transmute(mb_skip_flag) };
+            mb_skip_flag as u64
+        });
+        __bindgen_bitfield_unit.set(3usize, 1u8, {
+            let reserved1: u32 = unsafe { ::std::mem::transmute(reserved1) };
+            reserved1 as u64
+        });
+        __bindgen_bitfield_unit.set(4usize, 2u8, {
+            let intra_mb_mode: u32 = unsafe { ::std::mem::transmute(intra_mb_mode) };
+            intra_mb_mode as u64
+        });
+        __bindgen_bitfield_unit.set(6usize, 1u8, {
+            let reserved2: u32 = unsafe { ::std::mem::transmute(reserved2) };
+            reserved2 as u64
+        });
+        __bindgen_bitfield_unit.set(7usize, 1u8, {
+            let field_mb_polarity_flag: u32 =
+                unsafe { ::std::mem::transmute(field_mb_polarity_flag) };
+            field_mb_polarity_flag as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 5u8, {
+            let mb_type: u32 = unsafe { ::std::mem::transmute(mb_type) };
+            mb_type as u64
+        });
+        __bindgen_bitfield_unit.set(13usize, 1u8, {
+            let intra_mb_flag: u32 = unsafe { ::std::mem::transmute(intra_mb_flag) };
+            intra_mb_flag as u64
+        });
+        __bindgen_bitfield_unit.set(14usize, 1u8, {
+            let field_mb_flag: u32 = unsafe { ::std::mem::transmute(field_mb_flag) };
+            field_mb_flag as u64
+        });
+        __bindgen_bitfield_unit.set(15usize, 1u8, {
+            let transform8x8_flag: u32 = unsafe { ::std::mem::transmute(transform8x8_flag) };
+            transform8x8_flag as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 1u8, {
+            let reserved3: u32 = unsafe { ::std::mem::transmute(reserved3) };
+            reserved3 as u64
+        });
+        __bindgen_bitfield_unit.set(17usize, 1u8, {
+            let dc_block_coded_cr_flag: u32 =
+                unsafe { ::std::mem::transmute(dc_block_coded_cr_flag) };
+            dc_block_coded_cr_flag as u64
+        });
+        __bindgen_bitfield_unit.set(18usize, 1u8, {
+            let dc_block_coded_cb_flag: u32 =
+                unsafe { ::std::mem::transmute(dc_block_coded_cb_flag) };
+            dc_block_coded_cb_flag as u64
+        });
+        __bindgen_bitfield_unit.set(19usize, 1u8, {
+            let dc_block_coded_y_flag: u32 =
+                unsafe { ::std::mem::transmute(dc_block_coded_y_flag) };
+            dc_block_coded_y_flag as u64
+        });
+        __bindgen_bitfield_unit.set(20usize, 12u8, {
+            let reserved4: u32 = unsafe { ::std::mem::transmute(reserved4) };
+            reserved4 as u64
+        });
+        __bindgen_bitfield_unit.set(32usize, 8u8, {
+            let horz_origin: u32 = unsafe { ::std::mem::transmute(horz_origin) };
+            horz_origin as u64
+        });
+        __bindgen_bitfield_unit.set(40usize, 8u8, {
+            let vert_origin: u32 = unsafe { ::std::mem::transmute(vert_origin) };
+            vert_origin as u64
+        });
+        __bindgen_bitfield_unit.set(48usize, 16u8, {
+            let cbp_y: u32 = unsafe { ::std::mem::transmute(cbp_y) };
+            cbp_y as u64
+        });
+        __bindgen_bitfield_unit.set(64usize, 16u8, {
+            let cbp_cb: u32 = unsafe { ::std::mem::transmute(cbp_cb) };
+            cbp_cb as u64
+        });
+        __bindgen_bitfield_unit.set(80usize, 16u8, {
+            let cbp_cr: u32 = unsafe { ::std::mem::transmute(cbp_cr) };
+            cbp_cr as u64
+        });
+        __bindgen_bitfield_unit.set(96usize, 8u8, {
+            let qp_prime_y: u32 = unsafe { ::std::mem::transmute(qp_prime_y) };
+            qp_prime_y as u64
+        });
+        __bindgen_bitfield_unit.set(104usize, 17u8, {
+            let reserved5: u32 = unsafe { ::std::mem::transmute(reserved5) };
+            reserved5 as u64
+        });
+        __bindgen_bitfield_unit.set(121usize, 1u8, {
+            let mb_skip_conv_disable: u32 = unsafe { ::std::mem::transmute(mb_skip_conv_disable) };
+            mb_skip_conv_disable as u64
+        });
+        __bindgen_bitfield_unit.set(122usize, 1u8, {
+            let is_last_mb: u32 = unsafe { ::std::mem::transmute(is_last_mb) };
+            is_last_mb as u64
+        });
+        __bindgen_bitfield_unit.set(123usize, 1u8, {
+            let enable_coefficient_clamp: u32 =
+                unsafe { ::std::mem::transmute(enable_coefficient_clamp) };
+            enable_coefficient_clamp as u64
+        });
+        __bindgen_bitfield_unit.set(124usize, 4u8, {
+            let direct8x8_pattern: u32 = unsafe { ::std::mem::transmute(direct8x8_pattern) };
+            direct8x8_pattern as u64
+        });
+        __bindgen_bitfield_unit
+    }
+    #[inline]
+    pub fn reserved8(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_2.get(0usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved8(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_2.set(0usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn target_size_in_word(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_2.get(16usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_target_size_in_word(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_2.set(16usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn max_size_in_word(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_2.get(24usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_max_size_in_word(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_2.set(24usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_2(
+        reserved8: u32,
+        target_size_in_word: u32,
+        max_size_in_word: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 16u8, {
+            let reserved8: u32 = unsafe { ::std::mem::transmute(reserved8) };
+            reserved8 as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 8u8, {
+            let target_size_in_word: u32 = unsafe { ::std::mem::transmute(target_size_in_word) };
+            target_size_in_word as u64
+        });
+        __bindgen_bitfield_unit.set(24usize, 8u8, {
+            let max_size_in_word: u32 = unsafe { ::std::mem::transmute(max_size_in_word) };
+            max_size_in_word as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+pub type VAEncFEIMBCodeH264 = _VAEncFEIMBCodeH264;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAEncFEIDistortionH264 {
+    pub inter_distortion: [u16; 16usize],
+    pub _bitfield_align_1: [u16; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 8usize]>,
+    pub reserved1: [u32; 2usize],
+}
+impl _VAEncFEIDistortionH264 {
+    #[inline]
+    pub fn best_inter_distortion(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_best_inter_distortion(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn best_intra_distortion(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_best_intra_distortion(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn colocated_mb_distortion(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(32usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_colocated_mb_distortion(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(32usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(48usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(48usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        best_inter_distortion: u32,
+        best_intra_distortion: u32,
+        colocated_mb_distortion: u32,
+        reserved0: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 8usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 8usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 16u8, {
+            let best_inter_distortion: u32 =
+                unsafe { ::std::mem::transmute(best_inter_distortion) };
+            best_inter_distortion as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 16u8, {
+            let best_intra_distortion: u32 =
+                unsafe { ::std::mem::transmute(best_intra_distortion) };
+            best_intra_distortion as u64
+        });
+        __bindgen_bitfield_unit.set(32usize, 16u8, {
+            let colocated_mb_distortion: u32 =
+                unsafe { ::std::mem::transmute(colocated_mb_distortion) };
+            colocated_mb_distortion as u64
+        });
+        __bindgen_bitfield_unit.set(48usize, 16u8, {
+            let reserved0: u32 = unsafe { ::std::mem::transmute(reserved0) };
+            reserved0 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+pub type VAEncFEIDistortionH264 = _VAEncFEIDistortionH264;
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VAStatsStatisticsParameterH264 {
+    pub stats_params: VAStatsStatisticsParameter,
+    pub _bitfield_align_1: [u32; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 16usize]>,
+    pub reserved4: [u32; 2usize],
+}
+impl Default for _VAStatsStatisticsParameterH264 {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+impl _VAStatsStatisticsParameterH264 {
+    #[inline]
+    pub fn frame_qp(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_frame_qp(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn len_sp(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_len_sp(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(8usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn search_path(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_search_path(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(24usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(24usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sub_mb_part_mask(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(32usize, 7u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sub_mb_part_mask(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(32usize, 7u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn sub_pel_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(39usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_sub_pel_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(39usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn inter_sad(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(41usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_inter_sad(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(41usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_sad(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(43usize, 2u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_sad(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(43usize, 2u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn adaptive_search(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(45usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_adaptive_search(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(45usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mv_predictor_ctrl(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(46usize, 3u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mv_predictor_ctrl(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(46usize, 3u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn mb_qp(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(49usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_qp(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(49usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ft_enable(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(50usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ft_enable(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(50usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_part_mask(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(51usize, 5u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_part_mask(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(51usize, 5u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(56usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(56usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_width(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(64usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_width(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(64usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn ref_height(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(72usize, 8u8) as u32) }
+    }
+    #[inline]
+    pub fn set_ref_height(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(72usize, 8u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn search_window(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(80usize, 4u8) as u32) }
+    }
+    #[inline]
+    pub fn set_search_window(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(80usize, 4u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved2(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(84usize, 12u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved2(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(84usize, 12u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn disable_mv_output(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(96usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_mv_output(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(96usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn disable_statistics_output(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(97usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_disable_statistics_output(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(97usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn enable_8x8_statistics(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(98usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_enable_8x8_statistics(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(98usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved3(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(99usize, 29u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved3(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(99usize, 29u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        frame_qp: u32,
+        len_sp: u32,
+        search_path: u32,
+        reserved0: u32,
+        sub_mb_part_mask: u32,
+        sub_pel_mode: u32,
+        inter_sad: u32,
+        intra_sad: u32,
+        adaptive_search: u32,
+        mv_predictor_ctrl: u32,
+        mb_qp: u32,
+        ft_enable: u32,
+        intra_part_mask: u32,
+        reserved1: u32,
+        ref_width: u32,
+        ref_height: u32,
+        search_window: u32,
+        reserved2: u32,
+        disable_mv_output: u32,
+        disable_statistics_output: u32,
+        enable_8x8_statistics: u32,
+        reserved3: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 16usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 16usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 8u8, {
+            let frame_qp: u32 = unsafe { ::std::mem::transmute(frame_qp) };
+            frame_qp as u64
+        });
+        __bindgen_bitfield_unit.set(8usize, 8u8, {
+            let len_sp: u32 = unsafe { ::std::mem::transmute(len_sp) };
+            len_sp as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 8u8, {
+            let search_path: u32 = unsafe { ::std::mem::transmute(search_path) };
+            search_path as u64
+        });
+        __bindgen_bitfield_unit.set(24usize, 8u8, {
+            let reserved0: u32 = unsafe { ::std::mem::transmute(reserved0) };
+            reserved0 as u64
+        });
+        __bindgen_bitfield_unit.set(32usize, 7u8, {
+            let sub_mb_part_mask: u32 = unsafe { ::std::mem::transmute(sub_mb_part_mask) };
+            sub_mb_part_mask as u64
+        });
+        __bindgen_bitfield_unit.set(39usize, 2u8, {
+            let sub_pel_mode: u32 = unsafe { ::std::mem::transmute(sub_pel_mode) };
+            sub_pel_mode as u64
+        });
+        __bindgen_bitfield_unit.set(41usize, 2u8, {
+            let inter_sad: u32 = unsafe { ::std::mem::transmute(inter_sad) };
+            inter_sad as u64
+        });
+        __bindgen_bitfield_unit.set(43usize, 2u8, {
+            let intra_sad: u32 = unsafe { ::std::mem::transmute(intra_sad) };
+            intra_sad as u64
+        });
+        __bindgen_bitfield_unit.set(45usize, 1u8, {
+            let adaptive_search: u32 = unsafe { ::std::mem::transmute(adaptive_search) };
+            adaptive_search as u64
+        });
+        __bindgen_bitfield_unit.set(46usize, 3u8, {
+            let mv_predictor_ctrl: u32 = unsafe { ::std::mem::transmute(mv_predictor_ctrl) };
+            mv_predictor_ctrl as u64
+        });
+        __bindgen_bitfield_unit.set(49usize, 1u8, {
+            let mb_qp: u32 = unsafe { ::std::mem::transmute(mb_qp) };
+            mb_qp as u64
+        });
+        __bindgen_bitfield_unit.set(50usize, 1u8, {
+            let ft_enable: u32 = unsafe { ::std::mem::transmute(ft_enable) };
+            ft_enable as u64
+        });
+        __bindgen_bitfield_unit.set(51usize, 5u8, {
+            let intra_part_mask: u32 = unsafe { ::std::mem::transmute(intra_part_mask) };
+            intra_part_mask as u64
+        });
+        __bindgen_bitfield_unit.set(56usize, 8u8, {
+            let reserved1: u32 = unsafe { ::std::mem::transmute(reserved1) };
+            reserved1 as u64
+        });
+        __bindgen_bitfield_unit.set(64usize, 8u8, {
+            let ref_width: u32 = unsafe { ::std::mem::transmute(ref_width) };
+            ref_width as u64
+        });
+        __bindgen_bitfield_unit.set(72usize, 8u8, {
+            let ref_height: u32 = unsafe { ::std::mem::transmute(ref_height) };
+            ref_height as u64
+        });
+        __bindgen_bitfield_unit.set(80usize, 4u8, {
+            let search_window: u32 = unsafe { ::std::mem::transmute(search_window) };
+            search_window as u64
+        });
+        __bindgen_bitfield_unit.set(84usize, 12u8, {
+            let reserved2: u32 = unsafe { ::std::mem::transmute(reserved2) };
+            reserved2 as u64
+        });
+        __bindgen_bitfield_unit.set(96usize, 1u8, {
+            let disable_mv_output: u32 = unsafe { ::std::mem::transmute(disable_mv_output) };
+            disable_mv_output as u64
+        });
+        __bindgen_bitfield_unit.set(97usize, 1u8, {
+            let disable_statistics_output: u32 =
+                unsafe { ::std::mem::transmute(disable_statistics_output) };
+            disable_statistics_output as u64
+        });
+        __bindgen_bitfield_unit.set(98usize, 1u8, {
+            let enable_8x8_statistics: u32 =
+                unsafe { ::std::mem::transmute(enable_8x8_statistics) };
+            enable_8x8_statistics as u64
+        });
+        __bindgen_bitfield_unit.set(99usize, 29u8, {
+            let reserved3: u32 = unsafe { ::std::mem::transmute(reserved3) };
+            reserved3 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+pub type VAStatsStatisticsParameterH264 = _VAStatsStatisticsParameterH264;
+#[repr(C)]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq)]
+pub struct _VAStatsStatisticsH264 {
+    pub _bitfield_align_1: [u16; 0],
+    pub _bitfield_1: __BindgenBitfieldUnit<[u8; 16usize]>,
+    pub sum_coef: u32,
+    pub _bitfield_align_2: [u32; 0],
+    pub _bitfield_2: __BindgenBitfieldUnit<[u8; 4usize]>,
+    pub variance_16x16: u32,
+    pub variance_8x8: [u32; 4usize],
+    pub pixel_average_16x16: u32,
+    pub pixel_average_8x8: [u32; 4usize],
+}
+impl _VAStatsStatisticsH264 {
+    #[inline]
+    pub fn best_inter_distortion0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_best_inter_distortion0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(0usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn inter_mode0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(16usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_inter_mode0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(16usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn best_inter_distortion1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(32usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_best_inter_distortion1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(32usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn inter_mode1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(48usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_inter_mode1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(48usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn best_intra_distortion(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(64usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_best_intra_distortion(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(64usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn intra_mode(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(80usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_intra_mode(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(80usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn num_non_zero_coef(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(96usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_num_non_zero_coef(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(96usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved0(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_1.get(112usize, 16u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved0(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_1.set(112usize, 16u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_1(
+        best_inter_distortion0: u32,
+        inter_mode0: u32,
+        best_inter_distortion1: u32,
+        inter_mode1: u32,
+        best_intra_distortion: u32,
+        intra_mode: u32,
+        num_non_zero_coef: u32,
+        reserved0: u32,
+    ) -> __BindgenBitfieldUnit<[u8; 16usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 16usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 16u8, {
+            let best_inter_distortion0: u32 =
+                unsafe { ::std::mem::transmute(best_inter_distortion0) };
+            best_inter_distortion0 as u64
+        });
+        __bindgen_bitfield_unit.set(16usize, 16u8, {
+            let inter_mode0: u32 = unsafe { ::std::mem::transmute(inter_mode0) };
+            inter_mode0 as u64
+        });
+        __bindgen_bitfield_unit.set(32usize, 16u8, {
+            let best_inter_distortion1: u32 =
+                unsafe { ::std::mem::transmute(best_inter_distortion1) };
+            best_inter_distortion1 as u64
+        });
+        __bindgen_bitfield_unit.set(48usize, 16u8, {
+            let inter_mode1: u32 = unsafe { ::std::mem::transmute(inter_mode1) };
+            inter_mode1 as u64
+        });
+        __bindgen_bitfield_unit.set(64usize, 16u8, {
+            let best_intra_distortion: u32 =
+                unsafe { ::std::mem::transmute(best_intra_distortion) };
+            best_intra_distortion as u64
+        });
+        __bindgen_bitfield_unit.set(80usize, 16u8, {
+            let intra_mode: u32 = unsafe { ::std::mem::transmute(intra_mode) };
+            intra_mode as u64
+        });
+        __bindgen_bitfield_unit.set(96usize, 16u8, {
+            let num_non_zero_coef: u32 = unsafe { ::std::mem::transmute(num_non_zero_coef) };
+            num_non_zero_coef as u64
+        });
+        __bindgen_bitfield_unit.set(112usize, 16u8, {
+            let reserved0: u32 = unsafe { ::std::mem::transmute(reserved0) };
+            reserved0 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+    #[inline]
+    pub fn mb_is_flat(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_2.get(0usize, 1u8) as u32) }
+    }
+    #[inline]
+    pub fn set_mb_is_flat(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_2.set(0usize, 1u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn reserved1(&self) -> u32 {
+        unsafe { ::std::mem::transmute(self._bitfield_2.get(1usize, 31u8) as u32) }
+    }
+    #[inline]
+    pub fn set_reserved1(&mut self, val: u32) {
+        unsafe {
+            let val: u32 = ::std::mem::transmute(val);
+            self._bitfield_2.set(1usize, 31u8, val as u64)
+        }
+    }
+    #[inline]
+    pub fn new_bitfield_2(mb_is_flat: u32, reserved1: u32) -> __BindgenBitfieldUnit<[u8; 4usize]> {
+        let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 4usize]> = Default::default();
+        __bindgen_bitfield_unit.set(0usize, 1u8, {
+            let mb_is_flat: u32 = unsafe { ::std::mem::transmute(mb_is_flat) };
+            mb_is_flat as u64
+        });
+        __bindgen_bitfield_unit.set(1usize, 31u8, {
+            let reserved1: u32 = unsafe { ::std::mem::transmute(reserved1) };
+            reserved1 as u64
+        });
+        __bindgen_bitfield_unit
+    }
+}
+pub type VAStatsStatisticsH264 = _VAStatsStatisticsH264;
+pub const _VAProcFilterType_VAProcFilterNone: _VAProcFilterType = 0;
+pub const _VAProcFilterType_VAProcFilterNoiseReduction: _VAProcFilterType = 1;
+pub const _VAProcFilterType_VAProcFilterDeinterlacing: _VAProcFilterType = 2;
+pub const _VAProcFilterType_VAProcFilterSharpening: _VAProcFilterType = 3;
+pub const _VAProcFilterType_VAProcFilterColorBalance: _VAProcFilterType = 4;
+pub const _VAProcFilterType_VAProcFilterSkinToneEnhancement: _VAProcFilterType = 5;
+pub const _VAProcFilterType_VAProcFilterTotalColorCorrection: _VAProcFilterType = 6;
+pub const _VAProcFilterType_VAProcFilterHVSNoiseReduction: _VAProcFilterType = 7;
+pub const _VAProcFilterType_VAProcFilterHighDynamicRangeToneMapping: _VAProcFilterType = 8;
+pub const _VAProcFilterType_VAProcFilter3DLUT: _VAProcFilterType = 9;
+pub const _VAProcFilterType_VAProcFilterCount: _VAProcFilterType = 10;
+pub type _VAProcFilterType = ::std::os::raw::c_uint;
+pub use self::_VAProcFilterType as VAProcFilterType;
+pub const _VAProcColorStandardType_VAProcColorStandardNone: _VAProcColorStandardType = 0;
+pub const _VAProcColorStandardType_VAProcColorStandardBT601: _VAProcColorStandardType = 1;
+pub const _VAProcColorStandardType_VAProcColorStandardBT709: _VAProcColorStandardType = 2;
+pub const _VAProcColorStandardType_VAProcColorStandardBT470M: _VAProcColorStandardType = 3;
+pub const _VAProcColorStandardType_VAProcColorStandardBT470BG: _VAProcColorStandardType = 4;
+pub const _VAProcColorStandardType_VAProcColorStandardSMPTE170M: _VAProcColorStandardType = 5;
+pub const _VAProcColorStandardType_VAProcColorStandardSMPTE240M: _VAProcColorStandardType = 6;
+pub const _VAProcColorStandardType_VAProcColorStandardGenericFilm: _VAProcColorStandardType = 7;
+pub const _VAProcColorStandardType_VAProcColorStandardSRGB: _VAProcColorStandardType = 8;
+pub const _VAProcColorStandardType_VAProcColorStandardSTRGB: _VAProcColorStandardType = 9;
+pub const _VAProcColorStandardType_VAProcColorStandardXVYCC601: _VAProcColorStandardType = 10;
+pub const _VAProcColorStandardType_VAProcColorStandardXVYCC709: _VAProcColorStandardType = 11;
+pub const _VAProcColorStandardType_VAProcColorStandardBT2020: _VAProcColorStandardType = 12;
+pub const _VAProcColorStandardType_VAProcColorStandardExplicit: _VAProcColorStandardType = 13;
+pub const _VAProcColorStandardType_VAProcColorStandardCount: _VAProcColorStandardType = 14;
+pub type _VAProcColorStandardType = ::std::os::raw::c_uint;
+pub use self::_VAProcColorStandardType as VAProcColorStandardType;
+#[repr(C)]
+#[derive(Debug, Copy, Clone, PartialEq, Eq)]
+pub struct _VAProcPipelineCaps {
+    pub pipeline_flags: u32,
+    pub filter_flags: u32,
+    pub num_forward_references: u32,
+    pub num_backward_references: u32,
+    pub input_color_standards: *mut VAProcColorStandardType,
+    pub num_input_color_standards: u32,
+    pub output_color_standards: *mut VAProcColorStandardType,
+    pub num_output_color_standards: u32,
+    pub rotation_flags: u32,
+    pub blend_flags: u32,
+    pub mirror_flags: u32,
+    pub num_additional_outputs: u32,
+    pub num_input_pixel_formats: u32,
+    pub input_pixel_format: *mut u32,
+    pub num_output_pixel_formats: u32,
+    pub output_pixel_format: *mut u32,
+    pub max_input_width: u32,
+    pub max_input_height: u32,
+    pub min_input_width: u32,
+    pub min_input_height: u32,
+    pub max_output_width: u32,
+    pub max_output_height: u32,
+    pub min_output_width: u32,
+    pub min_output_height: u32,
+    pub va_reserved: [u32; 14usize],
+}
+impl Default for _VAProcPipelineCaps {
+    fn default() -> Self {
+        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
+        unsafe {
+            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
+            s.assume_init()
+        }
+    }
+}
+pub type VAProcPipelineCaps = _VAProcPipelineCaps;
+extern "C" {
+    pub fn vaQueryVideoProcFilters(
+        dpy: VADisplay,
+        context: VAContextID,
+        filters: *mut VAProcFilterType,
+        num_filters: *mut ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaQueryVideoProcFilterCaps(
+        dpy: VADisplay,
+        context: VAContextID,
+        type_: VAProcFilterType,
+        filter_caps: *mut ::std::os::raw::c_void,
+        num_filter_caps: *mut ::std::os::raw::c_uint,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaQueryVideoProcPipelineCaps(
+        dpy: VADisplay,
+        context: VAContextID,
+        filters: *mut VABufferID,
+        num_filters: ::std::os::raw::c_uint,
+        pipeline_caps: *mut VAProcPipelineCaps,
+    ) -> VAStatus;
+}
+pub type VAProtectedSessionID = VAGenericID;
+extern "C" {
+    pub fn vaCreateProtectedSession(
+        dpy: VADisplay,
+        config_id: VAConfigID,
+        protected_session: *mut VAProtectedSessionID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDestroyProtectedSession(
+        dpy: VADisplay,
+        protected_session: VAProtectedSessionID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaAttachProtectedSession(
+        dpy: VADisplay,
+        id: VAGenericID,
+        protected_session: VAProtectedSessionID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaDetachProtectedSession(dpy: VADisplay, id: VAGenericID) -> VAStatus;
+}
+extern "C" {
+    pub fn vaProtectedSessionExecute(
+        dpy: VADisplay,
+        protected_session: VAProtectedSessionID,
+        buf_id: VABufferID,
+    ) -> VAStatus;
+}
+extern "C" {
+    pub fn vaGetDisplayDRM(fd: ::std::os::raw::c_int) -> VADisplay;
+}