ddr.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Copyright 2015 Freescale Semiconductor, Inc.
  4. */
  5. #ifndef __DDR_H__
  6. #define __DDR_H__
  7. struct board_specific_parameters {
  8. u32 n_ranks;
  9. u32 datarate_mhz_high;
  10. u32 rank_gb;
  11. u32 clk_adjust;
  12. u32 wrlvl_start;
  13. u32 wrlvl_ctl_2;
  14. u32 wrlvl_ctl_3;
  15. };
  16. /*
  17. * These tables contain all valid speeds we want to override with board
  18. * specific parameters. datarate_mhz_high values need to be in ascending order
  19. * for each n_ranks group.
  20. */
  21. static const struct board_specific_parameters udimm0[] = {
  22. /*
  23. * memory controller 0
  24. * num| hi| rank| clk| wrlvl | wrlvl | wrlvl
  25. * ranks| mhz| GB |adjst| start | ctl2 | ctl3
  26. */
  27. {2, 1350, 0, 8, 6, 0x0708090B, 0x0C0D0E09,},
  28. {2, 1666, 0, 10, 9, 0x090A0B0E, 0x0F11110C,},
  29. {2, 1900, 0, 12, 0xA, 0x0B0C0E11, 0x1214140F,},
  30. {2, 2300, 0, 12, 0xB, 0x0C0D0F12, 0x14161610,},
  31. {}
  32. };
  33. /* DP-DDR DIMM */
  34. static const struct board_specific_parameters udimm2[] = {
  35. /*
  36. * memory controller 2
  37. * num| hi| rank| clk| wrlvl | wrlvl | wrlvl
  38. * ranks| mhz| GB |adjst| start | ctl2 | ctl3
  39. */
  40. {2, 1350, 0, 8, 0xd, 0x0C0A0A00, 0x00000009,},
  41. {2, 1666, 0, 8, 0xd, 0x0C0A0A00, 0x00000009,},
  42. {2, 1900, 0, 8, 0xe, 0x0D0C0B00, 0x0000000A,},
  43. {2, 2200, 0, 8, 0xe, 0x0D0C0B00, 0x0000000A,},
  44. {}
  45. };
  46. static const struct board_specific_parameters rdimm0[] = {
  47. /*
  48. * memory controller 0
  49. * num| hi| rank| clk| wrlvl | wrlvl | wrlvl
  50. * ranks| mhz| GB |adjst| start | ctl2 | ctl3
  51. */
  52. {2, 1666, 0, 8, 0x0F, 0x0D0C0A09, 0x0B0C0E08,},
  53. {2, 1900, 0, 8, 0x10, 0x0F0D0B0A, 0x0B0E0F09,},
  54. {2, 2200, 0, 8, 0x13, 0x120F0E0B, 0x0D10110B,},
  55. {}
  56. };
  57. static const struct board_specific_parameters *udimms[] = {
  58. udimm0,
  59. udimm0,
  60. udimm2,
  61. };
  62. static const struct board_specific_parameters *rdimms[] = {
  63. rdimm0,
  64. rdimm0,
  65. udimm2, /* DP-DDR doesn't support RDIMM */
  66. };
  67. #endif