18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0+ */
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * vsp1_brx.h  --  R-Car VSP1 Blend ROP Unit (BRU and BRS)
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright (C) 2013 Renesas Corporation
68c2ecf20Sopenharmony_ci *
78c2ecf20Sopenharmony_ci * Contact: Laurent Pinchart (laurent.pinchart@ideasonboard.com)
88c2ecf20Sopenharmony_ci */
98c2ecf20Sopenharmony_ci#ifndef __VSP1_BRX_H__
108c2ecf20Sopenharmony_ci#define __VSP1_BRX_H__
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_ci#include <media/media-entity.h>
138c2ecf20Sopenharmony_ci#include <media/v4l2-ctrls.h>
148c2ecf20Sopenharmony_ci#include <media/v4l2-subdev.h>
158c2ecf20Sopenharmony_ci
168c2ecf20Sopenharmony_ci#include "vsp1_entity.h"
178c2ecf20Sopenharmony_ci
188c2ecf20Sopenharmony_cistruct vsp1_device;
198c2ecf20Sopenharmony_cistruct vsp1_rwpf;
208c2ecf20Sopenharmony_ci
218c2ecf20Sopenharmony_ci#define BRX_PAD_SINK(n)				(n)
228c2ecf20Sopenharmony_ci
238c2ecf20Sopenharmony_cistruct vsp1_brx {
248c2ecf20Sopenharmony_ci	struct vsp1_entity entity;
258c2ecf20Sopenharmony_ci	unsigned int base;
268c2ecf20Sopenharmony_ci
278c2ecf20Sopenharmony_ci	struct v4l2_ctrl_handler ctrls;
288c2ecf20Sopenharmony_ci
298c2ecf20Sopenharmony_ci	struct {
308c2ecf20Sopenharmony_ci		struct vsp1_rwpf *rpf;
318c2ecf20Sopenharmony_ci	} inputs[VSP1_MAX_RPF];
328c2ecf20Sopenharmony_ci
338c2ecf20Sopenharmony_ci	u32 bgcolor;
348c2ecf20Sopenharmony_ci};
358c2ecf20Sopenharmony_ci
368c2ecf20Sopenharmony_cistatic inline struct vsp1_brx *to_brx(struct v4l2_subdev *subdev)
378c2ecf20Sopenharmony_ci{
388c2ecf20Sopenharmony_ci	return container_of(subdev, struct vsp1_brx, entity.subdev);
398c2ecf20Sopenharmony_ci}
408c2ecf20Sopenharmony_ci
418c2ecf20Sopenharmony_cistruct vsp1_brx *vsp1_brx_create(struct vsp1_device *vsp1,
428c2ecf20Sopenharmony_ci				 enum vsp1_entity_type type);
438c2ecf20Sopenharmony_ci
448c2ecf20Sopenharmony_ci#endif /* __VSP1_BRX_H__ */
45