at91sam9263_matrix.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /*
  2. * [origin: Linux kernel include/asm-arm/arch-at91/at91sam9263_matrix.h]
  3. *
  4. * Copyright (C) 2006 Atmel Corporation.
  5. *
  6. * Memory Controllers (MATRIX, EBI) - System peripherals registers.
  7. * Based on AT91SAM9263 datasheet revision B (Preliminary).
  8. *
  9. * SPDX-License-Identifier: GPL-2.0+
  10. */
  11. #ifndef AT91SAM9263_MATRIX_H
  12. #define AT91SAM9263_MATRIX_H
  13. #ifndef __ASSEMBLY__
  14. /*
  15. * This struct defines access to the matrix' maximum of
  16. * 16 masters and 16 slaves.
  17. * Note: not all masters/slaves are available
  18. */
  19. struct at91_matrix {
  20. u32 mcfg[16]; /* Master Configuration Registers */
  21. u32 scfg[16]; /* Slave Configuration Registers */
  22. u32 pras[16][2]; /* Priority Assignment Slave Registers */
  23. u32 mrcr; /* Master Remap Control Register */
  24. u32 filler[0x06];
  25. u32 ebicsa; /* EBI Chip Select Assignment Register */
  26. };
  27. #endif /* __ASSEMBLY__ */
  28. #define AT91_MATRIX_ULBT_INFINITE (0 << 0)
  29. #define AT91_MATRIX_ULBT_SINGLE (1 << 0)
  30. #define AT91_MATRIX_ULBT_FOUR (2 << 0)
  31. #define AT91_MATRIX_ULBT_EIGHT (3 << 0)
  32. #define AT91_MATRIX_ULBT_SIXTEEN (4 << 0)
  33. #define AT91_MATRIX_DEFMSTR_TYPE_NONE (0 << 16)
  34. #define AT91_MATRIX_DEFMSTR_TYPE_LAST (1 << 16)
  35. #define AT91_MATRIX_DEFMSTR_TYPE_FIXED (2 << 16)
  36. #define AT91_MATRIX_FIXED_DEFMSTR_SHIFT 18
  37. #define AT91_MATRIX_ARBT_ROUND_ROBIN (0 << 24)
  38. #define AT91_MATRIX_ARBT_FIXED_PRIORITY (1 << 24)
  39. #define AT91_MATRIX_M0PR_SHIFT 0
  40. #define AT91_MATRIX_M1PR_SHIFT 4
  41. #define AT91_MATRIX_M2PR_SHIFT 8
  42. #define AT91_MATRIX_M3PR_SHIFT 12
  43. #define AT91_MATRIX_M4PR_SHIFT 16
  44. #define AT91_MATRIX_M5PR_SHIFT 20
  45. #define AT91_MATRIX_RCB0 (1 << 0)
  46. #define AT91_MATRIX_RCB1 (1 << 1)
  47. #define AT91_MATRIX_CS1A_SDRAMC (1 << 1)
  48. #define AT91_MATRIX_CS3A_SMC_SMARTMEDIA (1 << 3)
  49. #define AT91_MATRIX_CS4A_SMC_CF1 (1 << 4)
  50. #define AT91_MATRIX_CS5A_SMC_CF2 (1 << 5)
  51. #define AT91_MATRIX_DBPUC (1 << 8)
  52. #define AT91_MATRIX_VDDIOMSEL_1_8V (0 << 16)
  53. #define AT91_MATRIX_VDDIOMSEL_3_3V (1 << 16)
  54. #endif