viper.h 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /*
  2. * arch/arm/mach-pxa/include/mach/viper.h
  3. *
  4. * Author: Ian Campbell
  5. * Created: Feb 03, 2003
  6. * Copyright: Arcom Control Systems.
  7. *
  8. * Maintained by Marc Zyngier <maz@misterjones.org>
  9. * <marc.zyngier@altran.com>
  10. *
  11. * Created based on lubbock.h:
  12. * Author: Nicolas Pitre
  13. * Created: Jun 15, 2001
  14. * Copyright: MontaVista Software Inc.
  15. *
  16. * This program is free software; you can redistribute it and/or modify
  17. * it under the terms of the GNU General Public License version 2 as
  18. * published by the Free Software Foundation.
  19. */
  20. #ifndef ARCH_VIPER_H
  21. #define ARCH_VIPER_H
  22. #define VIPER_BOOT_PHYS PXA_CS0_PHYS
  23. #define VIPER_FLASH_PHYS PXA_CS1_PHYS
  24. #define VIPER_ETH_PHYS PXA_CS2_PHYS
  25. #define VIPER_USB_PHYS PXA_CS3_PHYS
  26. #define VIPER_ETH_DATA_PHYS PXA_CS4_PHYS
  27. #define VIPER_CPLD_PHYS PXA_CS5_PHYS
  28. #define VIPER_CPLD_BASE (0xf0000000)
  29. #define VIPER_PC104IO_BASE (0xf1000000)
  30. #define VIPER_USB_BASE (0xf1800000)
  31. #define VIPER_ETH_GPIO (0)
  32. #define VIPER_CPLD_GPIO (1)
  33. #define VIPER_USB_GPIO (2)
  34. #define VIPER_UARTA_GPIO (4)
  35. #define VIPER_UARTB_GPIO (3)
  36. #define VIPER_CF_CD_GPIO (32)
  37. #define VIPER_CF_RDY_GPIO (8)
  38. #define VIPER_BCKLIGHT_EN_GPIO (9)
  39. #define VIPER_LCD_EN_GPIO (10)
  40. #define VIPER_PSU_DATA_GPIO (6)
  41. #define VIPER_PSU_CLK_GPIO (11)
  42. #define VIPER_UART_SHDN_GPIO (12)
  43. #define VIPER_BRIGHTNESS_GPIO (16)
  44. #define VIPER_PSU_nCS_LD_GPIO (19)
  45. #define VIPER_UPS_GPIO (20)
  46. #define VIPER_CF_POWER_GPIO (82)
  47. #define VIPER_TPM_I2C_SDA_GPIO (26)
  48. #define VIPER_TPM_I2C_SCL_GPIO (27)
  49. #define VIPER_RTC_I2C_SDA_GPIO (83)
  50. #define VIPER_RTC_I2C_SCL_GPIO (84)
  51. #define VIPER_CPLD_P2V(x) ((x) - VIPER_CPLD_PHYS + VIPER_CPLD_BASE)
  52. #define VIPER_CPLD_V2P(x) ((x) - VIPER_CPLD_BASE + VIPER_CPLD_PHYS)
  53. #ifndef __ASSEMBLY__
  54. # define __VIPER_CPLD_REG(x) (*((volatile u16 *)VIPER_CPLD_P2V(x)))
  55. #endif
  56. /* board level registers in the CPLD: (offsets from CPLD_BASE) ... */
  57. /* ... Physical addresses */
  58. #define _VIPER_LO_IRQ_STATUS (VIPER_CPLD_PHYS + 0x100000)
  59. #define _VIPER_ICR_PHYS (VIPER_CPLD_PHYS + 0x100002)
  60. #define _VIPER_HI_IRQ_STATUS (VIPER_CPLD_PHYS + 0x100004)
  61. #define _VIPER_VERSION_PHYS (VIPER_CPLD_PHYS + 0x100006)
  62. #define VIPER_UARTA_PHYS (VIPER_CPLD_PHYS + 0x300010)
  63. #define VIPER_UARTB_PHYS (VIPER_CPLD_PHYS + 0x300000)
  64. #define _VIPER_SRAM_BASE (VIPER_CPLD_PHYS + 0x800000)
  65. /* ... Virtual addresses */
  66. #define VIPER_LO_IRQ_STATUS __VIPER_CPLD_REG(_VIPER_LO_IRQ_STATUS)
  67. #define VIPER_HI_IRQ_STATUS __VIPER_CPLD_REG(_VIPER_HI_IRQ_STATUS)
  68. #define VIPER_VERSION __VIPER_CPLD_REG(_VIPER_VERSION_PHYS)
  69. #define VIPER_ICR __VIPER_CPLD_REG(_VIPER_ICR_PHYS)
  70. /* Decode VIPER_VERSION register */
  71. #define VIPER_CPLD_REVISION(x) (((x) >> 5) & 0x7)
  72. #define VIPER_BOARD_VERSION(x) (((x) >> 3) & 0x3)
  73. #define VIPER_BOARD_ISSUE(x) (((x) >> 0) & 0x7)
  74. /* Interrupt and Configuration Register (VIPER_ICR) */
  75. /* This is a write only register. Only CF_RST is used under Linux */
  76. #define VIPER_ICR_RETRIG (1 << 0)
  77. #define VIPER_ICR_AUTO_CLR (1 << 1)
  78. #define VIPER_ICR_R_DIS (1 << 2)
  79. #define VIPER_ICR_CF_RST (1 << 3)
  80. #endif