]>
Commit | Line | Data |
---|---|---|
6ac48b45 MCC |
1 | /* |
2 | * tvp5150 - Texas Instruments TVP5150A/AM1 video decoder registers | |
3 | * | |
4 | * Copyright (c) 2005,2006 Mauro Carvalho Chehab (mchehab@infradead.org) | |
5 | * This code is placed under the terms of the GNU General Public License v2 | |
6 | */ | |
7 | ||
cd4665c5 MCC |
8 | #define TVP5150_VD_IN_SRC_SEL_1 0x00 /* Video input source selection #1 */ |
9 | #define TVP5150_ANAL_CHL_CTL 0x01 /* Analog channel controls */ | |
10 | #define TVP5150_OP_MODE_CTL 0x02 /* Operation mode controls */ | |
11 | #define TVP5150_MISC_CTL 0x03 /* Miscellaneous controls */ | |
b4b2de38 LP |
12 | #define TVP5150_MISC_CTL_VBLK_GPCL BIT(7) |
13 | #define TVP5150_MISC_CTL_GPCL BIT(6) | |
14 | #define TVP5150_MISC_CTL_INTREQ_OE BIT(5) | |
15 | #define TVP5150_MISC_CTL_HVLK BIT(4) | |
16 | #define TVP5150_MISC_CTL_YCBCR_OE BIT(3) | |
17 | #define TVP5150_MISC_CTL_SYNC_OE BIT(2) | |
18 | #define TVP5150_MISC_CTL_VBLANK BIT(1) | |
19 | #define TVP5150_MISC_CTL_CLOCK_OE BIT(0) | |
20 | ||
cd4665c5 MCC |
21 | #define TVP5150_AUTOSW_MSK 0x04 /* Autoswitch mask: TVP5150A / TVP5150AM */ |
22 | ||
23 | /* Reserved 05h */ | |
24 | ||
25 | #define TVP5150_COLOR_KIL_THSH_CTL 0x06 /* Color killer threshold control */ | |
26 | #define TVP5150_LUMA_PROC_CTL_1 0x07 /* Luminance processing control #1 */ | |
27 | #define TVP5150_LUMA_PROC_CTL_2 0x08 /* Luminance processing control #2 */ | |
28 | #define TVP5150_BRIGHT_CTL 0x09 /* Brightness control */ | |
29 | #define TVP5150_SATURATION_CTL 0x0a /* Color saturation control */ | |
30 | #define TVP5150_HUE_CTL 0x0b /* Hue control */ | |
31 | #define TVP5150_CONTRAST_CTL 0x0c /* Contrast control */ | |
32 | #define TVP5150_DATA_RATE_SEL 0x0d /* Outputs and data rates select */ | |
33 | #define TVP5150_LUMA_PROC_CTL_3 0x0e /* Luminance processing control #3 */ | |
34 | #define TVP5150_CONF_SHARED_PIN 0x0f /* Configuration shared pins */ | |
35 | ||
36 | /* Reserved 10h */ | |
37 | ||
38 | #define TVP5150_ACT_VD_CROP_ST_MSB 0x11 /* Active video cropping start MSB */ | |
39 | #define TVP5150_ACT_VD_CROP_ST_LSB 0x12 /* Active video cropping start LSB */ | |
40 | #define TVP5150_ACT_VD_CROP_STP_MSB 0x13 /* Active video cropping stop MSB */ | |
41 | #define TVP5150_ACT_VD_CROP_STP_LSB 0x14 /* Active video cropping stop LSB */ | |
42 | #define TVP5150_GENLOCK 0x15 /* Genlock/RTC */ | |
43 | #define TVP5150_HORIZ_SYNC_START 0x16 /* Horizontal sync start */ | |
44 | ||
45 | /* Reserved 17h */ | |
46 | ||
47 | #define TVP5150_VERT_BLANKING_START 0x18 /* Vertical blanking start */ | |
48 | #define TVP5150_VERT_BLANKING_STOP 0x19 /* Vertical blanking stop */ | |
49 | #define TVP5150_CHROMA_PROC_CTL_1 0x1a /* Chrominance processing control #1 */ | |
50 | #define TVP5150_CHROMA_PROC_CTL_2 0x1b /* Chrominance processing control #2 */ | |
51 | #define TVP5150_INT_RESET_REG_B 0x1c /* Interrupt reset register B */ | |
52 | #define TVP5150_INT_ENABLE_REG_B 0x1d /* Interrupt enable register B */ | |
53 | #define TVP5150_INTT_CONFIG_REG_B 0x1e /* Interrupt configuration register B */ | |
54 | ||
55 | /* Reserved 1Fh-27h */ | |
56 | ||
64933337 JMC |
57 | #define VIDEO_STD_MASK (0x07 >> 1) |
58 | #define TVP5150_VIDEO_STD 0x28 /* Video standard */ | |
59 | #define VIDEO_STD_AUTO_SWITCH_BIT 0x00 | |
60 | #define VIDEO_STD_NTSC_MJ_BIT 0x02 | |
61 | #define VIDEO_STD_PAL_BDGHIN_BIT 0x04 | |
62 | #define VIDEO_STD_PAL_M_BIT 0x06 | |
63 | #define VIDEO_STD_PAL_COMBINATION_N_BIT 0x08 | |
64 | #define VIDEO_STD_NTSC_4_43_BIT 0x0a | |
65 | #define VIDEO_STD_SECAM_BIT 0x0c | |
66 | ||
67 | #define VIDEO_STD_NTSC_MJ_BIT_AS 0x01 | |
68 | #define VIDEO_STD_PAL_BDGHIN_BIT_AS 0x03 | |
69 | #define VIDEO_STD_PAL_M_BIT_AS 0x05 | |
70 | #define VIDEO_STD_PAL_COMBINATION_N_BIT_AS 0x07 | |
71 | #define VIDEO_STD_NTSC_4_43_BIT_AS 0x09 | |
72 | #define VIDEO_STD_SECAM_BIT_AS 0x0b | |
cd4665c5 MCC |
73 | |
74 | /* Reserved 29h-2bh */ | |
75 | ||
76 | #define TVP5150_CB_GAIN_FACT 0x2c /* Cb gain factor */ | |
77 | #define TVP5150_CR_GAIN_FACTOR 0x2d /* Cr gain factor */ | |
78 | #define TVP5150_MACROVISION_ON_CTR 0x2e /* Macrovision on counter */ | |
79 | #define TVP5150_MACROVISION_OFF_CTR 0x2f /* Macrovision off counter */ | |
80 | #define TVP5150_REV_SELECT 0x30 /* revision select (TVP5150AM1 only) */ | |
81 | ||
82 | /* Reserved 31h-7Fh */ | |
83 | ||
84 | #define TVP5150_MSB_DEV_ID 0x80 /* MSB of device ID */ | |
85 | #define TVP5150_LSB_DEV_ID 0x81 /* LSB of device ID */ | |
86 | #define TVP5150_ROM_MAJOR_VER 0x82 /* ROM major version */ | |
87 | #define TVP5150_ROM_MINOR_VER 0x83 /* ROM minor version */ | |
88 | #define TVP5150_VERT_LN_COUNT_MSB 0x84 /* Vertical line count MSB */ | |
89 | #define TVP5150_VERT_LN_COUNT_LSB 0x85 /* Vertical line count LSB */ | |
90 | #define TVP5150_INT_STATUS_REG_B 0x86 /* Interrupt status register B */ | |
91 | #define TVP5150_INT_ACTIVE_REG_B 0x87 /* Interrupt active register B */ | |
92 | #define TVP5150_STATUS_REG_1 0x88 /* Status register #1 */ | |
93 | #define TVP5150_STATUS_REG_2 0x89 /* Status register #2 */ | |
94 | #define TVP5150_STATUS_REG_3 0x8a /* Status register #3 */ | |
95 | #define TVP5150_STATUS_REG_4 0x8b /* Status register #4 */ | |
96 | #define TVP5150_STATUS_REG_5 0x8c /* Status register #5 */ | |
97 | /* Reserved 8Dh-8Fh */ | |
3ad96835 MCC |
98 | /* Closed caption data registers */ |
99 | #define TVP5150_CC_DATA_INI 0x90 | |
100 | #define TVP5150_CC_DATA_END 0x93 | |
101 | ||
102 | /* WSS data registers */ | |
103 | #define TVP5150_WSS_DATA_INI 0x94 | |
104 | #define TVP5150_WSS_DATA_END 0x99 | |
105 | ||
106 | /* VPS data registers */ | |
107 | #define TVP5150_VPS_DATA_INI 0x9a | |
108 | #define TVP5150_VPS_DATA_END 0xa6 | |
109 | ||
110 | /* VITC data registers */ | |
111 | #define TVP5150_VITC_DATA_INI 0xa7 | |
112 | #define TVP5150_VITC_DATA_END 0xaf | |
113 | ||
cd4665c5 | 114 | #define TVP5150_VBI_FIFO_READ_DATA 0xb0 /* VBI FIFO read data */ |
3ad96835 MCC |
115 | |
116 | /* Teletext filter 1 */ | |
117 | #define TVP5150_TELETEXT_FIL1_INI 0xb1 | |
118 | #define TVP5150_TELETEXT_FIL1_END 0xb5 | |
119 | ||
120 | /* Teletext filter 2 */ | |
121 | #define TVP5150_TELETEXT_FIL2_INI 0xb6 | |
122 | #define TVP5150_TELETEXT_FIL2_END 0xba | |
123 | ||
cd4665c5 MCC |
124 | #define TVP5150_TELETEXT_FIL_ENA 0xbb /* Teletext filter enable */ |
125 | /* Reserved BCh-BFh */ | |
126 | #define TVP5150_INT_STATUS_REG_A 0xc0 /* Interrupt status register A */ | |
127 | #define TVP5150_INT_ENABLE_REG_A 0xc1 /* Interrupt enable register A */ | |
128 | #define TVP5150_INT_CONF 0xc2 /* Interrupt configuration */ | |
129 | #define TVP5150_VDP_CONF_RAM_DATA 0xc3 /* VDP configuration RAM data */ | |
130 | #define TVP5150_CONF_RAM_ADDR_LOW 0xc4 /* Configuration RAM address low byte */ | |
131 | #define TVP5150_CONF_RAM_ADDR_HIGH 0xc5 /* Configuration RAM address high byte */ | |
132 | #define TVP5150_VDP_STATUS_REG 0xc6 /* VDP status register */ | |
133 | #define TVP5150_FIFO_WORD_COUNT 0xc7 /* FIFO word count */ | |
134 | #define TVP5150_FIFO_INT_THRESHOLD 0xc8 /* FIFO interrupt threshold */ | |
135 | #define TVP5150_FIFO_RESET 0xc9 /* FIFO reset */ | |
136 | #define TVP5150_LINE_NUMBER_INT 0xca /* Line number interrupt */ | |
137 | #define TVP5150_PIX_ALIGN_REG_LOW 0xcb /* Pixel alignment register low byte */ | |
138 | #define TVP5150_PIX_ALIGN_REG_HIGH 0xcc /* Pixel alignment register high byte */ | |
139 | #define TVP5150_FIFO_OUT_CTRL 0xcd /* FIFO output control */ | |
140 | /* Reserved CEh */ | |
3ad96835 MCC |
141 | #define TVP5150_FULL_FIELD_ENA 0xcf /* Full field enable 1 */ |
142 | ||
143 | /* Line mode registers */ | |
144 | #define TVP5150_LINE_MODE_INI 0xd0 | |
145 | #define TVP5150_LINE_MODE_END 0xfb | |
146 | ||
cd4665c5 MCC |
147 | #define TVP5150_FULL_FIELD_MODE_REG 0xfc /* Full field mode register */ |
148 | /* Reserved FDh-FFh */ |