^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0-only */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * Copyright (C) 2010 Texas Instruments Inc
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) #ifndef _VPBE_VENC_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) #define _VPBE_VENC_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) #include <media/v4l2-subdev.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) #include <media/davinci/vpbe_types.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) #define DM644X_VPBE_VENC_SUBDEV_NAME "dm644x,vpbe-venc"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) #define DM365_VPBE_VENC_SUBDEV_NAME "dm365,vpbe-venc"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) #define DM355_VPBE_VENC_SUBDEV_NAME "dm355,vpbe-venc"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) /* venc events */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) #define VENC_END_OF_FRAME BIT(0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) #define VENC_FIRST_FIELD BIT(1)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) #define VENC_SECOND_FIELD BIT(2)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) struct venc_platform_data {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) int (*setup_pinmux)(u32 if_type, int field);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) int (*setup_clock)(enum vpbe_enc_timings_type type,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) unsigned int pixclock);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) int (*setup_if_config)(u32 pixcode);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) /* Number of LCD outputs supported */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) int num_lcd_outputs;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) struct vpbe_if_params *lcd_if_params;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) enum venc_ioctls {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) VENC_GET_FLD = 1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) /* exported functions */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) struct v4l2_subdev *venc_sub_dev_init(struct v4l2_device *v4l2_dev,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) const char *venc_name);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) #endif