Merge master.kernel.org:/pub/scm/linux/kernel/git/mchehab/v4l-dvb
* master.kernel.org:/pub/scm/linux/kernel/git/mchehab/v4l-dvb: V4L/DVB (5305): Mark VIDIOC_DBG_S/G_REGISTER as experimental V4L/DVB (5271): Add VIDIOC_TRY_ENCODER_CMD and VIDIOC_ENCODER_CMD ioctls. V4L/DVB (5270): Add VIDIOC_G_ENC_INDEX ioctl V4L/DVB (5276): Cxusb: fix firmware patch for big endian systems V4L/DVB (5258): Cafe_ccic: fix compiler warning V4L/DVB (5295): Digitv: open nxt6000 i2c_gate for TDED4 tuner handling V4L/DVB (5304): Improve chip matching in v4l2_register V4L/DVB (5255): Fix cx25840 firmware loading.
This commit is contained in:
@@ -1192,6 +1192,55 @@ struct v4l2_audioout
|
||||
__u32 reserved[2];
|
||||
};
|
||||
|
||||
/*
|
||||
* M P E G S E R V I C E S
|
||||
*
|
||||
* NOTE: EXPERIMENTAL API
|
||||
*/
|
||||
#if 1
|
||||
#define V4L2_ENC_IDX_FRAME_I (0)
|
||||
#define V4L2_ENC_IDX_FRAME_P (1)
|
||||
#define V4L2_ENC_IDX_FRAME_B (2)
|
||||
#define V4L2_ENC_IDX_FRAME_MASK (0xf)
|
||||
|
||||
struct v4l2_enc_idx_entry {
|
||||
__u64 offset;
|
||||
__u64 pts;
|
||||
__u32 length;
|
||||
__u32 flags;
|
||||
__u32 reserved[2];
|
||||
};
|
||||
|
||||
#define V4L2_ENC_IDX_ENTRIES (64)
|
||||
struct v4l2_enc_idx {
|
||||
__u32 entries;
|
||||
__u32 entries_cap;
|
||||
__u32 reserved[4];
|
||||
struct v4l2_enc_idx_entry entry[V4L2_ENC_IDX_ENTRIES];
|
||||
};
|
||||
|
||||
|
||||
#define V4L2_ENC_CMD_START (0)
|
||||
#define V4L2_ENC_CMD_STOP (1)
|
||||
#define V4L2_ENC_CMD_PAUSE (2)
|
||||
#define V4L2_ENC_CMD_RESUME (3)
|
||||
|
||||
/* Flags for V4L2_ENC_CMD_STOP */
|
||||
#define V4L2_ENC_CMD_STOP_AT_GOP_END (1 << 0)
|
||||
|
||||
struct v4l2_encoder_cmd {
|
||||
__u32 cmd;
|
||||
__u32 flags;
|
||||
union {
|
||||
struct {
|
||||
__u32 data[8];
|
||||
} raw;
|
||||
};
|
||||
};
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
/*
|
||||
* D A T A S E R V I C E S ( V B I )
|
||||
*
|
||||
@@ -1303,13 +1352,21 @@ struct v4l2_streamparm
|
||||
|
||||
/*
|
||||
* A D V A N C E D D E B U G G I N G
|
||||
*
|
||||
* NOTE: EXPERIMENTAL API
|
||||
*/
|
||||
|
||||
/* VIDIOC_DBG_G_REGISTER and VIDIOC_DBG_S_REGISTER */
|
||||
|
||||
#define V4L2_CHIP_MATCH_HOST 0 /* Match against chip ID on host (0 for the host) */
|
||||
#define V4L2_CHIP_MATCH_I2C_DRIVER 1 /* Match against I2C driver ID */
|
||||
#define V4L2_CHIP_MATCH_I2C_ADDR 2 /* Match against I2C 7-bit address */
|
||||
|
||||
struct v4l2_register {
|
||||
__u32 match_type; /* Match type */
|
||||
__u32 match_chip; /* Match this chip, meaning determined by match_type */
|
||||
__u64 reg;
|
||||
__u32 i2c_id; /* I2C driver ID of the I2C chip, or 0 for the host */
|
||||
__u32 val;
|
||||
__u64 val;
|
||||
};
|
||||
|
||||
/*
|
||||
@@ -1378,10 +1435,14 @@ struct v4l2_register {
|
||||
#if 1
|
||||
#define VIDIOC_ENUM_FRAMESIZES _IOWR ('V', 74, struct v4l2_frmsizeenum)
|
||||
#define VIDIOC_ENUM_FRAMEINTERVALS _IOWR ('V', 75, struct v4l2_frmivalenum)
|
||||
#define VIDIOC_G_ENC_INDEX _IOR ('V', 76, struct v4l2_enc_idx)
|
||||
#define VIDIOC_ENCODER_CMD _IOWR ('V', 77, struct v4l2_encoder_cmd)
|
||||
#define VIDIOC_TRY_ENCODER_CMD _IOWR ('V', 78, struct v4l2_encoder_cmd)
|
||||
|
||||
/* Experimental, only implemented if CONFIG_VIDEO_ADV_DEBUG is defined */
|
||||
#define VIDIOC_DBG_S_REGISTER _IOW ('V', 79, struct v4l2_register)
|
||||
#define VIDIOC_DBG_G_REGISTER _IOWR ('V', 80, struct v4l2_register)
|
||||
#endif
|
||||
/* only implemented if CONFIG_VIDEO_ADV_DEBUG is defined */
|
||||
#define VIDIOC_DBG_S_REGISTER _IOW ('d', 100, struct v4l2_register)
|
||||
#define VIDIOC_DBG_G_REGISTER _IOWR('d', 101, struct v4l2_register)
|
||||
|
||||
#ifdef __OLD_VIDIOC_
|
||||
/* for compatibility, will go away some day */
|
||||
|
||||
Reference in New Issue
Block a user