common.h 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. #ifndef __ARCH_ORION5X_COMMON_H
  2. #define __ARCH_ORION5X_COMMON_H
  3. struct dsa_platform_data;
  4. struct mv643xx_eth_platform_data;
  5. struct mv_sata_platform_data;
  6. /*
  7. * Basic Orion init functions used early by machine-setup.
  8. */
  9. void orion5x_map_io(void);
  10. void orion5x_init_early(void);
  11. void orion5x_init_irq(void);
  12. void orion5x_init(void);
  13. extern int orion5x_tclk;
  14. extern struct sys_timer orion5x_timer;
  15. /*
  16. * Enumerations and functions for Orion windows mapping. Used by Orion core
  17. * functions to map its interfaces and by the machine-setup to map its on-
  18. * board devices. Details in /mach-orion/addr-map.c
  19. */
  20. void orion5x_setup_cpu_mbus_bridge(void);
  21. void orion5x_setup_dev_boot_win(u32 base, u32 size);
  22. void orion5x_setup_dev0_win(u32 base, u32 size);
  23. void orion5x_setup_dev1_win(u32 base, u32 size);
  24. void orion5x_setup_dev2_win(u32 base, u32 size);
  25. void orion5x_setup_pcie_wa_win(u32 base, u32 size);
  26. void orion5x_setup_sram_win(void);
  27. void orion5x_ehci0_init(void);
  28. void orion5x_ehci1_init(void);
  29. void orion5x_eth_init(struct mv643xx_eth_platform_data *eth_data);
  30. void orion5x_eth_switch_init(struct dsa_platform_data *d, int irq);
  31. void orion5x_i2c_init(void);
  32. void orion5x_sata_init(struct mv_sata_platform_data *sata_data);
  33. void orion5x_spi_init(void);
  34. void orion5x_uart0_init(void);
  35. void orion5x_uart1_init(void);
  36. void orion5x_xor_init(void);
  37. void orion5x_restart(char, const char *);
  38. /*
  39. * PCIe/PCI functions.
  40. */
  41. struct pci_bus;
  42. struct pci_sys_data;
  43. struct pci_dev;
  44. void orion5x_pcie_id(u32 *dev, u32 *rev);
  45. void orion5x_pci_disable(void);
  46. void orion5x_pci_set_cardbus_mode(void);
  47. int orion5x_pci_sys_setup(int nr, struct pci_sys_data *sys);
  48. struct pci_bus *orion5x_pci_sys_scan_bus(int nr, struct pci_sys_data *sys);
  49. int orion5x_pci_map_irq(const struct pci_dev *dev, u8 slot, u8 pin);
  50. struct meminfo;
  51. struct tag;
  52. extern void __init tag_fixup_mem32(struct tag *, char **, struct meminfo *);
  53. /*****************************************************************************
  54. * Helpers to access Orion registers
  55. ****************************************************************************/
  56. /*
  57. * These are not preempt-safe. Locks, if needed, must be taken
  58. * care of by the caller.
  59. */
  60. #define orion5x_setbits(r, mask) writel(readl(r) | (mask), (r))
  61. #define orion5x_clrbits(r, mask) writel(readl(r) & ~(mask), (r))
  62. #endif