日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

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

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

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

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

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

/*NOR/SRAM的存儲(chǔ)塊,共4個(gè)選項(xiàng)*/

FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM2;

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

FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;

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

FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_NOR;

/*存儲(chǔ)器數(shù)據(jù)總線(xiàn)寬度*/

FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;

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

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

FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;

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

/*設(shè)置WAIT信號(hào)有效時(shí)機(jī)*/

FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;

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

FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;

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

FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;

/*使能或關(guān)閉擴(kuò)展模式,擴(kuò)展模式用于訪(fǎng)問(wèn)具有不同讀寫(xiě)操作時(shí)序的存儲(chǔ)器,設(shè)定是否使用單獨(dú)的寫(xiě)時(shí)序*/

FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable;

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

FSMC_NORSRAMInitStructure.FSMC_AsyncWait = FSMC_AsyncWait_Disable;

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

/*設(shè)定讀寫(xiě)時(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讀寫(xiě)外NOR FLASH 存儲(chǔ)器 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)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀(guān)點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

中國(guó)北京(2025年9月10日)—— 業(yè)界領(lǐng)先的半導(dǎo)體器件供應(yīng)商兆易創(chuàng)新GigaDevice(股票代碼 603986)亮相于深圳國(guó)際會(huì)展中心舉辦的第26屆中國(guó)國(guó)際光電博覽會(huì)(展位號(hào):12C12),全面展示GD25 SPI...

關(guān)鍵字: 光通信 MCU Flash

在嵌入式系統(tǒng)中,F(xiàn)lash存儲(chǔ)器因其非易失性、高密度和低成本特性,成為代碼存儲(chǔ)和關(guān)鍵數(shù)據(jù)保存的核心組件。然而,MCU驅(qū)動(dòng)Flash讀寫(xiě)時(shí),開(kāi)發(fā)者常因?qū)τ布匦岳斫獠蛔慊虿僮髁鞒淌韬?,陷入性能下降、?shù)據(jù)損壞甚至硬件損壞的陷...

關(guān)鍵字: MCU驅(qū)動(dòng) Flash

在嵌入式開(kāi)發(fā)中,STM32的時(shí)鐘系統(tǒng)因其靈活性和復(fù)雜性成為開(kāi)發(fā)者關(guān)注的焦點(diǎn)。然而,看似簡(jiǎn)單的時(shí)鐘配置背后,隱藏著諸多易被忽視的陷阱,輕則導(dǎo)致系統(tǒng)不穩(wěn)定,重則引發(fā)硬件損壞。本文從時(shí)鐘源選擇、PLL配置、總線(xiàn)時(shí)鐘分配等關(guān)鍵環(huán)...

關(guān)鍵字: STM32 時(shí)鐘系統(tǒng)

在嵌入式系統(tǒng)開(kāi)發(fā)中,STM32系列微控制器的內(nèi)部溫度傳感器因其低成本、高集成度特性,廣泛應(yīng)用于設(shè)備自檢、環(huán)境監(jiān)測(cè)等場(chǎng)景。然而,受芯片工藝差異和電源噪聲影響,其原始數(shù)據(jù)存在±1.5℃的固有誤差。本文從硬件配置、校準(zhǔn)算法、軟...

關(guān)鍵字: STM32 溫度傳感器

在能源效率與智能化需求雙重驅(qū)動(dòng)下,AC-DC轉(zhuǎn)換器的數(shù)字控制技術(shù)正經(jīng)歷從傳統(tǒng)模擬方案向全數(shù)字架構(gòu)的深刻變革。基于STM32微控制器的PFM(脈沖頻率調(diào)制)+PWM(脈沖寬度調(diào)制)混合調(diào)制策略,結(jié)合動(dòng)態(tài)電壓調(diào)整(Dynam...

關(guān)鍵字: AC-DC STM32

當(dāng)前智能家居產(chǎn)品需求不斷增長(zhǎng) ,在這一背景下 ,對(duì)現(xiàn)有澆花裝置缺陷進(jìn)行了改進(jìn) ,設(shè)計(jì)出基于STM32單片機(jī)的全 自動(dòng)家用澆花機(jī)器人。該設(shè)計(jì)主要由機(jī)械結(jié)構(gòu)和控制系統(tǒng)構(gòu)成 ,機(jī)械結(jié)構(gòu)通過(guò)麥克納姆輪底盤(pán)與噴灑裝置的結(jié)合實(shí)現(xiàn)機(jī)器...

關(guān)鍵字: STM32 麥克納姆輪 安全可靠 通過(guò)性強(qiáng)

用c++編程似乎是讓你的Arduino項(xiàng)目起步的障礙嗎?您想要一種更直觀(guān)的微控制器編程方式嗎?那你需要了解一下Visuino!這個(gè)圖形化編程平臺(tái)將復(fù)雜電子項(xiàng)目的創(chuàng)建變成了拖動(dòng)和連接塊的簡(jiǎn)單任務(wù)。在本文中,我們將帶您完成使...

關(guān)鍵字: Visuino Arduino ESP32 STM32
關(guān)閉