|
|
|
/*
|
|
|
|
* Register definitions for SDRAM Controller
|
|
|
|
*/
|
|
|
|
#ifndef __ASM_AVR32_HSDRAMC1_H__
|
|
|
|
#define __ASM_AVR32_HSDRAMC1_H__
|
|
|
|
|
|
|
|
/* HSDRAMC1 register offsets */
|
|
|
|
#define HSDRAMC1_MR 0x0000
|
|
|
|
#define HSDRAMC1_TR 0x0004
|
|
|
|
#define HSDRAMC1_CR 0x0008
|
|
|
|
#define HSDRAMC1_HSR 0x000c
|
|
|
|
#define HSDRAMC1_LPR 0x0010
|
|
|
|
#define HSDRAMC1_IER 0x0014
|
|
|
|
#define HSDRAMC1_IDR 0x0018
|
|
|
|
#define HSDRAMC1_IMR 0x001c
|
|
|
|
#define HSDRAMC1_ISR 0x0020
|
|
|
|
#define HSDRAMC1_MDR 0x0024
|
|
|
|
#define HSDRAMC1_VERSION 0x00fc
|
|
|
|
|
|
|
|
/* Bitfields in MR */
|
|
|
|
#define HSDRAMC1_MODE_OFFSET 0
|
|
|
|
#define HSDRAMC1_MODE_SIZE 3
|
|
|
|
|
|
|
|
/* Bitfields in TR */
|
|
|
|
#define HSDRAMC1_COUNT_OFFSET 0
|
|
|
|
#define HSDRAMC1_COUNT_SIZE 12
|
|
|
|
|
|
|
|
/* Bitfields in CR */
|
|
|
|
#define HSDRAMC1_NC_OFFSET 0
|
|
|
|
#define HSDRAMC1_NC_SIZE 2
|
|
|
|
#define HSDRAMC1_NR_OFFSET 2
|
|
|
|
#define HSDRAMC1_NR_SIZE 2
|
|
|
|
#define HSDRAMC1_NB_OFFSET 4
|
|
|
|
#define HSDRAMC1_NB_SIZE 1
|
|
|
|
#define HSDRAMC1_CAS_OFFSET 5
|
|
|
|
#define HSDRAMC1_CAS_SIZE 2
|
|
|
|
#define HSDRAMC1_DBW_OFFSET 7
|
|
|
|
#define HSDRAMC1_DBW_SIZE 1
|
|
|
|
#define HSDRAMC1_TWR_OFFSET 8
|
|
|
|
#define HSDRAMC1_TWR_SIZE 4
|
|
|
|
#define HSDRAMC1_TRC_OFFSET 12
|
|
|
|
#define HSDRAMC1_TRC_SIZE 4
|
|
|
|
#define HSDRAMC1_TRP_OFFSET 16
|
|
|
|
#define HSDRAMC1_TRP_SIZE 4
|
|
|
|
#define HSDRAMC1_TRCD_OFFSET 20
|
|
|
|
#define HSDRAMC1_TRCD_SIZE 4
|
|
|
|
#define HSDRAMC1_TRAS_OFFSET 24
|
|
|
|
#define HSDRAMC1_TRAS_SIZE 4
|
|
|
|
#define HSDRAMC1_TXSR_OFFSET 28
|
|
|
|
#define HSDRAMC1_TXSR_SIZE 4
|
|
|
|
|
|
|
|
/* Bitfields in HSR */
|
|
|
|
#define HSDRAMC1_DA_OFFSET 0
|
|
|
|
#define HSDRAMC1_DA_SIZE 1
|
|
|
|
|
|
|
|
/* Bitfields in LPR */
|
|
|
|
#define HSDRAMC1_LPCB_OFFSET 0
|
|
|
|
#define HSDRAMC1_LPCB_SIZE 2
|
|
|
|
#define HSDRAMC1_PASR_OFFSET 4
|
|
|
|
#define HSDRAMC1_PASR_SIZE 3
|
|
|
|
#define HSDRAMC1_TCSR_OFFSET 8
|
|
|
|
#define HSDRAMC1_TCSR_SIZE 2
|
|
|
|
#define HSDRAMC1_DS_OFFSET 10
|
|
|
|
#define HSDRAMC1_DS_SIZE 2
|
|
|
|
#define HSDRAMC1_TIMEOUT_OFFSET 12
|
|
|
|
#define HSDRAMC1_TIMEOUT_SIZE 2
|
|
|
|
|
|
|
|
/* Bitfields in IDR */
|
|
|
|
#define HSDRAMC1_RES_OFFSET 0
|
|
|
|
#define HSDRAMC1_RES_SIZE 1
|
|
|
|
|
|
|
|
/* Bitfields in MDR */
|
|
|
|
#define HSDRAMC1_MD_OFFSET 0
|
|
|
|
#define HSDRAMC1_MD_SIZE 2
|
|
|
|
|
|
|
|
/* Bitfields in VERSION */
|
|
|
|
#define HSDRAMC1_VERSION_OFFSET 0
|
|
|
|
#define HSDRAMC1_VERSION_SIZE 12
|
|
|
|
#define HSDRAMC1_MFN_OFFSET 16
|
|
|
|
#define HSDRAMC1_MFN_SIZE 3
|
|
|
|
|
|
|
|
/* Constants for MODE */
|
|
|
|
#define HSDRAMC1_MODE_NORMAL 0
|
|
|
|
#define HSDRAMC1_MODE_NOP 1
|
|
|
|
#define HSDRAMC1_MODE_BANKS_PRECHARGE 2
|
|
|
|
#define HSDRAMC1_MODE_LOAD_MODE 3
|
|
|
|
#define HSDRAMC1_MODE_AUTO_REFRESH 4
|
|
|
|
#define HSDRAMC1_MODE_EXT_LOAD_MODE 5
|
|
|
|
#define HSDRAMC1_MODE_POWER_DOWN 6
|
|
|
|
|
|
|
|
/* Constants for NC */
|
|
|
|
#define HSDRAMC1_NC_8_COLUMN_BITS 0
|
|
|
|
#define HSDRAMC1_NC_9_COLUMN_BITS 1
|
|
|
|
#define HSDRAMC1_NC_10_COLUMN_BITS 2
|
|
|
|
#define HSDRAMC1_NC_11_COLUMN_BITS 3
|
|
|
|
|
|
|
|
/* Constants for NR */
|
|
|
|
#define HSDRAMC1_NR_11_ROW_BITS 0
|
|
|
|
#define HSDRAMC1_NR_12_ROW_BITS 1
|
|
|
|
#define HSDRAMC1_NR_13_ROW_BITS 2
|
|
|
|
|
|
|
|
/* Constants for NB */
|
|
|
|
#define HSDRAMC1_NB_TWO_BANKS 0
|
|
|
|
#define HSDRAMC1_NB_FOUR_BANKS 1
|
|
|
|
|
|
|
|
/* Constants for CAS */
|
|
|
|
#define HSDRAMC1_CAS_ONE_CYCLE 1
|
|
|
|
#define HSDRAMC1_CAS_TWO_CYCLES 2
|
|
|
|
|
|
|
|
/* Constants for DBW */
|
|
|
|
#define HSDRAMC1_DBW_32_BITS 0
|
|
|
|
#define HSDRAMC1_DBW_16_BITS 1
|
|
|
|
|
|
|
|
/* Constants for TIMEOUT */
|
|
|
|
#define HSDRAMC1_TIMEOUT_AFTER_END 0
|
|
|
|
#define HSDRAMC1_TIMEOUT_64_CYC_AFTER_END 1
|
|
|
|
#define HSDRAMC1_TIMEOUT_128_CYC_AFTER_END 2
|
|
|
|
|
|
|
|
/* Constants for MD */
|
|
|
|
#define HSDRAMC1_MD_SDRAM 0
|
|
|
|
#define HSDRAMC1_MD_LOW_POWER_SDRAM 1
|
|
|
|
|
|
|
|
/* Bit manipulation macros */
|
|
|
|
#define HSDRAMC1_BIT(name) \
|
|
|
|
(1 << HSDRAMC1_##name##_OFFSET)
|
|
|
|
#define HSDRAMC1_BF(name,value) \
|
|
|
|
(((value) & ((1 << HSDRAMC1_##name##_SIZE) - 1)) \
|
|
|
|
<< HSDRAMC1_##name##_OFFSET)
|
|
|
|
#define HSDRAMC1_BFEXT(name,value) \
|
|
|
|
(((value) >> HSDRAMC1_##name##_OFFSET) \
|
|
|
|
& ((1 << HSDRAMC1_##name##_SIZE) - 1))
|
|
|
|
#define HSDRAMC1_BFINS(name,value,old) \
|
|
|
|
(((old) & ~(((1 << HSDRAMC1_##name##_SIZE) - 1) \
|
|
|
|
<< HSDRAMC1_##name##_OFFSET)) \
|
|
|
|
| HSDRAMC1_BF(name,value))
|
|
|
|
|
|
|
|
/* Register access macros */
|
|
|
|
#define hsdramc1_readl(reg) \
|
|
|
|
readl((void *)HSDRAMC_BASE + HSDRAMC1_##reg)
|
|
|
|
#define hsdramc1_writel(reg,value) \
|
|
|
|
writel((value), (void *)HSDRAMC_BASE + HSDRAMC1_##reg)
|
|
|
|
|
|
|
|
#endif /* __ASM_AVR32_HSDRAMC1_H__ */
|