2008-03-27 14:51:41 -04:00
# ifndef __ARCH_ORION5X_COMMON_H
# define __ARCH_ORION5X_COMMON_H
2013-07-08 16:01:40 -07:00
# include <linux/reboot.h>
2008-09-25 16:23:48 +02:00
struct dsa_platform_data ;
2008-04-22 05:37:12 +02:00
struct mv643xx_eth_platform_data ;
struct mv_sata_platform_data ;
2013-07-26 10:17:42 -03:00
# define ORION_MBUS_PCIE_MEM_TARGET 0x04
# define ORION_MBUS_PCIE_MEM_ATTR 0x59
# define ORION_MBUS_PCIE_IO_TARGET 0x04
# define ORION_MBUS_PCIE_IO_ATTR 0x51
# define ORION_MBUS_PCIE_WA_TARGET 0x04
# define ORION_MBUS_PCIE_WA_ATTR 0x79
# define ORION_MBUS_PCI_MEM_TARGET 0x03
# define ORION_MBUS_PCI_MEM_ATTR 0x59
# define ORION_MBUS_PCI_IO_TARGET 0x03
# define ORION_MBUS_PCI_IO_ATTR 0x51
# define ORION_MBUS_DEVBUS_BOOT_TARGET 0x01
# define ORION_MBUS_DEVBUS_BOOT_ATTR 0x0f
# define ORION_MBUS_DEVBUS_TARGET(cs) 0x01
# define ORION_MBUS_DEVBUS_ATTR(cs) (~(1 << cs))
2014-04-13 16:39:38 +02:00
# define ORION_MBUS_SRAM_TARGET 0x09
2013-07-26 10:17:42 -03:00
# define ORION_MBUS_SRAM_ATTR 0x00
2008-03-27 14:51:41 -04:00
/*
* Basic Orion init functions used early by machine - setup .
*/
void orion5x_map_io ( void ) ;
2010-10-15 16:50:26 +02:00
void orion5x_init_early ( void ) ;
2008-03-27 14:51:41 -04:00
void orion5x_init_irq ( void ) ;
void orion5x_init ( void ) ;
2012-11-16 16:39:45 +01:00
void orion5x_id ( u32 * dev , u32 * rev , char * * dev_name ) ;
void clk_init ( void ) ;
2008-08-29 05:55:51 +02:00
extern int orion5x_tclk ;
2012-11-08 12:40:59 -07:00
extern void orion5x_timer_init ( void ) ;
2008-03-27 14:51:41 -04:00
2013-03-21 17:59:18 +01:00
void orion5x_setup_wins ( void ) ;
2008-03-27 14:51:41 -04:00
2008-04-22 05:37:12 +02:00
void orion5x_ehci0_init ( void ) ;
void orion5x_ehci1_init ( void ) ;
void orion5x_eth_init ( struct mv643xx_eth_platform_data * eth_data ) ;
2008-09-25 16:23:48 +02:00
void orion5x_eth_switch_init ( struct dsa_platform_data * d , int irq ) ;
2008-04-22 05:37:12 +02:00
void orion5x_i2c_init ( void ) ;
void orion5x_sata_init ( struct mv_sata_platform_data * sata_data ) ;
[ARM] Orion: add 88F6183 (Orion-1-90) support
The Orion-1-90 (88F6183) is another member of the Orion SoC family,
which has a 16 bit DDR2 interface, one x1 PCIe port (configurable as
Root Complex or Endpoint), one 10/100/1000 ethernet interface, one
USB 2.0 port with PHY, one SPDIF/I2S interface, one SDIO interface,
one TWSI interface, two UARTs, one SPI interface, a NAND controller,
a crypto engine, and a 4-channel DMA engine.
Signed-off-by: Lennert Buytenhek <buytenh@marvell.com>
2008-08-29 06:55:06 +02:00
void orion5x_spi_init ( void ) ;
2008-04-22 05:37:12 +02:00
void orion5x_uart0_init ( void ) ;
void orion5x_uart1_init ( void ) ;
2008-06-16 23:25:12 -11:00
void orion5x_xor_init ( void ) ;
2013-07-08 16:01:40 -07:00
void orion5x_restart ( enum reboot_mode , const char * ) ;
2008-04-22 05:37:12 +02:00
2008-03-27 14:51:41 -04:00
/*
2008-04-22 05:37:12 +02:00
* PCIe / PCI functions .
2008-03-27 14:51:41 -04:00
*/
struct pci_bus ;
2008-04-22 05:37:12 +02:00
struct pci_sys_data ;
2012-05-10 13:25:33 +02:00
struct pci_dev ;
2008-03-27 14:51:41 -04:00
void orion5x_pcie_id ( u32 * dev , u32 * rev ) ;
2008-08-11 12:00:52 +02:00
void orion5x_pci_disable ( void ) ;
2008-06-26 17:12:50 +02:00
void orion5x_pci_set_cardbus_mode ( void ) ;
2008-03-27 14:51:41 -04:00
int orion5x_pci_sys_setup ( int nr , struct pci_sys_data * sys ) ;
struct pci_bus * orion5x_pci_sys_scan_bus ( int nr , struct pci_sys_data * sys ) ;
2011-06-10 15:30:21 +01:00
int orion5x_pci_map_irq ( const struct pci_dev * dev , u8 slot , u8 pin ) ;
2008-03-27 14:51:41 -04:00
struct tag ;
2014-04-13 22:54:58 +01:00
extern void __init tag_fixup_mem32 ( struct tag * , char * * ) ;
2008-03-27 14:51:41 -04:00
2014-04-22 23:26:40 +02:00
# ifdef CONFIG_MACH_MSS2_DT
extern void mss2_init ( void ) ;
# else
static inline void mss2_init ( void ) { }
# endif
2012-02-10 18:29:09 -06:00
/*****************************************************************************
* Helpers to access Orion registers
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
* These are not preempt - safe . Locks , if needed , must be taken
* care of by the caller .
*/
# define orion5x_setbits(r, mask) writel(readl(r) | (mask), (r))
# define orion5x_clrbits(r, mask) writel(readl(r) & ~(mask), (r))
2008-03-27 14:51:41 -04:00
# endif