標(biāo)題: STM32 接外部 SRAM 詳解 [打印本頁]

作者: geige    時(shí)間: 2015-7-26 01:55
標(biāo)題: STM32 接外部 SRAM 詳解
        STM32F103ZET6 自帶了 64K 字節(jié)的 SRAM,對一般應(yīng)用來說,已經(jīng)足夠了,不過在一些對內(nèi)存要求高的場合,STM32 自帶的這些內(nèi)存就不夠用了。比如跑算法或者跑 GUI 等,就可能不太夠用
        IS62WV51216 簡介
        IS62WV51216 是 ISSI(Integrated  Silicon  Solution,  Inc)公司生產(chǎn)的一顆 16 位寬 512K(512*16,即 1M 字節(jié))容量的 CMOS 靜態(tài)內(nèi)存芯片。該芯片具有如下幾個(gè)特點(diǎn):
        l 高速。具有 45ns/55ns 訪問速度。
        l 低功耗。
        l TTL 電平兼容。
        l 全靜態(tài)操作。不需要刷新和時(shí)鐘電路。
        l 三態(tài)輸出。
        l 字節(jié)控制功能。支持高/低字節(jié)控制。
        看看實(shí)現(xiàn) IS62WV51216 的訪問,需要對 FSMC進(jìn)行哪些配置。 這里就做一個(gè)概括性的講解。步驟如下:
        1)使能 FSMC 時(shí)鐘,并配置 FSMC 相關(guān)的 IO 及其時(shí)鐘使能。
        要使用 FSMC,當(dāng)然首先得開啟其時(shí)鐘。然后需要把 FSMC_D0~15,F(xiàn)SMCA0~18 等相關(guān)IO 口,全部配置為復(fù)用輸出,并使能各 IO 組的時(shí)鐘。
        使能 FSMC 時(shí)鐘的方法:
        RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC,ENABLE);
        對于其他 IO 口設(shè)置的方法前面講解很詳細(xì),這里不做過多的講解。
        2)設(shè)置 FSMC BANK1 區(qū)域 3。
        此部分包括設(shè)置區(qū)域 3 的存儲(chǔ)器的工作模式、位寬和讀寫時(shí)序等。我們使用模式 A、16 位寬,讀寫共用一個(gè)時(shí)序寄存器。使用的函數(shù)是:
        void FSMC_NORSRAMInit(FSMC_NORSRAMInitTypeDef* FSMC_NORSRAMInitStruct)
        3)使能 BANK1 區(qū)域 3。
        使能 BANK 的方法跟前面 LCD 實(shí)驗(yàn)也是一樣的,這里也不做詳細(xì)講解,函數(shù)是:
        void FSMC_NORSRAMCmd(uint32_t FSMC_Bank, FunctionalState NewState);
        通過以上幾個(gè)步驟,我們就完成了 FSMC 的配置,可以訪問 IS62WV51216 了,這里還需要注意,因?yàn)槲覀兪褂玫氖?BANK1 的區(qū)域 3,所以 HADDR[27:26]=10,故外部內(nèi)存的首地址為 0X68000000。


  1.     //使用NOR/SRAM的 Bank1.sector3,地址位HADDR[27,26]=10
  2.     //對IS61LV25616/IS62WV25616,地址線范圍為A0~A17
  3.     //對IS61LV51216/IS62WV51216,地址線范圍為A0~A18
  4.     #define Bank1_SRAM3_ADDR ((u32)(0x68000000))        
  5.                               
  6.     //初始化外部SRAM
  7.     void FSMC_SRAM_Init(void)
  8.     {   
  9.         FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;
  10.         FSMC_NORSRAMTimingInitTypeDef readWriteTiming;
  11.         GPIO_InitTypeDef GPIO_InitStructure;
  12.      
  13.          RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_GPIOE|RCC_APB2Periph_GPIOF|RCC_APB2Periph_GPIOG,ENABLE);
  14.           RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC,ENABLE);
  15.       
  16.         GPIO_InitStructure.GPIO_Pin = 0xFF33;                  //PORTD復(fù)用推挽輸出
  17.          GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;          //復(fù)用推挽輸出
  18.          GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  19.          GPIO_Init(GPIOD, &GPIO_InitStructure);

  20.      
  21.         GPIO_InitStructure.GPIO_Pin = 0xFF83;                  //PORTE復(fù)用推挽輸出
  22.          GPIO_Init(GPIOE, &GPIO_InitStructure);

  23.          GPIO_InitStructure.GPIO_Pin = 0xF03F;                  //PORTD復(fù)用推挽輸出
  24.          GPIO_Init(GPIOF, &GPIO_InitStructure);

  25.         GPIO_InitStructure.GPIO_Pin = 0x043F;                  //PORTD復(fù)用推挽輸出
  26.          GPIO_Init(GPIOG, &GPIO_InitStructure);
  27.      
  28.                           
  29.          readWriteTiming.FSMC_AddressSetupTime = 0x00;     //地址建立時(shí)間(ADDSET)為1個(gè)HCLK 1/36M=27ns
  30.         readWriteTiming.FSMC_AddressHoldTime = 0x00;     //地址保持時(shí)間(ADDHLD)模式A未用到   
  31.         readWriteTiming.FSMC_DataSetupTime = 0x03;         //數(shù)據(jù)保持時(shí)間(DATAST)為3個(gè)HCLK 4/72M=55ns(對EM的SRAM芯片)   
  32.         readWriteTiming.FSMC_BusTurnAroundDuration = 0x00;
  33.         readWriteTiming.FSMC_CLKDivision = 0x00;
  34.         readWriteTiming.FSMC_DataLatency = 0x00;
  35.         readWriteTiming.FSMC_AccessMode = FSMC_AccessMode_A;     //模式A
  36.         

  37.      
  38.         FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3;// 這里我們使用NE3 ,也就對應(yīng)BTCR[4],[5]。
  39.         FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;
  40.         FSMC_NORSRAMInitStructure.FSMC_MemoryType =FSMC_MemoryType_SRAM;// FSMC_MemoryType_SRAM; //SRAM
  41.         FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;//存儲(chǔ)器數(shù)據(jù)寬度為16bit
  42.         FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode =FSMC_BurstAccessMode_Disable;// FSMC_BurstAccessMode_Disable;
  43.         FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
  44.         FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait=FSMC_AsynchronousWait_Disable;
  45.         FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;
  46.         FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;
  47.         FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;    //存儲(chǔ)器寫使能
  48.         FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;
  49.         FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; // 讀寫使用相同的時(shí)序
  50.         FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;
  51.         FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &readWriteTiming;
  52.         FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &readWriteTiming; //讀寫同樣時(shí)序

  53.         FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure); //初始化FSMC配置

  54.            FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM3, ENABLE); // 使能BANK3                                       
  55.                                                 
  56.     }
  57.                                                                  
  58.     //在指定地址開始,連續(xù)寫入n個(gè)字節(jié).
  59.     //pBuffer:字節(jié)指針
  60.     //WriteAddr:要寫入的地址
  61.     //n:要寫入的字節(jié)數(shù)
  62.     void FSMC_SRAM_WriteBuffer(u8* pBuffer,u32 WriteAddr,u32 n)
  63.     {
  64.         for(;n!=0;n--)
  65.         {                                       
  66.             *(vu8*)(Bank1_SRAM3_ADDR+WriteAddr)=*pBuffer;   
  67.             WriteAddr+=2;//這里需要加2,是因?yàn)镾TM32的FSMC地址右移一位對其.加2相當(dāng)于加1.
  68.             pBuffer++;
  69.         }
  70.     }                                                                           
  71.     //在指定地址開始,連續(xù)讀出n個(gè)字節(jié).
  72.     //pBuffer:字節(jié)指針
  73.     //ReadAddr:要讀出的起始地址
  74.     //n:要寫入的字節(jié)數(shù)
  75.     void FSMC_SRAM_ReadBuffer(u8* pBuffer,u32 ReadAddr,u32 n)
  76.     {
  77.         for(;n!=0;n--)
  78.         {                                            
  79.             *pBuffer++=*(vu8*)(Bank1_SRAM3_ADDR+ReadAddr);
  80.             ReadAddr+=2;//這里需要加2,是因?yàn)镾TM32的FSMC地址右移一位對其.加2相當(dāng)于加1.
  81.         }
  82.     }
  83.     ////////////////////////////////////////////////////////////////////////////////////////
  84.     //測試函數(shù)
  85.     //在指定地址寫入1個(gè)字節(jié)
  86.     //addr:地址
  87.     //data:要寫入的數(shù)據(jù)
  88.     void fsmc_sram_test_write(u8 data,u32 addr)
  89.     {            
  90.         FSMC_SRAM_WriteBuffer(&data,addr,1);//寫入1個(gè)字節(jié)
  91.     }
  92.     //讀取1個(gè)字節(jié)
  93.     //addr:要讀取的地址
  94.     //返回值:讀取到的數(shù)據(jù)
  95.     u8 fsmc_sram_test_read(u32 addr)
  96.     {
  97.         u8 data;
  98.         FSMC_SRAM_ReadBuffer(&data,addr,1);
  99.         return data;
  100.     }
復(fù)制代碼




作者: psram    時(shí)間: 2016-11-24 14:19
我司代理韓國FIDELIX & JSC品牌psram, sram產(chǎn)品。與ISSI品牌同規(guī)格產(chǎn)品pin to pin兼容, 性價(jià)比高,可以常年穩(wěn)定供貨。已在STM32系列多項(xiàng)平臺(tái)批量出貨中 QQ:1140784820,
作者: SQPI_PSRAM    時(shí)間: 2016-12-5 17:21
本帖最后由 SQPI_PSRAM 于 2016-12-7 10:13 編輯

外接SRAM內(nèi)存擴(kuò)展方案, PSRAM是其中的一種,它分并行PSRAM和串行PSRAM,而串行PSRAM是一種新的、面向小型化應(yīng)用的解決方案

大部分MCU的片上SRAM資源都非常有限,只有幾十KB,有256KB的已經(jīng)非常奢侈。SRAM由于速度比NAND或NOR 閃存的速度快很多,也不存在讀寫壽命限制問題,因此作為高速數(shù)據(jù)存儲(chǔ)無可取代。

然而,由于MCU的管腳數(shù)量有限,一個(gè)并行接口的SRAM、或SDRAM卻需要3~40個(gè)封裝管腳,所以很多MCU并不具備外擴(kuò)SRAM的能力。
串行SRAM是一種解決方案,然而,SRAM比較貴,串行SRAM更加昂貴。

這里介紹一種PSRAM,只要有SPI接口或者QPI接口,就可以實(shí)現(xiàn)SRAM的擴(kuò)展。PSRAM - Pseudo SRAM是一種具有SRAM接口協(xié)議(無需刷新,無需DRAM控制器)、具有DRAM單管存儲(chǔ)結(jié)構(gòu)的存儲(chǔ)器,比SRAM容量大很多,價(jià)格便宜很多,比SDRAM容易使用,功耗也低很多。因此,已經(jīng)得到越來越多的MCU及WiFi-SoC相關(guān)廠家的支持。

一個(gè)8腳SOP-8封裝的SPI/QPI PSRAM,可以提供4MB容量,高達(dá)50MB/s的帶寬。只要由SPI或QPI接口,就可以使用。而一個(gè)13腳的OPI PSRAM,可以提供400MB/s或者3.2Gbps的數(shù)據(jù)吞吐速率。

目前,主要應(yīng)用為2G BB的SIP (MTK, SPRD, RDA)、智能語音交互、可穿戴設(shè)備的GUI動(dòng)畫顯示存儲(chǔ)、圖片數(shù)據(jù)緩存等應(yīng)用。我們的串行PSRAM容量從2MB到8MB,并行PSRAM,容量從4MB到16MB,是MTK、RDA、展訊(SPRD)的主力供應(yīng)商

歡迎交流 SQPI_PSRAM@163.com
作者: JAMESKING    時(shí)間: 2019-5-6 20:49
VTI7064能否放一個(gè)51的例程?謝謝
作者: 英尚微電子    時(shí)間: 2019-5-28 11:57
JAMESKING 發(fā)表于 2019-5-6 20:49
VTI7064能否放一個(gè)51的例程?謝謝

可以加我~Q 3161422826 我發(fā)給你
作者: 電子小萌    時(shí)間: 2020-4-14 11:24
感謝樓主分享
作者: harywang    時(shí)間: 2020-4-23 14:37
現(xiàn)在SRAM價(jià)格多少
作者: luy3728000    時(shí)間: 2020-4-27 11:32
英尚微電子 發(fā)表于 2019-5-28 11:57
可以加我~Q 3161422826 我發(fā)給你

芯片手冊下不了喲,把stm32的驅(qū)動(dòng)代碼也發(fā)我一份吧




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1