aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/video/saa7164/saa7164-bus.c2
-rw-r--r--drivers/media/video/saa7164/saa7164-core.c12
-rw-r--r--drivers/media/video/saa7164/saa7164.h6
3 files changed, 10 insertions, 10 deletions
diff --git a/drivers/media/video/saa7164/saa7164-bus.c b/drivers/media/video/saa7164/saa7164-bus.c
index 8d813f5b54a8..83a04640a25a 100644
--- a/drivers/media/video/saa7164/saa7164-bus.c
+++ b/drivers/media/video/saa7164/saa7164-bus.c
@@ -257,7 +257,7 @@ int saa7164_bus_set(struct saa7164_dev *dev, tmComResInfo_t* msg, void *buf)
257 257
258 dprintk(DBGLVL_BUS, "%s() new_swp = %x\n", __func__, new_swp); 258 dprintk(DBGLVL_BUS, "%s() new_swp = %x\n", __func__, new_swp);
259 259
260 /* TODO: Convert all of the volatiles and direct PCI writes into 260 /* TODO: Convert all of the direct PCI writes into
261 * saa7164_writel/b calls for consistency. 261 * saa7164_writel/b calls for consistency.
262 */ 262 */
263 263
diff --git a/drivers/media/video/saa7164/saa7164-core.c b/drivers/media/video/saa7164/saa7164-core.c
index bf4ca4f29b01..968ecd4ad495 100644
--- a/drivers/media/video/saa7164/saa7164-core.c
+++ b/drivers/media/video/saa7164/saa7164-core.c
@@ -126,12 +126,13 @@ static irqreturn_t saa7164_irq(int irq, void *dev_id)
126 /* Check that the hardware is accessable. If the status bytes are 126 /* Check that the hardware is accessable. If the status bytes are
127 * 0xFF then the device is not accessable, the the IRQ belongs 127 * 0xFF then the device is not accessable, the the IRQ belongs
128 * to another driver. 128 * to another driver.
129 * 4 x u32 interrupt registers.
129 */ 130 */
130 for (i = 0; i < INT_SIZE/4; i++) { 131 for (i = 0; i < INT_SIZE/4; i++) {
131 132
132 /* TODO: Convert into saa7164_readl() */ 133 /* TODO: Convert into saa7164_readl() */
133 /* Read the 4 hardware interrupt registers */ 134 /* Read the 4 hardware interrupt registers */
134 intstat[i] = *(dev->InterruptStatus + i); 135 intstat[i] = saa7164_readl(dev->int_status + (i * 4));
135 136
136 if (intstat[i] != 0xffffffff) 137 if (intstat[i] != 0xffffffff)
137 hwacc = 1; 138 hwacc = 1;
@@ -184,9 +185,8 @@ static irqreturn_t saa7164_irq(int irq, void *dev_id)
184 } 185 }
185 } 186 }
186 187
187 /* TODO: Convert into saa7164_writel() */
188 /* Ack it */ 188 /* Ack it */
189 *(dev->InterruptAck + i) = intstat[i]; 189 saa7164_writel(dev->int_ack + (i * 4), intstat[i]);
190 190
191 } 191 }
192 } 192 }
@@ -487,9 +487,9 @@ static int saa7164_dev_setup(struct saa7164_dev *dev)
487 printk(KERN_INFO "CORE %s: dev->bmmio2 = 0x%p\n", dev->name, 487 printk(KERN_INFO "CORE %s: dev->bmmio2 = 0x%p\n", dev->name,
488 dev->bmmio2); 488 dev->bmmio2);
489 489
490 /* TODO: Magic defines used in the windows driver, define these */ 490 /* Inerrupt and ack register locations offset of bmmio */
491 dev->InterruptStatus = (u32 *)(dev->bmmio + 0x183000 + 0xf80); 491 dev->int_status = 0x183000 + 0xf80;
492 dev->InterruptAck = (u32 *)(dev->bmmio + 0x183000 + 0xf90); 492 dev->int_ack = 0x183000 + 0xf90;
493 493
494 printk(KERN_INFO 494 printk(KERN_INFO
495 "CORE %s: subsystem: %04x:%04x, board: %s [card=%d,%s]\n", 495 "CORE %s: subsystem: %04x:%04x, board: %s [card=%d,%s]\n",
diff --git a/drivers/media/video/saa7164/saa7164.h b/drivers/media/video/saa7164/saa7164.h
index 338804f6cd57..2d4d47ba3c1a 100644
--- a/drivers/media/video/saa7164/saa7164.h
+++ b/drivers/media/video/saa7164/saa7164.h
@@ -274,9 +274,9 @@ struct saa7164_dev {
274 274
275 tmComResBusInfo_t bus; 275 tmComResBusInfo_t bus;
276 276
277 /* TODO: Urgh, remove volatiles */ 277 /* Interrupt status and ack registers */
278 volatile u32 *InterruptStatus; 278 u32 int_status;
279 volatile u32 *InterruptAck; 279 u32 int_ack;
280 280
281 struct cmd cmds[SAA_CMD_MAX_MSG_UNITS]; 281 struct cmd cmds[SAA_CMD_MAX_MSG_UNITS];
282 struct mutex lock; 282 struct mutex lock;