127 lines
7.4 KiB
C
127 lines
7.4 KiB
C
|
/*!
|
||
|
\file gd32vf103_exmc.h
|
||
|
\brief definitions for the EXMC
|
||
|
|
||
|
\version 2019-6-5, V1.0.0, firmware for GD32VF103
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
Copyright (c) 2019, GigaDevice Semiconductor Inc.
|
||
|
|
||
|
Redistribution and use in source and binary forms, with or without modification,
|
||
|
are permitted provided that the following conditions are met:
|
||
|
|
||
|
1. Redistributions of source code must retain the above copyright notice, this
|
||
|
list of conditions and the following disclaimer.
|
||
|
2. 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.
|
||
|
3. Neither the name of the copyright holder 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 HOLDER 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 GD32VF103_EXMC_H
|
||
|
#define GD32VF103_EXMC_H
|
||
|
|
||
|
#include "gd32vf103.h"
|
||
|
|
||
|
/* EXMC definitions */
|
||
|
#define EXMC (EXMC_BASE) /*!< EXMC register base address */
|
||
|
|
||
|
/* registers definitions */
|
||
|
/* NOR/PSRAM */
|
||
|
#define EXMC_SNCTL0 REG32(EXMC + 0x00U) /*!< EXMC SRAM/NOR flash control register 0 */
|
||
|
#define EXMC_SNTCFG0 REG32(EXMC + 0x04U) /*!< EXMC SRAM/NOR flash timing configuration register 0 */
|
||
|
#define EXMC_SNWTCFG0 REG32(EXMC + 0x104U) /*!< EXMC SRAM/NOR flash write timing configuration register 0 */
|
||
|
|
||
|
/* bits definitions */
|
||
|
/* NOR/PSRAM */
|
||
|
/* EXMC_SNCTLx, x=0 */
|
||
|
#define EXMC_SNCTL_NRBKEN BIT(0) /*!< NOR bank enable */
|
||
|
#define EXMC_SNCTL_NRMUX BIT(1) /*!< NOR bank memory address/data multiplexing */
|
||
|
#define EXMC_SNCTL_NRTP BITS(2,3) /*!< NOR bank memory type */
|
||
|
#define EXMC_SNCTL_NRW BITS(4,5) /*!< NOR bank memory data bus width */
|
||
|
#define EXMC_SNCTL_NREN BIT(6) /*!< NOR flash access enable */
|
||
|
#define EXMC_SNCTL_NRWTPOL BIT(9) /*!< NWAIT signal polarity */
|
||
|
#define EXMC_SNCTL_WREN BIT(12) /*!< write enable */
|
||
|
#define EXMC_SNCTL_NRWTEN BIT(13) /*!< NWAIT signal enable */
|
||
|
#define EXMC_SNCTL_ASYNCWAIT BIT(15) /*!< asynchronous wait */
|
||
|
|
||
|
/* EXMC_SNTCFGx, x=0 */
|
||
|
#define EXMC_SNTCFG_ASET BITS(0,3) /*!< address setup time */
|
||
|
#define EXMC_SNTCFG_AHLD BITS(4,7) /*!< address hold time */
|
||
|
#define EXMC_SNTCFG_DSET BITS(8,15) /*!< data setup time */
|
||
|
#define EXMC_SNTCFG_BUSLAT BITS(16,19) /*!< bus latency */
|
||
|
|
||
|
/* constants definitions */
|
||
|
/* EXMC NOR/SRAM timing initialize struct */
|
||
|
typedef struct
|
||
|
{
|
||
|
uint32_t bus_latency; /*!< configure the bus latency */
|
||
|
uint32_t asyn_data_setuptime; /*!< configure the data setup time,asynchronous access mode valid */
|
||
|
uint32_t asyn_address_holdtime; /*!< configure the address hold time,asynchronous access mode valid */
|
||
|
uint32_t asyn_address_setuptime; /*!< configure the data setup time,asynchronous access mode valid */
|
||
|
}exmc_norsram_timing_parameter_struct;
|
||
|
|
||
|
/* EXMC NOR/SRAM initialize struct */
|
||
|
typedef struct
|
||
|
{
|
||
|
uint32_t norsram_region; /*!< select the region of EXMC NOR/SRAM bank */
|
||
|
uint32_t asyn_wait; /*!< enable or disable the asynchronous wait function */
|
||
|
uint32_t nwait_signal; /*!< enable or disable the NWAIT signal */
|
||
|
uint32_t memory_write; /*!< enable or disable the write operation */
|
||
|
uint32_t nwait_polarity; /*!< specifies the polarity of NWAIT signal from memory */
|
||
|
uint32_t databus_width; /*!< specifies the databus width of external memory */
|
||
|
uint32_t memory_type; /*!< specifies the type of external memory */
|
||
|
uint32_t address_data_mux; /*!< specifies whether the data bus and address bus are multiplexed */
|
||
|
exmc_norsram_timing_parameter_struct* read_write_timing; /*!< timing parameters for read and write */
|
||
|
}exmc_norsram_parameter_struct;
|
||
|
|
||
|
/* EXMC register address */
|
||
|
#define EXMC_SNCTL(region) REG32(EXMC + 0x08U * (region)) /*!< EXMC SRAM/NOR flash control register */
|
||
|
#define EXMC_SNTCFG(region) REG32(EXMC + 0x04U + 0x08U * (region)) /*!< EXMC SRAM/NOR flash timing configuration register */
|
||
|
|
||
|
/* NOR bank memory data bus width */
|
||
|
#define SNCTL_NRW(regval) (BITS(4,5) & ((uint32_t)(regval) << 4))
|
||
|
#define EXMC_NOR_DATABUS_WIDTH_8B SNCTL_NRW(0) /*!< NOR data width 8 bits */
|
||
|
#define EXMC_NOR_DATABUS_WIDTH_16B SNCTL_NRW(1) /*!< NOR data width 16 bits */
|
||
|
|
||
|
/* NOR bank memory type */
|
||
|
#define SNCTL_NRTP(regval) (BITS(2,3) & ((uint32_t)(regval) << 2))
|
||
|
#define EXMC_MEMORY_TYPE_SRAM SNCTL_NRTP(0) /*!< SRAM,ROM */
|
||
|
#define EXMC_MEMORY_TYPE_PSRAM SNCTL_NRTP(1) /*!< PSRAM,CRAM */
|
||
|
#define EXMC_MEMORY_TYPE_NOR SNCTL_NRTP(2) /*!< NOR flash */
|
||
|
|
||
|
/* EXMC NOR/SRAM bank region definition */
|
||
|
#define EXMC_BANK0_NORSRAM_REGION0 ((uint32_t)0x00000000U) /*!< bank0 NOR/SRAM region0 */
|
||
|
|
||
|
/* EXMC NWAIT signal polarity configuration */
|
||
|
#define EXMC_NWAIT_POLARITY_LOW ((uint32_t)0x00000000U) /*!< low level is active of NWAIT */
|
||
|
#define EXMC_NWAIT_POLARITY_HIGH ((uint32_t)0x00000200U) /*!< high level is active of NWAIT */
|
||
|
|
||
|
/* function declarations */
|
||
|
/* deinitialize EXMC NOR/SRAM region */
|
||
|
void exmc_norsram_deinit(uint32_t norsram_region);
|
||
|
/* exmc_norsram_parameter_struct parameter initialize */
|
||
|
void exmc_norsram_struct_para_init(exmc_norsram_parameter_struct* exmc_norsram_init_struct);
|
||
|
/* initialize EXMC NOR/SRAM region */
|
||
|
void exmc_norsram_init(exmc_norsram_parameter_struct* exmc_norsram_init_struct);
|
||
|
/* EXMC NOR/SRAM bank enable */
|
||
|
void exmc_norsram_enable(uint32_t norsram_region);
|
||
|
/* EXMC NOR/SRAM bank disable */
|
||
|
void exmc_norsram_disable(uint32_t norsram_region);
|
||
|
|
||
|
#endif /* GD32VF103_EXMC_H */
|