powerpc/powernv: Fix endian issues in powernv PCI code

Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent 81063cdd
...@@ -457,7 +457,7 @@ static void pnv_ioda_setup_bus_dma(struct pnv_ioda_pe *pe, struct pci_bus *bus) ...@@ -457,7 +457,7 @@ static void pnv_ioda_setup_bus_dma(struct pnv_ioda_pe *pe, struct pci_bus *bus)
static void pnv_pci_ioda1_tce_invalidate(struct iommu_table *tbl, static void pnv_pci_ioda1_tce_invalidate(struct iommu_table *tbl,
u64 *startp, u64 *endp) u64 *startp, u64 *endp)
{ {
u64 __iomem *invalidate = (u64 __iomem *)tbl->it_index; __be64 __iomem *invalidate = (__be64 __iomem *)tbl->it_index;
unsigned long start, end, inc; unsigned long start, end, inc;
start = __pa(startp); start = __pa(startp);
...@@ -484,7 +484,7 @@ static void pnv_pci_ioda1_tce_invalidate(struct iommu_table *tbl, ...@@ -484,7 +484,7 @@ static void pnv_pci_ioda1_tce_invalidate(struct iommu_table *tbl,
mb(); /* Ensure above stores are visible */ mb(); /* Ensure above stores are visible */
while (start <= end) { while (start <= end) {
__raw_writeq(start, invalidate); __raw_writeq(cpu_to_be64(start), invalidate);
start += inc; start += inc;
} }
...@@ -499,7 +499,7 @@ static void pnv_pci_ioda2_tce_invalidate(struct pnv_ioda_pe *pe, ...@@ -499,7 +499,7 @@ static void pnv_pci_ioda2_tce_invalidate(struct pnv_ioda_pe *pe,
u64 *startp, u64 *endp) u64 *startp, u64 *endp)
{ {
unsigned long start, end, inc; unsigned long start, end, inc;
u64 __iomem *invalidate = (u64 __iomem *)tbl->it_index; __be64 __iomem *invalidate = (__be64 __iomem *)tbl->it_index;
/* We'll invalidate DMA address in PE scope */ /* We'll invalidate DMA address in PE scope */
start = 0x2ul << 60; start = 0x2ul << 60;
...@@ -515,7 +515,7 @@ static void pnv_pci_ioda2_tce_invalidate(struct pnv_ioda_pe *pe, ...@@ -515,7 +515,7 @@ static void pnv_pci_ioda2_tce_invalidate(struct pnv_ioda_pe *pe,
mb(); mb();
while (start <= end) { while (start <= end) {
__raw_writeq(start, invalidate); __raw_writeq(cpu_to_be64(start), invalidate);
start += inc; start += inc;
} }
} }
...@@ -786,8 +786,7 @@ static int pnv_pci_ioda_msi_setup(struct pnv_phb *phb, struct pci_dev *dev, ...@@ -786,8 +786,7 @@ static int pnv_pci_ioda_msi_setup(struct pnv_phb *phb, struct pci_dev *dev,
struct irq_data *idata; struct irq_data *idata;
struct irq_chip *ichip; struct irq_chip *ichip;
unsigned int xive_num = hwirq - phb->msi_base; unsigned int xive_num = hwirq - phb->msi_base;
uint64_t addr64; __be32 data;
uint32_t addr32, data;
int rc; int rc;
/* No PE assigned ? bail out ... no MSI for you ! */ /* No PE assigned ? bail out ... no MSI for you ! */
...@@ -811,6 +810,8 @@ static int pnv_pci_ioda_msi_setup(struct pnv_phb *phb, struct pci_dev *dev, ...@@ -811,6 +810,8 @@ static int pnv_pci_ioda_msi_setup(struct pnv_phb *phb, struct pci_dev *dev,
} }
if (is_64) { if (is_64) {
__be64 addr64;
rc = opal_get_msi_64(phb->opal_id, pe->mve_number, xive_num, 1, rc = opal_get_msi_64(phb->opal_id, pe->mve_number, xive_num, 1,
&addr64, &data); &addr64, &data);
if (rc) { if (rc) {
...@@ -818,9 +819,11 @@ static int pnv_pci_ioda_msi_setup(struct pnv_phb *phb, struct pci_dev *dev, ...@@ -818,9 +819,11 @@ static int pnv_pci_ioda_msi_setup(struct pnv_phb *phb, struct pci_dev *dev,
pci_name(dev), rc); pci_name(dev), rc);
return -EIO; return -EIO;
} }
msg->address_hi = addr64 >> 32; msg->address_hi = be64_to_cpu(addr64) >> 32;
msg->address_lo = addr64 & 0xfffffffful; msg->address_lo = be64_to_cpu(addr64) & 0xfffffffful;
} else { } else {
__be32 addr32;
rc = opal_get_msi_32(phb->opal_id, pe->mve_number, xive_num, 1, rc = opal_get_msi_32(phb->opal_id, pe->mve_number, xive_num, 1,
&addr32, &data); &addr32, &data);
if (rc) { if (rc) {
...@@ -829,9 +832,9 @@ static int pnv_pci_ioda_msi_setup(struct pnv_phb *phb, struct pci_dev *dev, ...@@ -829,9 +832,9 @@ static int pnv_pci_ioda_msi_setup(struct pnv_phb *phb, struct pci_dev *dev,
return -EIO; return -EIO;
} }
msg->address_hi = 0; msg->address_hi = 0;
msg->address_lo = addr32; msg->address_lo = be32_to_cpu(addr32);
} }
msg->data = data; msg->data = be32_to_cpu(data);
/* /*
* Change the IRQ chip for the MSI interrupts on PHB3. * Change the IRQ chip for the MSI interrupts on PHB3.
...@@ -1107,7 +1110,7 @@ void __init pnv_pci_init_ioda_phb(struct device_node *np, ...@@ -1107,7 +1110,7 @@ void __init pnv_pci_init_ioda_phb(struct device_node *np,
struct pnv_phb *phb; struct pnv_phb *phb;
unsigned long size, m32map_off, iomap_off, pemap_off; unsigned long size, m32map_off, iomap_off, pemap_off;
const __be64 *prop64; const __be64 *prop64;
const u32 *prop32; const __be32 *prop32;
int len; int len;
u64 phb_id; u64 phb_id;
void *aux; void *aux;
...@@ -1142,8 +1145,8 @@ void __init pnv_pci_init_ioda_phb(struct device_node *np, ...@@ -1142,8 +1145,8 @@ void __init pnv_pci_init_ioda_phb(struct device_node *np,
spin_lock_init(&phb->lock); spin_lock_init(&phb->lock);
prop32 = of_get_property(np, "bus-range", &len); prop32 = of_get_property(np, "bus-range", &len);
if (prop32 && len == 8) { if (prop32 && len == 8) {
hose->first_busno = prop32[0]; hose->first_busno = be32_to_cpu(prop32[0]);
hose->last_busno = prop32[1]; hose->last_busno = be32_to_cpu(prop32[1]);
} else { } else {
pr_warn(" Broken <bus-range> on %s\n", np->full_name); pr_warn(" Broken <bus-range> on %s\n", np->full_name);
hose->first_busno = 0; hose->first_busno = 0;
...@@ -1175,7 +1178,7 @@ void __init pnv_pci_init_ioda_phb(struct device_node *np, ...@@ -1175,7 +1178,7 @@ void __init pnv_pci_init_ioda_phb(struct device_node *np,
if (!prop32) if (!prop32)
phb->ioda.total_pe = 1; phb->ioda.total_pe = 1;
else else
phb->ioda.total_pe = *prop32; phb->ioda.total_pe = be32_to_cpup(prop32);
phb->ioda.m32_size = resource_size(&hose->mem_resources[0]); phb->ioda.m32_size = resource_size(&hose->mem_resources[0]);
/* FW Has already off top 64k of M32 space (MSI space) */ /* FW Has already off top 64k of M32 space (MSI space) */
......
...@@ -236,7 +236,7 @@ static void pnv_pci_config_check_eeh(struct pnv_phb *phb, ...@@ -236,7 +236,7 @@ static void pnv_pci_config_check_eeh(struct pnv_phb *phb,
{ {
s64 rc; s64 rc;
u8 fstate; u8 fstate;
u16 pcierr; __be16 pcierr;
u32 pe_no; u32 pe_no;
/* /*
...@@ -283,16 +283,16 @@ int pnv_pci_cfg_read(struct device_node *dn, ...@@ -283,16 +283,16 @@ int pnv_pci_cfg_read(struct device_node *dn,
break; break;
} }
case 2: { case 2: {
u16 v16; __be16 v16;
rc = opal_pci_config_read_half_word(phb->opal_id, bdfn, where, rc = opal_pci_config_read_half_word(phb->opal_id, bdfn, where,
&v16); &v16);
*val = (rc == OPAL_SUCCESS) ? v16 : 0xffff; *val = (rc == OPAL_SUCCESS) ? be16_to_cpu(v16) : 0xffff;
break; break;
} }
case 4: { case 4: {
u32 v32; __be32 v32;
rc = opal_pci_config_read_word(phb->opal_id, bdfn, where, &v32); rc = opal_pci_config_read_word(phb->opal_id, bdfn, where, &v32);
*val = (rc == OPAL_SUCCESS) ? v32 : 0xffffffff; *val = (rc == OPAL_SUCCESS) ? be32_to_cpu(v32) : 0xffffffff;
break; break;
} }
default: default:
...@@ -404,7 +404,7 @@ static int pnv_tce_build(struct iommu_table *tbl, long index, long npages, ...@@ -404,7 +404,7 @@ static int pnv_tce_build(struct iommu_table *tbl, long index, long npages,
struct dma_attrs *attrs) struct dma_attrs *attrs)
{ {
u64 proto_tce; u64 proto_tce;
u64 *tcep, *tces; __be64 *tcep, *tces;
u64 rpn; u64 rpn;
proto_tce = TCE_PCI_READ; // Read allowed proto_tce = TCE_PCI_READ; // Read allowed
...@@ -416,7 +416,7 @@ static int pnv_tce_build(struct iommu_table *tbl, long index, long npages, ...@@ -416,7 +416,7 @@ static int pnv_tce_build(struct iommu_table *tbl, long index, long npages,
rpn = __pa(uaddr) >> TCE_SHIFT; rpn = __pa(uaddr) >> TCE_SHIFT;
while (npages--) while (npages--)
*(tcep++) = proto_tce | (rpn++ << TCE_RPN_SHIFT); *(tcep++) = cpu_to_be64(proto_tce | (rpn++ << TCE_RPN_SHIFT));
/* Some implementations won't cache invalid TCEs and thus may not /* Some implementations won't cache invalid TCEs and thus may not
* need that flush. We'll probably turn it_type into a bit mask * need that flush. We'll probably turn it_type into a bit mask
...@@ -430,12 +430,12 @@ static int pnv_tce_build(struct iommu_table *tbl, long index, long npages, ...@@ -430,12 +430,12 @@ static int pnv_tce_build(struct iommu_table *tbl, long index, long npages,
static void pnv_tce_free(struct iommu_table *tbl, long index, long npages) static void pnv_tce_free(struct iommu_table *tbl, long index, long npages)
{ {
u64 *tcep, *tces; __be64 *tcep, *tces;
tces = tcep = ((u64 *)tbl->it_base) + index - tbl->it_offset; tces = tcep = ((u64 *)tbl->it_base) + index - tbl->it_offset;
while (npages--) while (npages--)
*(tcep++) = 0; *(tcep++) = cpu_to_be64(0);
if (tbl->it_type & TCE_PCI_SWINV_FREE) if (tbl->it_type & TCE_PCI_SWINV_FREE)
pnv_pci_ioda_tce_invalidate(tbl, tces, tcep - 1); pnv_pci_ioda_tce_invalidate(tbl, tces, tcep - 1);
...@@ -462,8 +462,8 @@ void pnv_pci_setup_iommu_table(struct iommu_table *tbl, ...@@ -462,8 +462,8 @@ void pnv_pci_setup_iommu_table(struct iommu_table *tbl,
static struct iommu_table *pnv_pci_setup_bml_iommu(struct pci_controller *hose) static struct iommu_table *pnv_pci_setup_bml_iommu(struct pci_controller *hose)
{ {
struct iommu_table *tbl; struct iommu_table *tbl;
const __be64 *basep; const __be64 *basep, *swinvp;
const __be32 *sizep, *swinvp; const __be32 *sizep;
basep = of_get_property(hose->dn, "linux,tce-base", NULL); basep = of_get_property(hose->dn, "linux,tce-base", NULL);
sizep = of_get_property(hose->dn, "linux,tce-size", NULL); sizep = of_get_property(hose->dn, "linux,tce-size", NULL);
...@@ -484,9 +484,8 @@ static struct iommu_table *pnv_pci_setup_bml_iommu(struct pci_controller *hose) ...@@ -484,9 +484,8 @@ static struct iommu_table *pnv_pci_setup_bml_iommu(struct pci_controller *hose)
swinvp = of_get_property(hose->dn, "linux,tce-sw-invalidate-info", swinvp = of_get_property(hose->dn, "linux,tce-sw-invalidate-info",
NULL); NULL);
if (swinvp) { if (swinvp) {
tbl->it_busno = of_read_ulong(&swinvp[1], 2); tbl->it_busno = swinvp[1];
tbl->it_index = tbl->it_index = (unsigned long)ioremap(be64_to_cpup(swinvp), 8);
(unsigned long)ioremap(of_read_number(swinvp, 2), 8);
tbl->it_type = TCE_PCI_SWINV_CREATE | TCE_PCI_SWINV_FREE; tbl->it_type = TCE_PCI_SWINV_CREATE | TCE_PCI_SWINV_FREE;
} }
return tbl; return tbl;
......
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