1 /* 2 * Copyright (c) 2006-2021, RT-Thread Development Team 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 * 6 * Change Logs: 7 * Date Author Notes 8 * 2019-02-16 jinsheng The first version for STM32F7xx 9 */ 10 11 #ifndef __SDRAM_PORT_H__ 12 #define __SDRAM_PORT_H__ 13 14 /* parameters for sdram peripheral */ 15 /* Bank1 or Bank2 */ 16 #define SDRAM_TARGET_BANK 1 17 /* stm32f7 Bank1:0XC0000000 Bank2:0XD0000000 */ 18 #define SDRAM_BANK_ADDR ((uint32_t)0XC0000000) 19 /* data width: 8, 16, 32 */ 20 #define SDRAM_DATA_WIDTH 16 21 /* column bit numbers: 8, 9, 10, 11 */ 22 #define SDRAM_COLUMN_BITS 8 23 /* row bit numbers: 11, 12, 13 */ 24 #define SDRAM_ROW_BITS 12 25 /* cas latency clock number: 1, 2, 3 */ 26 #define SDRAM_CAS_LATENCY 3 27 /* read pipe delay: 0, 1, 2 */ 28 #define SDRAM_RPIPE_DELAY 0 29 /* clock divid: 2, 3 */ 30 #define SDCLOCK_PERIOD 2 31 /* refresh rate counter */ 32 #define SDRAM_REFRESH_COUNT ((uint32_t)0x1000) 33 #define SDRAM_SIZE ((uint32_t)0x800000) 34 35 /* Timing configuration for MT48LC4M32B2B5-6A */ 36 /* TMRD: 2 Clock cycles */ 37 #define LOADTOACTIVEDELAY 2 38 /* TXSR: 7x11.90ns */ 39 #define EXITSELFREFRESHDELAY 7 40 /* TRAS: 4x11.90ns */ 41 #define SELFREFRESHTIME 4 42 /* TRC: 7x11.90ns */ 43 #define ROWCYCLEDELAY 7 44 /* TWR: 2 Clock cycles */ 45 #define WRITERECOVERYTIME 3 46 /* TRP: 2x11.90ns */ 47 #define RPDELAY 2 48 /* TRCD: 2x11.90ns */ 49 #define RCDDELAY 2 50 51 /* memory mode register */ 52 #define SDRAM_MODEREG_BURST_LENGTH_1 ((uint16_t)0x0000) 53 #define SDRAM_MODEREG_BURST_LENGTH_2 ((uint16_t)0x0001) 54 #define SDRAM_MODEREG_BURST_LENGTH_4 ((uint16_t)0x0002) 55 #define SDRAM_MODEREG_BURST_LENGTH_8 ((uint16_t)0x0004) 56 #define SDRAM_MODEREG_BURST_TYPE_SEQUENTIAL ((uint16_t)0x0000) 57 #define SDRAM_MODEREG_BURST_TYPE_INTERLEAVED ((uint16_t)0x0008) 58 #define SDRAM_MODEREG_CAS_LATENCY_2 ((uint16_t)0x0020) 59 #define SDRAM_MODEREG_CAS_LATENCY_3 ((uint16_t)0x0030) 60 #define SDRAM_MODEREG_OPERATING_MODE_STANDARD ((uint16_t)0x0000) 61 #define SDRAM_MODEREG_WRITEBURST_MODE_PROGRAMMED ((uint16_t)0x0000) 62 #define SDRAM_MODEREG_WRITEBURST_MODE_SINGLE ((uint16_t)0x0200) 63 64 #endif 65