1 /* SPDX-License-Identifier: GPL-2.0-or-later */
4 * cx25840.h - definition for cx25840/1/2/3 inputs
6 * Copyright (C) 2006 Hans Verkuil (hverkuil@xs4all.nl)
13 * Note that the cx25840 driver requires that the bridge driver calls the
14 * v4l2_subdev's load_fw operation in order to load the driver's firmware.
15 * This will load the firmware on the first invocation (further ones are NOP).
16 * Without this the audio standard detection will fail and you will
18 * Alternatively, you can call the reset operation (this can be done
19 * multiple times if needed, each invocation will fully reinitialize
22 * Since loading the firmware is often problematic when the driver is
23 * compiled into the kernel I recommend postponing calling this function
24 * until the first open of the video device. Another reason for
25 * postponing it is that loading this firmware takes a long time (seconds)
26 * due to the slow i2c bus speed. So it will speed up the boot process if
27 * you can avoid loading the fw as long as the video device isn't used.
30 enum cx25840_video_input
{
31 /* Composite video inputs In1-In8 */
32 CX25840_COMPOSITE1
= 1,
42 * S-Video inputs consist of one luma input (In1-In8) ORed with one
43 * chroma input (In5-In8)
45 CX25840_SVIDEO_LUMA1
= 0x10,
46 CX25840_SVIDEO_LUMA2
= 0x20,
47 CX25840_SVIDEO_LUMA3
= 0x30,
48 CX25840_SVIDEO_LUMA4
= 0x40,
49 CX25840_SVIDEO_LUMA5
= 0x50,
50 CX25840_SVIDEO_LUMA6
= 0x60,
51 CX25840_SVIDEO_LUMA7
= 0x70,
52 CX25840_SVIDEO_LUMA8
= 0x80,
53 CX25840_SVIDEO_CHROMA4
= 0x400,
54 CX25840_SVIDEO_CHROMA5
= 0x500,
55 CX25840_SVIDEO_CHROMA6
= 0x600,
56 CX25840_SVIDEO_CHROMA7
= 0x700,
57 CX25840_SVIDEO_CHROMA8
= 0x800,
59 /* S-Video aliases for common luma/chroma combinations */
60 CX25840_SVIDEO1
= 0x510,
61 CX25840_SVIDEO2
= 0x620,
62 CX25840_SVIDEO3
= 0x730,
63 CX25840_SVIDEO4
= 0x840,
65 /* Allow frames to specify specific input configurations */
66 CX25840_VIN1_CH1
= 0x80000000,
67 CX25840_VIN2_CH1
= 0x80000001,
68 CX25840_VIN3_CH1
= 0x80000002,
69 CX25840_VIN4_CH1
= 0x80000003,
70 CX25840_VIN5_CH1
= 0x80000004,
71 CX25840_VIN6_CH1
= 0x80000005,
72 CX25840_VIN7_CH1
= 0x80000006,
73 CX25840_VIN8_CH1
= 0x80000007,
74 CX25840_VIN4_CH2
= 0x80000000,
75 CX25840_VIN5_CH2
= 0x80000010,
76 CX25840_VIN6_CH2
= 0x80000020,
77 CX25840_NONE_CH2
= 0x80000030,
78 CX25840_VIN7_CH3
= 0x80000000,
79 CX25840_VIN8_CH3
= 0x80000040,
80 CX25840_NONE0_CH3
= 0x80000080,
81 CX25840_NONE1_CH3
= 0x800000c0,
82 CX25840_SVIDEO_ON
= 0x80000100,
83 CX25840_COMPONENT_ON
= 0x80000200,
84 CX25840_DIF_ON
= 0x80000400,
88 * The defines below are used to set the chip video output settings
89 * in the generic mode that can be enabled by calling the subdevice
92 * The requested settings can be passed to the init core op as
93 * @val parameter and to the s_routing video op as @config parameter.
95 * For details please refer to the section 3.7 Video Output Formatting and
96 * to Video Out Control 1 to 4 registers in the section 5.6 Video Decoder Core
97 * of the chip datasheet.
99 #define CX25840_VCONFIG_FMT_SHIFT 0
100 #define CX25840_VCONFIG_FMT_MASK GENMASK(2, 0)
101 #define CX25840_VCONFIG_FMT_BT601 BIT(0)
102 #define CX25840_VCONFIG_FMT_BT656 BIT(1)
103 #define CX25840_VCONFIG_FMT_VIP11 GENMASK(1, 0)
104 #define CX25840_VCONFIG_FMT_VIP2 BIT(2)
106 #define CX25840_VCONFIG_RES_SHIFT 3
107 #define CX25840_VCONFIG_RES_MASK GENMASK(4, 3)
108 #define CX25840_VCONFIG_RES_8BIT BIT(3)
109 #define CX25840_VCONFIG_RES_10BIT BIT(4)
111 #define CX25840_VCONFIG_VBIRAW_SHIFT 5
112 #define CX25840_VCONFIG_VBIRAW_MASK GENMASK(6, 5)
113 #define CX25840_VCONFIG_VBIRAW_DISABLED BIT(5)
114 #define CX25840_VCONFIG_VBIRAW_ENABLED BIT(6)
116 #define CX25840_VCONFIG_ANCDATA_SHIFT 7
117 #define CX25840_VCONFIG_ANCDATA_MASK GENMASK(8, 7)
118 #define CX25840_VCONFIG_ANCDATA_DISABLED BIT(7)
119 #define CX25840_VCONFIG_ANCDATA_ENABLED BIT(8)
121 #define CX25840_VCONFIG_TASKBIT_SHIFT 9
122 #define CX25840_VCONFIG_TASKBIT_MASK GENMASK(10, 9)
123 #define CX25840_VCONFIG_TASKBIT_ZERO BIT(9)
124 #define CX25840_VCONFIG_TASKBIT_ONE BIT(10)
126 #define CX25840_VCONFIG_ACTIVE_SHIFT 11
127 #define CX25840_VCONFIG_ACTIVE_MASK GENMASK(12, 11)
128 #define CX25840_VCONFIG_ACTIVE_COMPOSITE BIT(11)
129 #define CX25840_VCONFIG_ACTIVE_HORIZONTAL BIT(12)
131 #define CX25840_VCONFIG_VALID_SHIFT 13
132 #define CX25840_VCONFIG_VALID_MASK GENMASK(14, 13)
133 #define CX25840_VCONFIG_VALID_NORMAL BIT(13)
134 #define CX25840_VCONFIG_VALID_ANDACTIVE BIT(14)
136 #define CX25840_VCONFIG_HRESETW_SHIFT 15
137 #define CX25840_VCONFIG_HRESETW_MASK GENMASK(16, 15)
138 #define CX25840_VCONFIG_HRESETW_NORMAL BIT(15)
139 #define CX25840_VCONFIG_HRESETW_PIXCLK BIT(16)
141 #define CX25840_VCONFIG_CLKGATE_SHIFT 17
142 #define CX25840_VCONFIG_CLKGATE_MASK GENMASK(18, 17)
143 #define CX25840_VCONFIG_CLKGATE_NONE BIT(17)
144 #define CX25840_VCONFIG_CLKGATE_VALID BIT(18)
145 #define CX25840_VCONFIG_CLKGATE_VALIDACTIVE GENMASK(18, 17)
147 #define CX25840_VCONFIG_DCMODE_SHIFT 19
148 #define CX25840_VCONFIG_DCMODE_MASK GENMASK(20, 19)
149 #define CX25840_VCONFIG_DCMODE_DWORDS BIT(19)
150 #define CX25840_VCONFIG_DCMODE_BYTES BIT(20)
152 #define CX25840_VCONFIG_IDID0S_SHIFT 21
153 #define CX25840_VCONFIG_IDID0S_MASK GENMASK(22, 21)
154 #define CX25840_VCONFIG_IDID0S_NORMAL BIT(21)
155 #define CX25840_VCONFIG_IDID0S_LINECNT BIT(22)
157 #define CX25840_VCONFIG_VIPCLAMP_SHIFT 23
158 #define CX25840_VCONFIG_VIPCLAMP_MASK GENMASK(24, 23)
159 #define CX25840_VCONFIG_VIPCLAMP_ENABLED BIT(23)
160 #define CX25840_VCONFIG_VIPCLAMP_DISABLED BIT(24)
162 enum cx25840_audio_input
{
163 /* Audio inputs: serial or In4-In8 */
164 CX25840_AUDIO_SERIAL
,
172 enum cx25840_io_pin
{
173 CX25840_PIN_DVALID_PRGM0
= 0,
174 CX25840_PIN_FIELD_PRGM1
,
175 CX25840_PIN_HRESET_PRGM2
,
176 CX25840_PIN_VRESET_HCTL_PRGM3
,
177 CX25840_PIN_IRQ_N_PRGM4
,
178 CX25840_PIN_IR_TX_PRGM6
,
179 CX25840_PIN_IR_RX_PRGM5
,
180 CX25840_PIN_GPIO0_PRGM8
,
181 CX25840_PIN_GPIO1_PRGM9
,
182 CX25840_PIN_SA_SDIN
, /* Alternate GP Input only */
183 CX25840_PIN_SA_SDOUT
, /* Alternate GP Input only */
184 CX25840_PIN_PLL_CLK_PRGM7
,
185 CX25840_PIN_CHIP_SEL_VIPCLK
, /* Output only */
188 enum cx25840_io_pad
{
189 /* Output pads, these must match the actual chip register values */
190 CX25840_PAD_DEFAULT
= 0,
194 CX25840_PAD_VID_DATA_EXT0
,
195 CX25840_PAD_VID_DATA_EXT1
,
202 CX25840_PAD_AC_SDOUT
,
205 CX25840_PAD_RESERVED
,
206 /* Pads for PLL_CLK output only */
207 CX25840_PAD_XTI_X5_DLL
,
218 enum cx25840_io_pin_strength
{
219 CX25840_PIN_DRIVE_MEDIUM
= 0,
220 CX25840_PIN_DRIVE_SLOW
,
221 CX25840_PIN_DRIVE_FAST
,
224 enum cx23885_io_pin
{
225 CX23885_PIN_IR_RX_GPIO19
,
226 CX23885_PIN_IR_TX_GPIO20
,
227 CX23885_PIN_I2S_SDAT_GPIO21
,
228 CX23885_PIN_I2S_WCLK_GPIO22
,
229 CX23885_PIN_I2S_BCLK_GPIO23
,
230 CX23885_PIN_IRQ_N_GPIO16
,
233 enum cx23885_io_pad
{
238 CX23885_PAD_I2S_SDAT
,
240 CX23885_PAD_I2S_WCLK
,
242 CX23885_PAD_I2S_BCLK
,
249 * pvr150_workaround activates a workaround for a hardware bug that is
250 * present in Hauppauge PVR-150 (and possibly PVR-500) cards that have
251 * certain NTSC tuners (tveeprom tuner model numbers 85, 99 and 112). The
252 * audio autodetect fails on some channels for these models and the workaround
253 * is to select the audio standard explicitly. Many thanks to Hauppauge for
254 * providing this information.
256 * This platform data only needs to be supplied by the ivtv driver.
258 struct cx25840_platform_data
{
259 int pvr150_workaround
;