ti-emif-sram.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /*
  2. * TI AM33XX EMIF Routines
  3. *
  4. * Copyright (C) 2016-2017 Texas Instruments Inc.
  5. * Dave Gerlach
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License as
  9. * published by the Free Software Foundation version 2.
  10. *
  11. * This program is distributed "as is" WITHOUT ANY WARRANTY of any
  12. * kind, whether express or implied; without even the implied warranty
  13. * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. */
  16. #ifndef __LINUX_TI_EMIF_H
  17. #define __LINUX_TI_EMIF_H
  18. #include <linux/kbuild.h>
  19. #include <linux/types.h>
  20. #ifndef __ASSEMBLY__
  21. struct emif_regs_amx3 {
  22. u32 emif_sdcfg_val;
  23. u32 emif_timing1_val;
  24. u32 emif_timing2_val;
  25. u32 emif_timing3_val;
  26. u32 emif_ref_ctrl_val;
  27. u32 emif_zqcfg_val;
  28. u32 emif_pmcr_val;
  29. u32 emif_pmcr_shdw_val;
  30. u32 emif_rd_wr_level_ramp_ctrl;
  31. u32 emif_rd_wr_exec_thresh;
  32. u32 emif_cos_config;
  33. u32 emif_priority_to_cos_mapping;
  34. u32 emif_connect_id_serv_1_map;
  35. u32 emif_connect_id_serv_2_map;
  36. u32 emif_ocp_config_val;
  37. u32 emif_lpddr2_nvm_tim;
  38. u32 emif_lpddr2_nvm_tim_shdw;
  39. u32 emif_dll_calib_ctrl_val;
  40. u32 emif_dll_calib_ctrl_val_shdw;
  41. u32 emif_ddr_phy_ctlr_1;
  42. u32 emif_ext_phy_ctrl_vals[120];
  43. };
  44. struct ti_emif_pm_data {
  45. void __iomem *ti_emif_base_addr_virt;
  46. phys_addr_t ti_emif_base_addr_phys;
  47. unsigned long ti_emif_sram_config;
  48. struct emif_regs_amx3 *regs_virt;
  49. phys_addr_t regs_phys;
  50. } __packed __aligned(8);
  51. struct ti_emif_pm_functions {
  52. u32 save_context;
  53. u32 restore_context;
  54. u32 enter_sr;
  55. u32 exit_sr;
  56. u32 abort_sr;
  57. } __packed __aligned(8);
  58. static inline void ti_emif_asm_offsets(void)
  59. {
  60. DEFINE(EMIF_SDCFG_VAL_OFFSET,
  61. offsetof(struct emif_regs_amx3, emif_sdcfg_val));
  62. DEFINE(EMIF_TIMING1_VAL_OFFSET,
  63. offsetof(struct emif_regs_amx3, emif_timing1_val));
  64. DEFINE(EMIF_TIMING2_VAL_OFFSET,
  65. offsetof(struct emif_regs_amx3, emif_timing2_val));
  66. DEFINE(EMIF_TIMING3_VAL_OFFSET,
  67. offsetof(struct emif_regs_amx3, emif_timing3_val));
  68. DEFINE(EMIF_REF_CTRL_VAL_OFFSET,
  69. offsetof(struct emif_regs_amx3, emif_ref_ctrl_val));
  70. DEFINE(EMIF_ZQCFG_VAL_OFFSET,
  71. offsetof(struct emif_regs_amx3, emif_zqcfg_val));
  72. DEFINE(EMIF_PMCR_VAL_OFFSET,
  73. offsetof(struct emif_regs_amx3, emif_pmcr_val));
  74. DEFINE(EMIF_PMCR_SHDW_VAL_OFFSET,
  75. offsetof(struct emif_regs_amx3, emif_pmcr_shdw_val));
  76. DEFINE(EMIF_RD_WR_LEVEL_RAMP_CTRL_OFFSET,
  77. offsetof(struct emif_regs_amx3, emif_rd_wr_level_ramp_ctrl));
  78. DEFINE(EMIF_RD_WR_EXEC_THRESH_OFFSET,
  79. offsetof(struct emif_regs_amx3, emif_rd_wr_exec_thresh));
  80. DEFINE(EMIF_COS_CONFIG_OFFSET,
  81. offsetof(struct emif_regs_amx3, emif_cos_config));
  82. DEFINE(EMIF_PRIORITY_TO_COS_MAPPING_OFFSET,
  83. offsetof(struct emif_regs_amx3, emif_priority_to_cos_mapping));
  84. DEFINE(EMIF_CONNECT_ID_SERV_1_MAP_OFFSET,
  85. offsetof(struct emif_regs_amx3, emif_connect_id_serv_1_map));
  86. DEFINE(EMIF_CONNECT_ID_SERV_2_MAP_OFFSET,
  87. offsetof(struct emif_regs_amx3, emif_connect_id_serv_2_map));
  88. DEFINE(EMIF_OCP_CONFIG_VAL_OFFSET,
  89. offsetof(struct emif_regs_amx3, emif_ocp_config_val));
  90. DEFINE(EMIF_LPDDR2_NVM_TIM_OFFSET,
  91. offsetof(struct emif_regs_amx3, emif_lpddr2_nvm_tim));
  92. DEFINE(EMIF_LPDDR2_NVM_TIM_SHDW_OFFSET,
  93. offsetof(struct emif_regs_amx3, emif_lpddr2_nvm_tim_shdw));
  94. DEFINE(EMIF_DLL_CALIB_CTRL_VAL_OFFSET,
  95. offsetof(struct emif_regs_amx3, emif_dll_calib_ctrl_val));
  96. DEFINE(EMIF_DLL_CALIB_CTRL_VAL_SHDW_OFFSET,
  97. offsetof(struct emif_regs_amx3, emif_dll_calib_ctrl_val_shdw));
  98. DEFINE(EMIF_DDR_PHY_CTLR_1_OFFSET,
  99. offsetof(struct emif_regs_amx3, emif_ddr_phy_ctlr_1));
  100. DEFINE(EMIF_EXT_PHY_CTRL_VALS_OFFSET,
  101. offsetof(struct emif_regs_amx3, emif_ext_phy_ctrl_vals));
  102. DEFINE(EMIF_REGS_AMX3_SIZE, sizeof(struct emif_regs_amx3));
  103. BLANK();
  104. DEFINE(EMIF_PM_BASE_ADDR_VIRT_OFFSET,
  105. offsetof(struct ti_emif_pm_data, ti_emif_base_addr_virt));
  106. DEFINE(EMIF_PM_BASE_ADDR_PHYS_OFFSET,
  107. offsetof(struct ti_emif_pm_data, ti_emif_base_addr_phys));
  108. DEFINE(EMIF_PM_CONFIG_OFFSET,
  109. offsetof(struct ti_emif_pm_data, ti_emif_sram_config));
  110. DEFINE(EMIF_PM_REGS_VIRT_OFFSET,
  111. offsetof(struct ti_emif_pm_data, regs_virt));
  112. DEFINE(EMIF_PM_REGS_PHYS_OFFSET,
  113. offsetof(struct ti_emif_pm_data, regs_phys));
  114. DEFINE(EMIF_PM_DATA_SIZE, sizeof(struct ti_emif_pm_data));
  115. BLANK();
  116. DEFINE(EMIF_PM_SAVE_CONTEXT_OFFSET,
  117. offsetof(struct ti_emif_pm_functions, save_context));
  118. DEFINE(EMIF_PM_RESTORE_CONTEXT_OFFSET,
  119. offsetof(struct ti_emif_pm_functions, restore_context));
  120. DEFINE(EMIF_PM_ENTER_SR_OFFSET,
  121. offsetof(struct ti_emif_pm_functions, enter_sr));
  122. DEFINE(EMIF_PM_EXIT_SR_OFFSET,
  123. offsetof(struct ti_emif_pm_functions, exit_sr));
  124. DEFINE(EMIF_PM_ABORT_SR_OFFSET,
  125. offsetof(struct ti_emif_pm_functions, abort_sr));
  126. DEFINE(EMIF_PM_FUNCTIONS_SIZE, sizeof(struct ti_emif_pm_functions));
  127. }
  128. struct gen_pool;
  129. int ti_emif_copy_pm_function_table(struct gen_pool *sram_pool, void *dst);
  130. int ti_emif_get_mem_type(void);
  131. #endif
  132. #endif /* __LINUX_TI_EMIF_H */