summaryrefslogtreecommitdiffstats
path: root/c/src/lib/libbsp/arm/atsam/startup/sdram-config.c
diff options
context:
space:
mode:
Diffstat (limited to 'c/src/lib/libbsp/arm/atsam/startup/sdram-config.c')
-rw-r--r--c/src/lib/libbsp/arm/atsam/startup/sdram-config.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/c/src/lib/libbsp/arm/atsam/startup/sdram-config.c b/c/src/lib/libbsp/arm/atsam/startup/sdram-config.c
index 65060a73f7..51c8f02034 100644
--- a/c/src/lib/libbsp/arm/atsam/startup/sdram-config.c
+++ b/c/src/lib/libbsp/arm/atsam/startup/sdram-config.c
@@ -12,10 +12,13 @@
* http://www.rtems.org/license/LICENSE.
*/
+#include <bspopts.h>
#include <chip.h>
#include <include/board_memories.h>
+#if defined ATSAM_SDRAM_IS42S16100E_7BLI
const struct BOARD_Sdram_Config BOARD_Sdram_Config = {
+ /* FIXME: a lot of these values should be calculated using CPU frequency */
.sdramc_tr = 1562,
.sdramc_cr =
SDRAMC_CR_NC_COL8 /* 8 column bits */
@@ -32,3 +35,41 @@ const struct BOARD_Sdram_Config BOARD_Sdram_Config = {
.sdramc_mdr = SDRAMC_MDR_MD_SDRAM,
.sdramc_cfr1 = SDRAMC_CFR1_UNAL_SUPPORTED | SDRAMC_CFR1_TMRD(2)
};
+
+#elif defined ATSAM_SDRAM_IS42S16320F_7BL
+#define CLOCK_CYCLES_FROM_NS_MAX(ns) \
+ (((ns) * (BOARD_MCK / 1000ul / 1000ul)) / 1000ul)
+#define CLOCK_CYCLES_FROM_NS_MIN(ns) (CLOCK_CYCLES_FROM_NS_MAX(ns) + 1)
+
+const struct BOARD_Sdram_Config BOARD_Sdram_Config = {
+ /* 8k refresh cycles every 64ms => 7.8125us */
+ .sdramc_tr = CLOCK_CYCLES_FROM_NS_MAX(7812ul),
+ .sdramc_cr =
+ SDRAMC_CR_NC_COL10
+ | SDRAMC_CR_NR_ROW13
+ | SDRAMC_CR_CAS_LATENCY3
+ | SDRAMC_CR_NB_BANK4
+ | SDRAMC_CR_DBW
+ /* t_WR = 30ns min (t_RC - t_RP - t_RCD;
+ * see data sheet November 2015 page 55);
+ * add some security margin */
+ | SDRAMC_CR_TWR(CLOCK_CYCLES_FROM_NS_MIN(40))
+ | SDRAMC_CR_TRC_TRFC(CLOCK_CYCLES_FROM_NS_MIN(60))
+ | SDRAMC_CR_TRP(CLOCK_CYCLES_FROM_NS_MIN(15))
+ | SDRAMC_CR_TRCD(CLOCK_CYCLES_FROM_NS_MIN(15))
+ | SDRAMC_CR_TRAS(CLOCK_CYCLES_FROM_NS_MIN(37))
+ | SDRAMC_CR_TXSR(CLOCK_CYCLES_FROM_NS_MIN(67)),
+ .sdramc_mdr = SDRAMC_MDR_MD_SDRAM,
+ .sdramc_cfr1 = SDRAMC_CFR1_UNAL_SUPPORTED |
+ SDRAMC_CFR1_TMRD(CLOCK_CYCLES_FROM_NS_MIN(14))
+};
+
+#if CLOCK_CYCLES_FROM_NS_MIN(67) > 0xF
+ /* Prevent the fields to be out of range by checking the one with the biggest
+ * value. */
+ #error SDRAM calculation does not work for the selected clock frequency
+#endif
+
+#else
+ #error SDRAM not supported.
+#endif