xref: /openbmc/linux/drivers/media/pci/cx25821/cx25821-core.c (revision 7f2e85840871f199057e65232ebde846192ed989)
1 /*
2  *  Driver for the Conexant CX25821 PCIe bridge
3  *
4  *  Copyright (C) 2009 Conexant Systems Inc.
5  *  Authors  <shu.lin@conexant.com>, <hiep.huynh@conexant.com>
6  *  Based on Steven Toth <stoth@linuxtv.org> cx23885 driver
7  *
8  *  This program is free software; you can redistribute it and/or modify
9  *  it under the terms of the GNU General Public License as published by
10  *  the Free Software Foundation; either version 2 of the License, or
11  *  (at your option) any later version.
12  *
13  *  This program is distributed in the hope that it will be useful,
14  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
15  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  *
17  *  GNU General Public License for more details.
18  */
19 
20 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
21 
22 #include <linux/i2c.h>
23 #include <linux/slab.h>
24 #include "cx25821.h"
25 #include "cx25821-sram.h"
26 #include "cx25821-video.h"
27 
28 MODULE_DESCRIPTION("Driver for Athena cards");
29 MODULE_AUTHOR("Shu Lin - Hiep Huynh");
30 MODULE_LICENSE("GPL");
31 
32 static unsigned int debug;
33 module_param(debug, int, 0644);
34 MODULE_PARM_DESC(debug, "enable debug messages");
35 
36 static unsigned int card[] = {[0 ... (CX25821_MAXBOARDS - 1)] = UNSET };
37 module_param_array(card, int, NULL, 0444);
38 MODULE_PARM_DESC(card, "card type");
39 
40 const struct sram_channel cx25821_sram_channels[] = {
41 	[SRAM_CH00] = {
42 		.i = SRAM_CH00,
43 		.name = "VID A",
44 		.cmds_start = VID_A_DOWN_CMDS,
45 		.ctrl_start = VID_A_IQ,
46 		.cdt = VID_A_CDT,
47 		.fifo_start = VID_A_DOWN_CLUSTER_1,
48 		.fifo_size = (VID_CLUSTER_SIZE << 2),
49 		.ptr1_reg = DMA1_PTR1,
50 		.ptr2_reg = DMA1_PTR2,
51 		.cnt1_reg = DMA1_CNT1,
52 		.cnt2_reg = DMA1_CNT2,
53 		.int_msk = VID_A_INT_MSK,
54 		.int_stat = VID_A_INT_STAT,
55 		.int_mstat = VID_A_INT_MSTAT,
56 		.dma_ctl = VID_DST_A_DMA_CTL,
57 		.gpcnt_ctl = VID_DST_A_GPCNT_CTL,
58 		.gpcnt = VID_DST_A_GPCNT,
59 		.vip_ctl = VID_DST_A_VIP_CTL,
60 		.pix_frmt = VID_DST_A_PIX_FRMT,
61 	},
62 
63 	[SRAM_CH01] = {
64 		.i = SRAM_CH01,
65 		.name = "VID B",
66 		.cmds_start = VID_B_DOWN_CMDS,
67 		.ctrl_start = VID_B_IQ,
68 		.cdt = VID_B_CDT,
69 		.fifo_start = VID_B_DOWN_CLUSTER_1,
70 		.fifo_size = (VID_CLUSTER_SIZE << 2),
71 		.ptr1_reg = DMA2_PTR1,
72 		.ptr2_reg = DMA2_PTR2,
73 		.cnt1_reg = DMA2_CNT1,
74 		.cnt2_reg = DMA2_CNT2,
75 		.int_msk = VID_B_INT_MSK,
76 		.int_stat = VID_B_INT_STAT,
77 		.int_mstat = VID_B_INT_MSTAT,
78 		.dma_ctl = VID_DST_B_DMA_CTL,
79 		.gpcnt_ctl = VID_DST_B_GPCNT_CTL,
80 		.gpcnt = VID_DST_B_GPCNT,
81 		.vip_ctl = VID_DST_B_VIP_CTL,
82 		.pix_frmt = VID_DST_B_PIX_FRMT,
83 	},
84 
85 	[SRAM_CH02] = {
86 		.i = SRAM_CH02,
87 		.name = "VID C",
88 		.cmds_start = VID_C_DOWN_CMDS,
89 		.ctrl_start = VID_C_IQ,
90 		.cdt = VID_C_CDT,
91 		.fifo_start = VID_C_DOWN_CLUSTER_1,
92 		.fifo_size = (VID_CLUSTER_SIZE << 2),
93 		.ptr1_reg = DMA3_PTR1,
94 		.ptr2_reg = DMA3_PTR2,
95 		.cnt1_reg = DMA3_CNT1,
96 		.cnt2_reg = DMA3_CNT2,
97 		.int_msk = VID_C_INT_MSK,
98 		.int_stat = VID_C_INT_STAT,
99 		.int_mstat = VID_C_INT_MSTAT,
100 		.dma_ctl = VID_DST_C_DMA_CTL,
101 		.gpcnt_ctl = VID_DST_C_GPCNT_CTL,
102 		.gpcnt = VID_DST_C_GPCNT,
103 		.vip_ctl = VID_DST_C_VIP_CTL,
104 		.pix_frmt = VID_DST_C_PIX_FRMT,
105 	},
106 
107 	[SRAM_CH03] = {
108 		.i = SRAM_CH03,
109 		.name = "VID D",
110 		.cmds_start = VID_D_DOWN_CMDS,
111 		.ctrl_start = VID_D_IQ,
112 		.cdt = VID_D_CDT,
113 		.fifo_start = VID_D_DOWN_CLUSTER_1,
114 		.fifo_size = (VID_CLUSTER_SIZE << 2),
115 		.ptr1_reg = DMA4_PTR1,
116 		.ptr2_reg = DMA4_PTR2,
117 		.cnt1_reg = DMA4_CNT1,
118 		.cnt2_reg = DMA4_CNT2,
119 		.int_msk = VID_D_INT_MSK,
120 		.int_stat = VID_D_INT_STAT,
121 		.int_mstat = VID_D_INT_MSTAT,
122 		.dma_ctl = VID_DST_D_DMA_CTL,
123 		.gpcnt_ctl = VID_DST_D_GPCNT_CTL,
124 		.gpcnt = VID_DST_D_GPCNT,
125 		.vip_ctl = VID_DST_D_VIP_CTL,
126 		.pix_frmt = VID_DST_D_PIX_FRMT,
127 	},
128 
129 	[SRAM_CH04] = {
130 		.i = SRAM_CH04,
131 		.name = "VID E",
132 		.cmds_start = VID_E_DOWN_CMDS,
133 		.ctrl_start = VID_E_IQ,
134 		.cdt = VID_E_CDT,
135 		.fifo_start = VID_E_DOWN_CLUSTER_1,
136 		.fifo_size = (VID_CLUSTER_SIZE << 2),
137 		.ptr1_reg = DMA5_PTR1,
138 		.ptr2_reg = DMA5_PTR2,
139 		.cnt1_reg = DMA5_CNT1,
140 		.cnt2_reg = DMA5_CNT2,
141 		.int_msk = VID_E_INT_MSK,
142 		.int_stat = VID_E_INT_STAT,
143 		.int_mstat = VID_E_INT_MSTAT,
144 		.dma_ctl = VID_DST_E_DMA_CTL,
145 		.gpcnt_ctl = VID_DST_E_GPCNT_CTL,
146 		.gpcnt = VID_DST_E_GPCNT,
147 		.vip_ctl = VID_DST_E_VIP_CTL,
148 		.pix_frmt = VID_DST_E_PIX_FRMT,
149 	},
150 
151 	[SRAM_CH05] = {
152 		.i = SRAM_CH05,
153 		.name = "VID F",
154 		.cmds_start = VID_F_DOWN_CMDS,
155 		.ctrl_start = VID_F_IQ,
156 		.cdt = VID_F_CDT,
157 		.fifo_start = VID_F_DOWN_CLUSTER_1,
158 		.fifo_size = (VID_CLUSTER_SIZE << 2),
159 		.ptr1_reg = DMA6_PTR1,
160 		.ptr2_reg = DMA6_PTR2,
161 		.cnt1_reg = DMA6_CNT1,
162 		.cnt2_reg = DMA6_CNT2,
163 		.int_msk = VID_F_INT_MSK,
164 		.int_stat = VID_F_INT_STAT,
165 		.int_mstat = VID_F_INT_MSTAT,
166 		.dma_ctl = VID_DST_F_DMA_CTL,
167 		.gpcnt_ctl = VID_DST_F_GPCNT_CTL,
168 		.gpcnt = VID_DST_F_GPCNT,
169 		.vip_ctl = VID_DST_F_VIP_CTL,
170 		.pix_frmt = VID_DST_F_PIX_FRMT,
171 	},
172 
173 	[SRAM_CH06] = {
174 		.i = SRAM_CH06,
175 		.name = "VID G",
176 		.cmds_start = VID_G_DOWN_CMDS,
177 		.ctrl_start = VID_G_IQ,
178 		.cdt = VID_G_CDT,
179 		.fifo_start = VID_G_DOWN_CLUSTER_1,
180 		.fifo_size = (VID_CLUSTER_SIZE << 2),
181 		.ptr1_reg = DMA7_PTR1,
182 		.ptr2_reg = DMA7_PTR2,
183 		.cnt1_reg = DMA7_CNT1,
184 		.cnt2_reg = DMA7_CNT2,
185 		.int_msk = VID_G_INT_MSK,
186 		.int_stat = VID_G_INT_STAT,
187 		.int_mstat = VID_G_INT_MSTAT,
188 		.dma_ctl = VID_DST_G_DMA_CTL,
189 		.gpcnt_ctl = VID_DST_G_GPCNT_CTL,
190 		.gpcnt = VID_DST_G_GPCNT,
191 		.vip_ctl = VID_DST_G_VIP_CTL,
192 		.pix_frmt = VID_DST_G_PIX_FRMT,
193 	},
194 
195 	[SRAM_CH07] = {
196 		.i = SRAM_CH07,
197 		.name = "VID H",
198 		.cmds_start = VID_H_DOWN_CMDS,
199 		.ctrl_start = VID_H_IQ,
200 		.cdt = VID_H_CDT,
201 		.fifo_start = VID_H_DOWN_CLUSTER_1,
202 		.fifo_size = (VID_CLUSTER_SIZE << 2),
203 		.ptr1_reg = DMA8_PTR1,
204 		.ptr2_reg = DMA8_PTR2,
205 		.cnt1_reg = DMA8_CNT1,
206 		.cnt2_reg = DMA8_CNT2,
207 		.int_msk = VID_H_INT_MSK,
208 		.int_stat = VID_H_INT_STAT,
209 		.int_mstat = VID_H_INT_MSTAT,
210 		.dma_ctl = VID_DST_H_DMA_CTL,
211 		.gpcnt_ctl = VID_DST_H_GPCNT_CTL,
212 		.gpcnt = VID_DST_H_GPCNT,
213 		.vip_ctl = VID_DST_H_VIP_CTL,
214 		.pix_frmt = VID_DST_H_PIX_FRMT,
215 	},
216 
217 	[SRAM_CH08] = {
218 		.name = "audio from",
219 		.cmds_start = AUD_A_DOWN_CMDS,
220 		.ctrl_start = AUD_A_IQ,
221 		.cdt = AUD_A_CDT,
222 		.fifo_start = AUD_A_DOWN_CLUSTER_1,
223 		.fifo_size = AUDIO_CLUSTER_SIZE * 3,
224 		.ptr1_reg = DMA17_PTR1,
225 		.ptr2_reg = DMA17_PTR2,
226 		.cnt1_reg = DMA17_CNT1,
227 		.cnt2_reg = DMA17_CNT2,
228 	},
229 
230 	[SRAM_CH09] = {
231 		.i = SRAM_CH09,
232 		.name = "VID Upstream I",
233 		.cmds_start = VID_I_UP_CMDS,
234 		.ctrl_start = VID_I_IQ,
235 		.cdt = VID_I_CDT,
236 		.fifo_start = VID_I_UP_CLUSTER_1,
237 		.fifo_size = (VID_CLUSTER_SIZE << 2),
238 		.ptr1_reg = DMA15_PTR1,
239 		.ptr2_reg = DMA15_PTR2,
240 		.cnt1_reg = DMA15_CNT1,
241 		.cnt2_reg = DMA15_CNT2,
242 		.int_msk = VID_I_INT_MSK,
243 		.int_stat = VID_I_INT_STAT,
244 		.int_mstat = VID_I_INT_MSTAT,
245 		.dma_ctl = VID_SRC_I_DMA_CTL,
246 		.gpcnt_ctl = VID_SRC_I_GPCNT_CTL,
247 		.gpcnt = VID_SRC_I_GPCNT,
248 
249 		.vid_fmt_ctl = VID_SRC_I_FMT_CTL,
250 		.vid_active_ctl1 = VID_SRC_I_ACTIVE_CTL1,
251 		.vid_active_ctl2 = VID_SRC_I_ACTIVE_CTL2,
252 		.vid_cdt_size = VID_SRC_I_CDT_SZ,
253 		.irq_bit = 8,
254 	},
255 
256 	[SRAM_CH10] = {
257 		.i = SRAM_CH10,
258 		.name = "VID Upstream J",
259 		.cmds_start = VID_J_UP_CMDS,
260 		.ctrl_start = VID_J_IQ,
261 		.cdt = VID_J_CDT,
262 		.fifo_start = VID_J_UP_CLUSTER_1,
263 		.fifo_size = (VID_CLUSTER_SIZE << 2),
264 		.ptr1_reg = DMA16_PTR1,
265 		.ptr2_reg = DMA16_PTR2,
266 		.cnt1_reg = DMA16_CNT1,
267 		.cnt2_reg = DMA16_CNT2,
268 		.int_msk = VID_J_INT_MSK,
269 		.int_stat = VID_J_INT_STAT,
270 		.int_mstat = VID_J_INT_MSTAT,
271 		.dma_ctl = VID_SRC_J_DMA_CTL,
272 		.gpcnt_ctl = VID_SRC_J_GPCNT_CTL,
273 		.gpcnt = VID_SRC_J_GPCNT,
274 
275 		.vid_fmt_ctl = VID_SRC_J_FMT_CTL,
276 		.vid_active_ctl1 = VID_SRC_J_ACTIVE_CTL1,
277 		.vid_active_ctl2 = VID_SRC_J_ACTIVE_CTL2,
278 		.vid_cdt_size = VID_SRC_J_CDT_SZ,
279 		.irq_bit = 9,
280 	},
281 
282 	[SRAM_CH11] = {
283 		.i = SRAM_CH11,
284 		.name = "Audio Upstream Channel B",
285 		.cmds_start = AUD_B_UP_CMDS,
286 		.ctrl_start = AUD_B_IQ,
287 		.cdt = AUD_B_CDT,
288 		.fifo_start = AUD_B_UP_CLUSTER_1,
289 		.fifo_size = (AUDIO_CLUSTER_SIZE * 3),
290 		.ptr1_reg = DMA22_PTR1,
291 		.ptr2_reg = DMA22_PTR2,
292 		.cnt1_reg = DMA22_CNT1,
293 		.cnt2_reg = DMA22_CNT2,
294 		.int_msk = AUD_B_INT_MSK,
295 		.int_stat = AUD_B_INT_STAT,
296 		.int_mstat = AUD_B_INT_MSTAT,
297 		.dma_ctl = AUD_INT_DMA_CTL,
298 		.gpcnt_ctl = AUD_B_GPCNT_CTL,
299 		.gpcnt = AUD_B_GPCNT,
300 		.aud_length = AUD_B_LNGTH,
301 		.aud_cfg = AUD_B_CFG,
302 		.fld_aud_fifo_en = FLD_AUD_SRC_B_FIFO_EN,
303 		.fld_aud_risc_en = FLD_AUD_SRC_B_RISC_EN,
304 		.irq_bit = 11,
305 	},
306 };
307 EXPORT_SYMBOL(cx25821_sram_channels);
308 
309 static int cx25821_risc_decode(u32 risc)
310 {
311 	static const char * const instr[16] = {
312 		[RISC_SYNC >> 28] = "sync",
313 		[RISC_WRITE >> 28] = "write",
314 		[RISC_WRITEC >> 28] = "writec",
315 		[RISC_READ >> 28] = "read",
316 		[RISC_READC >> 28] = "readc",
317 		[RISC_JUMP >> 28] = "jump",
318 		[RISC_SKIP >> 28] = "skip",
319 		[RISC_WRITERM >> 28] = "writerm",
320 		[RISC_WRITECM >> 28] = "writecm",
321 		[RISC_WRITECR >> 28] = "writecr",
322 	};
323 	static const int incr[16] = {
324 		[RISC_WRITE >> 28] = 3,
325 		[RISC_JUMP >> 28] = 3,
326 		[RISC_SKIP >> 28] = 1,
327 		[RISC_SYNC >> 28] = 1,
328 		[RISC_WRITERM >> 28] = 3,
329 		[RISC_WRITECM >> 28] = 3,
330 		[RISC_WRITECR >> 28] = 4,
331 	};
332 	static const char * const bits[] = {
333 		"12", "13", "14", "resync",
334 		"cnt0", "cnt1", "18", "19",
335 		"20", "21", "22", "23",
336 		"irq1", "irq2", "eol", "sol",
337 	};
338 	int i;
339 
340 	pr_cont("0x%08x [ %s",
341 		risc, instr[risc >> 28] ? instr[risc >> 28] : "INVALID");
342 	for (i = ARRAY_SIZE(bits) - 1; i >= 0; i--) {
343 		if (risc & (1 << (i + 12)))
344 			pr_cont(" %s", bits[i]);
345 	}
346 	pr_cont(" count=%d ]\n", risc & 0xfff);
347 	return incr[risc >> 28] ? incr[risc >> 28] : 1;
348 }
349 
350 static inline int i2c_slave_did_ack(struct i2c_adapter *i2c_adap)
351 {
352 	struct cx25821_i2c *bus = i2c_adap->algo_data;
353 	struct cx25821_dev *dev = bus->dev;
354 	return cx_read(bus->reg_stat) & 0x01;
355 }
356 
357 static void cx25821_registers_init(struct cx25821_dev *dev)
358 {
359 	u32 tmp;
360 
361 	/* enable RUN_RISC in Pecos */
362 	cx_write(DEV_CNTRL2, 0x20);
363 
364 	/* Set the master PCI interrupt masks to enable video, audio, MBIF,
365 	 * and GPIO interrupts
366 	 * I2C interrupt masking is handled by the I2C objects themselves. */
367 	cx_write(PCI_INT_MSK, 0x2001FFFF);
368 
369 	tmp = cx_read(RDR_TLCTL0);
370 	tmp &= ~FLD_CFG_RCB_CK_EN;	/* Clear the RCB_CK_EN bit */
371 	cx_write(RDR_TLCTL0, tmp);
372 
373 	/* PLL-A setting for the Audio Master Clock */
374 	cx_write(PLL_A_INT_FRAC, 0x9807A58B);
375 
376 	/* PLL_A_POST = 0x1C, PLL_A_OUT_TO_PIN = 0x1 */
377 	cx_write(PLL_A_POST_STAT_BIST, 0x8000019C);
378 
379 	/* clear reset bit [31] */
380 	tmp = cx_read(PLL_A_INT_FRAC);
381 	cx_write(PLL_A_INT_FRAC, tmp & 0x7FFFFFFF);
382 
383 	/* PLL-B setting for Mobilygen Host Bus Interface */
384 	cx_write(PLL_B_INT_FRAC, 0x9883A86F);
385 
386 	/* PLL_B_POST = 0xD, PLL_B_OUT_TO_PIN = 0x0 */
387 	cx_write(PLL_B_POST_STAT_BIST, 0x8000018D);
388 
389 	/* clear reset bit [31] */
390 	tmp = cx_read(PLL_B_INT_FRAC);
391 	cx_write(PLL_B_INT_FRAC, tmp & 0x7FFFFFFF);
392 
393 	/* PLL-C setting for video upstream channel */
394 	cx_write(PLL_C_INT_FRAC, 0x96A0EA3F);
395 
396 	/* PLL_C_POST = 0x3, PLL_C_OUT_TO_PIN = 0x0 */
397 	cx_write(PLL_C_POST_STAT_BIST, 0x80000103);
398 
399 	/* clear reset bit [31] */
400 	tmp = cx_read(PLL_C_INT_FRAC);
401 	cx_write(PLL_C_INT_FRAC, tmp & 0x7FFFFFFF);
402 
403 	/* PLL-D setting for audio upstream channel */
404 	cx_write(PLL_D_INT_FRAC, 0x98757F5B);
405 
406 	/* PLL_D_POST = 0x13, PLL_D_OUT_TO_PIN = 0x0 */
407 	cx_write(PLL_D_POST_STAT_BIST, 0x80000113);
408 
409 	/* clear reset bit [31] */
410 	tmp = cx_read(PLL_D_INT_FRAC);
411 	cx_write(PLL_D_INT_FRAC, tmp & 0x7FFFFFFF);
412 
413 	/* This selects the PLL C clock source for the video upstream channel
414 	 * I and J */
415 	tmp = cx_read(VID_CH_CLK_SEL);
416 	cx_write(VID_CH_CLK_SEL, (tmp & 0x00FFFFFF) | 0x24000000);
417 
418 	/* 656/VIP SRC Upstream Channel I & J and 7 - Host Bus Interface for
419 	 * channel A-C
420 	 * select 656/VIP DST for downstream Channel A - C */
421 	tmp = cx_read(VID_CH_MODE_SEL);
422 	/* cx_write( VID_CH_MODE_SEL, tmp | 0x1B0001FF); */
423 	cx_write(VID_CH_MODE_SEL, tmp & 0xFFFFFE00);
424 
425 	/* enables 656 port I and J as output */
426 	tmp = cx_read(CLK_RST);
427 	/* use external ALT_PLL_REF pin as its reference clock instead */
428 	tmp |= FLD_USE_ALT_PLL_REF;
429 	cx_write(CLK_RST, tmp & ~(FLD_VID_I_CLK_NOE | FLD_VID_J_CLK_NOE));
430 
431 	mdelay(100);
432 }
433 
434 int cx25821_sram_channel_setup(struct cx25821_dev *dev,
435 			       const struct sram_channel *ch,
436 			       unsigned int bpl, u32 risc)
437 {
438 	unsigned int i, lines;
439 	u32 cdt;
440 
441 	if (ch->cmds_start == 0) {
442 		cx_write(ch->ptr1_reg, 0);
443 		cx_write(ch->ptr2_reg, 0);
444 		cx_write(ch->cnt2_reg, 0);
445 		cx_write(ch->cnt1_reg, 0);
446 		return 0;
447 	}
448 
449 	bpl = (bpl + 7) & ~7;	/* alignment */
450 	cdt = ch->cdt;
451 	lines = ch->fifo_size / bpl;
452 
453 	if (lines > 4)
454 		lines = 4;
455 
456 	BUG_ON(lines < 2);
457 
458 	cx_write(8 + 0, RISC_JUMP | RISC_IRQ1 | RISC_CNT_INC);
459 	cx_write(8 + 4, 8);
460 	cx_write(8 + 8, 0);
461 
462 	/* write CDT */
463 	for (i = 0; i < lines; i++) {
464 		cx_write(cdt + 16 * i, ch->fifo_start + bpl * i);
465 		cx_write(cdt + 16 * i + 4, 0);
466 		cx_write(cdt + 16 * i + 8, 0);
467 		cx_write(cdt + 16 * i + 12, 0);
468 	}
469 
470 	/* init the first cdt buffer */
471 	for (i = 0; i < 128; i++)
472 		cx_write(ch->fifo_start + 4 * i, i);
473 
474 	/* write CMDS */
475 	if (ch->jumponly)
476 		cx_write(ch->cmds_start + 0, 8);
477 	else
478 		cx_write(ch->cmds_start + 0, risc);
479 
480 	cx_write(ch->cmds_start + 4, 0);	/* 64 bits 63-32 */
481 	cx_write(ch->cmds_start + 8, cdt);
482 	cx_write(ch->cmds_start + 12, (lines * 16) >> 3);
483 	cx_write(ch->cmds_start + 16, ch->ctrl_start);
484 
485 	if (ch->jumponly)
486 		cx_write(ch->cmds_start + 20, 0x80000000 | (64 >> 2));
487 	else
488 		cx_write(ch->cmds_start + 20, 64 >> 2);
489 
490 	for (i = 24; i < 80; i += 4)
491 		cx_write(ch->cmds_start + i, 0);
492 
493 	/* fill registers */
494 	cx_write(ch->ptr1_reg, ch->fifo_start);
495 	cx_write(ch->ptr2_reg, cdt);
496 	cx_write(ch->cnt2_reg, (lines * 16) >> 3);
497 	cx_write(ch->cnt1_reg, (bpl >> 3) - 1);
498 
499 	return 0;
500 }
501 
502 int cx25821_sram_channel_setup_audio(struct cx25821_dev *dev,
503 				     const struct sram_channel *ch,
504 				     unsigned int bpl, u32 risc)
505 {
506 	unsigned int i, lines;
507 	u32 cdt;
508 
509 	if (ch->cmds_start == 0) {
510 		cx_write(ch->ptr1_reg, 0);
511 		cx_write(ch->ptr2_reg, 0);
512 		cx_write(ch->cnt2_reg, 0);
513 		cx_write(ch->cnt1_reg, 0);
514 		return 0;
515 	}
516 
517 	bpl = (bpl + 7) & ~7;	/* alignment */
518 	cdt = ch->cdt;
519 	lines = ch->fifo_size / bpl;
520 
521 	if (lines > 3)
522 		lines = 3;	/* for AUDIO */
523 
524 	BUG_ON(lines < 2);
525 
526 	cx_write(8 + 0, RISC_JUMP | RISC_IRQ1 | RISC_CNT_INC);
527 	cx_write(8 + 4, 8);
528 	cx_write(8 + 8, 0);
529 
530 	/* write CDT */
531 	for (i = 0; i < lines; i++) {
532 		cx_write(cdt + 16 * i, ch->fifo_start + bpl * i);
533 		cx_write(cdt + 16 * i + 4, 0);
534 		cx_write(cdt + 16 * i + 8, 0);
535 		cx_write(cdt + 16 * i + 12, 0);
536 	}
537 
538 	/* write CMDS */
539 	if (ch->jumponly)
540 		cx_write(ch->cmds_start + 0, 8);
541 	else
542 		cx_write(ch->cmds_start + 0, risc);
543 
544 	cx_write(ch->cmds_start + 4, 0);	/* 64 bits 63-32 */
545 	cx_write(ch->cmds_start + 8, cdt);
546 	cx_write(ch->cmds_start + 12, (lines * 16) >> 3);
547 	cx_write(ch->cmds_start + 16, ch->ctrl_start);
548 
549 	/* IQ size */
550 	if (ch->jumponly)
551 		cx_write(ch->cmds_start + 20, 0x80000000 | (64 >> 2));
552 	else
553 		cx_write(ch->cmds_start + 20, 64 >> 2);
554 
555 	/* zero out */
556 	for (i = 24; i < 80; i += 4)
557 		cx_write(ch->cmds_start + i, 0);
558 
559 	/* fill registers */
560 	cx_write(ch->ptr1_reg, ch->fifo_start);
561 	cx_write(ch->ptr2_reg, cdt);
562 	cx_write(ch->cnt2_reg, (lines * 16) >> 3);
563 	cx_write(ch->cnt1_reg, (bpl >> 3) - 1);
564 
565 	return 0;
566 }
567 EXPORT_SYMBOL(cx25821_sram_channel_setup_audio);
568 
569 void cx25821_sram_channel_dump(struct cx25821_dev *dev, const struct sram_channel *ch)
570 {
571 	static char *name[] = {
572 		"init risc lo",
573 		"init risc hi",
574 		"cdt base",
575 		"cdt size",
576 		"iq base",
577 		"iq size",
578 		"risc pc lo",
579 		"risc pc hi",
580 		"iq wr ptr",
581 		"iq rd ptr",
582 		"cdt current",
583 		"pci target lo",
584 		"pci target hi",
585 		"line / byte",
586 	};
587 	u32 risc;
588 	unsigned int i, j, n;
589 
590 	pr_warn("%s: %s - dma channel status dump\n", dev->name, ch->name);
591 	for (i = 0; i < ARRAY_SIZE(name); i++)
592 		pr_warn("cmds + 0x%2x:   %-15s: 0x%08x\n",
593 			i * 4, name[i], cx_read(ch->cmds_start + 4 * i));
594 
595 	j = i * 4;
596 	for (i = 0; i < 4;) {
597 		risc = cx_read(ch->cmds_start + 4 * (i + 14));
598 		pr_warn("cmds + 0x%2x:   risc%d: ", j + i * 4, i);
599 		i += cx25821_risc_decode(risc);
600 	}
601 
602 	for (i = 0; i < (64 >> 2); i += n) {
603 		risc = cx_read(ch->ctrl_start + 4 * i);
604 		/* No consideration for bits 63-32 */
605 
606 		pr_warn("ctrl + 0x%2x (0x%08x): iq %x: ",
607 			i * 4, ch->ctrl_start + 4 * i, i);
608 		n = cx25821_risc_decode(risc);
609 		for (j = 1; j < n; j++) {
610 			risc = cx_read(ch->ctrl_start + 4 * (i + j));
611 			pr_warn("ctrl + 0x%2x :   iq %x: 0x%08x [ arg #%d ]\n",
612 				4 * (i + j), i + j, risc, j);
613 		}
614 	}
615 
616 	pr_warn("        :   fifo: 0x%08x -> 0x%x\n",
617 		ch->fifo_start, ch->fifo_start + ch->fifo_size);
618 	pr_warn("        :   ctrl: 0x%08x -> 0x%x\n",
619 		ch->ctrl_start, ch->ctrl_start + 6 * 16);
620 	pr_warn("        :   ptr1_reg: 0x%08x\n",
621 		cx_read(ch->ptr1_reg));
622 	pr_warn("        :   ptr2_reg: 0x%08x\n",
623 		cx_read(ch->ptr2_reg));
624 	pr_warn("        :   cnt1_reg: 0x%08x\n",
625 		cx_read(ch->cnt1_reg));
626 	pr_warn("        :   cnt2_reg: 0x%08x\n",
627 		cx_read(ch->cnt2_reg));
628 }
629 
630 void cx25821_sram_channel_dump_audio(struct cx25821_dev *dev,
631 				     const struct sram_channel *ch)
632 {
633 	static const char * const name[] = {
634 		"init risc lo",
635 		"init risc hi",
636 		"cdt base",
637 		"cdt size",
638 		"iq base",
639 		"iq size",
640 		"risc pc lo",
641 		"risc pc hi",
642 		"iq wr ptr",
643 		"iq rd ptr",
644 		"cdt current",
645 		"pci target lo",
646 		"pci target hi",
647 		"line / byte",
648 	};
649 
650 	u32 risc, value, tmp;
651 	unsigned int i, j, n;
652 
653 	pr_info("\n%s: %s - dma Audio channel status dump\n",
654 		dev->name, ch->name);
655 
656 	for (i = 0; i < ARRAY_SIZE(name); i++)
657 		pr_info("%s: cmds + 0x%2x:   %-15s: 0x%08x\n",
658 			dev->name, i * 4, name[i],
659 			cx_read(ch->cmds_start + 4 * i));
660 
661 	j = i * 4;
662 	for (i = 0; i < 4;) {
663 		risc = cx_read(ch->cmds_start + 4 * (i + 14));
664 		pr_warn("cmds + 0x%2x:   risc%d: ", j + i * 4, i);
665 		i += cx25821_risc_decode(risc);
666 	}
667 
668 	for (i = 0; i < (64 >> 2); i += n) {
669 		risc = cx_read(ch->ctrl_start + 4 * i);
670 		/* No consideration for bits 63-32 */
671 
672 		pr_warn("ctrl + 0x%2x (0x%08x): iq %x: ",
673 			i * 4, ch->ctrl_start + 4 * i, i);
674 		n = cx25821_risc_decode(risc);
675 
676 		for (j = 1; j < n; j++) {
677 			risc = cx_read(ch->ctrl_start + 4 * (i + j));
678 			pr_warn("ctrl + 0x%2x :   iq %x: 0x%08x [ arg #%d ]\n",
679 				4 * (i + j), i + j, risc, j);
680 		}
681 	}
682 
683 	pr_warn("        :   fifo: 0x%08x -> 0x%x\n",
684 		ch->fifo_start, ch->fifo_start + ch->fifo_size);
685 	pr_warn("        :   ctrl: 0x%08x -> 0x%x\n",
686 		ch->ctrl_start, ch->ctrl_start + 6 * 16);
687 	pr_warn("        :   ptr1_reg: 0x%08x\n",
688 		cx_read(ch->ptr1_reg));
689 	pr_warn("        :   ptr2_reg: 0x%08x\n",
690 		cx_read(ch->ptr2_reg));
691 	pr_warn("        :   cnt1_reg: 0x%08x\n",
692 		cx_read(ch->cnt1_reg));
693 	pr_warn("        :   cnt2_reg: 0x%08x\n",
694 		cx_read(ch->cnt2_reg));
695 
696 	for (i = 0; i < 4; i++) {
697 		risc = cx_read(ch->cmds_start + 56 + (i * 4));
698 		pr_warn("instruction %d = 0x%x\n", i, risc);
699 	}
700 
701 	/* read data from the first cdt buffer */
702 	risc = cx_read(AUD_A_CDT);
703 	pr_warn("\nread cdt loc=0x%x\n", risc);
704 	for (i = 0; i < 8; i++) {
705 		n = cx_read(risc + i * 4);
706 		pr_cont("0x%x ", n);
707 	}
708 	pr_cont("\n\n");
709 
710 	value = cx_read(CLK_RST);
711 	CX25821_INFO(" CLK_RST = 0x%x\n\n", value);
712 
713 	value = cx_read(PLL_A_POST_STAT_BIST);
714 	CX25821_INFO(" PLL_A_POST_STAT_BIST = 0x%x\n\n", value);
715 	value = cx_read(PLL_A_INT_FRAC);
716 	CX25821_INFO(" PLL_A_INT_FRAC = 0x%x\n\n", value);
717 
718 	value = cx_read(PLL_B_POST_STAT_BIST);
719 	CX25821_INFO(" PLL_B_POST_STAT_BIST = 0x%x\n\n", value);
720 	value = cx_read(PLL_B_INT_FRAC);
721 	CX25821_INFO(" PLL_B_INT_FRAC = 0x%x\n\n", value);
722 
723 	value = cx_read(PLL_C_POST_STAT_BIST);
724 	CX25821_INFO(" PLL_C_POST_STAT_BIST = 0x%x\n\n", value);
725 	value = cx_read(PLL_C_INT_FRAC);
726 	CX25821_INFO(" PLL_C_INT_FRAC = 0x%x\n\n", value);
727 
728 	value = cx_read(PLL_D_POST_STAT_BIST);
729 	CX25821_INFO(" PLL_D_POST_STAT_BIST = 0x%x\n\n", value);
730 	value = cx_read(PLL_D_INT_FRAC);
731 	CX25821_INFO(" PLL_D_INT_FRAC = 0x%x\n\n", value);
732 
733 	value = cx25821_i2c_read(&dev->i2c_bus[0], AFE_AB_DIAG_CTRL, &tmp);
734 	CX25821_INFO(" AFE_AB_DIAG_CTRL (0x10900090) = 0x%x\n\n", value);
735 }
736 EXPORT_SYMBOL(cx25821_sram_channel_dump_audio);
737 
738 static void cx25821_shutdown(struct cx25821_dev *dev)
739 {
740 	int i;
741 
742 	/* disable RISC controller */
743 	cx_write(DEV_CNTRL2, 0);
744 
745 	/* Disable Video A/B activity */
746 	for (i = 0; i < VID_CHANNEL_NUM; i++) {
747 		cx_write(dev->channels[i].sram_channels->dma_ctl, 0);
748 		cx_write(dev->channels[i].sram_channels->int_msk, 0);
749 	}
750 
751 	for (i = VID_UPSTREAM_SRAM_CHANNEL_I;
752 		i <= VID_UPSTREAM_SRAM_CHANNEL_J; i++) {
753 		cx_write(dev->channels[i].sram_channels->dma_ctl, 0);
754 		cx_write(dev->channels[i].sram_channels->int_msk, 0);
755 	}
756 
757 	/* Disable Audio activity */
758 	cx_write(AUD_INT_DMA_CTL, 0);
759 
760 	/* Disable Serial port */
761 	cx_write(UART_CTL, 0);
762 
763 	/* Disable Interrupts */
764 	cx_write(PCI_INT_MSK, 0);
765 	cx_write(AUD_A_INT_MSK, 0);
766 }
767 
768 void cx25821_set_pixel_format(struct cx25821_dev *dev, int channel_select,
769 			      u32 format)
770 {
771 	if (channel_select <= 7 && channel_select >= 0) {
772 		cx_write(dev->channels[channel_select].sram_channels->pix_frmt,
773 				format);
774 	}
775 	dev->channels[channel_select].pixel_formats = format;
776 }
777 
778 static void cx25821_set_vip_mode(struct cx25821_dev *dev,
779 				 const struct sram_channel *ch)
780 {
781 	cx_write(ch->pix_frmt, PIXEL_FRMT_422);
782 	cx_write(ch->vip_ctl, PIXEL_ENGINE_VIP1);
783 }
784 
785 static void cx25821_initialize(struct cx25821_dev *dev)
786 {
787 	int i;
788 
789 	dprintk(1, "%s()\n", __func__);
790 
791 	cx25821_shutdown(dev);
792 	cx_write(PCI_INT_STAT, 0xffffffff);
793 
794 	for (i = 0; i < VID_CHANNEL_NUM; i++)
795 		cx_write(dev->channels[i].sram_channels->int_stat, 0xffffffff);
796 
797 	cx_write(AUD_A_INT_STAT, 0xffffffff);
798 	cx_write(AUD_B_INT_STAT, 0xffffffff);
799 	cx_write(AUD_C_INT_STAT, 0xffffffff);
800 	cx_write(AUD_D_INT_STAT, 0xffffffff);
801 	cx_write(AUD_E_INT_STAT, 0xffffffff);
802 
803 	cx_write(CLK_DELAY, cx_read(CLK_DELAY) & 0x80000000);
804 	cx_write(PAD_CTRL, 0x12);	/* for I2C */
805 	cx25821_registers_init(dev);	/* init Pecos registers */
806 	mdelay(100);
807 
808 	for (i = 0; i < VID_CHANNEL_NUM; i++) {
809 		cx25821_set_vip_mode(dev, dev->channels[i].sram_channels);
810 		cx25821_sram_channel_setup(dev, dev->channels[i].sram_channels,
811 						1440, 0);
812 		dev->channels[i].pixel_formats = PIXEL_FRMT_422;
813 		dev->channels[i].use_cif_resolution = 0;
814 	}
815 
816 	/* Probably only affect Downstream */
817 	for (i = VID_UPSTREAM_SRAM_CHANNEL_I;
818 		i <= VID_UPSTREAM_SRAM_CHANNEL_J; i++) {
819 		dev->channels[i].pixel_formats = PIXEL_FRMT_422;
820 		cx25821_set_vip_mode(dev, dev->channels[i].sram_channels);
821 	}
822 
823 	cx25821_sram_channel_setup_audio(dev,
824 			dev->channels[SRAM_CH08].sram_channels, 128, 0);
825 
826 	cx25821_gpio_init(dev);
827 }
828 
829 static int cx25821_get_resources(struct cx25821_dev *dev)
830 {
831 	if (request_mem_region(pci_resource_start(dev->pci, 0),
832 				pci_resource_len(dev->pci, 0), dev->name))
833 		return 0;
834 
835 	pr_err("%s: can't get MMIO memory @ 0x%llx\n",
836 		dev->name, (unsigned long long)pci_resource_start(dev->pci, 0));
837 
838 	return -EBUSY;
839 }
840 
841 static void cx25821_dev_checkrevision(struct cx25821_dev *dev)
842 {
843 	dev->hwrevision = cx_read(RDR_CFG2) & 0xff;
844 
845 	pr_info("Hardware revision = 0x%02x\n", dev->hwrevision);
846 }
847 
848 static void cx25821_iounmap(struct cx25821_dev *dev)
849 {
850 	if (dev == NULL)
851 		return;
852 
853 	/* Releasing IO memory */
854 	if (dev->lmmio != NULL) {
855 		iounmap(dev->lmmio);
856 		dev->lmmio = NULL;
857 	}
858 }
859 
860 static int cx25821_dev_setup(struct cx25821_dev *dev)
861 {
862 	static unsigned int cx25821_devcount;
863 	int i;
864 
865 	mutex_init(&dev->lock);
866 
867 	dev->nr = ++cx25821_devcount;
868 	sprintf(dev->name, "cx25821[%d]", dev->nr);
869 
870 	if (dev->pci->device != 0x8210) {
871 		pr_info("%s(): Exiting. Incorrect Hardware device = 0x%02x\n",
872 			__func__, dev->pci->device);
873 		return -ENODEV;
874 	}
875 	pr_info("Athena Hardware device = 0x%02x\n", dev->pci->device);
876 
877 	/* Apply a sensible clock frequency for the PCIe bridge */
878 	dev->clk_freq = 28000000;
879 	for (i = 0; i < MAX_VID_CHANNEL_NUM; i++) {
880 		dev->channels[i].dev = dev;
881 		dev->channels[i].id = i;
882 		dev->channels[i].sram_channels = &cx25821_sram_channels[i];
883 	}
884 
885 	if (dev->nr > 1)
886 		CX25821_INFO("dev->nr > 1!");
887 
888 	/* board config */
889 	dev->board = 1;		/* card[dev->nr]; */
890 	dev->_max_num_decoders = MAX_DECODERS;
891 
892 	dev->pci_bus = dev->pci->bus->number;
893 	dev->pci_slot = PCI_SLOT(dev->pci->devfn);
894 	dev->pci_irqmask = 0x001f00;
895 
896 	/* External Master 1 Bus */
897 	dev->i2c_bus[0].nr = 0;
898 	dev->i2c_bus[0].dev = dev;
899 	dev->i2c_bus[0].reg_stat = I2C1_STAT;
900 	dev->i2c_bus[0].reg_ctrl = I2C1_CTRL;
901 	dev->i2c_bus[0].reg_addr = I2C1_ADDR;
902 	dev->i2c_bus[0].reg_rdata = I2C1_RDATA;
903 	dev->i2c_bus[0].reg_wdata = I2C1_WDATA;
904 	dev->i2c_bus[0].i2c_period = (0x07 << 24);	/* 1.95MHz */
905 
906 	if (cx25821_get_resources(dev) < 0) {
907 		pr_err("%s: No more PCIe resources for subsystem: %04x:%04x\n",
908 		       dev->name, dev->pci->subsystem_vendor,
909 		       dev->pci->subsystem_device);
910 
911 		cx25821_devcount--;
912 		return -EBUSY;
913 	}
914 
915 	/* PCIe stuff */
916 	dev->base_io_addr = pci_resource_start(dev->pci, 0);
917 
918 	if (!dev->base_io_addr) {
919 		CX25821_ERR("No PCI Memory resources, exiting!\n");
920 		return -ENODEV;
921 	}
922 
923 	dev->lmmio = ioremap(dev->base_io_addr, pci_resource_len(dev->pci, 0));
924 
925 	if (!dev->lmmio) {
926 		CX25821_ERR("ioremap failed, maybe increasing __VMALLOC_RESERVE in page.h\n");
927 		cx25821_iounmap(dev);
928 		return -ENOMEM;
929 	}
930 
931 	dev->bmmio = (u8 __iomem *) dev->lmmio;
932 
933 	pr_info("%s: subsystem: %04x:%04x, board: %s [card=%d,%s]\n",
934 		dev->name, dev->pci->subsystem_vendor,
935 		dev->pci->subsystem_device, cx25821_boards[dev->board].name,
936 		dev->board, card[dev->nr] == dev->board ?
937 		"insmod option" : "autodetected");
938 
939 	/* init hardware */
940 	cx25821_initialize(dev);
941 
942 	cx25821_i2c_register(&dev->i2c_bus[0]);
943 /*  cx25821_i2c_register(&dev->i2c_bus[1]);
944  *  cx25821_i2c_register(&dev->i2c_bus[2]); */
945 
946 	if (medusa_video_init(dev) < 0)
947 		CX25821_ERR("%s(): Failed to initialize medusa!\n", __func__);
948 
949 	cx25821_video_register(dev);
950 
951 	cx25821_dev_checkrevision(dev);
952 	return 0;
953 }
954 
955 void cx25821_dev_unregister(struct cx25821_dev *dev)
956 {
957 	int i;
958 
959 	if (!dev->base_io_addr)
960 		return;
961 
962 	release_mem_region(dev->base_io_addr, pci_resource_len(dev->pci, 0));
963 
964 	for (i = 0; i < MAX_VID_CAP_CHANNEL_NUM - 1; i++) {
965 		if (i == SRAM_CH08) /* audio channel */
966 			continue;
967 		/*
968 		 * TODO: enable when video output is properly
969 		 * supported.
970 		if (i == SRAM_CH09 || i == SRAM_CH10)
971 			cx25821_free_mem_upstream(&dev->channels[i]);
972 		 */
973 		cx25821_video_unregister(dev, i);
974 	}
975 
976 	cx25821_i2c_unregister(&dev->i2c_bus[0]);
977 	cx25821_iounmap(dev);
978 }
979 EXPORT_SYMBOL(cx25821_dev_unregister);
980 
981 int cx25821_riscmem_alloc(struct pci_dev *pci,
982 		       struct cx25821_riscmem *risc,
983 		       unsigned int size)
984 {
985 	__le32 *cpu;
986 	dma_addr_t dma = 0;
987 
988 	if (NULL != risc->cpu && risc->size < size)
989 		pci_free_consistent(pci, risc->size, risc->cpu, risc->dma);
990 	if (NULL == risc->cpu) {
991 		cpu = pci_zalloc_consistent(pci, size, &dma);
992 		if (NULL == cpu)
993 			return -ENOMEM;
994 		risc->cpu  = cpu;
995 		risc->dma  = dma;
996 		risc->size = size;
997 	}
998 	return 0;
999 }
1000 EXPORT_SYMBOL(cx25821_riscmem_alloc);
1001 
1002 static __le32 *cx25821_risc_field(__le32 * rp, struct scatterlist *sglist,
1003 				  unsigned int offset, u32 sync_line,
1004 				  unsigned int bpl, unsigned int padding,
1005 				  unsigned int lines, bool jump)
1006 {
1007 	struct scatterlist *sg;
1008 	unsigned int line, todo;
1009 
1010 	if (jump) {
1011 		*(rp++) = cpu_to_le32(RISC_JUMP);
1012 		*(rp++) = cpu_to_le32(0);
1013 		*(rp++) = cpu_to_le32(0); /* bits 63-32 */
1014 	}
1015 
1016 	/* sync instruction */
1017 	if (sync_line != NO_SYNC_LINE)
1018 		*(rp++) = cpu_to_le32(RISC_RESYNC | sync_line);
1019 
1020 	/* scan lines */
1021 	sg = sglist;
1022 	for (line = 0; line < lines; line++) {
1023 		while (offset && offset >= sg_dma_len(sg)) {
1024 			offset -= sg_dma_len(sg);
1025 			sg = sg_next(sg);
1026 		}
1027 		if (bpl <= sg_dma_len(sg) - offset) {
1028 			/* fits into current chunk */
1029 			*(rp++) = cpu_to_le32(RISC_WRITE | RISC_SOL | RISC_EOL |
1030 					bpl);
1031 			*(rp++) = cpu_to_le32(sg_dma_address(sg) + offset);
1032 			*(rp++) = cpu_to_le32(0);	/* bits 63-32 */
1033 			offset += bpl;
1034 		} else {
1035 			/* scanline needs to be split */
1036 			todo = bpl;
1037 			*(rp++) = cpu_to_le32(RISC_WRITE | RISC_SOL |
1038 					(sg_dma_len(sg) - offset));
1039 			*(rp++) = cpu_to_le32(sg_dma_address(sg) + offset);
1040 			*(rp++) = cpu_to_le32(0);	/* bits 63-32 */
1041 			todo -= (sg_dma_len(sg) - offset);
1042 			offset = 0;
1043 			sg = sg_next(sg);
1044 			while (todo > sg_dma_len(sg)) {
1045 				*(rp++) = cpu_to_le32(RISC_WRITE |
1046 						sg_dma_len(sg));
1047 				*(rp++) = cpu_to_le32(sg_dma_address(sg));
1048 				*(rp++) = cpu_to_le32(0);	/* bits 63-32 */
1049 				todo -= sg_dma_len(sg);
1050 				sg = sg_next(sg);
1051 			}
1052 			*(rp++) = cpu_to_le32(RISC_WRITE | RISC_EOL | todo);
1053 			*(rp++) = cpu_to_le32(sg_dma_address(sg));
1054 			*(rp++) = cpu_to_le32(0);	/* bits 63-32 */
1055 			offset += todo;
1056 		}
1057 
1058 		offset += padding;
1059 	}
1060 
1061 	return rp;
1062 }
1063 
1064 int cx25821_risc_buffer(struct pci_dev *pci, struct cx25821_riscmem *risc,
1065 			struct scatterlist *sglist, unsigned int top_offset,
1066 			unsigned int bottom_offset, unsigned int bpl,
1067 			unsigned int padding, unsigned int lines)
1068 {
1069 	u32 instructions;
1070 	u32 fields;
1071 	__le32 *rp;
1072 	int rc;
1073 
1074 	fields = 0;
1075 	if (UNSET != top_offset)
1076 		fields++;
1077 	if (UNSET != bottom_offset)
1078 		fields++;
1079 
1080 	/* estimate risc mem: worst case is one write per page border +
1081 	   one write per scan line + syncs + jump (all 3 dwords).  Padding
1082 	   can cause next bpl to start close to a page border.  First DMA
1083 	   region may be smaller than PAGE_SIZE */
1084 	/* write and jump need and extra dword */
1085 	instructions = fields * (1 + ((bpl + padding) * lines) / PAGE_SIZE +
1086 			lines);
1087 	instructions += 5;
1088 	rc = cx25821_riscmem_alloc(pci, risc, instructions * 12);
1089 
1090 	if (rc < 0)
1091 		return rc;
1092 
1093 	/* write risc instructions */
1094 	rp = risc->cpu;
1095 
1096 	if (UNSET != top_offset) {
1097 		rp = cx25821_risc_field(rp, sglist, top_offset, 0, bpl, padding,
1098 					lines, true);
1099 	}
1100 
1101 	if (UNSET != bottom_offset) {
1102 		rp = cx25821_risc_field(rp, sglist, bottom_offset, 0x200, bpl,
1103 					padding, lines, UNSET == top_offset);
1104 	}
1105 
1106 	/* save pointer to jmp instruction address */
1107 	risc->jmp = rp;
1108 	BUG_ON((risc->jmp - risc->cpu + 3) * sizeof(*risc->cpu) > risc->size);
1109 
1110 	return 0;
1111 }
1112 
1113 static __le32 *cx25821_risc_field_audio(__le32 * rp, struct scatterlist *sglist,
1114 					unsigned int offset, u32 sync_line,
1115 					unsigned int bpl, unsigned int padding,
1116 					unsigned int lines, unsigned int lpi)
1117 {
1118 	struct scatterlist *sg;
1119 	unsigned int line, todo, sol;
1120 
1121 	/* sync instruction */
1122 	if (sync_line != NO_SYNC_LINE)
1123 		*(rp++) = cpu_to_le32(RISC_RESYNC | sync_line);
1124 
1125 	/* scan lines */
1126 	sg = sglist;
1127 	for (line = 0; line < lines; line++) {
1128 		while (offset && offset >= sg_dma_len(sg)) {
1129 			offset -= sg_dma_len(sg);
1130 			sg = sg_next(sg);
1131 		}
1132 
1133 		if (lpi && line > 0 && !(line % lpi))
1134 			sol = RISC_SOL | RISC_IRQ1 | RISC_CNT_INC;
1135 		else
1136 			sol = RISC_SOL;
1137 
1138 		if (bpl <= sg_dma_len(sg) - offset) {
1139 			/* fits into current chunk */
1140 			*(rp++) = cpu_to_le32(RISC_WRITE | sol | RISC_EOL |
1141 					bpl);
1142 			*(rp++) = cpu_to_le32(sg_dma_address(sg) + offset);
1143 			*(rp++) = cpu_to_le32(0);	/* bits 63-32 */
1144 			offset += bpl;
1145 		} else {
1146 			/* scanline needs to be split */
1147 			todo = bpl;
1148 			*(rp++) = cpu_to_le32(RISC_WRITE | sol |
1149 					(sg_dma_len(sg) - offset));
1150 			*(rp++) = cpu_to_le32(sg_dma_address(sg) + offset);
1151 			*(rp++) = cpu_to_le32(0);	/* bits 63-32 */
1152 			todo -= (sg_dma_len(sg) - offset);
1153 			offset = 0;
1154 			sg = sg_next(sg);
1155 			while (todo > sg_dma_len(sg)) {
1156 				*(rp++) = cpu_to_le32(RISC_WRITE |
1157 						sg_dma_len(sg));
1158 				*(rp++) = cpu_to_le32(sg_dma_address(sg));
1159 				*(rp++) = cpu_to_le32(0);	/* bits 63-32 */
1160 				todo -= sg_dma_len(sg);
1161 				sg = sg_next(sg);
1162 			}
1163 			*(rp++) = cpu_to_le32(RISC_WRITE | RISC_EOL | todo);
1164 			*(rp++) = cpu_to_le32(sg_dma_address(sg));
1165 			*(rp++) = cpu_to_le32(0);	/* bits 63-32 */
1166 			offset += todo;
1167 		}
1168 		offset += padding;
1169 	}
1170 
1171 	return rp;
1172 }
1173 
1174 int cx25821_risc_databuffer_audio(struct pci_dev *pci,
1175 				  struct cx25821_riscmem *risc,
1176 				  struct scatterlist *sglist,
1177 				  unsigned int bpl,
1178 				  unsigned int lines, unsigned int lpi)
1179 {
1180 	u32 instructions;
1181 	__le32 *rp;
1182 	int rc;
1183 
1184 	/* estimate risc mem: worst case is one write per page border +
1185 	   one write per scan line + syncs + jump (all 2 dwords).  Here
1186 	   there is no padding and no sync.  First DMA region may be smaller
1187 	   than PAGE_SIZE */
1188 	/* Jump and write need an extra dword */
1189 	instructions = 1 + (bpl * lines) / PAGE_SIZE + lines;
1190 	instructions += 1;
1191 
1192 	rc = cx25821_riscmem_alloc(pci, risc, instructions * 12);
1193 	if (rc < 0)
1194 		return rc;
1195 
1196 	/* write risc instructions */
1197 	rp = risc->cpu;
1198 	rp = cx25821_risc_field_audio(rp, sglist, 0, NO_SYNC_LINE, bpl, 0,
1199 				      lines, lpi);
1200 
1201 	/* save pointer to jmp instruction address */
1202 	risc->jmp = rp;
1203 	BUG_ON((risc->jmp - risc->cpu + 2) * sizeof(*risc->cpu) > risc->size);
1204 	return 0;
1205 }
1206 EXPORT_SYMBOL(cx25821_risc_databuffer_audio);
1207 
1208 void cx25821_free_buffer(struct cx25821_dev *dev, struct cx25821_buffer *buf)
1209 {
1210 	BUG_ON(in_interrupt());
1211 	if (WARN_ON(buf->risc.size == 0))
1212 		return;
1213 	pci_free_consistent(dev->pci,
1214 			buf->risc.size, buf->risc.cpu, buf->risc.dma);
1215 	memset(&buf->risc, 0, sizeof(buf->risc));
1216 }
1217 
1218 static irqreturn_t cx25821_irq(int irq, void *dev_id)
1219 {
1220 	struct cx25821_dev *dev = dev_id;
1221 	u32 pci_status;
1222 	u32 vid_status;
1223 	int i, handled = 0;
1224 	u32 mask[8] = { 1, 2, 4, 8, 16, 32, 64, 128 };
1225 
1226 	pci_status = cx_read(PCI_INT_STAT);
1227 
1228 	if (pci_status == 0)
1229 		goto out;
1230 
1231 	for (i = 0; i < VID_CHANNEL_NUM; i++) {
1232 		if (pci_status & mask[i]) {
1233 			vid_status = cx_read(dev->channels[i].
1234 				sram_channels->int_stat);
1235 
1236 			if (vid_status)
1237 				handled += cx25821_video_irq(dev, i,
1238 						vid_status);
1239 
1240 			cx_write(PCI_INT_STAT, mask[i]);
1241 		}
1242 	}
1243 
1244 out:
1245 	return IRQ_RETVAL(handled);
1246 }
1247 
1248 void cx25821_print_irqbits(char *name, char *tag, char **strings,
1249 			   int len, u32 bits, u32 mask)
1250 {
1251 	unsigned int i;
1252 
1253 	printk(KERN_DEBUG pr_fmt("%s: %s [0x%x]"), name, tag, bits);
1254 
1255 	for (i = 0; i < len; i++) {
1256 		if (!(bits & (1 << i)))
1257 			continue;
1258 		if (strings[i])
1259 			pr_cont(" %s", strings[i]);
1260 		else
1261 			pr_cont(" %d", i);
1262 		if (!(mask & (1 << i)))
1263 			continue;
1264 		pr_cont("*");
1265 	}
1266 	pr_cont("\n");
1267 }
1268 EXPORT_SYMBOL(cx25821_print_irqbits);
1269 
1270 struct cx25821_dev *cx25821_dev_get(struct pci_dev *pci)
1271 {
1272 	struct cx25821_dev *dev = pci_get_drvdata(pci);
1273 	return dev;
1274 }
1275 EXPORT_SYMBOL(cx25821_dev_get);
1276 
1277 static int cx25821_initdev(struct pci_dev *pci_dev,
1278 			   const struct pci_device_id *pci_id)
1279 {
1280 	struct cx25821_dev *dev;
1281 	int err = 0;
1282 
1283 	dev = kzalloc(sizeof(*dev), GFP_KERNEL);
1284 	if (NULL == dev)
1285 		return -ENOMEM;
1286 
1287 	err = v4l2_device_register(&pci_dev->dev, &dev->v4l2_dev);
1288 	if (err < 0)
1289 		goto fail_free;
1290 
1291 	/* pci init */
1292 	dev->pci = pci_dev;
1293 	if (pci_enable_device(pci_dev)) {
1294 		err = -EIO;
1295 
1296 		pr_info("pci enable failed!\n");
1297 
1298 		goto fail_unregister_device;
1299 	}
1300 
1301 	err = cx25821_dev_setup(dev);
1302 	if (err)
1303 		goto fail_unregister_pci;
1304 
1305 	/* print pci info */
1306 	pci_read_config_byte(pci_dev, PCI_CLASS_REVISION, &dev->pci_rev);
1307 	pci_read_config_byte(pci_dev, PCI_LATENCY_TIMER, &dev->pci_lat);
1308 	pr_info("%s/0: found at %s, rev: %d, irq: %d, latency: %d, mmio: 0x%llx\n",
1309 		dev->name, pci_name(pci_dev), dev->pci_rev, pci_dev->irq,
1310 		dev->pci_lat, (unsigned long long)dev->base_io_addr);
1311 
1312 	pci_set_master(pci_dev);
1313 	err = pci_set_dma_mask(pci_dev, 0xffffffff);
1314 	if (err) {
1315 		pr_err("%s/0: Oops: no 32bit PCI DMA ???\n", dev->name);
1316 		err = -EIO;
1317 		goto fail_irq;
1318 	}
1319 
1320 	err = request_irq(pci_dev->irq, cx25821_irq,
1321 			IRQF_SHARED, dev->name, dev);
1322 
1323 	if (err < 0) {
1324 		pr_err("%s: can't get IRQ %d\n", dev->name, pci_dev->irq);
1325 		goto fail_irq;
1326 	}
1327 
1328 	return 0;
1329 
1330 fail_irq:
1331 	pr_info("cx25821_initdev() can't get IRQ !\n");
1332 	cx25821_dev_unregister(dev);
1333 
1334 fail_unregister_pci:
1335 	pci_disable_device(pci_dev);
1336 fail_unregister_device:
1337 	v4l2_device_unregister(&dev->v4l2_dev);
1338 
1339 fail_free:
1340 	kfree(dev);
1341 	return err;
1342 }
1343 
1344 static void cx25821_finidev(struct pci_dev *pci_dev)
1345 {
1346 	struct v4l2_device *v4l2_dev = pci_get_drvdata(pci_dev);
1347 	struct cx25821_dev *dev = get_cx25821(v4l2_dev);
1348 
1349 	cx25821_shutdown(dev);
1350 	pci_disable_device(pci_dev);
1351 
1352 	/* unregister stuff */
1353 	if (pci_dev->irq)
1354 		free_irq(pci_dev->irq, dev);
1355 
1356 	cx25821_dev_unregister(dev);
1357 	v4l2_device_unregister(v4l2_dev);
1358 	kfree(dev);
1359 }
1360 
1361 static const struct pci_device_id cx25821_pci_tbl[] = {
1362 	{
1363 		/* CX25821 Athena */
1364 		.vendor = 0x14f1,
1365 		.device = 0x8210,
1366 		.subvendor = 0x14f1,
1367 		.subdevice = 0x0920,
1368 	}, {
1369 		/* CX25821 No Brand */
1370 		.vendor = 0x14f1,
1371 		.device = 0x8210,
1372 		.subvendor = 0x0000,
1373 		.subdevice = 0x0000,
1374 	}, {
1375 		/* --- end of list --- */
1376 	}
1377 };
1378 
1379 MODULE_DEVICE_TABLE(pci, cx25821_pci_tbl);
1380 
1381 static struct pci_driver cx25821_pci_driver = {
1382 	.name = "cx25821",
1383 	.id_table = cx25821_pci_tbl,
1384 	.probe = cx25821_initdev,
1385 	.remove = cx25821_finidev,
1386 	/* TODO */
1387 	.suspend = NULL,
1388 	.resume = NULL,
1389 };
1390 
1391 static int __init cx25821_init(void)
1392 {
1393 	pr_info("driver loaded\n");
1394 	return pci_register_driver(&cx25821_pci_driver);
1395 }
1396 
1397 static void __exit cx25821_fini(void)
1398 {
1399 	pci_unregister_driver(&cx25821_pci_driver);
1400 }
1401 
1402 module_init(cx25821_init);
1403 module_exit(cx25821_fini);
1404