vsp1_rwpf.h 2.9 KB
Newer Older
1 2 3
/*
 * vsp1_rwpf.h  --  R-Car VSP1 Read and Write Pixel Formatters
 *
4
 * Copyright (C) 2013-2014 Renesas Electronics Corporation
5 6 7 8 9 10 11 12 13 14 15 16
 *
 * Contact: Laurent Pinchart (laurent.pinchart@ideasonboard.com)
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 */
#ifndef __VSP1_RWPF_H__
#define __VSP1_RWPF_H__

#include <media/media-entity.h>
17
#include <media/v4l2-ctrls.h>
18 19 20 21 22 23 24 25
#include <media/v4l2-subdev.h>

#include "vsp1.h"
#include "vsp1_entity.h"

#define RWPF_PAD_SINK				0
#define RWPF_PAD_SOURCE				1

26
struct v4l2_ctrl;
27
struct vsp1_dl_manager;
28
struct vsp1_rwpf;
29
struct vsp1_video;
30 31 32 33

struct vsp1_rwpf_memory {
	dma_addr_t addr[3];
};
34

35 36
struct vsp1_rwpf {
	struct vsp1_entity entity;
37
	struct v4l2_ctrl_handler ctrls;
38

39 40
	struct vsp1_video *video;

41 42
	unsigned int max_width;
	unsigned int max_height;
43

44 45
	struct v4l2_pix_format_mplane format;
	const struct vsp1_format_info *fmtinfo;
46
	unsigned int bru_input;
47

48 49
	unsigned int alpha;

50
	unsigned int offsets[2];
51
	struct vsp1_rwpf_memory mem;
52 53

	struct vsp1_dl_manager *dlm;
54 55 56 57 58 59 60
};

static inline struct vsp1_rwpf *to_rwpf(struct v4l2_subdev *subdev)
{
	return container_of(subdev, struct vsp1_rwpf, entity.subdev);
}

61 62 63 64 65
static inline struct vsp1_rwpf *entity_to_rwpf(struct vsp1_entity *entity)
{
	return container_of(entity, struct vsp1_rwpf, entity);
}

66 67 68
struct vsp1_rwpf *vsp1_rpf_create(struct vsp1_device *vsp1, unsigned int index);
struct vsp1_rwpf *vsp1_wpf_create(struct vsp1_device *vsp1, unsigned int index);

69 70
int vsp1_rwpf_init_ctrls(struct vsp1_rwpf *rwpf);

71
int vsp1_rwpf_enum_mbus_code(struct v4l2_subdev *subdev,
72
			     struct v4l2_subdev_pad_config *cfg,
73 74
			     struct v4l2_subdev_mbus_code_enum *code);
int vsp1_rwpf_enum_frame_size(struct v4l2_subdev *subdev,
75
			      struct v4l2_subdev_pad_config *cfg,
76
			      struct v4l2_subdev_frame_size_enum *fse);
77 78
int vsp1_rwpf_get_format(struct v4l2_subdev *subdev,
			 struct v4l2_subdev_pad_config *cfg,
79
			 struct v4l2_subdev_format *fmt);
80 81
int vsp1_rwpf_set_format(struct v4l2_subdev *subdev,
			 struct v4l2_subdev_pad_config *cfg,
82
			 struct v4l2_subdev_format *fmt);
83
int vsp1_rwpf_get_selection(struct v4l2_subdev *subdev,
84
			    struct v4l2_subdev_pad_config *cfg,
85 86
			    struct v4l2_subdev_selection *sel);
int vsp1_rwpf_set_selection(struct v4l2_subdev *subdev,
87
			    struct v4l2_subdev_pad_config *cfg,
88
			    struct v4l2_subdev_selection *sel);
89

90 91
struct v4l2_rect *vsp1_rwpf_get_crop(struct vsp1_rwpf *rwpf,
				     struct v4l2_subdev_pad_config *config);
92 93 94 95 96 97 98 99
/**
 * vsp1_rwpf_set_memory - Configure DMA addresses for a [RW]PF
 * @rwpf: the [RW]PF instance
 *
 * This function applies the cached memory buffer address to the hardware.
 */
static inline void vsp1_rwpf_set_memory(struct vsp1_rwpf *rwpf)
{
100
	rwpf->entity.ops->set_memory(&rwpf->entity);
101
}
102

103
#endif /* __VSP1_RWPF_H__ */