mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-07 05:04:04 +08:00
b4b2de386b
The FID/GLCO/VLK/HVLK and INTREQ/GPCL/VBLK pins are muxed differently depending on whether the input is an S-Video or composite signal. The comment that explains the logic doesn't reflect the code. It appears that the comment is incorrect, as disabling the output data bus in composite mode makes no sense. Update the comment to match the code. While at it define macros for the MISC_CTL register bits, the code is too confusing with numerical values. Cc: stable@vger.kernel.org # For Kernel 4.5 and upper Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
149 lines
6.7 KiB
C
149 lines
6.7 KiB
C
/*
|
|
* tvp5150 - Texas Instruments TVP5150A/AM1 video decoder registers
|
|
*
|
|
* Copyright (c) 2005,2006 Mauro Carvalho Chehab (mchehab@infradead.org)
|
|
* This code is placed under the terms of the GNU General Public License v2
|
|
*/
|
|
|
|
#define TVP5150_VD_IN_SRC_SEL_1 0x00 /* Video input source selection #1 */
|
|
#define TVP5150_ANAL_CHL_CTL 0x01 /* Analog channel controls */
|
|
#define TVP5150_OP_MODE_CTL 0x02 /* Operation mode controls */
|
|
#define TVP5150_MISC_CTL 0x03 /* Miscellaneous controls */
|
|
#define TVP5150_MISC_CTL_VBLK_GPCL BIT(7)
|
|
#define TVP5150_MISC_CTL_GPCL BIT(6)
|
|
#define TVP5150_MISC_CTL_INTREQ_OE BIT(5)
|
|
#define TVP5150_MISC_CTL_HVLK BIT(4)
|
|
#define TVP5150_MISC_CTL_YCBCR_OE BIT(3)
|
|
#define TVP5150_MISC_CTL_SYNC_OE BIT(2)
|
|
#define TVP5150_MISC_CTL_VBLANK BIT(1)
|
|
#define TVP5150_MISC_CTL_CLOCK_OE BIT(0)
|
|
|
|
#define TVP5150_AUTOSW_MSK 0x04 /* Autoswitch mask: TVP5150A / TVP5150AM */
|
|
|
|
/* Reserved 05h */
|
|
|
|
#define TVP5150_COLOR_KIL_THSH_CTL 0x06 /* Color killer threshold control */
|
|
#define TVP5150_LUMA_PROC_CTL_1 0x07 /* Luminance processing control #1 */
|
|
#define TVP5150_LUMA_PROC_CTL_2 0x08 /* Luminance processing control #2 */
|
|
#define TVP5150_BRIGHT_CTL 0x09 /* Brightness control */
|
|
#define TVP5150_SATURATION_CTL 0x0a /* Color saturation control */
|
|
#define TVP5150_HUE_CTL 0x0b /* Hue control */
|
|
#define TVP5150_CONTRAST_CTL 0x0c /* Contrast control */
|
|
#define TVP5150_DATA_RATE_SEL 0x0d /* Outputs and data rates select */
|
|
#define TVP5150_LUMA_PROC_CTL_3 0x0e /* Luminance processing control #3 */
|
|
#define TVP5150_CONF_SHARED_PIN 0x0f /* Configuration shared pins */
|
|
|
|
/* Reserved 10h */
|
|
|
|
#define TVP5150_ACT_VD_CROP_ST_MSB 0x11 /* Active video cropping start MSB */
|
|
#define TVP5150_ACT_VD_CROP_ST_LSB 0x12 /* Active video cropping start LSB */
|
|
#define TVP5150_ACT_VD_CROP_STP_MSB 0x13 /* Active video cropping stop MSB */
|
|
#define TVP5150_ACT_VD_CROP_STP_LSB 0x14 /* Active video cropping stop LSB */
|
|
#define TVP5150_GENLOCK 0x15 /* Genlock/RTC */
|
|
#define TVP5150_HORIZ_SYNC_START 0x16 /* Horizontal sync start */
|
|
|
|
/* Reserved 17h */
|
|
|
|
#define TVP5150_VERT_BLANKING_START 0x18 /* Vertical blanking start */
|
|
#define TVP5150_VERT_BLANKING_STOP 0x19 /* Vertical blanking stop */
|
|
#define TVP5150_CHROMA_PROC_CTL_1 0x1a /* Chrominance processing control #1 */
|
|
#define TVP5150_CHROMA_PROC_CTL_2 0x1b /* Chrominance processing control #2 */
|
|
#define TVP5150_INT_RESET_REG_B 0x1c /* Interrupt reset register B */
|
|
#define TVP5150_INT_ENABLE_REG_B 0x1d /* Interrupt enable register B */
|
|
#define TVP5150_INTT_CONFIG_REG_B 0x1e /* Interrupt configuration register B */
|
|
|
|
/* Reserved 1Fh-27h */
|
|
|
|
#define VIDEO_STD_MASK (0x07 >> 1)
|
|
#define TVP5150_VIDEO_STD 0x28 /* Video standard */
|
|
#define VIDEO_STD_AUTO_SWITCH_BIT 0x00
|
|
#define VIDEO_STD_NTSC_MJ_BIT 0x02
|
|
#define VIDEO_STD_PAL_BDGHIN_BIT 0x04
|
|
#define VIDEO_STD_PAL_M_BIT 0x06
|
|
#define VIDEO_STD_PAL_COMBINATION_N_BIT 0x08
|
|
#define VIDEO_STD_NTSC_4_43_BIT 0x0a
|
|
#define VIDEO_STD_SECAM_BIT 0x0c
|
|
|
|
#define VIDEO_STD_NTSC_MJ_BIT_AS 0x01
|
|
#define VIDEO_STD_PAL_BDGHIN_BIT_AS 0x03
|
|
#define VIDEO_STD_PAL_M_BIT_AS 0x05
|
|
#define VIDEO_STD_PAL_COMBINATION_N_BIT_AS 0x07
|
|
#define VIDEO_STD_NTSC_4_43_BIT_AS 0x09
|
|
#define VIDEO_STD_SECAM_BIT_AS 0x0b
|
|
|
|
/* Reserved 29h-2bh */
|
|
|
|
#define TVP5150_CB_GAIN_FACT 0x2c /* Cb gain factor */
|
|
#define TVP5150_CR_GAIN_FACTOR 0x2d /* Cr gain factor */
|
|
#define TVP5150_MACROVISION_ON_CTR 0x2e /* Macrovision on counter */
|
|
#define TVP5150_MACROVISION_OFF_CTR 0x2f /* Macrovision off counter */
|
|
#define TVP5150_REV_SELECT 0x30 /* revision select (TVP5150AM1 only) */
|
|
|
|
/* Reserved 31h-7Fh */
|
|
|
|
#define TVP5150_MSB_DEV_ID 0x80 /* MSB of device ID */
|
|
#define TVP5150_LSB_DEV_ID 0x81 /* LSB of device ID */
|
|
#define TVP5150_ROM_MAJOR_VER 0x82 /* ROM major version */
|
|
#define TVP5150_ROM_MINOR_VER 0x83 /* ROM minor version */
|
|
#define TVP5150_VERT_LN_COUNT_MSB 0x84 /* Vertical line count MSB */
|
|
#define TVP5150_VERT_LN_COUNT_LSB 0x85 /* Vertical line count LSB */
|
|
#define TVP5150_INT_STATUS_REG_B 0x86 /* Interrupt status register B */
|
|
#define TVP5150_INT_ACTIVE_REG_B 0x87 /* Interrupt active register B */
|
|
#define TVP5150_STATUS_REG_1 0x88 /* Status register #1 */
|
|
#define TVP5150_STATUS_REG_2 0x89 /* Status register #2 */
|
|
#define TVP5150_STATUS_REG_3 0x8a /* Status register #3 */
|
|
#define TVP5150_STATUS_REG_4 0x8b /* Status register #4 */
|
|
#define TVP5150_STATUS_REG_5 0x8c /* Status register #5 */
|
|
/* Reserved 8Dh-8Fh */
|
|
/* Closed caption data registers */
|
|
#define TVP5150_CC_DATA_INI 0x90
|
|
#define TVP5150_CC_DATA_END 0x93
|
|
|
|
/* WSS data registers */
|
|
#define TVP5150_WSS_DATA_INI 0x94
|
|
#define TVP5150_WSS_DATA_END 0x99
|
|
|
|
/* VPS data registers */
|
|
#define TVP5150_VPS_DATA_INI 0x9a
|
|
#define TVP5150_VPS_DATA_END 0xa6
|
|
|
|
/* VITC data registers */
|
|
#define TVP5150_VITC_DATA_INI 0xa7
|
|
#define TVP5150_VITC_DATA_END 0xaf
|
|
|
|
#define TVP5150_VBI_FIFO_READ_DATA 0xb0 /* VBI FIFO read data */
|
|
|
|
/* Teletext filter 1 */
|
|
#define TVP5150_TELETEXT_FIL1_INI 0xb1
|
|
#define TVP5150_TELETEXT_FIL1_END 0xb5
|
|
|
|
/* Teletext filter 2 */
|
|
#define TVP5150_TELETEXT_FIL2_INI 0xb6
|
|
#define TVP5150_TELETEXT_FIL2_END 0xba
|
|
|
|
#define TVP5150_TELETEXT_FIL_ENA 0xbb /* Teletext filter enable */
|
|
/* Reserved BCh-BFh */
|
|
#define TVP5150_INT_STATUS_REG_A 0xc0 /* Interrupt status register A */
|
|
#define TVP5150_INT_ENABLE_REG_A 0xc1 /* Interrupt enable register A */
|
|
#define TVP5150_INT_CONF 0xc2 /* Interrupt configuration */
|
|
#define TVP5150_VDP_CONF_RAM_DATA 0xc3 /* VDP configuration RAM data */
|
|
#define TVP5150_CONF_RAM_ADDR_LOW 0xc4 /* Configuration RAM address low byte */
|
|
#define TVP5150_CONF_RAM_ADDR_HIGH 0xc5 /* Configuration RAM address high byte */
|
|
#define TVP5150_VDP_STATUS_REG 0xc6 /* VDP status register */
|
|
#define TVP5150_FIFO_WORD_COUNT 0xc7 /* FIFO word count */
|
|
#define TVP5150_FIFO_INT_THRESHOLD 0xc8 /* FIFO interrupt threshold */
|
|
#define TVP5150_FIFO_RESET 0xc9 /* FIFO reset */
|
|
#define TVP5150_LINE_NUMBER_INT 0xca /* Line number interrupt */
|
|
#define TVP5150_PIX_ALIGN_REG_LOW 0xcb /* Pixel alignment register low byte */
|
|
#define TVP5150_PIX_ALIGN_REG_HIGH 0xcc /* Pixel alignment register high byte */
|
|
#define TVP5150_FIFO_OUT_CTRL 0xcd /* FIFO output control */
|
|
/* Reserved CEh */
|
|
#define TVP5150_FULL_FIELD_ENA 0xcf /* Full field enable 1 */
|
|
|
|
/* Line mode registers */
|
|
#define TVP5150_LINE_MODE_INI 0xd0
|
|
#define TVP5150_LINE_MODE_END 0xfb
|
|
|
|
#define TVP5150_FULL_FIELD_MODE_REG 0xfc /* Full field mode register */
|
|
/* Reserved FDh-FFh */
|