2008-03-28 02:51:40 +08:00
|
|
|
/*
|
2008-08-09 19:44:58 +08:00
|
|
|
* arch/arm/plat-orion/include/plat/pcie.h
|
2008-03-28 02:51:40 +08:00
|
|
|
*
|
|
|
|
* Marvell Orion SoC PCIe handling.
|
|
|
|
*
|
|
|
|
* This file is licensed under the terms of the GNU General Public
|
|
|
|
* License version 2. This program is licensed "as is" without any
|
|
|
|
* warranty of any kind, whether express or implied.
|
|
|
|
*/
|
|
|
|
|
2008-08-09 19:44:58 +08:00
|
|
|
#ifndef __PLAT_PCIE_H
|
|
|
|
#define __PLAT_PCIE_H
|
2008-03-28 02:51:40 +08:00
|
|
|
|
2010-10-22 03:48:33 +08:00
|
|
|
struct pci_bus;
|
|
|
|
|
2008-03-28 02:51:40 +08:00
|
|
|
u32 orion_pcie_dev_id(void __iomem *base);
|
|
|
|
u32 orion_pcie_rev(void __iomem *base);
|
|
|
|
int orion_pcie_link_up(void __iomem *base);
|
2008-06-23 04:45:09 +08:00
|
|
|
int orion_pcie_x4_mode(void __iomem *base);
|
2008-03-28 02:51:40 +08:00
|
|
|
int orion_pcie_get_local_bus_nr(void __iomem *base);
|
|
|
|
void orion_pcie_set_local_bus_nr(void __iomem *base, int nr);
|
2010-10-22 03:48:33 +08:00
|
|
|
void orion_pcie_reset(void __iomem *base);
|
2008-03-28 02:51:40 +08:00
|
|
|
void orion_pcie_setup(void __iomem *base,
|
|
|
|
struct mbus_dram_target_info *dram);
|
|
|
|
int orion_pcie_rd_conf(void __iomem *base, struct pci_bus *bus,
|
|
|
|
u32 devfn, int where, int size, u32 *val);
|
|
|
|
int orion_pcie_rd_conf_tlp(void __iomem *base, struct pci_bus *bus,
|
|
|
|
u32 devfn, int where, int size, u32 *val);
|
|
|
|
int orion_pcie_rd_conf_wa(void __iomem *wa_base, struct pci_bus *bus,
|
|
|
|
u32 devfn, int where, int size, u32 *val);
|
|
|
|
int orion_pcie_wr_conf(void __iomem *base, struct pci_bus *bus,
|
|
|
|
u32 devfn, int where, int size, u32 val);
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|