12ba890ecSMauro Carvalho Chehab #define EM_GPIO_0 (1 << 0) 22ba890ecSMauro Carvalho Chehab #define EM_GPIO_1 (1 << 1) 32ba890ecSMauro Carvalho Chehab #define EM_GPIO_2 (1 << 2) 42ba890ecSMauro Carvalho Chehab #define EM_GPIO_3 (1 << 3) 52ba890ecSMauro Carvalho Chehab #define EM_GPIO_4 (1 << 4) 62ba890ecSMauro Carvalho Chehab #define EM_GPIO_5 (1 << 5) 72ba890ecSMauro Carvalho Chehab #define EM_GPIO_6 (1 << 6) 82ba890ecSMauro Carvalho Chehab #define EM_GPIO_7 (1 << 7) 92ba890ecSMauro Carvalho Chehab 102ba890ecSMauro Carvalho Chehab #define EM_GPO_0 (1 << 0) 112ba890ecSMauro Carvalho Chehab #define EM_GPO_1 (1 << 1) 122ba890ecSMauro Carvalho Chehab #define EM_GPO_2 (1 << 2) 132ba890ecSMauro Carvalho Chehab #define EM_GPO_3 (1 << 3) 142ba890ecSMauro Carvalho Chehab 158ab33626SHolger Nelson /* em28xx endpoints */ 168ab33626SHolger Nelson #define EM28XX_EP_ANALOG 0x82 178ab33626SHolger Nelson #define EM28XX_EP_AUDIO 0x83 188ab33626SHolger Nelson #define EM28XX_EP_DIGITAL 0x84 198ab33626SHolger Nelson 202ba890ecSMauro Carvalho Chehab /* em2800 registers */ 2141facaa4SMauro Carvalho Chehab #define EM2800_R08_AUDIOSRC 0x08 222ba890ecSMauro Carvalho Chehab 232ba890ecSMauro Carvalho Chehab /* em28xx registers */ 242ba890ecSMauro Carvalho Chehab 255c2231c8SDevin Heitmueller #define EM28XX_R00_CHIPCFG 0x00 265c2231c8SDevin Heitmueller 275c2231c8SDevin Heitmueller /* em28xx Chip Configuration 0x00 */ 285c2231c8SDevin Heitmueller #define EM28XX_CHIPCFG_VENDOR_AUDIO 0x80 295c2231c8SDevin Heitmueller #define EM28XX_CHIPCFG_I2S_VOLUME_CAPABLE 0x40 3054d79e33SDevin Heitmueller #define EM28XX_CHIPCFG_I2S_5_SAMPRATES 0x30 3154d79e33SDevin Heitmueller #define EM28XX_CHIPCFG_I2S_3_SAMPRATES 0x20 325c2231c8SDevin Heitmueller #define EM28XX_CHIPCFG_AC97 0x10 335c2231c8SDevin Heitmueller #define EM28XX_CHIPCFG_AUDIOMASK 0x30 345c2231c8SDevin Heitmueller 35d18e2fdaSDevin Heitmueller #define EM28XX_R01_CHIPCFG2 0x01 36d18e2fdaSDevin Heitmueller 37d18e2fdaSDevin Heitmueller /* em28xx Chip Configuration 2 0x01 */ 38d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_PRESENT 0x10 39d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_REQ_INTERVAL_MASK 0x0c /* bits 3-2 */ 40d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_REQ_INTERVAL_1MF 0x00 41d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_REQ_INTERVAL_2MF 0x04 42d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_REQ_INTERVAL_4MF 0x08 43d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_REQ_INTERVAL_8MF 0x0c 44d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_PACKETSIZE_MASK 0x03 /* bits 0-1 */ 45d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_PACKETSIZE_188 0x00 46d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_PACKETSIZE_376 0x01 47d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_PACKETSIZE_564 0x02 48d18e2fdaSDevin Heitmueller #define EM28XX_CHIPCFG2_TS_PACKETSIZE_752 0x03 49d18e2fdaSDevin Heitmueller 50d18e2fdaSDevin Heitmueller 512ba890ecSMauro Carvalho Chehab /* GPIO/GPO registers */ 5241facaa4SMauro Carvalho Chehab #define EM2880_R04_GPO 0x04 /* em2880-em2883 only */ 5341facaa4SMauro Carvalho Chehab #define EM28XX_R08_GPIO 0x08 /* em2820 or upper */ 542ba890ecSMauro Carvalho Chehab 5541facaa4SMauro Carvalho Chehab #define EM28XX_R06_I2C_CLK 0x06 5623159a0bSDevin Heitmueller 5723159a0bSDevin Heitmueller /* em28xx I2C Clock Register (0x06) */ 5823159a0bSDevin Heitmueller #define EM28XX_I2C_CLK_ACK_LAST_READ 0x80 5923159a0bSDevin Heitmueller #define EM28XX_I2C_CLK_WAIT_ENABLE 0x40 6023159a0bSDevin Heitmueller #define EM28XX_I2C_EEPROM_ON_BOARD 0x08 6123159a0bSDevin Heitmueller #define EM28XX_I2C_EEPROM_KEY_VALID 0x04 6223159a0bSDevin Heitmueller #define EM2874_I2C_SECONDARY_BUS_SELECT 0x04 /* em2874 has two i2c busses */ 6323159a0bSDevin Heitmueller #define EM28XX_I2C_FREQ_1_5_MHZ 0x03 /* bus frequency (bits [1-0]) */ 6423159a0bSDevin Heitmueller #define EM28XX_I2C_FREQ_25_KHZ 0x02 6523159a0bSDevin Heitmueller #define EM28XX_I2C_FREQ_400_KHZ 0x01 6623159a0bSDevin Heitmueller #define EM28XX_I2C_FREQ_100_KHZ 0x00 6723159a0bSDevin Heitmueller 6823159a0bSDevin Heitmueller 6941facaa4SMauro Carvalho Chehab #define EM28XX_R0A_CHIPID 0x0a 7041facaa4SMauro Carvalho Chehab #define EM28XX_R0C_USBSUSP 0x0c /* */ 712ba890ecSMauro Carvalho Chehab 7241facaa4SMauro Carvalho Chehab #define EM28XX_R0E_AUDIOSRC 0x0e 7341facaa4SMauro Carvalho Chehab #define EM28XX_R0F_XCLK 0x0f 742ba890ecSMauro Carvalho Chehab 7555927684SDevin Heitmueller /* em28xx XCLK Register (0x0f) */ 7655927684SDevin Heitmueller #define EM28XX_XCLK_AUDIO_UNMUTE 0x80 /* otherwise audio muted */ 7755927684SDevin Heitmueller #define EM28XX_XCLK_I2S_MSB_TIMING 0x40 /* otherwise standard timing */ 7855927684SDevin Heitmueller #define EM28XX_XCLK_IR_RC5_MODE 0x20 /* otherwise NEC mode */ 7955927684SDevin Heitmueller #define EM28XX_XCLK_IR_NEC_CHK_PARITY 0x10 8055927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_30MHZ 0x00 /* Freq. select (bits [3-0]) */ 8155927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_15MHZ 0x01 8255927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_10MHZ 0x02 8355927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_7_5MHZ 0x03 8455927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_6MHZ 0x04 8555927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_5MHZ 0x05 8655927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_4_3MHZ 0x06 8755927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_12MHZ 0x07 8855927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_20MHZ 0x08 8955927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_20MHZ_2 0x09 9055927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_48MHZ 0x0a 9155927684SDevin Heitmueller #define EM28XX_XCLK_FREQUENCY_24MHZ 0x0b 9255927684SDevin Heitmueller 9341facaa4SMauro Carvalho Chehab #define EM28XX_R10_VINMODE 0x10 94206313dbSDevin Heitmueller 9541facaa4SMauro Carvalho Chehab #define EM28XX_R11_VINCTRL 0x11 96206313dbSDevin Heitmueller 97206313dbSDevin Heitmueller /* em28xx Video Input Control Register 0x11 */ 98206313dbSDevin Heitmueller #define EM28XX_VINCTRL_VBI_SLICED 0x80 99206313dbSDevin Heitmueller #define EM28XX_VINCTRL_VBI_RAW 0x40 100206313dbSDevin Heitmueller #define EM28XX_VINCTRL_VOUT_MODE_IN 0x20 /* HREF,VREF,VACT in output */ 101206313dbSDevin Heitmueller #define EM28XX_VINCTRL_CCIR656_ENABLE 0x10 102206313dbSDevin Heitmueller #define EM28XX_VINCTRL_VBI_16BIT_RAW 0x08 /* otherwise 8-bit raw */ 103206313dbSDevin Heitmueller #define EM28XX_VINCTRL_FID_ON_HREF 0x04 104206313dbSDevin Heitmueller #define EM28XX_VINCTRL_DUAL_EDGE_STROBE 0x02 105206313dbSDevin Heitmueller #define EM28XX_VINCTRL_INTERLACED 0x01 106206313dbSDevin Heitmueller 10741facaa4SMauro Carvalho Chehab #define EM28XX_R12_VINENABLE 0x12 /* */ 1082ba890ecSMauro Carvalho Chehab 10941facaa4SMauro Carvalho Chehab #define EM28XX_R14_GAMMA 0x14 11041facaa4SMauro Carvalho Chehab #define EM28XX_R15_RGAIN 0x15 11141facaa4SMauro Carvalho Chehab #define EM28XX_R16_GGAIN 0x16 11241facaa4SMauro Carvalho Chehab #define EM28XX_R17_BGAIN 0x17 11341facaa4SMauro Carvalho Chehab #define EM28XX_R18_ROFFSET 0x18 11441facaa4SMauro Carvalho Chehab #define EM28XX_R19_GOFFSET 0x19 11541facaa4SMauro Carvalho Chehab #define EM28XX_R1A_BOFFSET 0x1a 1162ba890ecSMauro Carvalho Chehab 11741facaa4SMauro Carvalho Chehab #define EM28XX_R1B_OFLOW 0x1b 11841facaa4SMauro Carvalho Chehab #define EM28XX_R1C_HSTART 0x1c 11941facaa4SMauro Carvalho Chehab #define EM28XX_R1D_VSTART 0x1d 12041facaa4SMauro Carvalho Chehab #define EM28XX_R1E_CWIDTH 0x1e 12141facaa4SMauro Carvalho Chehab #define EM28XX_R1F_CHEIGHT 0x1f 1222ba890ecSMauro Carvalho Chehab 12341facaa4SMauro Carvalho Chehab #define EM28XX_R20_YGAIN 0x20 12441facaa4SMauro Carvalho Chehab #define EM28XX_R21_YOFFSET 0x21 12541facaa4SMauro Carvalho Chehab #define EM28XX_R22_UVGAIN 0x22 12641facaa4SMauro Carvalho Chehab #define EM28XX_R23_UOFFSET 0x23 12741facaa4SMauro Carvalho Chehab #define EM28XX_R24_VOFFSET 0x24 12841facaa4SMauro Carvalho Chehab #define EM28XX_R25_SHARPNESS 0x25 1292ba890ecSMauro Carvalho Chehab 13041facaa4SMauro Carvalho Chehab #define EM28XX_R26_COMPR 0x26 13141facaa4SMauro Carvalho Chehab #define EM28XX_R27_OUTFMT 0x27 1322ba890ecSMauro Carvalho Chehab 1333fbf9309SDevin Heitmueller /* em28xx Output Format Register (0x27) */ 1343fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_RGB_8_RGRG 0x00 1353fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_RGB_8_GRGR 0x01 1363fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_RGB_8_GBGB 0x02 1373fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_RGB_8_BGBG 0x03 1383fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_RGB_16_656 0x04 1393fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_RGB_8_BAYER 0x08 /* Pattern in Reg 0x10[1-0] */ 1403fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_YUV211 0x10 1413fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_YUV422_Y0UY1V 0x14 1423fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_YUV422_Y1UY0V 0x15 1433fbf9309SDevin Heitmueller #define EM28XX_OUTFMT_YUV411 0x18 1443fbf9309SDevin Heitmueller 1453fbf9309SDevin Heitmueller 14641facaa4SMauro Carvalho Chehab #define EM28XX_R28_XMIN 0x28 14741facaa4SMauro Carvalho Chehab #define EM28XX_R29_XMAX 0x29 14841facaa4SMauro Carvalho Chehab #define EM28XX_R2A_YMIN 0x2a 14941facaa4SMauro Carvalho Chehab #define EM28XX_R2B_YMAX 0x2b 1502ba890ecSMauro Carvalho Chehab 15141facaa4SMauro Carvalho Chehab #define EM28XX_R30_HSCALELOW 0x30 15241facaa4SMauro Carvalho Chehab #define EM28XX_R31_HSCALEHIGH 0x31 15341facaa4SMauro Carvalho Chehab #define EM28XX_R32_VSCALELOW 0x32 15441facaa4SMauro Carvalho Chehab #define EM28XX_R33_VSCALEHIGH 0x33 155da52a55cSDevin Heitmueller #define EM28XX_R34_VBI_START_H 0x34 156da52a55cSDevin Heitmueller #define EM28XX_R35_VBI_START_V 0x35 157da52a55cSDevin Heitmueller #define EM28XX_R36_VBI_WIDTH 0x36 158da52a55cSDevin Heitmueller #define EM28XX_R37_VBI_HEIGHT 0x37 1592ba890ecSMauro Carvalho Chehab 16041facaa4SMauro Carvalho Chehab #define EM28XX_R40_AC97LSB 0x40 16141facaa4SMauro Carvalho Chehab #define EM28XX_R41_AC97MSB 0x41 16241facaa4SMauro Carvalho Chehab #define EM28XX_R42_AC97ADDR 0x42 16341facaa4SMauro Carvalho Chehab #define EM28XX_R43_AC97BUSY 0x43 1642ba890ecSMauro Carvalho Chehab 165a924a499SMauro Carvalho Chehab #define EM28XX_R45_IR 0x45 166a924a499SMauro Carvalho Chehab /* 0x45 bit 7 - parity bit 167a924a499SMauro Carvalho Chehab bits 6-0 - count 168a924a499SMauro Carvalho Chehab 0x46 IR brand 169a924a499SMauro Carvalho Chehab 0x47 IR data 170a924a499SMauro Carvalho Chehab */ 171a924a499SMauro Carvalho Chehab 1726a1acc3bSDevin Heitmueller /* em2874 registers */ 1734b92253aSDevin Heitmueller #define EM2874_R50_IR_CONFIG 0x50 1744b92253aSDevin Heitmueller #define EM2874_R51_IR 0x51 175ebef13d4SDevin Heitmueller #define EM2874_R5F_TS_ENABLE 0x5f 1766a1acc3bSDevin Heitmueller #define EM2874_R80_GPIO 0x80 1776a1acc3bSDevin Heitmueller 1784b92253aSDevin Heitmueller /* em2874 IR config register (0x50) */ 1794b92253aSDevin Heitmueller #define EM2874_IR_NEC 0x00 180105e3687SMauro Carvalho Chehab #define EM2874_IR_NEC_NO_PARITY 0x01 1814b92253aSDevin Heitmueller #define EM2874_IR_RC5 0x04 1825599678cSMauro Carvalho Chehab #define EM2874_IR_RC6_MODE_0 0x08 1835599678cSMauro Carvalho Chehab #define EM2874_IR_RC6_MODE_6A 0x0b 1844b92253aSDevin Heitmueller 185ebef13d4SDevin Heitmueller /* em2874 Transport Stream Enable Register (0x5f) */ 186ebef13d4SDevin Heitmueller #define EM2874_TS1_CAPTURE_ENABLE (1 << 0) 187ebef13d4SDevin Heitmueller #define EM2874_TS1_FILTER_ENABLE (1 << 1) 188ebef13d4SDevin Heitmueller #define EM2874_TS1_NULL_DISCARD (1 << 2) 189ebef13d4SDevin Heitmueller #define EM2874_TS2_CAPTURE_ENABLE (1 << 4) 190ebef13d4SDevin Heitmueller #define EM2874_TS2_FILTER_ENABLE (1 << 5) 191ebef13d4SDevin Heitmueller #define EM2874_TS2_NULL_DISCARD (1 << 6) 192ebef13d4SDevin Heitmueller 1932ba890ecSMauro Carvalho Chehab /* register settings */ 1942ba890ecSMauro Carvalho Chehab #define EM2800_AUDIO_SRC_TUNER 0x0d 1952ba890ecSMauro Carvalho Chehab #define EM2800_AUDIO_SRC_LINE 0x0c 1962ba890ecSMauro Carvalho Chehab #define EM28XX_AUDIO_SRC_TUNER 0xc0 1972ba890ecSMauro Carvalho Chehab #define EM28XX_AUDIO_SRC_LINE 0x80 1982ba890ecSMauro Carvalho Chehab 1992ba890ecSMauro Carvalho Chehab /* FIXME: Need to be populated with the other chip ID's */ 2002ba890ecSMauro Carvalho Chehab enum em28xx_chip_id { 201f57b17c3SMauro Carvalho Chehab CHIP_ID_EM2800 = 7, 202d594317bSMauro Carvalho Chehab CHIP_ID_EM2710 = 17, 203d594317bSMauro Carvalho Chehab CHIP_ID_EM2820 = 18, /* Also used by some em2710 */ 204f09fb530SMauro Carvalho Chehab CHIP_ID_EM2840 = 20, 20567c96f67SDevin Heitmueller CHIP_ID_EM2750 = 33, 206a8a1f8ccSDevin Heitmueller CHIP_ID_EM2860 = 34, 207b1fa26c6SDevin Heitmueller CHIP_ID_EM2870 = 35, 2082ba890ecSMauro Carvalho Chehab CHIP_ID_EM2883 = 36, 2095caeba04SDevin Heitmueller CHIP_ID_EM2874 = 65, 210fec528b7SMauro Carvalho Chehab CHIP_ID_EM2884 = 68, 211bc022694SAntti Palosaari CHIP_ID_EM28174 = 113, 2122ba890ecSMauro Carvalho Chehab }; 2136fbcebf0SMauro Carvalho Chehab 2146fbcebf0SMauro Carvalho Chehab /* 2159f98f7bbSEzequiel García * Registers used by em202 2166fbcebf0SMauro Carvalho Chehab */ 2176fbcebf0SMauro Carvalho Chehab 2186fbcebf0SMauro Carvalho Chehab /* EMP202 vendor registers */ 2196fbcebf0SMauro Carvalho Chehab #define EM202_EXT_MODEM_CTRL 0x3e 2206fbcebf0SMauro Carvalho Chehab #define EM202_GPIO_CONF 0x4c 2216fbcebf0SMauro Carvalho Chehab #define EM202_GPIO_POLARITY 0x4e 2226fbcebf0SMauro Carvalho Chehab #define EM202_GPIO_STICKY 0x50 2236fbcebf0SMauro Carvalho Chehab #define EM202_GPIO_MASK 0x52 2246fbcebf0SMauro Carvalho Chehab #define EM202_GPIO_STATUS 0x54 2256fbcebf0SMauro Carvalho Chehab #define EM202_SPDIF_OUT_SEL 0x6a 2266fbcebf0SMauro Carvalho Chehab #define EM202_ANTIPOP 0x72 2276fbcebf0SMauro Carvalho Chehab #define EM202_EAPD_GPIO_ACCESS 0x74 228