sram.h 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * Interface for functions that need to be run in internal SRAM
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. */
  8. #ifndef __ASSEMBLY__
  9. #include <plat/sram.h>
  10. extern void omap2_sram_ddr_init(u32 *slow_dll_ctrl, u32 fast_dll_ctrl,
  11. u32 base_cs, u32 force_unlock);
  12. extern void omap2_sram_reprogram_sdrc(u32 perf_level, u32 dll_val,
  13. u32 mem_type);
  14. extern u32 omap2_set_prcm(u32 dpll_ctrl_val, u32 sdrc_rfr_val, int bypass);
  15. extern u32 omap3_configure_core_dpll(
  16. u32 m2, u32 unlock_dll, u32 f, u32 inc,
  17. u32 sdrc_rfr_ctrl_0, u32 sdrc_actim_ctrl_a_0,
  18. u32 sdrc_actim_ctrl_b_0, u32 sdrc_mr_0,
  19. u32 sdrc_rfr_ctrl_1, u32 sdrc_actim_ctrl_a_1,
  20. u32 sdrc_actim_ctrl_b_1, u32 sdrc_mr_1);
  21. extern void omap3_sram_restore_context(void);
  22. /* Do not use these */
  23. extern void omap24xx_sram_reprogram_clock(u32 ckctl, u32 dpllctl);
  24. extern unsigned long omap24xx_sram_reprogram_clock_sz;
  25. extern void omap242x_sram_ddr_init(u32 *slow_dll_ctrl, u32 fast_dll_ctrl,
  26. u32 base_cs, u32 force_unlock);
  27. extern unsigned long omap242x_sram_ddr_init_sz;
  28. extern u32 omap242x_sram_set_prcm(u32 dpll_ctrl_val, u32 sdrc_rfr_val,
  29. int bypass);
  30. extern unsigned long omap242x_sram_set_prcm_sz;
  31. extern void omap242x_sram_reprogram_sdrc(u32 perf_level, u32 dll_val,
  32. u32 mem_type);
  33. extern unsigned long omap242x_sram_reprogram_sdrc_sz;
  34. extern void omap243x_sram_ddr_init(u32 *slow_dll_ctrl, u32 fast_dll_ctrl,
  35. u32 base_cs, u32 force_unlock);
  36. extern unsigned long omap243x_sram_ddr_init_sz;
  37. extern u32 omap243x_sram_set_prcm(u32 dpll_ctrl_val, u32 sdrc_rfr_val,
  38. int bypass);
  39. extern unsigned long omap243x_sram_set_prcm_sz;
  40. extern void omap243x_sram_reprogram_sdrc(u32 perf_level, u32 dll_val,
  41. u32 mem_type);
  42. extern unsigned long omap243x_sram_reprogram_sdrc_sz;
  43. extern u32 omap3_sram_configure_core_dpll(
  44. u32 m2, u32 unlock_dll, u32 f, u32 inc,
  45. u32 sdrc_rfr_ctrl_0, u32 sdrc_actim_ctrl_a_0,
  46. u32 sdrc_actim_ctrl_b_0, u32 sdrc_mr_0,
  47. u32 sdrc_rfr_ctrl_1, u32 sdrc_actim_ctrl_a_1,
  48. u32 sdrc_actim_ctrl_b_1, u32 sdrc_mr_1);
  49. extern unsigned long omap3_sram_configure_core_dpll_sz;
  50. #ifdef CONFIG_PM
  51. extern void omap_push_sram_idle(void);
  52. #else
  53. static inline void omap_push_sram_idle(void) {}
  54. #endif /* CONFIG_PM */
  55. #endif /* __ASSEMBLY__ */
  56. /*
  57. * OMAP2+: define the SRAM PA addresses.
  58. * Used by the SRAM management code and the idle sleep code.
  59. */
  60. #define OMAP2_SRAM_PA 0x40200000
  61. #define OMAP3_SRAM_PA 0x40200000
  62. #ifdef CONFIG_OMAP4_ERRATA_I688
  63. #define OMAP4_SRAM_PA 0x40304000
  64. #define OMAP4_SRAM_VA 0xfe404000
  65. #else
  66. #define OMAP4_SRAM_PA 0x40300000
  67. #endif
  68. #define AM33XX_SRAM_PA 0x40300000