Commit e578588e authored by Sylwester Nawrocki's avatar Sylwester Nawrocki Committed by Mauro Carvalho Chehab

[media] s5p-fimc: Conversion to use struct v4l2_fh

This is a prerequisite for the patch converting the driver to use
the control framework. As the capture driver does not use per file
handle contexts, two separate ioctl handlers are created for it
(vidioc_try_fmt_mplane, and vidioc_g_fmt_mplane) so there is no
handlers shared between the memory-to-memory and capture video node.
Signed-off-by: default avatarSylwester Nawrocki <s.nawrocki@samsung.com>
Signed-off-by: default avatarKyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent d3953223
...@@ -276,7 +276,10 @@ static struct vb2_ops fimc_capture_qops = { ...@@ -276,7 +276,10 @@ static struct vb2_ops fimc_capture_qops = {
static int fimc_capture_open(struct file *file) static int fimc_capture_open(struct file *file)
{ {
struct fimc_dev *fimc = video_drvdata(file); struct fimc_dev *fimc = video_drvdata(file);
int ret = 0; int ret = v4l2_fh_open(file);
if (ret)
return ret;
dbg("pid: %d, state: 0x%lx", task_pid_nr(current), fimc->state); dbg("pid: %d, state: 0x%lx", task_pid_nr(current), fimc->state);
...@@ -285,11 +288,12 @@ static int fimc_capture_open(struct file *file) ...@@ -285,11 +288,12 @@ static int fimc_capture_open(struct file *file)
return -EBUSY; return -EBUSY;
ret = pm_runtime_get_sync(&fimc->pdev->dev); ret = pm_runtime_get_sync(&fimc->pdev->dev);
if (ret) if (ret < 0) {
v4l2_fh_release(file);
return ret; return ret;
}
++fimc->vid_cap.refcnt; ++fimc->vid_cap.refcnt;
file->private_data = fimc->vid_cap.ctx;
return 0; return 0;
} }
...@@ -307,22 +311,20 @@ static int fimc_capture_close(struct file *file) ...@@ -307,22 +311,20 @@ static int fimc_capture_close(struct file *file)
pm_runtime_put(&fimc->pdev->dev); pm_runtime_put(&fimc->pdev->dev);
return 0; return v4l2_fh_release(file);
} }
static unsigned int fimc_capture_poll(struct file *file, static unsigned int fimc_capture_poll(struct file *file,
struct poll_table_struct *wait) struct poll_table_struct *wait)
{ {
struct fimc_ctx *ctx = file->private_data; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_dev *fimc = ctx->fimc_dev;
return vb2_poll(&fimc->vid_cap.vbq, file, wait); return vb2_poll(&fimc->vid_cap.vbq, file, wait);
} }
static int fimc_capture_mmap(struct file *file, struct vm_area_struct *vma) static int fimc_capture_mmap(struct file *file, struct vm_area_struct *vma)
{ {
struct fimc_ctx *ctx = file->private_data; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_dev *fimc = ctx->fimc_dev;
return vb2_mmap(&fimc->vid_cap.vbq, vma); return vb2_mmap(&fimc->vid_cap.vbq, vma);
} }
...@@ -340,8 +342,7 @@ static const struct v4l2_file_operations fimc_capture_fops = { ...@@ -340,8 +342,7 @@ static const struct v4l2_file_operations fimc_capture_fops = {
static int fimc_vidioc_querycap_capture(struct file *file, void *priv, static int fimc_vidioc_querycap_capture(struct file *file, void *priv,
struct v4l2_capability *cap) struct v4l2_capability *cap)
{ {
struct fimc_ctx *ctx = file->private_data; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_dev *fimc = ctx->fimc_dev;
strncpy(cap->driver, fimc->pdev->name, sizeof(cap->driver) - 1); strncpy(cap->driver, fimc->pdev->name, sizeof(cap->driver) - 1);
strncpy(cap->card, fimc->pdev->name, sizeof(cap->card) - 1); strncpy(cap->card, fimc->pdev->name, sizeof(cap->card) - 1);
...@@ -388,20 +389,41 @@ static int sync_capture_fmt(struct fimc_ctx *ctx) ...@@ -388,20 +389,41 @@ static int sync_capture_fmt(struct fimc_ctx *ctx)
return 0; return 0;
} }
static int fimc_cap_g_fmt_mplane(struct file *file, void *fh,
struct v4l2_format *f)
{
struct fimc_dev *fimc = video_drvdata(file);
struct fimc_ctx *ctx = fimc->vid_cap.ctx;
if (f->type != V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE)
return -EINVAL;
return fimc_fill_format(&ctx->d_frame, f);
}
static int fimc_cap_try_fmt_mplane(struct file *file, void *fh,
struct v4l2_format *f)
{
struct fimc_dev *fimc = video_drvdata(file);
struct fimc_ctx *ctx = fimc->vid_cap.ctx;
return fimc_try_fmt_mplane(ctx, f);
}
static int fimc_cap_s_fmt_mplane(struct file *file, void *priv, static int fimc_cap_s_fmt_mplane(struct file *file, void *priv,
struct v4l2_format *f) struct v4l2_format *f)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_dev *fimc = ctx->fimc_dev; struct fimc_ctx *ctx = fimc->vid_cap.ctx;
struct fimc_frame *frame;
struct v4l2_pix_format_mplane *pix; struct v4l2_pix_format_mplane *pix;
struct fimc_frame *frame;
int ret; int ret;
int i; int i;
if (f->type != V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE) if (f->type != V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE)
return -EINVAL; return -EINVAL;
ret = fimc_vidioc_try_fmt_mplane(file, priv, f); ret = fimc_try_fmt_mplane(ctx, f);
if (ret) if (ret)
return ret; return ret;
...@@ -443,7 +465,7 @@ static int fimc_cap_s_fmt_mplane(struct file *file, void *priv, ...@@ -443,7 +465,7 @@ static int fimc_cap_s_fmt_mplane(struct file *file, void *priv,
static int fimc_cap_enum_input(struct file *file, void *priv, static int fimc_cap_enum_input(struct file *file, void *priv,
struct v4l2_input *i) struct v4l2_input *i)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
if (i->index != 0) if (i->index != 0)
return -EINVAL; return -EINVAL;
...@@ -467,8 +489,8 @@ static int fimc_cap_g_input(struct file *file, void *priv, unsigned int *i) ...@@ -467,8 +489,8 @@ static int fimc_cap_g_input(struct file *file, void *priv, unsigned int *i)
static int fimc_cap_streamon(struct file *file, void *priv, static int fimc_cap_streamon(struct file *file, void *priv,
enum v4l2_buf_type type) enum v4l2_buf_type type)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_dev *fimc = ctx->fimc_dev; struct fimc_ctx *ctx = fimc->vid_cap.ctx;
if (fimc_capture_active(fimc) || !fimc->vid_cap.sd) if (fimc_capture_active(fimc) || !fimc->vid_cap.sd)
return -EBUSY; return -EBUSY;
...@@ -484,8 +506,7 @@ static int fimc_cap_streamon(struct file *file, void *priv, ...@@ -484,8 +506,7 @@ static int fimc_cap_streamon(struct file *file, void *priv,
static int fimc_cap_streamoff(struct file *file, void *priv, static int fimc_cap_streamoff(struct file *file, void *priv,
enum v4l2_buf_type type) enum v4l2_buf_type type)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_dev *fimc = ctx->fimc_dev;
return vb2_streamoff(&fimc->vid_cap.vbq, type); return vb2_streamoff(&fimc->vid_cap.vbq, type);
} }
...@@ -493,47 +514,43 @@ static int fimc_cap_streamoff(struct file *file, void *priv, ...@@ -493,47 +514,43 @@ static int fimc_cap_streamoff(struct file *file, void *priv,
static int fimc_cap_reqbufs(struct file *file, void *priv, static int fimc_cap_reqbufs(struct file *file, void *priv,
struct v4l2_requestbuffers *reqbufs) struct v4l2_requestbuffers *reqbufs)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_vid_cap *cap = &ctx->fimc_dev->vid_cap; int ret = vb2_reqbufs(&fimc->vid_cap.vbq, reqbufs);
int ret;
ret = vb2_reqbufs(&cap->vbq, reqbufs);
if (!ret) if (!ret)
cap->reqbufs_count = reqbufs->count; fimc->vid_cap.reqbufs_count = reqbufs->count;
return ret; return ret;
} }
static int fimc_cap_querybuf(struct file *file, void *priv, static int fimc_cap_querybuf(struct file *file, void *priv,
struct v4l2_buffer *buf) struct v4l2_buffer *buf)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_vid_cap *cap = &ctx->fimc_dev->vid_cap;
return vb2_querybuf(&cap->vbq, buf); return vb2_querybuf(&fimc->vid_cap.vbq, buf);
} }
static int fimc_cap_qbuf(struct file *file, void *priv, static int fimc_cap_qbuf(struct file *file, void *priv,
struct v4l2_buffer *buf) struct v4l2_buffer *buf)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_vid_cap *cap = &ctx->fimc_dev->vid_cap;
return vb2_qbuf(&cap->vbq, buf); return vb2_qbuf(&fimc->vid_cap.vbq, buf);
} }
static int fimc_cap_dqbuf(struct file *file, void *priv, static int fimc_cap_dqbuf(struct file *file, void *priv,
struct v4l2_buffer *buf) struct v4l2_buffer *buf)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
return vb2_dqbuf(&ctx->fimc_dev->vid_cap.vbq, buf,
file->f_flags & O_NONBLOCK); return vb2_dqbuf(&fimc->vid_cap.vbq, buf, file->f_flags & O_NONBLOCK);
} }
static int fimc_cap_s_ctrl(struct file *file, void *priv, static int fimc_cap_s_ctrl(struct file *file, void *priv,
struct v4l2_control *ctrl) struct v4l2_control *ctrl)
{ {
struct fimc_ctx *ctx = priv; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_ctx *ctx = fimc->vid_cap.ctx;
int ret = -EINVAL; int ret = -EINVAL;
/* Allow any controls but 90/270 rotation while streaming */ /* Allow any controls but 90/270 rotation while streaming */
...@@ -556,14 +573,12 @@ static int fimc_cap_s_ctrl(struct file *file, void *priv, ...@@ -556,14 +573,12 @@ static int fimc_cap_s_ctrl(struct file *file, void *priv,
static int fimc_cap_cropcap(struct file *file, void *fh, static int fimc_cap_cropcap(struct file *file, void *fh,
struct v4l2_cropcap *cr) struct v4l2_cropcap *cr)
{ {
struct fimc_frame *f; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_ctx *ctx = fh; struct fimc_frame *f = &fimc->vid_cap.ctx->s_frame;
if (cr->type != V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE) if (cr->type != V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE)
return -EINVAL; return -EINVAL;
f = &ctx->s_frame;
cr->bounds.left = 0; cr->bounds.left = 0;
cr->bounds.top = 0; cr->bounds.top = 0;
cr->bounds.width = f->o_width; cr->bounds.width = f->o_width;
...@@ -575,10 +590,8 @@ static int fimc_cap_cropcap(struct file *file, void *fh, ...@@ -575,10 +590,8 @@ static int fimc_cap_cropcap(struct file *file, void *fh,
static int fimc_cap_g_crop(struct file *file, void *fh, struct v4l2_crop *cr) static int fimc_cap_g_crop(struct file *file, void *fh, struct v4l2_crop *cr)
{ {
struct fimc_frame *f; struct fimc_dev *fimc = video_drvdata(file);
struct fimc_ctx *ctx = file->private_data; struct fimc_frame *f = &fimc->vid_cap.ctx->s_frame;
f = &ctx->s_frame;
cr->c.left = f->offs_h; cr->c.left = f->offs_h;
cr->c.top = f->offs_v; cr->c.top = f->offs_v;
...@@ -588,12 +601,11 @@ static int fimc_cap_g_crop(struct file *file, void *fh, struct v4l2_crop *cr) ...@@ -588,12 +601,11 @@ static int fimc_cap_g_crop(struct file *file, void *fh, struct v4l2_crop *cr)
return 0; return 0;
} }
static int fimc_cap_s_crop(struct file *file, void *fh, static int fimc_cap_s_crop(struct file *file, void *fh, struct v4l2_crop *cr)
struct v4l2_crop *cr)
{ {
struct fimc_dev *fimc = video_drvdata(file);
struct fimc_ctx *ctx = fimc->vid_cap.ctx;
struct fimc_frame *f; struct fimc_frame *f;
struct fimc_ctx *ctx = file->private_data;
struct fimc_dev *fimc = ctx->fimc_dev;
int ret = -EINVAL; int ret = -EINVAL;
if (fimc_capture_active(fimc)) if (fimc_capture_active(fimc))
...@@ -631,9 +643,9 @@ static const struct v4l2_ioctl_ops fimc_capture_ioctl_ops = { ...@@ -631,9 +643,9 @@ static const struct v4l2_ioctl_ops fimc_capture_ioctl_ops = {
.vidioc_querycap = fimc_vidioc_querycap_capture, .vidioc_querycap = fimc_vidioc_querycap_capture,
.vidioc_enum_fmt_vid_cap_mplane = fimc_vidioc_enum_fmt_mplane, .vidioc_enum_fmt_vid_cap_mplane = fimc_vidioc_enum_fmt_mplane,
.vidioc_try_fmt_vid_cap_mplane = fimc_vidioc_try_fmt_mplane, .vidioc_try_fmt_vid_cap_mplane = fimc_cap_try_fmt_mplane,
.vidioc_s_fmt_vid_cap_mplane = fimc_cap_s_fmt_mplane, .vidioc_s_fmt_vid_cap_mplane = fimc_cap_s_fmt_mplane,
.vidioc_g_fmt_vid_cap_mplane = fimc_vidioc_g_fmt_mplane, .vidioc_g_fmt_vid_cap_mplane = fimc_cap_g_fmt_mplane,
.vidioc_reqbufs = fimc_cap_reqbufs, .vidioc_reqbufs = fimc_cap_reqbufs,
.vidioc_querybuf = fimc_cap_querybuf, .vidioc_querybuf = fimc_cap_querybuf,
......
This diff is collapsed.
...@@ -460,6 +460,7 @@ struct fimc_dev { ...@@ -460,6 +460,7 @@ struct fimc_dev {
* @state: flags to keep track of user configuration * @state: flags to keep track of user configuration
* @fimc_dev: the FIMC device this context applies to * @fimc_dev: the FIMC device this context applies to
* @m2m_ctx: memory-to-memory device context * @m2m_ctx: memory-to-memory device context
* @fh: v4l2 file handle
*/ */
struct fimc_ctx { struct fimc_ctx {
spinlock_t slock; spinlock_t slock;
...@@ -479,8 +480,11 @@ struct fimc_ctx { ...@@ -479,8 +480,11 @@ struct fimc_ctx {
u32 state; u32 state;
struct fimc_dev *fimc_dev; struct fimc_dev *fimc_dev;
struct v4l2_m2m_ctx *m2m_ctx; struct v4l2_m2m_ctx *m2m_ctx;
struct v4l2_fh fh;
}; };
#define fh_to_ctx(__fh) container_of(__fh, struct fimc_ctx, fh)
static inline bool fimc_capture_active(struct fimc_dev *fimc) static inline bool fimc_capture_active(struct fimc_dev *fimc)
{ {
unsigned long flags; unsigned long flags;
...@@ -632,18 +636,16 @@ int fimc_hw_set_camera_type(struct fimc_dev *fimc, ...@@ -632,18 +636,16 @@ int fimc_hw_set_camera_type(struct fimc_dev *fimc,
/* fimc-core.c */ /* fimc-core.c */
int fimc_vidioc_enum_fmt_mplane(struct file *file, void *priv, int fimc_vidioc_enum_fmt_mplane(struct file *file, void *priv,
struct v4l2_fmtdesc *f); struct v4l2_fmtdesc *f);
int fimc_vidioc_g_fmt_mplane(struct file *file, void *priv,
struct v4l2_format *f);
int fimc_vidioc_try_fmt_mplane(struct file *file, void *priv,
struct v4l2_format *f);
int fimc_vidioc_queryctrl(struct file *file, void *priv, int fimc_vidioc_queryctrl(struct file *file, void *priv,
struct v4l2_queryctrl *qc); struct v4l2_queryctrl *qc);
int fimc_vidioc_g_ctrl(struct file *file, void *priv, int fimc_vidioc_g_ctrl(struct file *file, void *priv,
struct v4l2_control *ctrl); struct v4l2_control *ctrl);
int fimc_try_fmt_mplane(struct fimc_ctx *ctx, struct v4l2_format *f);
int fimc_try_crop(struct fimc_ctx *ctx, struct v4l2_crop *cr); int fimc_try_crop(struct fimc_ctx *ctx, struct v4l2_crop *cr);
int check_ctrl_val(struct fimc_ctx *ctx, struct v4l2_control *ctrl); int check_ctrl_val(struct fimc_ctx *ctx, struct v4l2_control *ctrl);
int fimc_s_ctrl(struct fimc_ctx *ctx, struct v4l2_control *ctrl); int fimc_s_ctrl(struct fimc_ctx *ctx, struct v4l2_control *ctrl);
int fimc_fill_format(struct fimc_frame *frame, struct v4l2_format *f);
struct fimc_fmt *find_format(struct v4l2_format *f, unsigned int mask); struct fimc_fmt *find_format(struct v4l2_format *f, unsigned int mask);
struct fimc_fmt *find_mbus_format(struct v4l2_mbus_framefmt *f, struct fimc_fmt *find_mbus_format(struct v4l2_mbus_framefmt *f,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment