blob: e8ca9b6ee689ccd4a3ff19fb95428425254b2702 [file] [log] [blame]
Laurent Pinchart26e0ca22013-06-04 11:22:30 -03001/*
2 * vsp1_rwpf.h -- R-Car VSP1 Read and Write Pixel Formatters
3 *
Laurent Pinchart8a1edc52014-02-06 14:42:31 -03004 * Copyright (C) 2013-2014 Renesas Electronics Corporation
Laurent Pinchart26e0ca22013-06-04 11:22:30 -03005 *
6 * Contact: Laurent Pinchart (laurent.pinchart@ideasonboard.com)
7 *
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.
12 */
13#ifndef __VSP1_RWPF_H__
14#define __VSP1_RWPF_H__
15
16#include <media/media-entity.h>
Laurent Pinchart7578c202014-05-21 19:00:05 -030017#include <media/v4l2-ctrls.h>
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030018#include <media/v4l2-subdev.h>
19
20#include "vsp1.h"
21#include "vsp1_entity.h"
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030022
23#define RWPF_PAD_SINK 0
24#define RWPF_PAD_SOURCE 1
25
Laurent Pinchart3dbb6102015-08-05 16:57:35 -030026struct v4l2_ctrl;
Laurent Pinchartef9621b2015-11-14 22:27:52 -020027struct vsp1_dl_manager;
Laurent Pinchartb6af10c2015-07-28 14:05:56 -030028struct vsp1_rwpf;
Laurent Pinchartfaf26442015-08-02 14:58:43 -030029struct vsp1_video;
Laurent Pinchartb58faa92015-07-28 16:04:47 -030030
31struct vsp1_rwpf_memory {
Laurent Pinchartb58faa92015-07-28 16:04:47 -030032 dma_addr_t addr[3];
Laurent Pinchartb58faa92015-07-28 16:04:47 -030033};
Laurent Pinchartb6af10c2015-07-28 14:05:56 -030034
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030035struct vsp1_rwpf {
36 struct vsp1_entity entity;
Laurent Pinchart7578c202014-05-21 19:00:05 -030037 struct v4l2_ctrl_handler ctrls;
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030038
Laurent Pinchartfaf26442015-08-02 14:58:43 -030039 struct vsp1_video *video;
40
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030041 unsigned int max_width;
42 unsigned int max_height;
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030043
Laurent Pinchart86960ee2015-07-28 14:00:43 -030044 struct v4l2_pix_format_mplane format;
45 const struct vsp1_format_info *fmtinfo;
Laurent Pinchart629bb6d2013-07-10 18:03:46 -030046 struct {
47 unsigned int left;
48 unsigned int top;
49 } location;
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030050 struct v4l2_rect crop;
51
Laurent Pinchartbd2fdd52015-11-01 12:19:42 -020052 unsigned int alpha;
53
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030054 unsigned int offsets[2];
Laurent Pinchart351bbf92015-11-01 15:18:56 -020055 struct vsp1_rwpf_memory mem;
Laurent Pinchartef9621b2015-11-14 22:27:52 -020056
57 struct vsp1_dl_manager *dlm;
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030058};
59
60static inline struct vsp1_rwpf *to_rwpf(struct v4l2_subdev *subdev)
61{
62 return container_of(subdev, struct vsp1_rwpf, entity.subdev);
63}
64
Laurent Pinchart52434532015-11-17 12:23:23 -020065static inline struct vsp1_rwpf *entity_to_rwpf(struct vsp1_entity *entity)
66{
67 return container_of(entity, struct vsp1_rwpf, entity);
68}
69
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030070struct vsp1_rwpf *vsp1_rpf_create(struct vsp1_device *vsp1, unsigned int index);
71struct vsp1_rwpf *vsp1_wpf_create(struct vsp1_device *vsp1, unsigned int index);
72
Laurent Pinchartbd2fdd52015-11-01 12:19:42 -020073int vsp1_rwpf_init_ctrls(struct vsp1_rwpf *rwpf);
74
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030075int vsp1_rwpf_enum_mbus_code(struct v4l2_subdev *subdev,
Hans Verkuilf7234132015-03-04 01:47:54 -080076 struct v4l2_subdev_pad_config *cfg,
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030077 struct v4l2_subdev_mbus_code_enum *code);
78int vsp1_rwpf_enum_frame_size(struct v4l2_subdev *subdev,
Hans Verkuilf7234132015-03-04 01:47:54 -080079 struct v4l2_subdev_pad_config *cfg,
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030080 struct v4l2_subdev_frame_size_enum *fse);
Laurent Pinchart1bd0a1b2015-11-01 15:18:32 -020081int vsp1_rwpf_get_format(struct v4l2_subdev *subdev,
82 struct v4l2_subdev_pad_config *cfg,
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030083 struct v4l2_subdev_format *fmt);
Laurent Pinchart1bd0a1b2015-11-01 15:18:32 -020084int vsp1_rwpf_set_format(struct v4l2_subdev *subdev,
85 struct v4l2_subdev_pad_config *cfg,
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030086 struct v4l2_subdev_format *fmt);
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030087int vsp1_rwpf_get_selection(struct v4l2_subdev *subdev,
Hans Verkuilf7234132015-03-04 01:47:54 -080088 struct v4l2_subdev_pad_config *cfg,
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030089 struct v4l2_subdev_selection *sel);
90int vsp1_rwpf_set_selection(struct v4l2_subdev *subdev,
Hans Verkuilf7234132015-03-04 01:47:54 -080091 struct v4l2_subdev_pad_config *cfg,
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030092 struct v4l2_subdev_selection *sel);
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030093
Laurent Pinchart351bbf92015-11-01 15:18:56 -020094/**
95 * vsp1_rwpf_set_memory - Configure DMA addresses for a [RW]PF
96 * @rwpf: the [RW]PF instance
97 *
98 * This function applies the cached memory buffer address to the hardware.
99 */
100static inline void vsp1_rwpf_set_memory(struct vsp1_rwpf *rwpf)
101{
Laurent Pinchart52434532015-11-17 12:23:23 -0200102 rwpf->entity.ops->set_memory(&rwpf->entity);
Laurent Pinchart351bbf92015-11-01 15:18:56 -0200103}
Laurent Pinchart4d346be52015-11-01 13:48:11 -0200104
Laurent Pinchart26e0ca22013-06-04 11:22:30 -0300105#endif /* __VSP1_RWPF_H__ */