blob: 4ebfab61e0ef2aa2d4cbe9aa597cae46d7d18d1d [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 Pinchartb7e51072015-11-15 19:14:22 -020046 unsigned int bru_input;
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030047
Laurent Pinchartbd2fdd52015-11-01 12:19:42 -020048 unsigned int alpha;
49
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030050 unsigned int offsets[2];
Laurent Pinchart351bbf92015-11-01 15:18:56 -020051 struct vsp1_rwpf_memory mem;
Laurent Pinchartef9621b2015-11-14 22:27:52 -020052
53 struct vsp1_dl_manager *dlm;
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030054};
55
56static inline struct vsp1_rwpf *to_rwpf(struct v4l2_subdev *subdev)
57{
58 return container_of(subdev, struct vsp1_rwpf, entity.subdev);
59}
60
Laurent Pinchart52434532015-11-17 12:23:23 -020061static inline struct vsp1_rwpf *entity_to_rwpf(struct vsp1_entity *entity)
62{
63 return container_of(entity, struct vsp1_rwpf, entity);
64}
65
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030066struct vsp1_rwpf *vsp1_rpf_create(struct vsp1_device *vsp1, unsigned int index);
67struct vsp1_rwpf *vsp1_wpf_create(struct vsp1_device *vsp1, unsigned int index);
68
Laurent Pinchartbd2fdd52015-11-01 12:19:42 -020069int vsp1_rwpf_init_ctrls(struct vsp1_rwpf *rwpf);
70
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030071int vsp1_rwpf_enum_mbus_code(struct v4l2_subdev *subdev,
Hans Verkuilf7234132015-03-04 01:47:54 -080072 struct v4l2_subdev_pad_config *cfg,
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030073 struct v4l2_subdev_mbus_code_enum *code);
74int vsp1_rwpf_enum_frame_size(struct v4l2_subdev *subdev,
Hans Verkuilf7234132015-03-04 01:47:54 -080075 struct v4l2_subdev_pad_config *cfg,
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030076 struct v4l2_subdev_frame_size_enum *fse);
Laurent Pinchart1bd0a1b2015-11-01 15:18:32 -020077int vsp1_rwpf_get_format(struct v4l2_subdev *subdev,
78 struct v4l2_subdev_pad_config *cfg,
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030079 struct v4l2_subdev_format *fmt);
Laurent Pinchart1bd0a1b2015-11-01 15:18:32 -020080int vsp1_rwpf_set_format(struct v4l2_subdev *subdev,
81 struct v4l2_subdev_pad_config *cfg,
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030082 struct v4l2_subdev_format *fmt);
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030083int vsp1_rwpf_get_selection(struct v4l2_subdev *subdev,
Hans Verkuilf7234132015-03-04 01:47:54 -080084 struct v4l2_subdev_pad_config *cfg,
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030085 struct v4l2_subdev_selection *sel);
86int vsp1_rwpf_set_selection(struct v4l2_subdev *subdev,
Hans Verkuilf7234132015-03-04 01:47:54 -080087 struct v4l2_subdev_pad_config *cfg,
Laurent Pincharte5ad37b2013-08-24 20:49:58 -030088 struct v4l2_subdev_selection *sel);
Laurent Pinchart26e0ca22013-06-04 11:22:30 -030089
Laurent Pinchartb7e51072015-11-15 19:14:22 -020090struct v4l2_rect *vsp1_rwpf_get_crop(struct vsp1_rwpf *rwpf,
91 struct v4l2_subdev_pad_config *config);
Laurent Pinchart351bbf92015-11-01 15:18:56 -020092/**
93 * vsp1_rwpf_set_memory - Configure DMA addresses for a [RW]PF
94 * @rwpf: the [RW]PF instance
95 *
96 * This function applies the cached memory buffer address to the hardware.
97 */
98static inline void vsp1_rwpf_set_memory(struct vsp1_rwpf *rwpf)
99{
Laurent Pinchart52434532015-11-17 12:23:23 -0200100 rwpf->entity.ops->set_memory(&rwpf->entity);
Laurent Pinchart351bbf92015-11-01 15:18:56 -0200101}
Laurent Pinchart4d346be52015-11-01 13:48:11 -0200102
Laurent Pinchart26e0ca22013-06-04 11:22:30 -0300103#endif /* __VSP1_RWPF_H__ */