Commit 6846e75c authored by Kashyap, Desai's avatar Kashyap, Desai Committed by James Bottomley

[SCSI] mpt2sas: User resource_size_t instead of unsigned long

Use resource_size_t to define the type resource for the system interface
register set.
The existing implementation was using "unsigned long" which would be 32 bit
in 32 bit OS.  If 32 bit OS is using 64 bit physical
address space for the system interface register set, we need to shift to
using resource_size_t which takes care of physical address space.
Signed-off-by: default avatarKashyap Desai <kashyap.desai@lsi.com>
Reviewed-by: default avatarEric Moore <eric.moore@lsi.com>
Signed-off-by: default avatarJames Bottomley <James.Bottomley@suse.de>
parent b2ff36ba
...@@ -1222,6 +1222,8 @@ mpt2sas_base_map_resources(struct MPT2SAS_ADAPTER *ioc) ...@@ -1222,6 +1222,8 @@ mpt2sas_base_map_resources(struct MPT2SAS_ADAPTER *ioc)
u32 memap_sz; u32 memap_sz;
u32 pio_sz; u32 pio_sz;
int i, r = 0; int i, r = 0;
u64 pio_chip = 0;
u64 chip_phys = 0;
dinitprintk(ioc, printk(MPT2SAS_DEBUG_FMT "%s\n", dinitprintk(ioc, printk(MPT2SAS_DEBUG_FMT "%s\n",
ioc->name, __func__)); ioc->name, __func__));
...@@ -1255,12 +1257,13 @@ mpt2sas_base_map_resources(struct MPT2SAS_ADAPTER *ioc) ...@@ -1255,12 +1257,13 @@ mpt2sas_base_map_resources(struct MPT2SAS_ADAPTER *ioc)
if (pci_resource_flags(pdev, i) & PCI_BASE_ADDRESS_SPACE_IO) { if (pci_resource_flags(pdev, i) & PCI_BASE_ADDRESS_SPACE_IO) {
if (pio_sz) if (pio_sz)
continue; continue;
ioc->pio_chip = pci_resource_start(pdev, i); pio_chip = (u64)pci_resource_start(pdev, i);
pio_sz = pci_resource_len(pdev, i); pio_sz = pci_resource_len(pdev, i);
} else { } else {
if (memap_sz) if (memap_sz)
continue; continue;
ioc->chip_phys = pci_resource_start(pdev, i); ioc->chip_phys = pci_resource_start(pdev, i);
chip_phys = (u64)ioc->chip_phys;
memap_sz = pci_resource_len(pdev, i); memap_sz = pci_resource_len(pdev, i);
ioc->chip = ioremap(ioc->chip_phys, memap_sz); ioc->chip = ioremap(ioc->chip_phys, memap_sz);
if (ioc->chip == NULL) { if (ioc->chip == NULL) {
...@@ -1280,10 +1283,10 @@ mpt2sas_base_map_resources(struct MPT2SAS_ADAPTER *ioc) ...@@ -1280,10 +1283,10 @@ mpt2sas_base_map_resources(struct MPT2SAS_ADAPTER *ioc)
printk(MPT2SAS_INFO_FMT "%s: IRQ %d\n", printk(MPT2SAS_INFO_FMT "%s: IRQ %d\n",
ioc->name, ((ioc->msix_enable) ? "PCI-MSI-X enabled" : ioc->name, ((ioc->msix_enable) ? "PCI-MSI-X enabled" :
"IO-APIC enabled"), ioc->pci_irq); "IO-APIC enabled"), ioc->pci_irq);
printk(MPT2SAS_INFO_FMT "iomem(0x%lx), mapped(0x%p), size(%d)\n", printk(MPT2SAS_INFO_FMT "iomem(0x%016llx), mapped(0x%p), size(%d)\n",
ioc->name, ioc->chip_phys, ioc->chip, memap_sz); ioc->name, (unsigned long long)chip_phys, ioc->chip, memap_sz);
printk(MPT2SAS_INFO_FMT "ioport(0x%lx), size(%d)\n", printk(MPT2SAS_INFO_FMT "ioport(0x%016llx), size(%d)\n",
ioc->name, ioc->pio_chip, pio_sz); ioc->name, (unsigned long long)pio_chip, pio_sz);
return 0; return 0;
......
...@@ -464,7 +464,6 @@ typedef void (*MPT_ADD_SGE)(void *paddr, u32 flags_length, dma_addr_t dma_addr); ...@@ -464,7 +464,6 @@ typedef void (*MPT_ADD_SGE)(void *paddr, u32 flags_length, dma_addr_t dma_addr);
* @pdev: pci pdev object * @pdev: pci pdev object
* @chip: memory mapped register space * @chip: memory mapped register space
* @chip_phys: physical addrss prior to mapping * @chip_phys: physical addrss prior to mapping
* @pio_chip: I/O mapped register space
* @logging_level: see mpt2sas_debug.h * @logging_level: see mpt2sas_debug.h
* @fwfault_debug: debuging FW timeouts * @fwfault_debug: debuging FW timeouts
* @ir_firmware: IR firmware present * @ir_firmware: IR firmware present
...@@ -587,8 +586,7 @@ struct MPT2SAS_ADAPTER { ...@@ -587,8 +586,7 @@ struct MPT2SAS_ADAPTER {
char tmp_string[MPT_STRING_LENGTH]; char tmp_string[MPT_STRING_LENGTH];
struct pci_dev *pdev; struct pci_dev *pdev;
Mpi2SystemInterfaceRegs_t __iomem *chip; Mpi2SystemInterfaceRegs_t __iomem *chip;
unsigned long chip_phys; resource_size_t chip_phys;
unsigned long pio_chip;
int logging_level; int logging_level;
int fwfault_debug; int fwfault_debug;
u8 ir_firmware; u8 ir_firmware;
......
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