4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-23 04:17:23 +08:00

303 lines
13 KiB
C

//###########################################################################
//
// FILE: F2837xD_emif.h
//
// TITLE: EMIF Register Definitions.
//
//###########################################################################
// $TI Release: F2837xD Support Library v3.05.00.00 $
// $Release Date: Tue Jun 26 03:15:23 CDT 2018 $
// $Copyright:
// Copyright (C) 2013-2018 Texas Instruments Incorporated - http://www.ti.com/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
//
// Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
//
// Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the
// distribution.
//
// Neither the name of Texas Instruments Incorporated nor the names of
// its contributors may be used to endorse or promote products derived
// from this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// $
//###########################################################################
#ifndef __F2837xD_EMIF_H__
#define __F2837xD_EMIF_H__
#ifdef __cplusplus
extern "C" {
#endif
//---------------------------------------------------------------------------
// EMIF Individual Register Bit Definitions:
struct RCSR_BITS { // bits description
Uint16 MINOR_REVISION:8; // 7:0 Minor Revision.
Uint16 MAJOR_REVISION:8; // 15:8 Major Revision.
Uint16 MODULE_ID:14; // 29:16 EMIF module ID.
Uint16 FR:1; // 30 EMIF is running in full rate or half rate.
Uint16 BE:1; // 31 EMIF endian mode.
};
union RCSR_REG {
Uint32 all;
struct RCSR_BITS bit;
};
struct ASYNC_WCCR_BITS { // bits description
Uint16 MAX_EXT_WAIT:8; // 7:0 Maximum Extended Wait cycles.
Uint16 rsvd1:8; // 15:8 Reserved
Uint16 rsvd2:2; // 17:16 Reserved
Uint16 rsvd3:2; // 19:18 Reserved
Uint16 rsvd4:2; // 21:20 Reserved
Uint16 rsvd5:2; // 23:22 Reserved
Uint16 rsvd6:4; // 27:24 Reserved
Uint16 WP0:1; // 28 Polarity for EMxWAIT.
Uint16 rsvd7:1; // 29 Reserved
Uint16 rsvd8:1; // 30 Reserved
Uint16 rsvd9:1; // 31 Reserved
};
union ASYNC_WCCR_REG {
Uint32 all;
struct ASYNC_WCCR_BITS bit;
};
struct SDRAM_CR_BITS { // bits description
Uint16 PAGESIGE:3; // 2:0 Page Size.
Uint16 rsvd1:1; // 3 Reserved
Uint16 IBANK:3; // 6:4 Internal Bank setup of SDRAM devices.
Uint16 rsvd2:1; // 7 Reserved
Uint16 BIT_11_9_LOCK:1; // 8 Bits 11 to 9 are writable only if this bit is set.
Uint16 CL:3; // 11:9 CAS Latency.
Uint16 rsvd3:1; // 12 Reserved
Uint16 rsvd4:1; // 13 Reserved
Uint16 NM:1; // 14 Narrow Mode.
Uint16 rsvd5:1; // 15 Reserved
Uint16 rsvd6:1; // 16 Reserved
Uint16 rsvd7:2; // 18:17 Reserved
Uint16 rsvd8:1; // 19 Reserved
Uint16 rsvd9:3; // 22:20 Reserved
Uint16 rsvd10:3; // 25:23 Reserved
Uint16 rsvd11:3; // 28:26 Reserved
Uint16 PDWR:1; // 29 Perform refreshes during Power Down.
Uint16 PD:1; // 30 Power Down.
Uint16 SR:1; // 31 Self Refresh.
};
union SDRAM_CR_REG {
Uint32 all;
struct SDRAM_CR_BITS bit;
};
struct SDRAM_RCR_BITS { // bits description
Uint16 REFRESH_RATE:13; // 12:0 Refresh Rate.
Uint16 rsvd1:3; // 15:13 Reserved
Uint16 rsvd2:3; // 18:16 Reserved
Uint16 rsvd3:13; // 31:19 Reserved
};
union SDRAM_RCR_REG {
Uint32 all;
struct SDRAM_RCR_BITS bit;
};
struct ASYNC_CS2_CR_BITS { // bits description
Uint16 ASIZE:2; // 1:0 Asynchronous Memory Size.
Uint16 TA:2; // 3:2 Turn Around cycles.
Uint16 R_HOLD:3; // 6:4 Read Strobe Hold cycles.
Uint16 R_STROBE:6; // 12:7 Read Strobe Duration cycles.
Uint32 R_SETUP:4; // 16:13 Read Strobe Setup cycles.
Uint16 W_HOLD:3; // 19:17 Write Strobe Hold cycles.
Uint16 W_STROBE:6; // 25:20 Write Strobe Duration cycles.
Uint16 W_SETUP:4; // 29:26 Write Strobe Setup cycles.
Uint16 EW:1; // 30 Extend Wait mode.
Uint16 SS:1; // 31 Select Strobe mode.
};
union ASYNC_CS2_CR_REG {
Uint32 all;
struct ASYNC_CS2_CR_BITS bit;
};
struct ASYNC_CS3_CR_BITS { // bits description
Uint16 ASIZE:2; // 1:0 Asynchronous Memory Size.
Uint16 TA:2; // 3:2 Turn Around cycles.
Uint16 R_HOLD:3; // 6:4 Read Strobe Hold cycles.
Uint16 R_STROBE:6; // 12:7 Read Strobe Duration cycles.
Uint32 R_SETUP:4; // 16:13 Read Strobe Setup cycles.
Uint16 W_HOLD:3; // 19:17 Write Strobe Hold cycles.
Uint16 W_STROBE:6; // 25:20 Write Strobe Duration cycles.
Uint16 W_SETUP:4; // 29:26 Write Strobe Setup cycles.
Uint16 EW:1; // 30 Extend Wait mode.
Uint16 SS:1; // 31 Select Strobe mode.
};
union ASYNC_CS3_CR_REG {
Uint32 all;
struct ASYNC_CS3_CR_BITS bit;
};
struct ASYNC_CS4_CR_BITS { // bits description
Uint16 ASIZE:2; // 1:0 Asynchronous Memory Size.
Uint16 TA:2; // 3:2 Turn Around cycles.
Uint16 R_HOLD:3; // 6:4 Read Strobe Hold cycles.
Uint16 R_STROBE:6; // 12:7 Read Strobe Duration cycles.
Uint32 R_SETUP:4; // 16:13 Read Strobe Setup cycles.
Uint16 W_HOLD:3; // 19:17 Write Strobe Hold cycles.
Uint16 W_STROBE:6; // 25:20 Write Strobe Duration cycles.
Uint16 W_SETUP:4; // 29:26 Write Strobe Setup cycles.
Uint16 EW:1; // 30 Extend Wait mode.
Uint16 SS:1; // 31 Select Strobe mode.
};
union ASYNC_CS4_CR_REG {
Uint32 all;
struct ASYNC_CS4_CR_BITS bit;
};
struct SDRAM_TR_BITS { // bits description
Uint16 rsvd1:4; // 3:0 Reserved
Uint16 T_RRD:3; // 6:4 Activate to Activate timing for different bank.
Uint16 rsvd2:1; // 7 Reserved
Uint16 T_RC:4; // 11:8 Activate to Activate timing .
Uint16 T_RAS:4; // 15:12 Activate to Precharge timing.
Uint16 T_WR:3; // 18:16 Last Write to Precharge timing.
Uint16 rsvd3:1; // 19 Reserved
Uint16 T_RCD:3; // 22:20 Activate to Read/Write timing.
Uint16 rsvd4:1; // 23 Reserved
Uint16 T_RP:3; // 26:24 Precharge to Activate/Refresh timing.
Uint16 T_RFC:5; // 31:27 Refresh/Load Mode to Refresh/Activate timing
};
union SDRAM_TR_REG {
Uint32 all;
struct SDRAM_TR_BITS bit;
};
struct SDR_EXT_TMNG_BITS { // bits description
Uint16 T_XS:5; // 4:0 Self Refresh exit to new command timing.
Uint16 rsvd1:11; // 15:5 Reserved
Uint16 rsvd2:16; // 31:16 Reserved
};
union SDR_EXT_TMNG_REG {
Uint32 all;
struct SDR_EXT_TMNG_BITS bit;
};
struct INT_RAW_BITS { // bits description
Uint16 AT:1; // 0 Asynchronous Timeout.
Uint16 LT:1; // 1 Line Trap.
Uint16 WR:4; // 5:2 Wait Rise.
Uint16 rsvd1:10; // 15:6 Reserved
Uint16 rsvd2:16; // 31:16 Reserved
};
union INT_RAW_REG {
Uint32 all;
struct INT_RAW_BITS bit;
};
struct INT_MSK_BITS { // bits description
Uint16 AT_MASKED:1; // 0 Asynchronous Timeout.
Uint16 LT_MASKED:1; // 1 Line Trap.
Uint16 WR_MASKED:4; // 5:2 Wait Rise.
Uint16 rsvd1:10; // 15:6 Reserved
Uint16 rsvd2:16; // 31:16 Reserved
};
union INT_MSK_REG {
Uint32 all;
struct INT_MSK_BITS bit;
};
struct INT_MSK_SET_BITS { // bits description
Uint16 AT_MASK_SET:1; // 0 Asynchronous Timeout.
Uint16 LT_MASK_SET:1; // 1 Line Trap.
Uint16 WR_MASK_SET:4; // 5:2 Wait Rise.
Uint16 rsvd1:10; // 15:6 Reserved
Uint16 rsvd2:16; // 31:16 Reserved
};
union INT_MSK_SET_REG {
Uint32 all;
struct INT_MSK_SET_BITS bit;
};
struct INT_MSK_CLR_BITS { // bits description
Uint16 AT_MASK_CLR:1; // 0 Asynchronous Timeout.
Uint16 LT_MASK_CLR:1; // 1 Line Trap.
Uint16 WR_MASK_CLR:4; // 5:2 Wait Rise.
Uint16 rsvd1:10; // 15:6 Reserved
Uint16 rsvd2:16; // 31:16 Reserved
};
union INT_MSK_CLR_REG {
Uint32 all;
struct INT_MSK_CLR_BITS bit;
};
struct EMIF_REGS {
union RCSR_REG RCSR; // Revision Code and Status Register
union ASYNC_WCCR_REG ASYNC_WCCR; // Async Wait Cycle Config Register
union SDRAM_CR_REG SDRAM_CR; // SDRAM (EMxCS0n) Config Register
union SDRAM_RCR_REG SDRAM_RCR; // SDRAM Refresh Control Register
union ASYNC_CS2_CR_REG ASYNC_CS2_CR; // Async 1 (EMxCS2n) Config Register
union ASYNC_CS3_CR_REG ASYNC_CS3_CR; // Async 2 (EMxCS3n) Config Register
union ASYNC_CS4_CR_REG ASYNC_CS4_CR; // Async 3 (EMxCS4n) Config Register
Uint16 rsvd1[2]; // Reserved
union SDRAM_TR_REG SDRAM_TR; // SDRAM Timing Register
Uint16 rsvd2[6]; // Reserved
Uint32 TOTAL_SDRAM_AR; // Total SDRAM Accesses Register
Uint32 TOTAL_SDRAM_ACTR; // Total SDRAM Activate Register
Uint16 rsvd3[2]; // Reserved
union SDR_EXT_TMNG_REG SDR_EXT_TMNG; // SDRAM SR/PD Exit Timing Register
union INT_RAW_REG INT_RAW; // Interrupt Raw Register
union INT_MSK_REG INT_MSK; // Interrupt Masked Register
union INT_MSK_SET_REG INT_MSK_SET; // Interrupt Mask Set Register
union INT_MSK_CLR_REG INT_MSK_CLR; // Interrupt Mask Clear Register
Uint16 rsvd4[72]; // Reserved
};
//---------------------------------------------------------------------------
// EMIF External References & Function Declarations:
//
#ifdef CPU1
extern volatile struct EMIF_REGS Emif1Regs;
extern volatile struct EMIF_REGS Emif2Regs;
#endif
#ifdef CPU2
extern volatile struct EMIF_REGS Emif1Regs;
extern volatile struct EMIF_REGS Emif2Regs;
#endif
#ifdef __cplusplus
}
#endif /* extern "C" */
#endif
//===========================================================================
// End of file.
//===========================================================================