[SCSI] megaraid: fix MMIO casts
megaraid's MMIO RD*/WR* macros directly call readl() and writel() with an 'unsigned long' argument. This throws a warning, but is otherwise OK because the 'unsigned long' is really the result of ioremap(). This setup is also OK because the variable can hold an ioremap cookie /or/ a PCI I/O port (PIO). However, to fix the warning thrown when readl() and writel() are passed an unsigned long cookie, I introduce 'void __iomem *mmio_base', holding the same value as 'base'. This will silence the warnings, and also cause an oops whenever these MMIO-only functions are ever accidentally passed an I/O address. Signed-off-by: Jeff Garzik <jeff@garzik.org> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
This commit is contained in:
committed by
James Bottomley
parent
e42ebefee1
commit
00769ec400
@@ -801,7 +801,8 @@ typedef struct {
|
||||
clustering is available */
|
||||
u32 flag;
|
||||
|
||||
unsigned long base;
|
||||
unsigned long base;
|
||||
void __iomem *mmio_base;
|
||||
|
||||
/* mbox64 with mbox not aligned on 16-byte boundry */
|
||||
mbox64_t *una_mbox64;
|
||||
|
Reference in New Issue
Block a user