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