[POWERPC] Remove PCI-e errata for MPC8641 silicon ver 1.0
Remove errata for PCI-e support of Rev 1.0 of MPC8641 since its considered obselete and is not production level silicon from Freescale. Signed-off-by: Zhang Wei <wei.zhang@freescale.com> Acked-by: Roy Zang <tie-fei.zang@freescale.com> Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
This commit is contained in:
@@ -419,10 +419,6 @@ config SBUS
|
|||||||
config FSL_SOC
|
config FSL_SOC
|
||||||
bool
|
bool
|
||||||
|
|
||||||
config FSL_PCIE
|
|
||||||
bool
|
|
||||||
depends on PPC_86xx
|
|
||||||
|
|
||||||
# Yes MCA RS/6000s exist but Linux-PPC does not currently support any
|
# Yes MCA RS/6000s exist but Linux-PPC does not currently support any
|
||||||
config MCA
|
config MCA
|
||||||
bool
|
bool
|
||||||
|
@@ -186,7 +186,7 @@
|
|||||||
#size-cells = <2>;
|
#size-cells = <2>;
|
||||||
#address-cells = <3>;
|
#address-cells = <3>;
|
||||||
reg = <8000 1000>;
|
reg = <8000 1000>;
|
||||||
bus-range = <0 fe>;
|
bus-range = <0 ff>;
|
||||||
ranges = <02000000 0 80000000 80000000 0 20000000
|
ranges = <02000000 0 80000000 80000000 0 20000000
|
||||||
01000000 0 00000000 e2000000 0 00100000>;
|
01000000 0 00000000 e2000000 0 00100000>;
|
||||||
clock-frequency = <1fca055>;
|
clock-frequency = <1fca055>;
|
||||||
|
@@ -20,12 +20,6 @@ extern int mpc86xx_add_bridge(struct device_node *dev);
|
|||||||
extern int mpc86xx_exclude_device(struct pci_controller *hose,
|
extern int mpc86xx_exclude_device(struct pci_controller *hose,
|
||||||
u_char bus, u_char devfn);
|
u_char bus, u_char devfn);
|
||||||
|
|
||||||
extern void setup_indirect_pcie(struct pci_controller *hose,
|
|
||||||
u32 cfg_addr, u32 cfg_data);
|
|
||||||
extern void setup_indirect_pcie_nomap(struct pci_controller *hose,
|
|
||||||
void __iomem *cfg_addr,
|
|
||||||
void __iomem *cfg_data);
|
|
||||||
|
|
||||||
extern void __init mpc86xx_smp_init(void);
|
extern void __init mpc86xx_smp_init(void);
|
||||||
|
|
||||||
#endif /* __MPC86XX_H__ */
|
#endif /* __MPC86XX_H__ */
|
||||||
|
@@ -358,8 +358,6 @@ mpc86xx_hpcn_setup_arch(void)
|
|||||||
#ifdef CONFIG_PCI
|
#ifdef CONFIG_PCI
|
||||||
for (np = NULL; (np = of_find_node_by_type(np, "pci")) != NULL;)
|
for (np = NULL; (np = of_find_node_by_type(np, "pci")) != NULL;)
|
||||||
mpc86xx_add_bridge(np);
|
mpc86xx_add_bridge(np);
|
||||||
|
|
||||||
ppc_md.pci_exclude_device = mpc86xx_exclude_device;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
printk("MPC86xx HPCN board from Freescale Semiconductor\n");
|
printk("MPC86xx HPCN board from Freescale Semiconductor\n");
|
||||||
|
@@ -133,19 +133,6 @@ mpc86xx_setup_pcie(struct pci_controller *hose, u32 pcie_offset, u32 pcie_size)
|
|||||||
early_write_config_word(hose, 0, 0, PCI_COMMAND, cmd);
|
early_write_config_word(hose, 0, 0, PCI_COMMAND, cmd);
|
||||||
|
|
||||||
early_write_config_byte(hose, 0, 0, PCI_LATENCY_TIMER, 0x80);
|
early_write_config_byte(hose, 0, 0, PCI_LATENCY_TIMER, 0x80);
|
||||||
|
|
||||||
/* PCIE Bus, Fix the MPC8641D host bridge's location to bus 0xFF. */
|
|
||||||
early_read_config_dword(hose, 0, 0, PCI_PRIMARY_BUS, &temps);
|
|
||||||
temps = (temps & 0xff000000) | (0xff) | (0x0 << 8) | (0xfe << 16);
|
|
||||||
early_write_config_dword(hose, 0, 0, PCI_PRIMARY_BUS, temps);
|
|
||||||
}
|
|
||||||
|
|
||||||
int mpc86xx_exclude_device(struct pci_controller *hose, u_char bus, u_char devfn)
|
|
||||||
{
|
|
||||||
if (bus == 0 && PCI_SLOT(devfn) == 0)
|
|
||||||
return PCIBIOS_DEVICE_NOT_FOUND;
|
|
||||||
|
|
||||||
return PCIBIOS_SUCCESSFUL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int __init mpc86xx_add_bridge(struct device_node *dev)
|
int __init mpc86xx_add_bridge(struct device_node *dev)
|
||||||
@@ -173,11 +160,10 @@ int __init mpc86xx_add_bridge(struct device_node *dev)
|
|||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
hose->arch_data = dev;
|
hose->arch_data = dev;
|
||||||
|
|
||||||
/* last_busno = 0xfe cause by MPC8641 PCIE bug */
|
|
||||||
hose->first_busno = bus_range ? bus_range[0] : 0x0;
|
hose->first_busno = bus_range ? bus_range[0] : 0x0;
|
||||||
hose->last_busno = bus_range ? bus_range[1] : 0xfe;
|
hose->last_busno = bus_range ? bus_range[1] : 0xff;
|
||||||
|
|
||||||
setup_indirect_pcie(hose, rsrc.start, rsrc.start + 0x4);
|
setup_indirect_pci(hose, rsrc.start, rsrc.start + 0x4);
|
||||||
|
|
||||||
/* Setup the PCIE host controller. */
|
/* Setup the PCIE host controller. */
|
||||||
mpc86xx_setup_pcie(hose, rsrc.start, rsrc.end - rsrc.start + 1);
|
mpc86xx_setup_pcie(hose, rsrc.start, rsrc.end - rsrc.start + 1);
|
||||||
|
@@ -31,7 +31,6 @@ config PPC_86xx
|
|||||||
bool "Freescale 86xx"
|
bool "Freescale 86xx"
|
||||||
depends on 6xx
|
depends on 6xx
|
||||||
select FSL_SOC
|
select FSL_SOC
|
||||||
select FSL_PCIE
|
|
||||||
select ALTIVEC
|
select ALTIVEC
|
||||||
help
|
help
|
||||||
The Freescale E600 SoCs have 74xx cores.
|
The Freescale E600 SoCs have 74xx cores.
|
||||||
|
@@ -12,7 +12,6 @@ obj-$(CONFIG_PPC_PMI) += pmi.o
|
|||||||
obj-$(CONFIG_U3_DART) += dart_iommu.o
|
obj-$(CONFIG_U3_DART) += dart_iommu.o
|
||||||
obj-$(CONFIG_MMIO_NVRAM) += mmio_nvram.o
|
obj-$(CONFIG_MMIO_NVRAM) += mmio_nvram.o
|
||||||
obj-$(CONFIG_FSL_SOC) += fsl_soc.o
|
obj-$(CONFIG_FSL_SOC) += fsl_soc.o
|
||||||
obj-$(CONFIG_FSL_PCIE) += fsl_pcie.o
|
|
||||||
obj-$(CONFIG_TSI108_BRIDGE) += tsi108_pci.o tsi108_dev.o
|
obj-$(CONFIG_TSI108_BRIDGE) += tsi108_pci.o tsi108_dev.o
|
||||||
obj-$(CONFIG_QUICC_ENGINE) += qe_lib/
|
obj-$(CONFIG_QUICC_ENGINE) += qe_lib/
|
||||||
mv64x60-$(CONFIG_PCI) += mv64x60_pci.o
|
mv64x60-$(CONFIG_PCI) += mv64x60_pci.o
|
||||||
|
@@ -1,171 +0,0 @@
|
|||||||
/*
|
|
||||||
* Support for indirect PCI bridges.
|
|
||||||
*
|
|
||||||
* Copyright (C) 1998 Gabriel Paubert.
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version
|
|
||||||
* 2 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* "Temporary" MPC8548 Errata file -
|
|
||||||
* The standard indirect_pci code should work with future silicon versions.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <linux/kernel.h>
|
|
||||||
#include <linux/pci.h>
|
|
||||||
#include <linux/delay.h>
|
|
||||||
#include <linux/string.h>
|
|
||||||
#include <linux/init.h>
|
|
||||||
#include <linux/bootmem.h>
|
|
||||||
|
|
||||||
#include <asm/io.h>
|
|
||||||
#include <asm/prom.h>
|
|
||||||
#include <asm/pci-bridge.h>
|
|
||||||
#include <asm/machdep.h>
|
|
||||||
|
|
||||||
#define PCI_CFG_OUT out_be32
|
|
||||||
|
|
||||||
/* ERRATA PCI-Ex 14 PCIE Controller timeout */
|
|
||||||
#define PCIE_FIX out_be32(hose->cfg_addr+0x4, 0x0400ffff)
|
|
||||||
|
|
||||||
|
|
||||||
static int
|
|
||||||
indirect_read_config_pcie(struct pci_bus *bus, unsigned int devfn, int offset,
|
|
||||||
int len, u32 *val)
|
|
||||||
{
|
|
||||||
struct pci_controller *hose = bus->sysdata;
|
|
||||||
volatile void __iomem *cfg_data;
|
|
||||||
u32 temp;
|
|
||||||
|
|
||||||
if (ppc_md.pci_exclude_device)
|
|
||||||
if (ppc_md.pci_exclude_device(hose, bus->number, devfn))
|
|
||||||
return PCIBIOS_DEVICE_NOT_FOUND;
|
|
||||||
|
|
||||||
/* Possible artifact of CDCpp50937 needs further investigation */
|
|
||||||
if (devfn != 0x0 && bus->number == 0xff)
|
|
||||||
return PCIBIOS_DEVICE_NOT_FOUND;
|
|
||||||
|
|
||||||
PCIE_FIX;
|
|
||||||
if (bus->number == 0xff) {
|
|
||||||
PCI_CFG_OUT(hose->cfg_addr,
|
|
||||||
(0x80000000 | ((offset & 0xf00) << 16) |
|
|
||||||
(bus->number<< 16)
|
|
||||||
| (devfn << 8) | ((offset & 0xfc) )));
|
|
||||||
} else {
|
|
||||||
PCI_CFG_OUT(hose->cfg_addr,
|
|
||||||
(0x80000001 | ((offset & 0xf00) << 16) |
|
|
||||||
(bus->number<< 16)
|
|
||||||
| (devfn << 8) | ((offset & 0xfc) )));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Note: the caller has already checked that offset is
|
|
||||||
* suitably aligned and that len is 1, 2 or 4.
|
|
||||||
*/
|
|
||||||
/* ERRATA PCI-Ex 12 - Configuration Address/Data Alignment */
|
|
||||||
cfg_data = hose->cfg_data;
|
|
||||||
PCIE_FIX;
|
|
||||||
temp = in_le32(cfg_data);
|
|
||||||
switch (len) {
|
|
||||||
case 1:
|
|
||||||
*val = (temp >> (((offset & 3))*8)) & 0xff;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
*val = (temp >> (((offset & 3))*8)) & 0xffff;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
*val = temp;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return PCIBIOS_SUCCESSFUL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
indirect_write_config_pcie(struct pci_bus *bus, unsigned int devfn, int offset,
|
|
||||||
int len, u32 val)
|
|
||||||
{
|
|
||||||
struct pci_controller *hose = bus->sysdata;
|
|
||||||
volatile void __iomem *cfg_data;
|
|
||||||
u32 temp;
|
|
||||||
|
|
||||||
if (ppc_md.pci_exclude_device)
|
|
||||||
if (ppc_md.pci_exclude_device(hose, bus->number, devfn))
|
|
||||||
return PCIBIOS_DEVICE_NOT_FOUND;
|
|
||||||
|
|
||||||
/* Possible artifact of CDCpp50937 needs further investigation */
|
|
||||||
if (devfn != 0x0 && bus->number == 0xff)
|
|
||||||
return PCIBIOS_DEVICE_NOT_FOUND;
|
|
||||||
|
|
||||||
PCIE_FIX;
|
|
||||||
if (bus->number == 0xff) {
|
|
||||||
PCI_CFG_OUT(hose->cfg_addr,
|
|
||||||
(0x80000000 | ((offset & 0xf00) << 16) |
|
|
||||||
(bus->number << 16)
|
|
||||||
| (devfn << 8) | ((offset & 0xfc) )));
|
|
||||||
} else {
|
|
||||||
PCI_CFG_OUT(hose->cfg_addr,
|
|
||||||
(0x80000001 | ((offset & 0xf00) << 16) |
|
|
||||||
(bus->number << 16)
|
|
||||||
| (devfn << 8) | ((offset & 0xfc) )));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Note: the caller has already checked that offset is
|
|
||||||
* suitably aligned and that len is 1, 2 or 4.
|
|
||||||
*/
|
|
||||||
/* ERRATA PCI-Ex 12 - Configuration Address/Data Alignment */
|
|
||||||
cfg_data = hose->cfg_data;
|
|
||||||
switch (len) {
|
|
||||||
case 1:
|
|
||||||
PCIE_FIX;
|
|
||||||
temp = in_le32(cfg_data);
|
|
||||||
temp = (temp & ~(0xff << ((offset & 3) * 8))) |
|
|
||||||
(val << ((offset & 3) * 8));
|
|
||||||
PCIE_FIX;
|
|
||||||
out_le32(cfg_data, temp);
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
PCIE_FIX;
|
|
||||||
temp = in_le32(cfg_data);
|
|
||||||
temp = (temp & ~(0xffff << ((offset & 3) * 8)));
|
|
||||||
temp |= (val << ((offset & 3) * 8)) ;
|
|
||||||
PCIE_FIX;
|
|
||||||
out_le32(cfg_data, temp);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
PCIE_FIX;
|
|
||||||
out_le32(cfg_data, val);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
PCIE_FIX;
|
|
||||||
return PCIBIOS_SUCCESSFUL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct pci_ops indirect_pcie_ops = {
|
|
||||||
indirect_read_config_pcie,
|
|
||||||
indirect_write_config_pcie
|
|
||||||
};
|
|
||||||
|
|
||||||
void __init
|
|
||||||
setup_indirect_pcie_nomap(struct pci_controller* hose, void __iomem * cfg_addr,
|
|
||||||
void __iomem * cfg_data)
|
|
||||||
{
|
|
||||||
hose->cfg_addr = cfg_addr;
|
|
||||||
hose->cfg_data = cfg_data;
|
|
||||||
hose->ops = &indirect_pcie_ops;
|
|
||||||
}
|
|
||||||
|
|
||||||
void __init
|
|
||||||
setup_indirect_pcie(struct pci_controller* hose, u32 cfg_addr, u32 cfg_data)
|
|
||||||
{
|
|
||||||
unsigned long base = cfg_addr & PAGE_MASK;
|
|
||||||
void __iomem *mbase, *addr, *data;
|
|
||||||
|
|
||||||
mbase = ioremap(base, PAGE_SIZE);
|
|
||||||
addr = mbase + (cfg_addr & ~PAGE_MASK);
|
|
||||||
if ((cfg_data & PAGE_MASK) != base)
|
|
||||||
mbase = ioremap(cfg_data & PAGE_MASK, PAGE_SIZE);
|
|
||||||
data = mbase + (cfg_data & ~PAGE_MASK);
|
|
||||||
setup_indirect_pcie_nomap(hose, addr, data);
|
|
||||||
}
|
|
Reference in New Issue
Block a user