/* * uvc_h264.h - Definitions of the UVC H.264 Payload specification Version 1.0 * * Copyright (c) 2011 USB Implementers Forum, Inc. * * Modification into glib-like header by : * Copyright (C) 2012 Cisco Systems, Inc. * Author: Youness Alaoui * * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ #ifndef _UVC_H264_H_ #define _UVC_H264_H_ /* Header File for the little-endian platform */ #include #include /* bmHints defines */ #define UVC_H264_BMHINTS_RESOLUTION (0x0001) #define UVC_H264_BMHINTS_PROFILE (0x0002) #define UVC_H264_BMHINTS_RATECONTROL (0x0004) #define UVC_H264_BMHINTS_USAGE (0x0008) #define UVC_H264_BMHINTS_SLICEMODE (0x0010) #define UVC_H264_BMHINTS_SLICEUNITS (0x0020) #define UVC_H264_BMHINTS_MVCVIEW (0x0040) #define UVC_H264_BMHINTS_TEMPORAL (0x0080) #define UVC_H264_BMHINTS_SNR (0x0100) #define UVC_H264_BMHINTS_SPATIAL (0x0200) #define UVC_H264_BMHINTS_SPATIAL_RATIO (0x0400) #define UVC_H264_BMHINTS_FRAME_INTERVAL (0x0800) #define UVC_H264_BMHINTS_LEAKY_BKT_SIZE (0x1000) #define UVC_H264_BMHINTS_BITRATE (0x2000) #define UVC_H264_BMHINTS_ENTROPY (0x4000) #define UVC_H264_BMHINTS_IFRAMEPERIOD (0x8000) #define UVC_H264_QP_STEPS_I_FRAME_TYPE (0x01) #define UVC_H264_QP_STEPS_P_FRAME_TYPE (0x02) #define UVC_H264_QP_STEPS_B_FRAME_TYPE (0x04) #define UVC_H264_QP_STEPS_ALL_FRAME_TYPES (UVC_H264_QP_STEPS_I_FRAME_TYPE | \ UVC_H264_QP_STEPS_P_FRAME_TYPE | UVC_H264_QP_STEPS_B_FRAME_TYPE) /* wSliceMode defines */ typedef enum { UVC_H264_SLICEMODE_IGNORED = 0x0000, UVC_H264_SLICEMODE_BITSPERSLICE = 0x0001, UVC_H264_SLICEMODE_MBSPERSLICE = 0x0002, UVC_H264_SLICEMODE_SLICEPERFRAME = 0x0003 } UvcH264SliceMode; #define UVC_H264_SLICEMODE_TYPE (uvc_h264_slicemode_get_type()) GType uvc_h264_slicemode_get_type (void); /* bUsageType defines */ typedef enum { UVC_H264_USAGETYPE_REALTIME = 0x01, UVC_H264_USAGETYPE_BROADCAST = 0x02, UVC_H264_USAGETYPE_STORAGE = 0x03, UVC_H264_USAGETYPE_UCCONFIG_0 = 0x04, UVC_H264_USAGETYPE_UCCONFIG_1 = 0x05, UVC_H264_USAGETYPE_UCCONFIG_2Q = 0x06, UVC_H264_USAGETYPE_UCCONFIG_2S = 0x07, UVC_H264_USAGETYPE_UCCONFIG_3 = 0x08, } UvcH264UsageType; #define UVC_H264_USAGETYPE_TYPE (uvc_h264_usagetype_get_type()) GType uvc_h264_usagetype_get_type (void); /* bRateControlMode defines */ typedef enum { UVC_H264_RATECONTROL_CBR = 0x01, UVC_H264_RATECONTROL_VBR = 0x02, UVC_H264_RATECONTROL_CONST_QP = 0x03, } UvcH264RateControl; #define UVC_H264_RATECONTROL_FIXED_FRM_FLG (0x10) #define UVC_H264_RATECONTROL_TYPE (uvc_h264_ratecontrol_get_type()) GType uvc_h264_ratecontrol_get_type (void); /* bStreamFormat defines */ typedef enum { UVC_H264_STREAMFORMAT_ANNEXB = 0x00, UVC_H264_STREAMFORMAT_NAL = 0x01, } UvcH264StreamFormat; #define UVC_H264_STREAMFORMAT_TYPE (uvc_h264_streamformat_get_type()) GType uvc_h264_streamformat_get_type (void); /* bEntropyCABAC defines */ typedef enum { UVC_H264_ENTROPY_CAVLC = 0x00, UVC_H264_ENTROPY_CABAC = 0x01, } UvcH264Entropy; #define UVC_H264_ENTROPY_TYPE (uvc_h264_entropy_get_type()) GType uvc_h264_entropy_get_type (void); /* bProfile defines */ #define UVC_H264_PROFILE_CONSTRAINED_BASELINE 0x4240 #define UVC_H264_PROFILE_BASELINE 0x4200 #define UVC_H264_PROFILE_MAIN 0x4D00 #define UVC_H264_PROFILE_HIGH 0x6400 /* bTimingstamp defines */ #define UVC_H264_TIMESTAMP_SEI_DISABLE (0x00) #define UVC_H264_TIMESTAMP_SEI_ENABLE (0x01) /* bPreviewFlipped defines */ #define UVC_H264_PREFLIPPED_DISABLE (0x00) #define UVC_H264_PREFLIPPED_HORIZONTAL (0x01) /* wPicType defines */ #define UVC_H264_PICTYPE_I_FRAME (0x00) #define UVC_H264_PICTYPE_IDR (0x01) #define UVC_H264_PICTYPE_IDR_WITH_PPS_SPS (0x02) /* wLayerID Macro */ /* wLayerID |------------+------------+------------+----------------+------------| | Reserved | StreamID | QualityID | DependencyID | TemporalID | | (3 bits) | (3 bits) | (3 bits) | (4 bits) | (3 bits) | |------------+------------+------------+----------------+------------| |15 13|12 10|9 7|6 3|2 0| |------------+------------+------------+----------------+------------| */ #define xLayerID(stream_id, quality_id, dependency_id, temporal_id) \ ((((stream_id) & 7) << 10) | \ (((quality_id) & 7) << 7) | \ (((dependency_id) & 15) << 3) | \ ((temporal_id) & 7)) /* id extraction from wLayerID */ #define xStream_id(layer_id) (((layer_id) >> 10) & 7) #define xQuality_id(layer_id) (((layer_id) >> 7) & 7) #define xDependency_id(layer_id) (((layer_id) >> 3) & 15) #define xTemporal_id(layer_id) ((layer_id)&7) /* UVC H.264 control selectors */ typedef enum _uvcx_control_selector_t { UVCX_VIDEO_CONFIG_PROBE = 0x01, UVCX_VIDEO_CONFIG_COMMIT = 0x02, UVCX_RATE_CONTROL_MODE = 0x03, UVCX_TEMPORAL_SCALE_MODE = 0x04, UVCX_SPATIAL_SCALE_MODE = 0x05, UVCX_SNR_SCALE_MODE = 0x06, UVCX_LTR_BUFFER_SIZE_CONTROL = 0x07, UVCX_LTR_PICTURE_CONTROL = 0x08, UVCX_PICTURE_TYPE_CONTROL = 0x09, UVCX_VERSION = 0x0A, UVCX_ENCODER_RESET = 0x0B, UVCX_FRAMERATE_CONFIG = 0x0C, UVCX_VIDEO_ADVANCE_CONFIG = 0x0D, UVCX_BITRATE_LAYERS = 0x0E, UVCX_QP_STEPS_LAYERS = 0x0F, } uvcx_control_selector_t; typedef struct _uvcx_video_config_probe_commit_t { guint32 dwFrameInterval; guint32 dwBitRate; guint16 bmHints; guint16 wConfigurationIndex; guint16 wWidth; guint16 wHeight; guint16 wSliceUnits; guint16 wSliceMode; guint16 wProfile; guint16 wIFramePeriod; guint16 wEstimatedVideoDelay; guint16 wEstimatedMaxConfigDelay; guint8 bUsageType; guint8 bRateControlMode; guint8 bTemporalScaleMode; guint8 bSpatialScaleMode; guint8 bSNRScaleMode; guint8 bStreamMuxOption; guint8 bStreamFormat; guint8 bEntropyCABAC; guint8 bTimestamp; guint8 bNumOfReorderFrames; guint8 bPreviewFlipped; guint8 bView; guint8 bReserved1; guint8 bReserved2; guint8 bStreamID; guint8 bSpatialLayerRatio; guint16 wLeakyBucketSize; } __attribute__((packed)) uvcx_video_config_probe_commit_t; typedef struct _uvcx_rate_control_mode_t { guint16 wLayerID; guint8 bRateControlMode; } __attribute__((packed)) uvcx_rate_control_mode_t; typedef struct _uvcx_temporal_scale_mode_t { guint16 wLayerID; guint8 bTemporalScaleMode; } __attribute__((packed)) uvcx_temporal_scale_mode_t; typedef struct _uvcx_spatial_scale_mode_t { guint16 wLayerID; guint8 bSpatialScaleMode; } __attribute__((packed)) uvcx_spatial_scale_mode_t; typedef struct _uvcx_snr_scale_mode_t { guint16 wLayerID; guint8 bSNRScaleMode; guint8 bMGSSublayerMode; } __attribute__((packed)) uvcx_snr_scale_mode_t; typedef struct _uvcx_ltr_buffer_size_control_t { guint16 wLayerID; guint8 bLTRBufferSize; guint8 bLTREncoderControl; } __attribute__((packed)) uvcx_ltr_buffer_size_control_t; typedef struct _uvcx_ltr_picture_control { guint16 wLayerID; guint8 bPutAtPositionInLTRBuffer; guint8 bEncodeUsingLTR; } __attribute__((packed)) uvcx_ltr_picture_control; typedef struct _uvcx_picture_type_control_t { guint16 wLayerID; guint16 wPicType; } __attribute__((packed)) uvcx_picture_type_control_t; typedef struct _uvcx_version_t { guint16 wVersion; } __attribute__((packed)) uvcx_version_t; typedef struct _uvcx_encoder_reset { guint16 wLayerID; } __attribute__((packed)) uvcx_encoder_reset; typedef struct _uvcx_framerate_config_t { guint16 wLayerID; guint32 dwFrameInterval; } __attribute__((packed)) uvcx_framerate_config_t; typedef struct _uvcx_video_advance_config_t { guint16 wLayerID; guint32 dwMb_max; guint8 blevel_idc; guint8 bReserved; } __attribute__((packed)) uvcx_video_advance_config_t; typedef struct _uvcx_bitrate_layers_t { guint16 wLayerID; guint32 dwPeakBitrate; guint32 dwAverageBitrate; } __attribute__((packed)) uvcx_bitrate_layers_t; typedef struct _uvcx_qp_steps_layers_t { guint16 wLayerID; guint8 bFrameType; guint8 bMinQp; guint8 bMaxQp; } __attribute__((packed)) uvcx_qp_steps_layers_t; #ifdef _WIN32 // GUID of the UVC H.264 extension unit: {A29E7641-DE04-47E3-8B2B-F4341AFF003B} DEFINE_GUID(GUID_UVCX_H264_XU, 0xA29E7641, 0xDE04, 0x47E3, 0x8B, 0x2B, 0xF4, 0x34, 0x1A, 0xFF, 0x00, 0x3B); #else #define GUID_UVCX_H264_XU \ {0x41, 0x76, 0x9e, 0xa2, 0x04, 0xde, 0xe3, 0x47, 0x8b, 0x2b, 0xF4, 0x34, 0x1A, 0xFF, 0x00, 0x3B} #endif #endif /*_UVC_H264_H_*/