1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * arch/arm/mach-mv78xx0/common.h 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Core functions for Marvell MV78xx0 SoCs 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * This file is licensed under the terms of the GNU General Public 7*4882a593Smuzhiyun * License version 2. This program is licensed "as is" without any 8*4882a593Smuzhiyun * warranty of any kind, whether express or implied. 9*4882a593Smuzhiyun */ 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #ifndef __ARCH_MV78XX0_COMMON_H 12*4882a593Smuzhiyun #define __ARCH_MV78XX0_COMMON_H 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun #include <linux/reboot.h> 15*4882a593Smuzhiyun 16*4882a593Smuzhiyun struct mv643xx_eth_platform_data; 17*4882a593Smuzhiyun struct mv_sata_platform_data; 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun /* 20*4882a593Smuzhiyun * Basic MV78xx0 init functions used early by machine-setup. 21*4882a593Smuzhiyun */ 22*4882a593Smuzhiyun int mv78xx0_core_index(void); 23*4882a593Smuzhiyun void mv78xx0_map_io(void); 24*4882a593Smuzhiyun void mv78xx0_init(void); 25*4882a593Smuzhiyun void mv78xx0_init_early(void); 26*4882a593Smuzhiyun void mv78xx0_init_irq(void); 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun void mv78xx0_setup_cpu_mbus(void); 29*4882a593Smuzhiyun void mv78xx0_setup_pcie_io_win(int window, u32 base, u32 size, 30*4882a593Smuzhiyun int maj, int min); 31*4882a593Smuzhiyun void mv78xx0_setup_pcie_mem_win(int window, u32 base, u32 size, 32*4882a593Smuzhiyun int maj, int min); 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun void mv78xx0_pcie_id(u32 *dev, u32 *rev); 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun void mv78xx0_ehci0_init(void); 37*4882a593Smuzhiyun void mv78xx0_ehci1_init(void); 38*4882a593Smuzhiyun void mv78xx0_ehci2_init(void); 39*4882a593Smuzhiyun void mv78xx0_ge00_init(struct mv643xx_eth_platform_data *eth_data); 40*4882a593Smuzhiyun void mv78xx0_ge01_init(struct mv643xx_eth_platform_data *eth_data); 41*4882a593Smuzhiyun void mv78xx0_ge10_init(struct mv643xx_eth_platform_data *eth_data); 42*4882a593Smuzhiyun void mv78xx0_ge11_init(struct mv643xx_eth_platform_data *eth_data); 43*4882a593Smuzhiyun void mv78xx0_pcie_init(int init_port0, int init_port1); 44*4882a593Smuzhiyun void mv78xx0_sata_init(struct mv_sata_platform_data *sata_data); 45*4882a593Smuzhiyun void mv78xx0_uart0_init(void); 46*4882a593Smuzhiyun void mv78xx0_uart1_init(void); 47*4882a593Smuzhiyun void mv78xx0_uart2_init(void); 48*4882a593Smuzhiyun void mv78xx0_uart3_init(void); 49*4882a593Smuzhiyun void mv78xx0_i2c_init(void); 50*4882a593Smuzhiyun void mv78xx0_restart(enum reboot_mode, const char *); 51*4882a593Smuzhiyun 52*4882a593Smuzhiyun extern void mv78xx0_timer_init(void); 53*4882a593Smuzhiyun 54*4882a593Smuzhiyun 55*4882a593Smuzhiyun #endif 56