ftsmc020.h 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /*
  2. * (C) Copyright 2009 Faraday Technology
  3. * Po-Yu Chuang <ratbert@faraday-tech.com>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  18. */
  19. /*
  20. * Static Memory Controller
  21. */
  22. #ifndef __FTSMC020_H
  23. #define __FTSMC020_H
  24. #ifndef __ASSEMBLY__
  25. struct ftsmc020_bank {
  26. unsigned int cr;
  27. unsigned int tpr;
  28. };
  29. struct ftsmc020 {
  30. struct ftsmc020_bank bank[4]; /* 0x00 - 0x1c */
  31. unsigned int pad[8]; /* 0x20 - 0x3c */
  32. unsigned int ssr; /* 0x40 */
  33. };
  34. void ftsmc020_init(void);
  35. #endif /* __ASSEMBLY__ */
  36. /*
  37. * Memory Bank Configuration Register
  38. */
  39. #define FTSMC020_BANK_ENABLE (1 << 28)
  40. #define FTSMC020_BANK_BASE(x) ((x) & 0x0fff1000)
  41. #define FTSMC020_BANK_WPROT (1 << 11)
  42. #define FTSMC020_BANK_TYPE1 (1 << 10)
  43. #define FTSMC020_BANK_TYPE2 (1 << 9)
  44. #define FTSMC020_BANK_TYPE3 (1 << 8)
  45. #define FTSMC020_BANK_SIZE_32K (0xb << 4)
  46. #define FTSMC020_BANK_SIZE_64K (0xc << 4)
  47. #define FTSMC020_BANK_SIZE_128K (0xd << 4)
  48. #define FTSMC020_BANK_SIZE_256K (0xe << 4)
  49. #define FTSMC020_BANK_SIZE_512K (0xf << 4)
  50. #define FTSMC020_BANK_SIZE_1M (0x0 << 4)
  51. #define FTSMC020_BANK_SIZE_2M (0x1 << 4)
  52. #define FTSMC020_BANK_SIZE_4M (0x2 << 4)
  53. #define FTSMC020_BANK_SIZE_8M (0x3 << 4)
  54. #define FTSMC020_BANK_SIZE_16M (0x4 << 4)
  55. #define FTSMC020_BANK_SIZE_32M (0x5 << 4)
  56. #define FTSMC020_BANK_SIZE_64M (0x6 << 4)
  57. #define FTSMC020_BANK_MBW_8 (0x0 << 0)
  58. #define FTSMC020_BANK_MBW_16 (0x1 << 0)
  59. #define FTSMC020_BANK_MBW_32 (0x2 << 0)
  60. /*
  61. * Memory Bank Timing Parameter Register
  62. */
  63. #define FTSMC020_TPR_ETRNA(x) (((x) & 0xf) << 28)
  64. #define FTSMC020_TPR_EATI(x) (((x) & 0xf) << 24)
  65. #define FTSMC020_TPR_RBE (1 << 20)
  66. #define FTSMC020_TPR_AST(x) (((x) & 0x3) << 18)
  67. #define FTSMC020_TPR_CTW(x) (((x) & 0x3) << 16)
  68. #define FTSMC020_TPR_ATI(x) (((x) & 0xf) << 12)
  69. #define FTSMC020_TPR_AT2(x) (((x) & 0x3) << 8)
  70. #define FTSMC020_TPR_WTC(x) (((x) & 0x3) << 6)
  71. #define FTSMC020_TPR_AHT(x) (((x) & 0x3) << 4)
  72. #define FTSMC020_TPR_TRNA(x) (((x) & 0xf) << 0)
  73. #endif /* __FTSMC020_H */