Re: [PATCH v4 1/2] v4l2-ctl: add is_compressed_format() helper

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu April 11 2013 21:46:54 Tzu-Jung Lee wrote:
> To bypass precalculate_bars() for OUTPUT device
> that takes encoded bitstreams.

I haven't forgotten your patches, but I want to clean up the streaming code
some more first. I hope to have finished with that this weekend.

Regards,

	Hans

> 
> Signed-off-by: Tzu-Jung Lee <tjlee@xxxxxxxxxxxxx>
> ---
>  utils/v4l2-ctl/v4l2-ctl-streaming.cpp | 40 ++++++++++++++++++++++++++++++++++-
>  1 file changed, 39 insertions(+), 1 deletion(-)
> 
> diff --git a/utils/v4l2-ctl/v4l2-ctl-streaming.cpp b/utils/v4l2-ctl/v4l2-ctl-streaming.cpp
> index 9e361af..035c3c7 100644
> --- a/utils/v4l2-ctl/v4l2-ctl-streaming.cpp
> +++ b/utils/v4l2-ctl/v4l2-ctl-streaming.cpp
> @@ -115,6 +115,23 @@ static const flag_def tc_flags_def[] = {
>  	{ 0, NULL }
>  };
>  
> +static bool is_compressed_format(int fd, struct v4l2_format *f)
> +{
> +	struct v4l2_fmtdesc fmt;
> +
> +	memset(&fmt, 0, sizeof(fmt));
> +	fmt.type = f->type;
> +
> +	while (test_ioctl(fd, VIDIOC_ENUM_FMT, &fmt) >= 0) {
> +		if (fmt.pixelformat == f->fmt.pix.pixelformat)
> +			return fmt.flags & V4L2_FMT_FLAG_COMPRESSED;
> +
> +		fmt.index++;
> +	}
> +
> +	return false;
> +}
> +
>  static void print_buffer(FILE *f, struct v4l2_buffer &buf)
>  {
>  	fprintf(f, "\tIndex    : %d\n", buf.index);
> @@ -312,12 +329,16 @@ static void do_setup_out_buffers(int fd, struct v4l2_requestbuffers *reqbufs,
>  				 bool is_mplane, unsigned &num_planes, bool is_mmap,
>  				 void *buffers[], unsigned buffer_lengths[], FILE *fin)
>  {
> +	bool is_compressed;
> +
>  	struct v4l2_format fmt;
>  	memset(&fmt, 0, sizeof(fmt));
>  	fmt.type = reqbufs->type;
>  	doioctl(fd, VIDIOC_G_FMT, &fmt);
>  
> -	if (!precalculate_bars(fmt.fmt.pix.pixelformat, stream_pat)) {
> +	is_compressed = is_compressed_format(fd, &fmt);
> +	if (!is_compressed &&
> +	    !precalculate_bars(fmt.fmt.pix.pixelformat, stream_pat)) {
>  		fprintf(stderr, "unsupported pixelformat\n");
>  		return;
>  	}
> @@ -688,7 +709,9 @@ static void streaming_set_cap(int fd)
>  static void streaming_set_out(int fd)
>  {
>  	struct v4l2_requestbuffers reqbufs;
> +	struct v4l2_format fmt;
>  	int fd_flags = fcntl(fd, F_GETFL);
> +	bool is_compressed;
>  	bool is_mplane = capabilities &
>  			(V4L2_CAP_VIDEO_OUTPUT_MPLANE |
>  				 V4L2_CAP_VIDEO_M2M_MPLANE);
> @@ -710,6 +733,12 @@ static void streaming_set_out(int fd)
>  	reqbufs.type = type;
>  	reqbufs.memory = is_mmap ? V4L2_MEMORY_MMAP : V4L2_MEMORY_USERPTR;
>  
> +	memset(&fmt, 0, sizeof(fmt));
> +	fmt.type = reqbufs.type;
> +	doioctl(fd, VIDIOC_G_FMT, &fmt);
> +
> +	is_compressed = is_compressed_format(fd, &fmt);
> +
>  	if (file_out) {
>  		if (!strcmp(file_out, "-"))
>  			fin = stdin;
> @@ -795,6 +824,9 @@ enum stream_type {
>  
>  static void streaming_set_m2m(int fd)
>  {
> +	struct v4l2_format fmt;
> +	bool is_compressed;
> +
>  	int fd_flags = fcntl(fd, F_GETFL);
>  	bool use_poll = options[OptStreamPoll];
>  
> @@ -864,6 +896,12 @@ static void streaming_set_m2m(int fd)
>  			     is_mmap, buffers_out, buffer_lengths_out,
>  			     file[OUT]);
>  
> +	memset(&fmt, 0, sizeof(fmt));
> +	fmt.type = reqbufs[OUT].type;
> +	doioctl(fd, VIDIOC_G_FMT, &fmt);
> +
> +	is_compressed = is_compressed_format(fd, &fmt);
> +
>  	if (doioctl(fd, VIDIOC_STREAMON, &type[CAP]) ||
>  	    doioctl(fd, VIDIOC_STREAMON, &type[OUT]))
>  		return;
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux