Commit 64b9a359 authored by Alexander Viro's avatar Alexander Viro Committed by Linus Torvalds

[PATCH] iomem annotations and isa_-ectomy: media/video/pms.c

switched to ioremap() + normal iomem access primitives
Signed-off-by: default avatarAl Viro <viro@parcelfarce.linux.theplanet.co.uk>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 7f7f54ca
...@@ -68,6 +68,7 @@ static int standard = 0; /* 0 - auto 1 - ntsc 2 - pal 3 - secam */ ...@@ -68,6 +68,7 @@ static int standard = 0; /* 0 - auto 1 - ntsc 2 - pal 3 - secam */
static int io_port = 0x250; static int io_port = 0x250;
static int data_port = 0x251; static int data_port = 0x251;
static int mem_base = 0xC8000; static int mem_base = 0xC8000;
static void __iomem *mem;
static int video_nr = -1; static int video_nr = -1;
...@@ -629,7 +630,6 @@ static int pms_capture(struct pms_device *dev, char __user *buf, int rgb555, int ...@@ -629,7 +630,6 @@ static int pms_capture(struct pms_device *dev, char __user *buf, int rgb555, int
{ {
int y; int y;
int dw = 2*dev->width; int dw = 2*dev->width;
u32 src = mem_base;
char tmp[dw+32]; /* using a temp buffer is faster than direct */ char tmp[dw+32]; /* using a temp buffer is faster than direct */
int cnt = 0; int cnt = 0;
...@@ -644,14 +644,14 @@ static int pms_capture(struct pms_device *dev, char __user *buf, int rgb555, int ...@@ -644,14 +644,14 @@ static int pms_capture(struct pms_device *dev, char __user *buf, int rgb555, int
for (y = 0; y < dev->height; y++ ) for (y = 0; y < dev->height; y++ )
{ {
isa_writeb(0, src); /* synchronisiert neue Zeile */ writeb(0, mem); /* synchronisiert neue Zeile */
/* /*
* This is in truth a fifo, be very careful as if you * This is in truth a fifo, be very careful as if you
* forgot this odd things will occur 8) * forgot this odd things will occur 8)
*/ */
isa_memcpy_fromio(tmp, src, dw+32); /* discard 16 word */ memcpy_fromio(tmp, mem, dw+32); /* discard 16 word */
cnt -= dev->height; cnt -= dev->height;
while (cnt <= 0) while (cnt <= 0)
{ {
...@@ -918,16 +918,22 @@ static int init_mediavision(void) ...@@ -918,16 +918,22 @@ static int init_mediavision(void)
0x34,0x0A,0xF4,0xCE, 0x34,0x0A,0xF4,0xCE,
0xE4 0xE4
}; };
mem = ioremap(mem_base, 0x800);
if (!mem)
return -ENOMEM;
if (!request_region(0x9A01, 1, "Mediavision PMS config")) if (!request_region(0x9A01, 1, "Mediavision PMS config"))
{ {
printk(KERN_WARNING "mediavision: unable to detect: 0x9A01 in use.\n"); printk(KERN_WARNING "mediavision: unable to detect: 0x9A01 in use.\n");
iounmap(mem);
return -EBUSY; return -EBUSY;
} }
if (!request_region(io_port, 3, "Mediavision PMS")) if (!request_region(io_port, 3, "Mediavision PMS"))
{ {
printk(KERN_WARNING "mediavision: I/O port %d in use.\n", io_port); printk(KERN_WARNING "mediavision: I/O port %d in use.\n", io_port);
release_region(0x9A01, 1); release_region(0x9A01, 1);
iounmap(mem);
return -EBUSY; return -EBUSY;
} }
outb(0xB8, 0x9A01); /* Unlock */ outb(0xB8, 0x9A01); /* Unlock */
...@@ -950,6 +956,7 @@ static int init_mediavision(void) ...@@ -950,6 +956,7 @@ static int init_mediavision(void)
if(idec == 0) { if(idec == 0) {
release_region(io_port, 3); release_region(io_port, 3);
release_region(0x9A01, 1); release_region(0x9A01, 1);
iounmap(mem);
return -ENODEV; return -ENODEV;
} }
...@@ -1045,6 +1052,7 @@ static void __exit cleanup_pms_module(void) ...@@ -1045,6 +1052,7 @@ static void __exit cleanup_pms_module(void)
{ {
shutdown_mediavision(); shutdown_mediavision();
video_unregister_device((struct video_device *)&pms_device); video_unregister_device((struct video_device *)&pms_device);
iounmap(mem);
} }
module_init(init_pms_cards); module_init(init_pms_cards);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment