1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * USB Driver for ALi m5602 based webcams 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 2008 Erik Andrén 6*4882a593Smuzhiyun * Copyright (C) 2007 Ilyes Gouta. Based on the m5603x Linux Driver Project. 7*4882a593Smuzhiyun * Copyright (C) 2005 m5603x Linux Driver Project <m5602@x3ng.com.br> 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * Portions of code to USB interface and ALi driver software, 10*4882a593Smuzhiyun * Copyright (c) 2006 Willem Duinker 11*4882a593Smuzhiyun * v4l2 interface modeled after the V4L2 driver 12*4882a593Smuzhiyun * for SN9C10x PC Camera Controllers 13*4882a593Smuzhiyun */ 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun #ifndef M5602_BRIDGE_H_ 16*4882a593Smuzhiyun #define M5602_BRIDGE_H_ 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun #include <linux/slab.h> 19*4882a593Smuzhiyun #include "gspca.h" 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun #define MODULE_NAME "ALi m5602" 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun /*****************************************************************************/ 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun #define M5602_XB_SENSOR_TYPE 0x00 26*4882a593Smuzhiyun #define M5602_XB_SENSOR_CTRL 0x01 27*4882a593Smuzhiyun #define M5602_XB_LINE_OF_FRAME_H 0x02 28*4882a593Smuzhiyun #define M5602_XB_LINE_OF_FRAME_L 0x03 29*4882a593Smuzhiyun #define M5602_XB_PIX_OF_LINE_H 0x04 30*4882a593Smuzhiyun #define M5602_XB_PIX_OF_LINE_L 0x05 31*4882a593Smuzhiyun #define M5602_XB_VSYNC_PARA 0x06 32*4882a593Smuzhiyun #define M5602_XB_HSYNC_PARA 0x07 33*4882a593Smuzhiyun #define M5602_XB_TEST_MODE_1 0x08 34*4882a593Smuzhiyun #define M5602_XB_TEST_MODE_2 0x09 35*4882a593Smuzhiyun #define M5602_XB_SIG_INI 0x0a 36*4882a593Smuzhiyun #define M5602_XB_DS_PARA 0x0e 37*4882a593Smuzhiyun #define M5602_XB_TRIG_PARA 0x0f 38*4882a593Smuzhiyun #define M5602_XB_CLK_PD 0x10 39*4882a593Smuzhiyun #define M5602_XB_MCU_CLK_CTRL 0x12 40*4882a593Smuzhiyun #define M5602_XB_MCU_CLK_DIV 0x13 41*4882a593Smuzhiyun #define M5602_XB_SEN_CLK_CTRL 0x14 42*4882a593Smuzhiyun #define M5602_XB_SEN_CLK_DIV 0x15 43*4882a593Smuzhiyun #define M5602_XB_AUD_CLK_CTRL 0x16 44*4882a593Smuzhiyun #define M5602_XB_AUD_CLK_DIV 0x17 45*4882a593Smuzhiyun #define M5602_OB_AC_LINK_STATE 0x22 46*4882a593Smuzhiyun #define M5602_OB_PCM_SLOT_INDEX 0x24 47*4882a593Smuzhiyun #define M5602_OB_GPIO_SLOT_INDEX 0x25 48*4882a593Smuzhiyun #define M5602_OB_ACRX_STATUS_ADDRESS_H 0x28 49*4882a593Smuzhiyun #define M5602_OB_ACRX_STATUS_DATA_L 0x29 50*4882a593Smuzhiyun #define M5602_OB_ACRX_STATUS_DATA_H 0x2a 51*4882a593Smuzhiyun #define M5602_OB_ACTX_COMMAND_ADDRESS 0x31 52*4882a593Smuzhiyun #define M5602_OB_ACRX_COMMAND_DATA_L 0x32 53*4882a593Smuzhiyun #define M5602_OB_ACTX_COMMAND_DATA_H 0X33 54*4882a593Smuzhiyun #define M5602_XB_DEVCTR1 0x41 55*4882a593Smuzhiyun #define M5602_XB_EPSETR0 0x42 56*4882a593Smuzhiyun #define M5602_XB_EPAFCTR 0x47 57*4882a593Smuzhiyun #define M5602_XB_EPBFCTR 0x49 58*4882a593Smuzhiyun #define M5602_XB_EPEFCTR 0x4f 59*4882a593Smuzhiyun #define M5602_XB_TEST_REG 0x53 60*4882a593Smuzhiyun #define M5602_XB_ALT2SIZE 0x54 61*4882a593Smuzhiyun #define M5602_XB_ALT3SIZE 0x55 62*4882a593Smuzhiyun #define M5602_XB_OBSFRAME 0x56 63*4882a593Smuzhiyun #define M5602_XB_PWR_CTL 0x59 64*4882a593Smuzhiyun #define M5602_XB_ADC_CTRL 0x60 65*4882a593Smuzhiyun #define M5602_XB_ADC_DATA 0x61 66*4882a593Smuzhiyun #define M5602_XB_MISC_CTRL 0x62 67*4882a593Smuzhiyun #define M5602_XB_SNAPSHOT 0x63 68*4882a593Smuzhiyun #define M5602_XB_SCRATCH_1 0x64 69*4882a593Smuzhiyun #define M5602_XB_SCRATCH_2 0x65 70*4882a593Smuzhiyun #define M5602_XB_SCRATCH_3 0x66 71*4882a593Smuzhiyun #define M5602_XB_SCRATCH_4 0x67 72*4882a593Smuzhiyun #define M5602_XB_I2C_CTRL 0x68 73*4882a593Smuzhiyun #define M5602_XB_I2C_CLK_DIV 0x69 74*4882a593Smuzhiyun #define M5602_XB_I2C_DEV_ADDR 0x6a 75*4882a593Smuzhiyun #define M5602_XB_I2C_REG_ADDR 0x6b 76*4882a593Smuzhiyun #define M5602_XB_I2C_DATA 0x6c 77*4882a593Smuzhiyun #define M5602_XB_I2C_STATUS 0x6d 78*4882a593Smuzhiyun #define M5602_XB_GPIO_DAT_H 0x70 79*4882a593Smuzhiyun #define M5602_XB_GPIO_DAT_L 0x71 80*4882a593Smuzhiyun #define M5602_XB_GPIO_DIR_H 0x72 81*4882a593Smuzhiyun #define M5602_XB_GPIO_DIR_L 0x73 82*4882a593Smuzhiyun #define M5602_XB_GPIO_EN_H 0x74 83*4882a593Smuzhiyun #define M5602_XB_GPIO_EN_L 0x75 84*4882a593Smuzhiyun #define M5602_XB_GPIO_DAT 0x76 85*4882a593Smuzhiyun #define M5602_XB_GPIO_DIR 0x77 86*4882a593Smuzhiyun #define M5602_XB_SEN_CLK_CONTROL 0x80 87*4882a593Smuzhiyun #define M5602_XB_SEN_CLK_DIVISION 0x81 88*4882a593Smuzhiyun #define M5602_XB_CPR_CLK_CONTROL 0x82 89*4882a593Smuzhiyun #define M5602_XB_CPR_CLK_DIVISION 0x83 90*4882a593Smuzhiyun #define M5602_XB_MCU_CLK_CONTROL 0x84 91*4882a593Smuzhiyun #define M5602_XB_MCU_CLK_DIVISION 0x85 92*4882a593Smuzhiyun #define M5602_XB_DCT_CLK_CONTROL 0x86 93*4882a593Smuzhiyun #define M5602_XB_DCT_CLK_DIVISION 0x87 94*4882a593Smuzhiyun #define M5602_XB_EC_CLK_CONTROL 0x88 95*4882a593Smuzhiyun #define M5602_XB_EC_CLK_DIVISION 0x89 96*4882a593Smuzhiyun #define M5602_XB_LBUF_CLK_CONTROL 0x8a 97*4882a593Smuzhiyun #define M5602_XB_LBUF_CLK_DIVISION 0x8b 98*4882a593Smuzhiyun 99*4882a593Smuzhiyun #define I2C_BUSY 0x80 100*4882a593Smuzhiyun 101*4882a593Smuzhiyun /*****************************************************************************/ 102*4882a593Smuzhiyun 103*4882a593Smuzhiyun /* Driver info */ 104*4882a593Smuzhiyun #define DRIVER_AUTHOR "ALi m5602 Linux Driver Project" 105*4882a593Smuzhiyun #define DRIVER_DESC "ALi m5602 webcam driver" 106*4882a593Smuzhiyun 107*4882a593Smuzhiyun #define M5602_ISOC_ENDPOINT_ADDR 0x81 108*4882a593Smuzhiyun #define M5602_INTR_ENDPOINT_ADDR 0x82 109*4882a593Smuzhiyun 110*4882a593Smuzhiyun #define M5602_URB_MSG_TIMEOUT 5000 111*4882a593Smuzhiyun 112*4882a593Smuzhiyun /*****************************************************************************/ 113*4882a593Smuzhiyun 114*4882a593Smuzhiyun struct sd { 115*4882a593Smuzhiyun struct gspca_dev gspca_dev; 116*4882a593Smuzhiyun 117*4882a593Smuzhiyun /* A pointer to the currently connected sensor */ 118*4882a593Smuzhiyun const struct m5602_sensor *sensor; 119*4882a593Smuzhiyun 120*4882a593Smuzhiyun /* The current frame's id, used to detect frame boundaries */ 121*4882a593Smuzhiyun u8 frame_id; 122*4882a593Smuzhiyun 123*4882a593Smuzhiyun /* The current frame count */ 124*4882a593Smuzhiyun u32 frame_count; 125*4882a593Smuzhiyun 126*4882a593Smuzhiyun /* Camera rotation polling thread for "flipable" cams */ 127*4882a593Smuzhiyun struct task_struct *rotation_thread; 128*4882a593Smuzhiyun 129*4882a593Smuzhiyun struct { /* auto-white-bal + green/red/blue balance control cluster */ 130*4882a593Smuzhiyun struct v4l2_ctrl *auto_white_bal; 131*4882a593Smuzhiyun struct v4l2_ctrl *red_bal; 132*4882a593Smuzhiyun struct v4l2_ctrl *blue_bal; 133*4882a593Smuzhiyun struct v4l2_ctrl *green_bal; 134*4882a593Smuzhiyun }; 135*4882a593Smuzhiyun struct { /* autoexpo / expo cluster */ 136*4882a593Smuzhiyun struct v4l2_ctrl *autoexpo; 137*4882a593Smuzhiyun struct v4l2_ctrl *expo; 138*4882a593Smuzhiyun }; 139*4882a593Smuzhiyun struct { /* autogain / gain cluster */ 140*4882a593Smuzhiyun struct v4l2_ctrl *autogain; 141*4882a593Smuzhiyun struct v4l2_ctrl *gain; 142*4882a593Smuzhiyun }; 143*4882a593Smuzhiyun struct { /* hflip/vflip cluster */ 144*4882a593Smuzhiyun struct v4l2_ctrl *hflip; 145*4882a593Smuzhiyun struct v4l2_ctrl *vflip; 146*4882a593Smuzhiyun }; 147*4882a593Smuzhiyun }; 148*4882a593Smuzhiyun 149*4882a593Smuzhiyun int m5602_read_bridge( 150*4882a593Smuzhiyun struct sd *sd, const u8 address, u8 *i2c_data); 151*4882a593Smuzhiyun 152*4882a593Smuzhiyun int m5602_write_bridge( 153*4882a593Smuzhiyun struct sd *sd, const u8 address, const u8 i2c_data); 154*4882a593Smuzhiyun 155*4882a593Smuzhiyun int m5602_write_sensor(struct sd *sd, const u8 address, 156*4882a593Smuzhiyun u8 *i2c_data, const u8 len); 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun int m5602_read_sensor(struct sd *sd, const u8 address, 159*4882a593Smuzhiyun u8 *i2c_data, const u8 len); 160*4882a593Smuzhiyun 161*4882a593Smuzhiyun #endif 162