Commit 2b4a8bd2 authored by Roy Zang's avatar Roy Zang Committed by Kumar Gala

powerpc/fsl_pci: fix 64 bit pci size issue

The size might be 64 bit, so use ilog2() instead of __ilog2() or
__ilog2_u64().

ilog2() can select 32bit or 64bit function automatically.
Signed-off-by: default avatarRoy Zang <tie-fei.zang@freescale.com>
Signed-off-by: default avatarKumar Gala <galak@kernel.crashing.org>
parent 4ba6c1f1
...@@ -128,7 +128,7 @@ static int setup_one_atmu(struct ccsr_pci __iomem *pci, ...@@ -128,7 +128,7 @@ static int setup_one_atmu(struct ccsr_pci __iomem *pci,
flags |= 0x10000000; /* enable relaxed ordering */ flags |= 0x10000000; /* enable relaxed ordering */
for (i = 0; size > 0; i++) { for (i = 0; size > 0; i++) {
unsigned int bits = min(__ilog2(size), unsigned int bits = min(ilog2(size),
__ffs(pci_addr | phys_addr)); __ffs(pci_addr | phys_addr));
if (index + i >= 5) if (index + i >= 5)
...@@ -218,7 +218,7 @@ static void setup_pci_atmu(struct pci_controller *hose, ...@@ -218,7 +218,7 @@ static void setup_pci_atmu(struct pci_controller *hose,
out_be32(&pci->pow[j].powbar, (hose->io_base_phys >> 12)); out_be32(&pci->pow[j].powbar, (hose->io_base_phys >> 12));
/* Enable, IO R/W */ /* Enable, IO R/W */
out_be32(&pci->pow[j].powar, 0x80088000 out_be32(&pci->pow[j].powar, 0x80088000
| (__ilog2(hose->io_resource.end | (ilog2(hose->io_resource.end
- hose->io_resource.start + 1) - 1)); - hose->io_resource.start + 1) - 1));
} }
} }
...@@ -283,7 +283,7 @@ static void setup_pci_atmu(struct pci_controller *hose, ...@@ -283,7 +283,7 @@ static void setup_pci_atmu(struct pci_controller *hose,
} }
sz = min(mem, paddr_lo); sz = min(mem, paddr_lo);
mem_log = __ilog2_u64(sz); mem_log = ilog2(sz);
/* PCIe can overmap inbound & outbound since RX & TX are separated */ /* PCIe can overmap inbound & outbound since RX & TX are separated */
if (early_find_capability(hose, 0, 0, PCI_CAP_ID_EXP)) { if (early_find_capability(hose, 0, 0, PCI_CAP_ID_EXP)) {
...@@ -312,7 +312,7 @@ static void setup_pci_atmu(struct pci_controller *hose, ...@@ -312,7 +312,7 @@ static void setup_pci_atmu(struct pci_controller *hose,
* SWIOTLB and access the full range of memory * SWIOTLB and access the full range of memory
*/ */
if (sz != mem) { if (sz != mem) {
mem_log = __ilog2_u64(mem); mem_log = ilog2(mem);
/* Size window up if we dont fit in exact power-of-2 */ /* Size window up if we dont fit in exact power-of-2 */
if ((1ull << mem_log) != mem) if ((1ull << mem_log) != mem)
...@@ -349,7 +349,7 @@ static void setup_pci_atmu(struct pci_controller *hose, ...@@ -349,7 +349,7 @@ static void setup_pci_atmu(struct pci_controller *hose,
sz -= 1ull << mem_log; sz -= 1ull << mem_log;
if (sz) { if (sz) {
mem_log = __ilog2_u64(sz); mem_log = ilog2(sz);
piwar |= (mem_log - 1); piwar |= (mem_log - 1);
out_be32(&pci->piw[win_idx].pitar, paddr >> 12); out_be32(&pci->piw[win_idx].pitar, paddr >> 12);
......
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