V4L/DVB (5496): Pluto2: fix incorrect TSCR register setting
The ADEF bits in the TSCR register have different meanings in read and write mode. For this reason ADEF has to be reset on every read-modify-write operation. This patch introduces a special write function for this register, which takes care of it. Thanks to Holger Magnussen for pointing my nose at this problem. Signed-off-by: Andreas Oberritter <obi@linuxtv.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
This commit is contained in:
parent
d420cb4469
commit
1489f90a49
1 changed files with 14 additions and 8 deletions
|
@ -149,6 +149,15 @@ static inline void pluto_rw(struct pluto *pluto, u32 reg, u32 mask, u32 bits)
|
||||||
writel(val, &pluto->io_mem[reg]);
|
writel(val, &pluto->io_mem[reg]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void pluto_write_tscr(struct pluto *pluto, u32 val)
|
||||||
|
{
|
||||||
|
/* set the number of packets */
|
||||||
|
val &= ~TSCR_ADEF;
|
||||||
|
val |= TS_DMA_PACKETS / 2;
|
||||||
|
|
||||||
|
pluto_writereg(pluto, REG_TSCR, val);
|
||||||
|
}
|
||||||
|
|
||||||
static void pluto_setsda(void *data, int state)
|
static void pluto_setsda(void *data, int state)
|
||||||
{
|
{
|
||||||
struct pluto *pluto = data;
|
struct pluto *pluto = data;
|
||||||
|
@ -213,11 +222,11 @@ static void pluto_reset_ts(struct pluto *pluto, int reenable)
|
||||||
|
|
||||||
if (val & TSCR_RSTN) {
|
if (val & TSCR_RSTN) {
|
||||||
val &= ~TSCR_RSTN;
|
val &= ~TSCR_RSTN;
|
||||||
pluto_writereg(pluto, REG_TSCR, val);
|
pluto_write_tscr(pluto, val);
|
||||||
}
|
}
|
||||||
if (reenable) {
|
if (reenable) {
|
||||||
val |= TSCR_RSTN;
|
val |= TSCR_RSTN;
|
||||||
pluto_writereg(pluto, REG_TSCR, val);
|
pluto_write_tscr(pluto, val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -339,7 +348,7 @@ static irqreturn_t pluto_irq(int irq, void *dev_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ACK the interrupt */
|
/* ACK the interrupt */
|
||||||
pluto_writereg(pluto, REG_TSCR, tscr | TSCR_IACK);
|
pluto_write_tscr(pluto, tscr | TSCR_IACK);
|
||||||
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
@ -348,9 +357,6 @@ static void __devinit pluto_enable_irqs(struct pluto *pluto)
|
||||||
{
|
{
|
||||||
u32 val = pluto_readreg(pluto, REG_TSCR);
|
u32 val = pluto_readreg(pluto, REG_TSCR);
|
||||||
|
|
||||||
/* set the number of packets */
|
|
||||||
val &= ~TSCR_ADEF;
|
|
||||||
val |= TS_DMA_PACKETS / 2;
|
|
||||||
/* disable AFUL and LOCK interrupts */
|
/* disable AFUL and LOCK interrupts */
|
||||||
val |= (TSCR_MSKA | TSCR_MSKL);
|
val |= (TSCR_MSKA | TSCR_MSKL);
|
||||||
/* enable DMA and OVERFLOW interrupts */
|
/* enable DMA and OVERFLOW interrupts */
|
||||||
|
@ -358,7 +364,7 @@ static void __devinit pluto_enable_irqs(struct pluto *pluto)
|
||||||
/* clear pending interrupts */
|
/* clear pending interrupts */
|
||||||
val |= TSCR_IACK;
|
val |= TSCR_IACK;
|
||||||
|
|
||||||
pluto_writereg(pluto, REG_TSCR, val);
|
pluto_write_tscr(pluto, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void pluto_disable_irqs(struct pluto *pluto)
|
static void pluto_disable_irqs(struct pluto *pluto)
|
||||||
|
@ -370,7 +376,7 @@ static void pluto_disable_irqs(struct pluto *pluto)
|
||||||
/* clear pending interrupts */
|
/* clear pending interrupts */
|
||||||
val |= TSCR_IACK;
|
val |= TSCR_IACK;
|
||||||
|
|
||||||
pluto_writereg(pluto, REG_TSCR, val);
|
pluto_write_tscr(pluto, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __devinit pluto_hw_init(struct pluto *pluto)
|
static int __devinit pluto_hw_init(struct pluto *pluto)
|
||||||
|
|
Loading…
Reference in a new issue