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 47 48 49
	struct {
		unsigned int left;
		unsigned int top;
	} location;
50 51
	struct v4l2_rect crop;

52 53
	unsigned int alpha;

54
	unsigned int offsets[2];
55
	struct vsp1_rwpf_memory mem;
56 57

	struct vsp1_dl_manager *dlm;
58 59 60 61 62 63 64
};

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

65 66 67 68 69
static inline struct vsp1_rwpf *entity_to_rwpf(struct vsp1_entity *entity)
{
	return container_of(entity, struct vsp1_rwpf, entity);
}

70 71 72
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);

73 74
int vsp1_rwpf_init_ctrls(struct vsp1_rwpf *rwpf);

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

94 95 96 97 98 99 100 101
/**
 * 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)
{
102
	rwpf->entity.ops->set_memory(&rwpf->entity);
103
}
104

105
#endif /* __VSP1_RWPF_H__ */