2 * linux/drivers/media/platform/s5p-mfc/s5p_mfc_dec.c
4 * Copyright (C) 2011 Samsung Electronics Co., Ltd.
5 * http://www.samsung.com/
6 * Kamil Debski, <k.debski@samsung.com>
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
14 #include <linux/clk.h>
15 #include <linux/interrupt.h>
17 #include <linux/module.h>
18 #include <linux/platform_device.h>
19 #include <linux/sched.h>
20 #include <linux/slab.h>
21 #include <linux/videodev2.h>
22 #include <linux/workqueue.h>
23 #include <media/v4l2-ctrls.h>
24 #include <media/v4l2-event.h>
25 #include <media/videobuf2-v4l2.h>
26 #include "s5p_mfc_common.h"
27 #include "s5p_mfc_ctrl.h"
28 #include "s5p_mfc_debug.h"
29 #include "s5p_mfc_dec.h"
30 #include "s5p_mfc_intr.h"
31 #include "s5p_mfc_opr.h"
32 #include "s5p_mfc_pm.h"
34 static struct s5p_mfc_fmt formats
[] = {
36 .name
= "4:2:0 2 Planes 16x16 Tiles",
37 .fourcc
= V4L2_PIX_FMT_NV12MT_16X16
,
38 .codec_mode
= S5P_MFC_CODEC_NONE
,
41 .versions
= MFC_V6_BIT
| MFC_V7_BIT
,
44 .name
= "4:2:0 2 Planes 64x32 Tiles",
45 .fourcc
= V4L2_PIX_FMT_NV12MT
,
46 .codec_mode
= S5P_MFC_CODEC_NONE
,
49 .versions
= MFC_V5_BIT
,
52 .name
= "4:2:0 2 Planes Y/CbCr",
53 .fourcc
= V4L2_PIX_FMT_NV12M
,
54 .codec_mode
= S5P_MFC_CODEC_NONE
,
57 .versions
= MFC_V6_BIT
| MFC_V7_BIT
| MFC_V8_BIT
,
60 .name
= "4:2:0 2 Planes Y/CrCb",
61 .fourcc
= V4L2_PIX_FMT_NV21M
,
62 .codec_mode
= S5P_MFC_CODEC_NONE
,
65 .versions
= MFC_V6_BIT
| MFC_V7_BIT
| MFC_V8_BIT
,
68 .name
= "H264 Encoded Stream",
69 .fourcc
= V4L2_PIX_FMT_H264
,
70 .codec_mode
= S5P_MFC_CODEC_H264_DEC
,
73 .versions
= MFC_V5_BIT
| MFC_V6_BIT
| MFC_V7_BIT
|
77 .name
= "H264/MVC Encoded Stream",
78 .fourcc
= V4L2_PIX_FMT_H264_MVC
,
79 .codec_mode
= S5P_MFC_CODEC_H264_MVC_DEC
,
82 .versions
= MFC_V6_BIT
| MFC_V7_BIT
| MFC_V8_BIT
,
85 .name
= "H263 Encoded Stream",
86 .fourcc
= V4L2_PIX_FMT_H263
,
87 .codec_mode
= S5P_MFC_CODEC_H263_DEC
,
90 .versions
= MFC_V5_BIT
| MFC_V6_BIT
| MFC_V7_BIT
|
94 .name
= "MPEG1 Encoded Stream",
95 .fourcc
= V4L2_PIX_FMT_MPEG1
,
96 .codec_mode
= S5P_MFC_CODEC_MPEG2_DEC
,
99 .versions
= MFC_V5_BIT
| MFC_V6_BIT
| MFC_V7_BIT
|
103 .name
= "MPEG2 Encoded Stream",
104 .fourcc
= V4L2_PIX_FMT_MPEG2
,
105 .codec_mode
= S5P_MFC_CODEC_MPEG2_DEC
,
108 .versions
= MFC_V5_BIT
| MFC_V6_BIT
| MFC_V7_BIT
|
112 .name
= "MPEG4 Encoded Stream",
113 .fourcc
= V4L2_PIX_FMT_MPEG4
,
114 .codec_mode
= S5P_MFC_CODEC_MPEG4_DEC
,
117 .versions
= MFC_V5_BIT
| MFC_V6_BIT
| MFC_V7_BIT
|
121 .name
= "XviD Encoded Stream",
122 .fourcc
= V4L2_PIX_FMT_XVID
,
123 .codec_mode
= S5P_MFC_CODEC_MPEG4_DEC
,
126 .versions
= MFC_V5_BIT
| MFC_V6_BIT
| MFC_V7_BIT
|
130 .name
= "VC1 Encoded Stream",
131 .fourcc
= V4L2_PIX_FMT_VC1_ANNEX_G
,
132 .codec_mode
= S5P_MFC_CODEC_VC1_DEC
,
135 .versions
= MFC_V5_BIT
| MFC_V6_BIT
| MFC_V7_BIT
|
139 .name
= "VC1 RCV Encoded Stream",
140 .fourcc
= V4L2_PIX_FMT_VC1_ANNEX_L
,
141 .codec_mode
= S5P_MFC_CODEC_VC1RCV_DEC
,
144 .versions
= MFC_V5_BIT
| MFC_V6_BIT
| MFC_V7_BIT
|
148 .name
= "VP8 Encoded Stream",
149 .fourcc
= V4L2_PIX_FMT_VP8
,
150 .codec_mode
= S5P_MFC_CODEC_VP8_DEC
,
153 .versions
= MFC_V6_BIT
| MFC_V7_BIT
| MFC_V8_BIT
,
157 #define NUM_FORMATS ARRAY_SIZE(formats)
159 /* Find selected format description */
160 static struct s5p_mfc_fmt
*find_format(struct v4l2_format
*f
, unsigned int t
)
164 for (i
= 0; i
< NUM_FORMATS
; i
++) {
165 if (formats
[i
].fourcc
== f
->fmt
.pix_mp
.pixelformat
&&
166 formats
[i
].type
== t
)
172 static struct mfc_control controls
[] = {
174 .id
= V4L2_CID_MPEG_MFC51_VIDEO_DECODER_H264_DISPLAY_DELAY
,
175 .type
= V4L2_CTRL_TYPE_INTEGER
,
176 .name
= "H264 Display Delay",
183 .id
= V4L2_CID_MPEG_MFC51_VIDEO_DECODER_H264_DISPLAY_DELAY_ENABLE
,
184 .type
= V4L2_CTRL_TYPE_BOOLEAN
,
185 .name
= "H264 Display Delay Enable",
192 .id
= V4L2_CID_MPEG_VIDEO_DECODER_MPEG4_DEBLOCK_FILTER
,
193 .type
= V4L2_CTRL_TYPE_BOOLEAN
,
194 .name
= "Mpeg4 Loop Filter Enable",
201 .id
= V4L2_CID_MPEG_VIDEO_DECODER_SLICE_INTERFACE
,
202 .type
= V4L2_CTRL_TYPE_BOOLEAN
,
203 .name
= "Slice Interface Enable",
210 .id
= V4L2_CID_MIN_BUFFERS_FOR_CAPTURE
,
211 .type
= V4L2_CTRL_TYPE_INTEGER
,
212 .name
= "Minimum number of cap bufs",
221 #define NUM_CTRLS ARRAY_SIZE(controls)
223 /* Check whether a context should be run on hardware */
224 static int s5p_mfc_ctx_ready(struct s5p_mfc_ctx
*ctx
)
226 /* Context is to parse header */
227 if (ctx
->src_queue_cnt
>= 1 && ctx
->state
== MFCINST_GOT_INST
)
229 /* Context is to decode a frame */
230 if (ctx
->src_queue_cnt
>= 1 &&
231 ctx
->state
== MFCINST_RUNNING
&&
232 ctx
->dst_queue_cnt
>= ctx
->pb_count
)
234 /* Context is to return last frame */
235 if (ctx
->state
== MFCINST_FINISHING
&&
236 ctx
->dst_queue_cnt
>= ctx
->pb_count
)
238 /* Context is to set buffers */
239 if (ctx
->src_queue_cnt
>= 1 &&
240 ctx
->state
== MFCINST_HEAD_PARSED
&&
241 ctx
->capture_state
== QUEUE_BUFS_MMAPED
)
243 /* Resolution change */
244 if ((ctx
->state
== MFCINST_RES_CHANGE_INIT
||
245 ctx
->state
== MFCINST_RES_CHANGE_FLUSH
) &&
246 ctx
->dst_queue_cnt
>= ctx
->pb_count
)
248 if (ctx
->state
== MFCINST_RES_CHANGE_END
&&
249 ctx
->src_queue_cnt
>= 1)
251 mfc_debug(2, "ctx is not ready\n");
255 static const struct s5p_mfc_codec_ops decoder_codec_ops
= {
256 .pre_seq_start
= NULL
,
257 .post_seq_start
= NULL
,
258 .pre_frame_start
= NULL
,
259 .post_frame_start
= NULL
,
262 /* Query capabilities of the device */
263 static int vidioc_querycap(struct file
*file
, void *priv
,
264 struct v4l2_capability
*cap
)
266 struct s5p_mfc_dev
*dev
= video_drvdata(file
);
268 strncpy(cap
->driver
, S5P_MFC_NAME
, sizeof(cap
->driver
) - 1);
269 strncpy(cap
->card
, dev
->vfd_dec
->name
, sizeof(cap
->card
) - 1);
270 snprintf(cap
->bus_info
, sizeof(cap
->bus_info
), "platform:%s",
271 dev_name(&dev
->plat_dev
->dev
));
273 * This is only a mem-to-mem video device. The capture and output
274 * device capability flags are left only for backward compatibility
275 * and are scheduled for removal.
277 cap
->device_caps
= V4L2_CAP_VIDEO_M2M_MPLANE
| V4L2_CAP_STREAMING
;
278 cap
->capabilities
= cap
->device_caps
| V4L2_CAP_DEVICE_CAPS
;
282 /* Enumerate format */
283 static int vidioc_enum_fmt(struct file
*file
, struct v4l2_fmtdesc
*f
,
286 struct s5p_mfc_dev
*dev
= video_drvdata(file
);
287 struct s5p_mfc_fmt
*fmt
;
290 for (i
= 0; i
< ARRAY_SIZE(formats
); ++i
) {
291 if (out
&& formats
[i
].type
!= MFC_FMT_DEC
)
293 else if (!out
&& formats
[i
].type
!= MFC_FMT_RAW
)
295 else if ((dev
->variant
->version_bit
& formats
[i
].versions
) == 0)
302 if (i
== ARRAY_SIZE(formats
))
305 strlcpy(f
->description
, fmt
->name
, sizeof(f
->description
));
306 f
->pixelformat
= fmt
->fourcc
;
310 static int vidioc_enum_fmt_vid_cap_mplane(struct file
*file
, void *pirv
,
311 struct v4l2_fmtdesc
*f
)
313 return vidioc_enum_fmt(file
, f
, false);
316 static int vidioc_enum_fmt_vid_out_mplane(struct file
*file
, void *priv
,
317 struct v4l2_fmtdesc
*f
)
319 return vidioc_enum_fmt(file
, f
, true);
323 static int vidioc_g_fmt(struct file
*file
, void *priv
, struct v4l2_format
*f
)
325 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
326 struct v4l2_pix_format_mplane
*pix_mp
;
329 pix_mp
= &f
->fmt
.pix_mp
;
330 if (f
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
&&
331 (ctx
->state
== MFCINST_GOT_INST
|| ctx
->state
==
332 MFCINST_RES_CHANGE_END
)) {
333 /* If the MFC is parsing the header,
334 * so wait until it is finished */
335 s5p_mfc_wait_for_done_ctx(ctx
, S5P_MFC_R2H_CMD_SEQ_DONE_RET
,
338 if (f
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
&&
339 ctx
->state
>= MFCINST_HEAD_PARSED
&&
340 ctx
->state
< MFCINST_ABORT
) {
341 /* This is run on CAPTURE (decode output) */
342 /* Width and height are set to the dimensions
343 of the movie, the buffer is bigger and
344 further processing stages should crop to this
346 pix_mp
->width
= ctx
->buf_width
;
347 pix_mp
->height
= ctx
->buf_height
;
348 pix_mp
->field
= V4L2_FIELD_NONE
;
349 pix_mp
->num_planes
= 2;
350 /* Set pixelformat to the format in which MFC
351 outputs the decoded frame */
352 pix_mp
->pixelformat
= ctx
->dst_fmt
->fourcc
;
353 pix_mp
->plane_fmt
[0].bytesperline
= ctx
->buf_width
;
354 pix_mp
->plane_fmt
[0].sizeimage
= ctx
->luma_size
;
355 pix_mp
->plane_fmt
[1].bytesperline
= ctx
->buf_width
;
356 pix_mp
->plane_fmt
[1].sizeimage
= ctx
->chroma_size
;
357 } else if (f
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
358 /* This is run on OUTPUT
359 The buffer contains compressed image
360 so width and height have no meaning */
363 pix_mp
->field
= V4L2_FIELD_NONE
;
364 pix_mp
->plane_fmt
[0].bytesperline
= ctx
->dec_src_buf_size
;
365 pix_mp
->plane_fmt
[0].sizeimage
= ctx
->dec_src_buf_size
;
366 pix_mp
->pixelformat
= ctx
->src_fmt
->fourcc
;
367 pix_mp
->num_planes
= ctx
->src_fmt
->num_planes
;
369 mfc_err("Format could not be read\n");
370 mfc_debug(2, "%s-- with error\n", __func__
);
378 static int vidioc_try_fmt(struct file
*file
, void *priv
, struct v4l2_format
*f
)
380 struct s5p_mfc_dev
*dev
= video_drvdata(file
);
381 struct s5p_mfc_fmt
*fmt
;
383 mfc_debug(2, "Type is %d\n", f
->type
);
384 if (f
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
385 fmt
= find_format(f
, MFC_FMT_DEC
);
387 mfc_err("Unsupported format for source.\n");
390 if (fmt
->codec_mode
== S5P_FIMV_CODEC_NONE
) {
391 mfc_err("Unknown codec\n");
394 if ((dev
->variant
->version_bit
& fmt
->versions
) == 0) {
395 mfc_err("Unsupported format by this MFC version.\n");
398 } else if (f
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
399 fmt
= find_format(f
, MFC_FMT_RAW
);
401 mfc_err("Unsupported format for destination.\n");
404 if ((dev
->variant
->version_bit
& fmt
->versions
) == 0) {
405 mfc_err("Unsupported format by this MFC version.\n");
414 static int vidioc_s_fmt(struct file
*file
, void *priv
, struct v4l2_format
*f
)
416 struct s5p_mfc_dev
*dev
= video_drvdata(file
);
417 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
419 struct v4l2_pix_format_mplane
*pix_mp
;
420 struct s5p_mfc_buf_size
*buf_size
= dev
->variant
->buf_size
;
423 ret
= vidioc_try_fmt(file
, priv
, f
);
424 pix_mp
= &f
->fmt
.pix_mp
;
427 if (vb2_is_streaming(&ctx
->vq_src
) || vb2_is_streaming(&ctx
->vq_dst
)) {
428 v4l2_err(&dev
->v4l2_dev
, "%s queue busy\n", __func__
);
432 if (f
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
433 /* dst_fmt is validated by call to vidioc_try_fmt */
434 ctx
->dst_fmt
= find_format(f
, MFC_FMT_RAW
);
437 } else if (f
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
438 /* src_fmt is validated by call to vidioc_try_fmt */
439 ctx
->src_fmt
= find_format(f
, MFC_FMT_DEC
);
440 ctx
->codec_mode
= ctx
->src_fmt
->codec_mode
;
441 mfc_debug(2, "The codec number is: %d\n", ctx
->codec_mode
);
444 if (pix_mp
->plane_fmt
[0].sizeimage
== 0)
445 pix_mp
->plane_fmt
[0].sizeimage
= ctx
->dec_src_buf_size
=
447 else if (pix_mp
->plane_fmt
[0].sizeimage
> buf_size
->cpb
)
448 ctx
->dec_src_buf_size
= buf_size
->cpb
;
450 ctx
->dec_src_buf_size
= pix_mp
->plane_fmt
[0].sizeimage
;
451 pix_mp
->plane_fmt
[0].bytesperline
= 0;
452 ctx
->state
= MFCINST_INIT
;
456 mfc_err("Wrong type error for S_FMT : %d", f
->type
);
466 static int reqbufs_output(struct s5p_mfc_dev
*dev
, struct s5p_mfc_ctx
*ctx
,
467 struct v4l2_requestbuffers
*reqbufs
)
473 if (reqbufs
->count
== 0) {
474 mfc_debug(2, "Freeing buffers\n");
475 ret
= vb2_reqbufs(&ctx
->vq_src
, reqbufs
);
478 ctx
->src_bufs_cnt
= 0;
479 ctx
->output_state
= QUEUE_FREE
;
480 } else if (ctx
->output_state
== QUEUE_FREE
) {
481 /* Can only request buffers when we have a valid format set. */
482 WARN_ON(ctx
->src_bufs_cnt
!= 0);
483 if (ctx
->state
!= MFCINST_INIT
) {
484 mfc_err("Reqbufs called in an invalid state\n");
489 mfc_debug(2, "Allocating %d buffers for OUTPUT queue\n",
491 ret
= vb2_reqbufs(&ctx
->vq_src
, reqbufs
);
495 ret
= s5p_mfc_open_mfc_inst(dev
, ctx
);
498 vb2_reqbufs(&ctx
->vq_src
, reqbufs
);
502 ctx
->output_state
= QUEUE_BUFS_REQUESTED
;
504 mfc_err("Buffers have already been requested\n");
510 mfc_err("Failed allocating buffers for OUTPUT queue\n");
514 static int reqbufs_capture(struct s5p_mfc_dev
*dev
, struct s5p_mfc_ctx
*ctx
,
515 struct v4l2_requestbuffers
*reqbufs
)
521 if (reqbufs
->count
== 0) {
522 mfc_debug(2, "Freeing buffers\n");
523 ret
= vb2_reqbufs(&ctx
->vq_dst
, reqbufs
);
526 s5p_mfc_hw_call(dev
->mfc_ops
, release_codec_buffers
, ctx
);
527 ctx
->dst_bufs_cnt
= 0;
528 } else if (ctx
->capture_state
== QUEUE_FREE
) {
529 WARN_ON(ctx
->dst_bufs_cnt
!= 0);
530 mfc_debug(2, "Allocating %d buffers for CAPTURE queue\n",
532 ret
= vb2_reqbufs(&ctx
->vq_dst
, reqbufs
);
536 ctx
->capture_state
= QUEUE_BUFS_REQUESTED
;
537 ctx
->total_dpb_count
= reqbufs
->count
;
539 ret
= s5p_mfc_hw_call(dev
->mfc_ops
, alloc_codec_buffers
, ctx
);
541 mfc_err("Failed to allocate decoding buffers\n");
543 vb2_reqbufs(&ctx
->vq_dst
, reqbufs
);
545 ctx
->capture_state
= QUEUE_FREE
;
549 WARN_ON(ctx
->dst_bufs_cnt
!= ctx
->total_dpb_count
);
550 ctx
->capture_state
= QUEUE_BUFS_MMAPED
;
552 if (s5p_mfc_ctx_ready(ctx
))
553 set_work_bit_irqsave(ctx
);
554 s5p_mfc_hw_call(dev
->mfc_ops
, try_run
, dev
);
555 s5p_mfc_wait_for_done_ctx(ctx
, S5P_MFC_R2H_CMD_INIT_BUFFERS_RET
,
558 mfc_err("Buffers have already been requested\n");
564 mfc_err("Failed allocating buffers for CAPTURE queue\n");
568 /* Request buffers */
569 static int vidioc_reqbufs(struct file
*file
, void *priv
,
570 struct v4l2_requestbuffers
*reqbufs
)
572 struct s5p_mfc_dev
*dev
= video_drvdata(file
);
573 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
575 if (reqbufs
->memory
!= V4L2_MEMORY_MMAP
) {
576 mfc_debug(2, "Only V4L2_MEMORY_MMAP is supported\n");
580 if (reqbufs
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
581 return reqbufs_output(dev
, ctx
, reqbufs
);
582 } else if (reqbufs
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
583 return reqbufs_capture(dev
, ctx
, reqbufs
);
585 mfc_err("Invalid type requested\n");
591 static int vidioc_querybuf(struct file
*file
, void *priv
,
592 struct v4l2_buffer
*buf
)
594 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
598 if (buf
->memory
!= V4L2_MEMORY_MMAP
) {
599 mfc_err("Only mmaped buffers can be used\n");
602 mfc_debug(2, "State: %d, buf->type: %d\n", ctx
->state
, buf
->type
);
603 if (ctx
->state
== MFCINST_GOT_INST
&&
604 buf
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
605 ret
= vb2_querybuf(&ctx
->vq_src
, buf
);
606 } else if (ctx
->state
== MFCINST_RUNNING
&&
607 buf
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
608 ret
= vb2_querybuf(&ctx
->vq_dst
, buf
);
609 for (i
= 0; i
< buf
->length
; i
++)
610 buf
->m
.planes
[i
].m
.mem_offset
+= DST_QUEUE_OFF_BASE
;
612 mfc_err("vidioc_querybuf called in an inappropriate state\n");
620 static int vidioc_qbuf(struct file
*file
, void *priv
, struct v4l2_buffer
*buf
)
622 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
624 if (ctx
->state
== MFCINST_ERROR
) {
625 mfc_err("Call on QBUF after unrecoverable error\n");
628 if (buf
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
)
629 return vb2_qbuf(&ctx
->vq_src
, buf
);
630 else if (buf
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
)
631 return vb2_qbuf(&ctx
->vq_dst
, buf
);
635 /* Dequeue a buffer */
636 static int vidioc_dqbuf(struct file
*file
, void *priv
, struct v4l2_buffer
*buf
)
638 const struct v4l2_event ev
= {
639 .type
= V4L2_EVENT_EOS
641 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
644 if (ctx
->state
== MFCINST_ERROR
) {
645 mfc_err_limited("Call on DQBUF after unrecoverable error\n");
650 case V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
:
651 return vb2_dqbuf(&ctx
->vq_src
, buf
, file
->f_flags
& O_NONBLOCK
);
652 case V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
:
653 ret
= vb2_dqbuf(&ctx
->vq_dst
, buf
, file
->f_flags
& O_NONBLOCK
);
657 if (ctx
->state
== MFCINST_FINISHED
&&
658 (ctx
->dst_bufs
[buf
->index
].flags
& MFC_BUF_FLAG_EOS
))
659 v4l2_event_queue_fh(&ctx
->fh
, &ev
);
666 /* Export DMA buffer */
667 static int vidioc_expbuf(struct file
*file
, void *priv
,
668 struct v4l2_exportbuffer
*eb
)
670 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
672 if (eb
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
)
673 return vb2_expbuf(&ctx
->vq_src
, eb
);
674 if (eb
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
)
675 return vb2_expbuf(&ctx
->vq_dst
, eb
);
680 static int vidioc_streamon(struct file
*file
, void *priv
,
681 enum v4l2_buf_type type
)
683 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
687 if (type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
)
688 ret
= vb2_streamon(&ctx
->vq_src
, type
);
689 else if (type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
)
690 ret
= vb2_streamon(&ctx
->vq_dst
, type
);
695 /* Stream off, which equals to a pause */
696 static int vidioc_streamoff(struct file
*file
, void *priv
,
697 enum v4l2_buf_type type
)
699 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
701 if (type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
)
702 return vb2_streamoff(&ctx
->vq_src
, type
);
703 else if (type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
)
704 return vb2_streamoff(&ctx
->vq_dst
, type
);
708 /* Set controls - v4l2 control framework */
709 static int s5p_mfc_dec_s_ctrl(struct v4l2_ctrl
*ctrl
)
711 struct s5p_mfc_ctx
*ctx
= ctrl_to_ctx(ctrl
);
714 case V4L2_CID_MPEG_MFC51_VIDEO_DECODER_H264_DISPLAY_DELAY
:
715 ctx
->display_delay
= ctrl
->val
;
717 case V4L2_CID_MPEG_MFC51_VIDEO_DECODER_H264_DISPLAY_DELAY_ENABLE
:
718 ctx
->display_delay_enable
= ctrl
->val
;
720 case V4L2_CID_MPEG_VIDEO_DECODER_MPEG4_DEBLOCK_FILTER
:
721 ctx
->loop_filter_mpeg4
= ctrl
->val
;
723 case V4L2_CID_MPEG_VIDEO_DECODER_SLICE_INTERFACE
:
724 ctx
->slice_interface
= ctrl
->val
;
727 mfc_err("Invalid control 0x%08x\n", ctrl
->id
);
733 static int s5p_mfc_dec_g_v_ctrl(struct v4l2_ctrl
*ctrl
)
735 struct s5p_mfc_ctx
*ctx
= ctrl_to_ctx(ctrl
);
736 struct s5p_mfc_dev
*dev
= ctx
->dev
;
739 case V4L2_CID_MIN_BUFFERS_FOR_CAPTURE
:
740 if (ctx
->state
>= MFCINST_HEAD_PARSED
&&
741 ctx
->state
< MFCINST_ABORT
) {
742 ctrl
->val
= ctx
->pb_count
;
744 } else if (ctx
->state
!= MFCINST_INIT
&&
745 ctx
->state
!= MFCINST_RES_CHANGE_END
) {
746 v4l2_err(&dev
->v4l2_dev
, "Decoding not initialised\n");
749 /* Should wait for the header to be parsed */
750 s5p_mfc_wait_for_done_ctx(ctx
,
751 S5P_MFC_R2H_CMD_SEQ_DONE_RET
, 0);
752 if (ctx
->state
>= MFCINST_HEAD_PARSED
&&
753 ctx
->state
< MFCINST_ABORT
) {
754 ctrl
->val
= ctx
->pb_count
;
756 v4l2_err(&dev
->v4l2_dev
, "Decoding not initialised\n");
765 static const struct v4l2_ctrl_ops s5p_mfc_dec_ctrl_ops
= {
766 .s_ctrl
= s5p_mfc_dec_s_ctrl
,
767 .g_volatile_ctrl
= s5p_mfc_dec_g_v_ctrl
,
770 /* Get cropping information */
771 static int vidioc_g_crop(struct file
*file
, void *priv
,
772 struct v4l2_crop
*cr
)
774 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
775 struct s5p_mfc_dev
*dev
= ctx
->dev
;
776 u32 left
, right
, top
, bottom
;
778 if (ctx
->state
!= MFCINST_HEAD_PARSED
&&
779 ctx
->state
!= MFCINST_RUNNING
&&
780 ctx
->state
!= MFCINST_FINISHING
&&
781 ctx
->state
!= MFCINST_FINISHED
) {
782 mfc_err("Can not get crop information\n");
785 if (ctx
->src_fmt
->fourcc
== V4L2_PIX_FMT_H264
) {
786 left
= s5p_mfc_hw_call(dev
->mfc_ops
, get_crop_info_h
, ctx
);
787 right
= left
>> S5P_FIMV_SHARED_CROP_RIGHT_SHIFT
;
788 left
= left
& S5P_FIMV_SHARED_CROP_LEFT_MASK
;
789 top
= s5p_mfc_hw_call(dev
->mfc_ops
, get_crop_info_v
, ctx
);
790 bottom
= top
>> S5P_FIMV_SHARED_CROP_BOTTOM_SHIFT
;
791 top
= top
& S5P_FIMV_SHARED_CROP_TOP_MASK
;
794 cr
->c
.width
= ctx
->img_width
- left
- right
;
795 cr
->c
.height
= ctx
->img_height
- top
- bottom
;
796 mfc_debug(2, "Cropping info [h264]: l=%d t=%d w=%d h=%d (r=%d b=%d fw=%d fh=%d\n",
797 left
, top
, cr
->c
.width
, cr
->c
.height
, right
, bottom
,
798 ctx
->buf_width
, ctx
->buf_height
);
802 cr
->c
.width
= ctx
->img_width
;
803 cr
->c
.height
= ctx
->img_height
;
804 mfc_debug(2, "Cropping info: w=%d h=%d fw=%d fh=%d\n",
805 cr
->c
.width
, cr
->c
.height
, ctx
->buf_width
,
811 static int vidioc_decoder_cmd(struct file
*file
, void *priv
,
812 struct v4l2_decoder_cmd
*cmd
)
814 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(priv
);
815 struct s5p_mfc_dev
*dev
= ctx
->dev
;
816 struct s5p_mfc_buf
*buf
;
820 case V4L2_DEC_CMD_STOP
:
824 if (!vb2_is_streaming(&ctx
->vq_src
))
827 spin_lock_irqsave(&dev
->irqlock
, flags
);
828 if (list_empty(&ctx
->src_queue
)) {
829 mfc_err("EOS: empty src queue, entering finishing state");
830 ctx
->state
= MFCINST_FINISHING
;
831 if (s5p_mfc_ctx_ready(ctx
))
832 set_work_bit_irqsave(ctx
);
833 spin_unlock_irqrestore(&dev
->irqlock
, flags
);
834 s5p_mfc_hw_call(dev
->mfc_ops
, try_run
, dev
);
836 mfc_err("EOS: marking last buffer of stream");
837 buf
= list_entry(ctx
->src_queue
.prev
,
838 struct s5p_mfc_buf
, list
);
839 if (buf
->flags
& MFC_BUF_FLAG_USED
)
840 ctx
->state
= MFCINST_FINISHING
;
842 buf
->flags
|= MFC_BUF_FLAG_EOS
;
843 spin_unlock_irqrestore(&dev
->irqlock
, flags
);
852 static int vidioc_subscribe_event(struct v4l2_fh
*fh
,
853 const struct v4l2_event_subscription
*sub
)
857 return v4l2_event_subscribe(fh
, sub
, 2, NULL
);
858 case V4L2_EVENT_SOURCE_CHANGE
:
859 return v4l2_src_change_event_subscribe(fh
, sub
);
867 static const struct v4l2_ioctl_ops s5p_mfc_dec_ioctl_ops
= {
868 .vidioc_querycap
= vidioc_querycap
,
869 .vidioc_enum_fmt_vid_cap_mplane
= vidioc_enum_fmt_vid_cap_mplane
,
870 .vidioc_enum_fmt_vid_out_mplane
= vidioc_enum_fmt_vid_out_mplane
,
871 .vidioc_g_fmt_vid_cap_mplane
= vidioc_g_fmt
,
872 .vidioc_g_fmt_vid_out_mplane
= vidioc_g_fmt
,
873 .vidioc_try_fmt_vid_cap_mplane
= vidioc_try_fmt
,
874 .vidioc_try_fmt_vid_out_mplane
= vidioc_try_fmt
,
875 .vidioc_s_fmt_vid_cap_mplane
= vidioc_s_fmt
,
876 .vidioc_s_fmt_vid_out_mplane
= vidioc_s_fmt
,
877 .vidioc_reqbufs
= vidioc_reqbufs
,
878 .vidioc_querybuf
= vidioc_querybuf
,
879 .vidioc_qbuf
= vidioc_qbuf
,
880 .vidioc_dqbuf
= vidioc_dqbuf
,
881 .vidioc_expbuf
= vidioc_expbuf
,
882 .vidioc_streamon
= vidioc_streamon
,
883 .vidioc_streamoff
= vidioc_streamoff
,
884 .vidioc_g_crop
= vidioc_g_crop
,
885 .vidioc_decoder_cmd
= vidioc_decoder_cmd
,
886 .vidioc_subscribe_event
= vidioc_subscribe_event
,
887 .vidioc_unsubscribe_event
= v4l2_event_unsubscribe
,
890 static int s5p_mfc_queue_setup(struct vb2_queue
*vq
,
891 unsigned int *buf_count
,
892 unsigned int *plane_count
, unsigned int psize
[],
893 struct device
*alloc_devs
[])
895 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(vq
->drv_priv
);
896 struct s5p_mfc_dev
*dev
= ctx
->dev
;
898 /* Video output for decoding (source)
899 * this can be set after getting an instance */
900 if (ctx
->state
== MFCINST_INIT
&&
901 vq
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
902 /* A single plane is required for input */
906 if (*buf_count
> MFC_MAX_BUFFERS
)
907 *buf_count
= MFC_MAX_BUFFERS
;
908 /* Video capture for decoding (destination)
909 * this can be set after the header was parsed */
910 } else if (ctx
->state
== MFCINST_HEAD_PARSED
&&
911 vq
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
912 /* Output plane count is 2 - one for Y and one for CbCr */
914 /* Setup buffer count */
915 if (*buf_count
< ctx
->pb_count
)
916 *buf_count
= ctx
->pb_count
;
917 if (*buf_count
> ctx
->pb_count
+ MFC_MAX_EXTRA_DPB
)
918 *buf_count
= ctx
->pb_count
+ MFC_MAX_EXTRA_DPB
;
919 if (*buf_count
> MFC_MAX_BUFFERS
)
920 *buf_count
= MFC_MAX_BUFFERS
;
922 mfc_err("State seems invalid. State = %d, vq->type = %d\n",
923 ctx
->state
, vq
->type
);
926 mfc_debug(2, "Buffer count=%d, plane count=%d\n",
927 *buf_count
, *plane_count
);
928 if (ctx
->state
== MFCINST_HEAD_PARSED
&&
929 vq
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
930 psize
[0] = ctx
->luma_size
;
931 psize
[1] = ctx
->chroma_size
;
933 if (IS_MFCV6_PLUS(dev
))
934 alloc_devs
[0] = ctx
->dev
->mem_dev_l
;
936 alloc_devs
[0] = ctx
->dev
->mem_dev_r
;
937 alloc_devs
[1] = ctx
->dev
->mem_dev_l
;
938 } else if (vq
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
&&
939 ctx
->state
== MFCINST_INIT
) {
940 psize
[0] = ctx
->dec_src_buf_size
;
941 alloc_devs
[0] = ctx
->dev
->mem_dev_l
;
943 mfc_err("This video node is dedicated to decoding. Decoding not initialized\n");
949 static int s5p_mfc_buf_init(struct vb2_buffer
*vb
)
951 struct vb2_v4l2_buffer
*vbuf
= to_vb2_v4l2_buffer(vb
);
952 struct vb2_queue
*vq
= vb
->vb2_queue
;
953 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(vq
->drv_priv
);
956 if (vq
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
957 if (ctx
->capture_state
== QUEUE_BUFS_MMAPED
)
959 for (i
= 0; i
< ctx
->dst_fmt
->num_planes
; i
++) {
960 if (IS_ERR_OR_NULL(ERR_PTR(
961 vb2_dma_contig_plane_dma_addr(vb
, i
)))) {
962 mfc_err("Plane mem not allocated\n");
966 if (vb2_plane_size(vb
, 0) < ctx
->luma_size
||
967 vb2_plane_size(vb
, 1) < ctx
->chroma_size
) {
968 mfc_err("Plane buffer (CAPTURE) is too small\n");
972 ctx
->dst_bufs
[i
].b
= vbuf
;
973 ctx
->dst_bufs
[i
].cookie
.raw
.luma
=
974 vb2_dma_contig_plane_dma_addr(vb
, 0);
975 ctx
->dst_bufs
[i
].cookie
.raw
.chroma
=
976 vb2_dma_contig_plane_dma_addr(vb
, 1);
978 } else if (vq
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
979 if (IS_ERR_OR_NULL(ERR_PTR(
980 vb2_dma_contig_plane_dma_addr(vb
, 0)))) {
981 mfc_err("Plane memory not allocated\n");
984 if (vb2_plane_size(vb
, 0) < ctx
->dec_src_buf_size
) {
985 mfc_err("Plane buffer (OUTPUT) is too small\n");
990 ctx
->src_bufs
[i
].b
= vbuf
;
991 ctx
->src_bufs
[i
].cookie
.stream
=
992 vb2_dma_contig_plane_dma_addr(vb
, 0);
995 mfc_err("s5p_mfc_buf_init: unknown queue type\n");
1001 static int s5p_mfc_start_streaming(struct vb2_queue
*q
, unsigned int count
)
1003 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(q
->drv_priv
);
1004 struct s5p_mfc_dev
*dev
= ctx
->dev
;
1006 v4l2_ctrl_handler_setup(&ctx
->ctrl_handler
);
1007 if (ctx
->state
== MFCINST_FINISHING
||
1008 ctx
->state
== MFCINST_FINISHED
)
1009 ctx
->state
= MFCINST_RUNNING
;
1010 /* If context is ready then dev = work->data;schedule it to run */
1011 if (s5p_mfc_ctx_ready(ctx
))
1012 set_work_bit_irqsave(ctx
);
1013 s5p_mfc_hw_call(dev
->mfc_ops
, try_run
, dev
);
1017 static void s5p_mfc_stop_streaming(struct vb2_queue
*q
)
1019 unsigned long flags
;
1020 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(q
->drv_priv
);
1021 struct s5p_mfc_dev
*dev
= ctx
->dev
;
1024 spin_lock_irqsave(&dev
->irqlock
, flags
);
1025 if ((ctx
->state
== MFCINST_FINISHING
||
1026 ctx
->state
== MFCINST_RUNNING
) &&
1027 dev
->curr_ctx
== ctx
->num
&& dev
->hw_lock
) {
1028 ctx
->state
= MFCINST_ABORT
;
1029 spin_unlock_irqrestore(&dev
->irqlock
, flags
);
1030 s5p_mfc_wait_for_done_ctx(ctx
,
1031 S5P_MFC_R2H_CMD_FRAME_DONE_RET
, 0);
1033 spin_lock_irqsave(&dev
->irqlock
, flags
);
1035 if (q
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
1036 s5p_mfc_cleanup_queue(&ctx
->dst_queue
, &ctx
->vq_dst
);
1037 INIT_LIST_HEAD(&ctx
->dst_queue
);
1038 ctx
->dst_queue_cnt
= 0;
1039 ctx
->dpb_flush_flag
= 1;
1040 ctx
->dec_dst_flag
= 0;
1041 if (IS_MFCV6_PLUS(dev
) && (ctx
->state
== MFCINST_RUNNING
)) {
1042 ctx
->state
= MFCINST_FLUSH
;
1043 set_work_bit_irqsave(ctx
);
1044 s5p_mfc_hw_call(dev
->mfc_ops
, try_run
, dev
);
1045 spin_unlock_irqrestore(&dev
->irqlock
, flags
);
1046 if (s5p_mfc_wait_for_done_ctx(ctx
,
1047 S5P_MFC_R2H_CMD_DPB_FLUSH_RET
, 0))
1048 mfc_err("Err flushing buffers\n");
1049 spin_lock_irqsave(&dev
->irqlock
, flags
);
1051 } else if (q
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
1052 s5p_mfc_cleanup_queue(&ctx
->src_queue
, &ctx
->vq_src
);
1053 INIT_LIST_HEAD(&ctx
->src_queue
);
1054 ctx
->src_queue_cnt
= 0;
1057 ctx
->state
= MFCINST_RUNNING
;
1058 spin_unlock_irqrestore(&dev
->irqlock
, flags
);
1062 static void s5p_mfc_buf_queue(struct vb2_buffer
*vb
)
1064 struct vb2_queue
*vq
= vb
->vb2_queue
;
1065 struct s5p_mfc_ctx
*ctx
= fh_to_ctx(vq
->drv_priv
);
1066 struct s5p_mfc_dev
*dev
= ctx
->dev
;
1067 unsigned long flags
;
1068 struct s5p_mfc_buf
*mfc_buf
;
1070 if (vq
->type
== V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE
) {
1071 mfc_buf
= &ctx
->src_bufs
[vb
->index
];
1072 mfc_buf
->flags
&= ~MFC_BUF_FLAG_USED
;
1073 spin_lock_irqsave(&dev
->irqlock
, flags
);
1074 list_add_tail(&mfc_buf
->list
, &ctx
->src_queue
);
1075 ctx
->src_queue_cnt
++;
1076 spin_unlock_irqrestore(&dev
->irqlock
, flags
);
1077 } else if (vq
->type
== V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
) {
1078 mfc_buf
= &ctx
->dst_bufs
[vb
->index
];
1079 mfc_buf
->flags
&= ~MFC_BUF_FLAG_USED
;
1080 /* Mark destination as available for use by MFC */
1081 spin_lock_irqsave(&dev
->irqlock
, flags
);
1082 set_bit(vb
->index
, &ctx
->dec_dst_flag
);
1083 list_add_tail(&mfc_buf
->list
, &ctx
->dst_queue
);
1084 ctx
->dst_queue_cnt
++;
1085 spin_unlock_irqrestore(&dev
->irqlock
, flags
);
1087 mfc_err("Unsupported buffer type (%d)\n", vq
->type
);
1089 if (s5p_mfc_ctx_ready(ctx
))
1090 set_work_bit_irqsave(ctx
);
1091 s5p_mfc_hw_call(dev
->mfc_ops
, try_run
, dev
);
1094 static struct vb2_ops s5p_mfc_dec_qops
= {
1095 .queue_setup
= s5p_mfc_queue_setup
,
1096 .wait_prepare
= vb2_ops_wait_prepare
,
1097 .wait_finish
= vb2_ops_wait_finish
,
1098 .buf_init
= s5p_mfc_buf_init
,
1099 .start_streaming
= s5p_mfc_start_streaming
,
1100 .stop_streaming
= s5p_mfc_stop_streaming
,
1101 .buf_queue
= s5p_mfc_buf_queue
,
1104 const struct s5p_mfc_codec_ops
*get_dec_codec_ops(void)
1106 return &decoder_codec_ops
;
1109 struct vb2_ops
*get_dec_queue_ops(void)
1111 return &s5p_mfc_dec_qops
;
1114 const struct v4l2_ioctl_ops
*get_dec_v4l2_ioctl_ops(void)
1116 return &s5p_mfc_dec_ioctl_ops
;
1119 #define IS_MFC51_PRIV(x) ((V4L2_CTRL_ID2WHICH(x) == V4L2_CTRL_CLASS_MPEG) \
1120 && V4L2_CTRL_DRIVER_PRIV(x))
1122 int s5p_mfc_dec_ctrls_setup(struct s5p_mfc_ctx
*ctx
)
1124 struct v4l2_ctrl_config cfg
;
1127 v4l2_ctrl_handler_init(&ctx
->ctrl_handler
, NUM_CTRLS
);
1128 if (ctx
->ctrl_handler
.error
) {
1129 mfc_err("v4l2_ctrl_handler_init failed\n");
1130 return ctx
->ctrl_handler
.error
;
1133 for (i
= 0; i
< NUM_CTRLS
; i
++) {
1134 if (IS_MFC51_PRIV(controls
[i
].id
)) {
1135 memset(&cfg
, 0, sizeof(struct v4l2_ctrl_config
));
1136 cfg
.ops
= &s5p_mfc_dec_ctrl_ops
;
1137 cfg
.id
= controls
[i
].id
;
1138 cfg
.min
= controls
[i
].minimum
;
1139 cfg
.max
= controls
[i
].maximum
;
1140 cfg
.def
= controls
[i
].default_value
;
1141 cfg
.name
= controls
[i
].name
;
1142 cfg
.type
= controls
[i
].type
;
1144 cfg
.step
= controls
[i
].step
;
1145 cfg
.menu_skip_mask
= 0;
1147 ctx
->ctrls
[i
] = v4l2_ctrl_new_custom(&ctx
->ctrl_handler
,
1150 ctx
->ctrls
[i
] = v4l2_ctrl_new_std(&ctx
->ctrl_handler
,
1151 &s5p_mfc_dec_ctrl_ops
,
1152 controls
[i
].id
, controls
[i
].minimum
,
1153 controls
[i
].maximum
, controls
[i
].step
,
1154 controls
[i
].default_value
);
1156 if (ctx
->ctrl_handler
.error
) {
1157 mfc_err("Adding control (%d) failed\n", i
);
1158 return ctx
->ctrl_handler
.error
;
1160 if (controls
[i
].is_volatile
&& ctx
->ctrls
[i
])
1161 ctx
->ctrls
[i
]->flags
|= V4L2_CTRL_FLAG_VOLATILE
;
1166 void s5p_mfc_dec_ctrls_delete(struct s5p_mfc_ctx
*ctx
)
1170 v4l2_ctrl_handler_free(&ctx
->ctrl_handler
);
1171 for (i
= 0; i
< NUM_CTRLS
; i
++)
1172 ctx
->ctrls
[i
] = NULL
;
1175 void s5p_mfc_dec_init(struct s5p_mfc_ctx
*ctx
)
1177 struct v4l2_format f
;
1178 f
.fmt
.pix_mp
.pixelformat
= V4L2_PIX_FMT_H264
;
1179 ctx
->src_fmt
= find_format(&f
, MFC_FMT_DEC
);
1180 if (IS_MFCV8(ctx
->dev
))
1181 f
.fmt
.pix_mp
.pixelformat
= V4L2_PIX_FMT_NV12M
;
1182 else if (IS_MFCV6_PLUS(ctx
->dev
))
1183 f
.fmt
.pix_mp
.pixelformat
= V4L2_PIX_FMT_NV12MT_16X16
;
1185 f
.fmt
.pix_mp
.pixelformat
= V4L2_PIX_FMT_NV12MT
;
1186 ctx
->dst_fmt
= find_format(&f
, MFC_FMT_RAW
);
1187 mfc_debug(2, "Default src_fmt is %p, dest_fmt is %p\n",
1188 ctx
->src_fmt
, ctx
->dst_fmt
);