當前位置:首頁 > 單片機 > 單片機
[導讀] 一、基本概念(詳細內(nèi)容見st網(wǎng)站stm32應(yīng)用筆記AN2784)1. FSMC配置控制一個NOR閃存存儲器,需要FSMC提供下述功能:●選擇合適的存儲塊映射NOR閃存存儲器:共有4個獨立的存儲塊可以用于與NOR閃存、SRAM和

一、基本概念(詳細內(nèi)容見st網(wǎng)站stm32應(yīng)用筆記AN2784)

1. FSMC配置
控制一個NOR閃存存儲器,需要FSMC提供下述功能:
●選擇合適的存儲塊映射NOR閃存存儲器:共有4個獨立的存儲塊可以用于與NOR閃存、SRAM和PSRAM存儲器接口,每個存儲塊都有一個專用的片選管腳。
●使用或禁止地址/數(shù)據(jù)總線的復用功能。
●選擇所用的存儲器類型:NOR閃存、SRAM或PSRAM。
●定義外部存儲器的數(shù)據(jù)總線寬度:8或16位。
●使用或關(guān)閉同步NOR閃存存儲器的突發(fā)訪問模式。
●配置等待信號的使用:開啟或關(guān)閉,極性設(shè)置,時序配置。
●使用或關(guān)閉擴展模式:擴展模式用于訪問那些具有不同讀寫操作時序的存儲器。
因為NOR閃存/SRAM控制器可以支持異步和同步存儲器,用戶只須根據(jù)存儲器的參數(shù)配置使用到的參數(shù)。
FSMC提供了一些可編程的參數(shù),可以正確地與外部存儲器接口。依存儲器類型的不同,有些參數(shù)是不需要的。
當使用一個外部異步存儲器時,用戶必須按照存儲器的數(shù)據(jù)手冊給出的時序數(shù)據(jù),計算和設(shè)置下列參數(shù):
●ADDSET:地址建立時間
●ADDHOLD:地址保持時間
●DATAST:數(shù)據(jù)建立時間
●ACCMOD:訪問模式 這個參數(shù)允許 FSMC可以靈活地訪問多種異步的靜態(tài)存儲器。共有4種擴展模式允許以不同的時序分別讀寫存儲器。 在擴展模式下,F(xiàn)SMC_BTR用于配置讀操作,F(xiàn)SMC_BWR用于配置寫操作。(譯注:如果讀時序與寫時序相同,只須使用FSMC_BTR即可。)
如果使用了同步的存儲器,用戶必須計算和設(shè)置下述參數(shù):
●CLKDIV:時鐘分頻系數(shù)
●DATLAT:數(shù)據(jù)延時
如果存儲器支持的話,NOR閃存的讀操作可以是同步的,而寫操作仍然是異步的。
當對一個同步的NOR閃存編程時,存儲器會自動地在同步與異步之間切換;因此,必須正確地設(shè)置所有的參數(shù)。

2. 時序計算
如上所述,對于異步NOR閃存存儲器或類似的存儲,有不同的訪問協(xié)議。首先要確定對特定存儲器所需要使用的操作協(xié)議,選擇的依據(jù)是不同的控制信號和存儲器在讀或?qū)懖僮髦械膭幼鳌?br/>對于異步NOR閃存存儲器,需要使用模式2協(xié)議。如果要使用的存儲器有NADV信號,則需要使用擴展的模式B協(xié)議。
我們將使用模式2操作M29W128FL,不使用任何擴展模式,即讀和寫操作的時序是一樣的。這時NOR閃存控制器需要3個時序參數(shù):ADDSET、DATAST和ADDHOLD。
需要根據(jù)NOR閃存存儲器的特性和STM32F10xxx的時鐘HCLK來這些計算參數(shù)。
基于圖3和圖4的NOR閃存存儲器訪問時序,可以得到下述公式:
寫或讀訪問時序是存儲器片選信號的下降沿與上升沿之間的時間,這個時間可以由FSMC時序參數(shù)的函數(shù)計算得到:
寫/讀訪問時間 = ((ADDSET + 1) + (DATAST + 1)) × HCLK
在寫操作中,DATAST用于衡量寫信號的下降沿與上升沿之間的時間參數(shù):
寫使能信號從低變高的時間 = tWP = DATAST × HCLK
為了得到正確的FSMC時序配置,下列時序應(yīng)予以考慮:
●最大的讀/寫訪問時間
●不同的FSMC內(nèi)部延遲
●不同的存儲器內(nèi)部延遲
因此得到:
((ADDSET + 1) + (DATAST + 1)) × HCLK = max (tWC, tRC)
DATAST × HCLK = tWP
DATAST必須滿足:
DATAST = (tAVQV + tsu(Data_NE) + tv(A_NE))/HCLK – ADDSET – 4
二、程序分析

/*-- FSMC Configuration ----------------------------------------------------*/
p.FSMC_AddressSetupTime = 0x05; /*ADDSET 地址建立時間*/
p.FSMC_AddressHoldTime = 0x00; /*ADDHOLD 地址保持時間*/
p.FSMC_DataSetupTime = 0x07; /*DATAST 數(shù)據(jù)建立時間*/
p.FSMC_BusTurnAroundDuration = 0x00; /*BUSTURN 總線返轉(zhuǎn)時間*/
p.FSMC_CLKDivision = 0x00; /*CLKDIV 時鐘分頻*/
p.FSMC_DataLatency = 0x00; /*DATLAT 數(shù)據(jù)保持時間*/
p.FSMC_AccessMode = FSMC_AccessMode_B; /*訪問模式*/

/*NOR/SRAM的存儲塊,共4個選項*/

FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM2;

/*是否選擇地址和數(shù)據(jù)復用數(shù)據(jù)線*/

FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;

/*連接到相應(yīng)存儲塊的外部存儲器類型*/

FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_NOR;

/*存儲器數(shù)據(jù)總線寬度*/

FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;

/*使能或關(guān)閉同步NOR閃存存儲器的突發(fā)訪問模式設(shè)置是否使用迸發(fā)訪問模式(應(yīng)該就是連續(xù)讀寫模式吧)*/
FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable;

/*設(shè)置WAIT信號的有效電平*/

FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;

/*設(shè)置是否使用環(huán)回模式*/
FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;

/*設(shè)置WAIT信號有效時機*/

FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;

/*設(shè)定是否使能寫操作*/

FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;

/*設(shè)定是否使用WAIT信號*/

FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;

/*使能或關(guān)閉擴展模式,擴展模式用于訪問具有不同讀寫操作時序的存儲器,設(shè)定是否使用單獨的寫時序*/

FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable;

/*設(shè)定是否使用異步等待信號*/

FSMC_NORSRAMInitStructure.FSMC_AsyncWait = FSMC_AsyncWait_Disable;

/*設(shè)定是否使用迸發(fā)寫模式*/
FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;

/*設(shè)定讀寫時序*/

FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &p; //

FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p;//

FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure); //

/* Enable FSMC Bank1_NOR Bank */
FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM2, ENABLE); //
}

三、例程:STM32讀寫外NOR FLASH 存儲器 39VF1601

1. fsmc_nor..c

/******************** (C) COPYRIGHT 2008 STMicroelectronics ********************
* File Name : fsmc_nor.c
* Author : MCD Application Team
* Version : V2.0.1
* Date : 06/13/2008
* Description : This file provides a set of functions needed to drive the
* M29W128FL, M29W128GL and S29GL128P NOR memories mounted
* on STM3210E-EVAL board.
********************************************************************************
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
* CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
*******************************************************************************/
/* Includes ------------------------------------------------------------------*/
#include "fsmc_nor.h"

/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
#define Bank1_NOR2_ADDR ((u32)0x64000000)

/* Delay definition */
#define BlockErase_Timeout ((u32)0x00A00000)
#define ChipErase_Timeout ((u32)0x30000000)
#define Program_Timeout ((u32)0x00001400)

/* Private macro -------------------------------------------------------------*/
#define ADDR_SHIFT(A) (Bank1_NOR2_ADDR + (2 * (A)))
#define NOR_WRITE(Address, Data) (*(vu16 *)(Address) = (Data))

/* Private variables ---------------------------------------------------------*/
/* Private function prototypes -----------------------------------------------*/
/* Private functions ---------------------------------------------------------*/
/*******************************************************************************
* Function Name : FSMC_NOR_Init
* Description : Configures the FSMC and GPIOs to interface with the NOR memory.
* This function must be called before any write/read operation
* on the NOR.
* Input : None
* Output : None
* Return : None
*******************************************************************************/
void FSMC_NOR_Init(void)
{
FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;
FSMC_NORSRAMTimingInitTypeDef p;
GPIO_InitTypeDef GPIO_InitStructure;

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉