lubbock.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Author: Nicolas Pitre
  4. * Created: Jun 15, 2001
  5. * Copyright: MontaVista Software Inc.
  6. */
  7. #include "irqs.h"
  8. #define LUBBOCK_ETH_PHYS PXA_CS3_PHYS
  9. #define LUBBOCK_FPGA_PHYS PXA_CS2_PHYS
  10. #define LUBBOCK_FPGA_VIRT (0xf0000000)
  11. #define LUB_P2V(x) ((x) - LUBBOCK_FPGA_PHYS + LUBBOCK_FPGA_VIRT)
  12. #define LUB_V2P(x) ((x) - LUBBOCK_FPGA_VIRT + LUBBOCK_FPGA_PHYS)
  13. #ifndef __ASSEMBLY__
  14. # define __LUB_REG(x) (*((volatile unsigned long *)LUB_P2V(x)))
  15. #else
  16. # define __LUB_REG(x) LUB_P2V(x)
  17. #endif
  18. /* FPGA register virtual addresses */
  19. #define LUB_WHOAMI __LUB_REG(LUBBOCK_FPGA_PHYS + 0x000)
  20. #define LUB_DISC_BLNK_LED __LUB_REG(LUBBOCK_FPGA_PHYS + 0x040)
  21. #define LUB_CONF_SWITCHES __LUB_REG(LUBBOCK_FPGA_PHYS + 0x050)
  22. #define LUB_USER_SWITCHES __LUB_REG(LUBBOCK_FPGA_PHYS + 0x060)
  23. #define LUB_MISC_WR __LUB_REG(LUBBOCK_FPGA_PHYS + 0x080)
  24. #define LUB_MISC_RD __LUB_REG(LUBBOCK_FPGA_PHYS + 0x090)
  25. #define LUB_IRQ_MASK_EN __LUB_REG(LUBBOCK_FPGA_PHYS + 0x0c0)
  26. #define LUB_IRQ_SET_CLR __LUB_REG(LUBBOCK_FPGA_PHYS + 0x0d0)
  27. #define LUB_GP __LUB_REG(LUBBOCK_FPGA_PHYS + 0x100)
  28. /* Board specific IRQs */
  29. #define LUBBOCK_NR_IRQS IRQ_BOARD_START
  30. #define LUBBOCK_IRQ(x) (LUBBOCK_NR_IRQS + (x))
  31. #define LUBBOCK_SD_IRQ LUBBOCK_IRQ(0)
  32. #define LUBBOCK_SA1111_IRQ LUBBOCK_IRQ(1)
  33. #define LUBBOCK_USB_IRQ LUBBOCK_IRQ(2) /* usb connect */
  34. #define LUBBOCK_ETH_IRQ LUBBOCK_IRQ(3)
  35. #define LUBBOCK_UCB1400_IRQ LUBBOCK_IRQ(4)
  36. #define LUBBOCK_BB_IRQ LUBBOCK_IRQ(5)
  37. #define LUBBOCK_USB_DISC_IRQ LUBBOCK_IRQ(6) /* usb disconnect */
  38. #define LUBBOCK_LAST_IRQ LUBBOCK_IRQ(6)
  39. #define LUBBOCK_SA1111_IRQ_BASE (LUBBOCK_NR_IRQS + 32)