0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

關于SPI_FLASH時序描述及驅動編程

黃工的嵌入式技術圈 ? 來源:黃工的嵌入式技術圈 ? 2020-03-25 11:15 ? 次閱讀

Ⅰ、寫在前面

寫這篇文章的目的有兩點:1.讓大家知道SPI在實際應用開發(fā)中的重要意義; 2.讓大家掌握SPI FLASH存儲芯片的時序及驅動編程。

市面上的SPI FLASH類型很多,但是絕大部的芯片在硬件和軟件上都是兼容的。雖然本文是以華邦的W25X16芯片為例來講述時序。其實,其它大部分SPI FLASH都適用。

有必要看芯片手冊,按照手冊一步一步寫程序嗎?

1、如果你是初學者,而且還有很多時間,建議花些時間掌握一下! 原因在于作為嵌入式開發(fā)者,需要對芯片的編程有一定了解,在以后工作項目中如果有使用新的芯片,自己就能很容易編寫驅動(如果沒有現(xiàn)成的驅動)。

2、如果你是工作了一斷時間,自己對芯片驅動編程有一些經(jīng)驗,在需要使用新的芯片,如果有現(xiàn)成的、比較成熟的驅動,那么,你可以不用再話費時間自己親自編寫驅動(編寫驅動很費時間,還需要花費一定時間驗證)。

關于本文的更多詳情請往下看。

Ⅱ、實例工程下載

筆者針對于初學者提供的例程都是去掉了許多不必要的功能,精簡了官方的代碼,對初學者一看就明白,以簡單明了的工程供大家學習。

筆者提供的實例工程都是在板子上經(jīng)過多次測試并沒有問題才上傳至360云盤,歡迎下載測試、參照學習。

提供下載的軟件工程是基于Keil(MDK-ARM) V5版本、STM32F103ZE芯片,但F1其他型號也適用(適用F1其他型號: 關注微信,回復“修改型號”)。

STM32F10x_SPI(硬件接口)讀寫Flash(25Q16)實例源代碼工程:

https://yunpan.cn/c6mfRJWva6AJ2訪問密碼 4bc4

STM32F10x_SPI(軟件模擬)讀寫Flash(25Q16)實例源代碼工程:

https://yunpan.cn/c6mf6zyzCaMwd訪問密碼 cf45

SPI FLASH資料:

https://yunpan.cn/c6Yi3agWUnGNQ訪問密碼 d790

STM32F1資料:

https://yunpan.cn/crBUdUGdYKam2訪問密碼 ca90

Ⅲ、關于SPIFLASH

1.SPI FLASH芯片系列

SPI FLASH的種類及型號有很多,但根據(jù)筆者的了解及經(jīng)驗,雖然存在這些差異,但他們之間的兼容性是很好的。

如:W25Xxx系列、W25Qxx系列、GD25Qxx系列、M25Pxx系列、KM25Lxx系列、SST25VFxx系列、AT25F系列等。

2.SPI FLASH命名

每一家公司的芯片型號命名可能略有差異,但看手冊就能明白。我們以華邦的W25系列芯片來舉例說明:


W:代表華邦公司

25X:代表SPI FLASH類型(25X是基本芯片, 25Q是快速芯片)

16:代表16MBit,即2M字節(jié)(64代表8M字節(jié), 128代表16M字節(jié),依次下去)

這個需要大家了解的(主要在項目研發(fā)初級階段對芯片的選型上使用到)。其他公司的芯片,查看方法類似.對比如圖是ST公司的M25PExx系列芯片:

3.W25Xxx讀寫特性

讀:無要求

寫:需要擦除才能寫,一次最多可寫入256字節(jié)(可編程頁)。

擦除:最小扇區(qū)擦除(4K)、可塊擦除(64K)、 可整個芯片擦除。

Ⅳ、SPIFLASH時序及編程

這里還是以華邦的W25X16為例來說明(其他大部分兼容),請下載手冊【W(wǎng)25Xxx手冊(英文版)】參考。

1.預先了解W25Xxx

A.控制和狀態(tài)寄存器命令(默認:0x00)

BIT位 7 6 5 4 3 2 1 0

SPR RV TB BP2 BP1 BP0 WEL BUSY

SPR:默認0,狀態(tài)寄存器保護位,配合WP使用

TB,BP2,BP1,BP0:FLASH區(qū)域寫保護設置

WEL:寫使能鎖定

BUSY:忙標記位(1,忙;0,空閑)

B.指令集表

編程主要就圍繞這些“指令”來編程。在我提供的軟件工程代碼“sflash.h”文件中就定義了和手冊對應的指令,如下圖:

2.寫使能(0x06)

在操作寫(控制、數(shù)據(jù))之前,都需要發(fā)送一條“寫使能”指令。

時序如下圖:


源代碼程序:

3.寫失能(0x04)

和“寫使能”類似,要失能寫,在操作寫(控制、數(shù)據(jù))之后,都需要發(fā)送一條“寫失能”指令。

時序如下圖:

源代碼程序:

4.讀狀態(tài)/控制(0x05)

W25X芯片唯一的狀態(tài)寄存器,各個位的意思請看上面的介紹,比如判斷忙不忙,就需要讀狀態(tài)。

時序如下圖:

源代碼程序:

5.寫狀態(tài)/控制(0x01)

寫狀態(tài)/控制 和 讀狀態(tài)/控制類似。

時序如下圖:

源代碼程序:

6.讀數(shù)據(jù)(0x03)

這個就是我們重要的讀數(shù)據(jù)指令。1.寫入指令0x03; 2.寫入24位地址; 3.連續(xù)讀出N字節(jié)數(shù)據(jù)(只要有時鐘,可以連續(xù)讀出多字節(jié));

時序如下圖:

源代碼程序:

7.快速讀數(shù)據(jù)(0x0B)

“快速讀數(shù)據(jù)”和“讀數(shù)據(jù)”類似,但它的區(qū)別:1.讀數(shù)據(jù)速度更快; 2.需要在寫入地址之后需要8個時鐘的等待。

1.寫入指令0x0B; 2.寫入24位地址; 3.寫入8個時鐘; 4.連續(xù)讀出N字節(jié)數(shù)據(jù)(只要有時鐘,可以連續(xù)讀出多字節(jié));

時序如下圖:

源代碼程序:

8.快速雙通道讀數(shù)據(jù)(0x3B)

“快速雙通道讀數(shù)據(jù)”和“快速讀數(shù)據(jù)”類似,但它的區(qū)別:在讀數(shù)據(jù)的時候是兩條通道,也就是我們平時主機的輸出引腳(MOSI)在這個時候拿來當做輸入引腳讀數(shù)據(jù)。

注意:

使用該指令功能,需要改變SPI底層驅動(即需要改變MOSI引腳的輸入輸出狀態(tài))。針對初學者,我提供的工程也沒有寫的那么復雜,即該指令功能沒有(感興趣的朋友可研究一下)。

9.寫數(shù)據(jù)(頁編程)(0x02)

“寫數(shù)據(jù)”和“讀數(shù)據(jù)”類似,但寫數(shù)據(jù)都是在同一條數(shù)據(jù)(DIO)線上,讀數(shù)據(jù)在地址之后是在DO數(shù)據(jù)上。

1.寫入指令0x02; 2.寫入24位地址; 3.連續(xù)寫入N字節(jié)數(shù)據(jù)(只要有時鐘,可以連續(xù)寫入多字節(jié),注意這里一次不能超過256字節(jié)數(shù)據(jù));

時序如下圖:

源代碼程序:

10.塊擦除(0xD8)

W25Xxx塊的多少有芯片型號決定,一塊數(shù)據(jù)大小64K。

W25X16共2M字節(jié),有16塊(2M/64K = 16)

W25X64共8M字節(jié),有64塊(8M/64K = 64)

以此類推...

注意:這個塊的地址是和數(shù)據(jù)的地址對應,我們程序塊擦除中將塊區(qū)分開來。

時序如下圖:

源代碼程序:

11.扇區(qū)擦除(0x20)

W25Xxx扇區(qū)的多少有芯片型號決定,扇區(qū)數(shù)據(jù)大小4K。

W25X16共2M字節(jié),有256塊(2M/4K = 256)

W25X64共8M字節(jié),有1024塊(8M/4K = 1024)

以此類推...

同樣,我們程序扇區(qū)擦除中將扇區(qū)以扇區(qū)的形式區(qū)分開來。

時序如下圖:

源代碼程序:

12.芯片擦除(0xC7)

這條指令是擦除整個芯片內容,如果要繼續(xù)操作芯片,需要等待擦除完成(檢查忙信號)。

時序如下圖:

源代碼程序:

13.掉電(低功耗)(0xB9)

需要將芯片處于低功耗,發(fā)送該指令。

時序如下圖:

源代碼程序:

14.喚醒/ID(0xAB)

該指令有兩個功能:1.將處于低功耗的芯片喚醒(常用); 2.讀取設備ID(不常用)。

發(fā)送該指令可以將芯片喚醒,繼續(xù)發(fā)送3字節(jié)無效數(shù)據(jù),可繼續(xù)讀出設備ID.由于讀取設備ID有單獨的指令,這里基本不常用于讀設備ID(程序中也沒有該功能)。

時序如下圖:

源代碼程序:

15.讀取ID(0x90)

這個指令讀取兩字節(jié)數(shù)據(jù)(ID):高字節(jié)是廠家Manufacturer,低字節(jié)是芯片型號ID.

如我開發(fā)板上是W25Q128,讀到的ID是:0XEF17

W25X16讀到的ID是:EF14

時序如下圖:

源代碼程序:

16.JEDEC_ID(0x9F)

出于兼容性考慮,有些芯片廠家使用該指令讀取ID,這條指令和上一條指令類似。

與上一條指令不同點:1.不用發(fā)送3字節(jié)無效數(shù)據(jù); 2.讀出來的ID是3字節(jié)(依次是:廠家ID、批次ID、型號ID)。

時序如下圖:

源代碼程序:

以上就是關于W25Xxx芯片所有的指令,其他廠家芯片或許還有一些指令,請根據(jù)情況看手冊編寫相應代碼。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • FlaSh
    +關注

    關注

    10

    文章

    1635

    瀏覽量

    148088
  • 驅動
    +關注

    關注

    12

    文章

    1840

    瀏覽量

    85310
  • SPI
    SPI
    +關注

    關注

    17

    文章

    1707

    瀏覽量

    91642
收藏 人收藏

    評論

    相關推薦

    【S32K146 RT-Thread】之 使用SFUD組件驅動spi flash

    【S32K146 RT-Thread】之 使用SFUD組件驅動spi flash
    的頭像 發(fā)表于 11-21 01:05 ?309次閱讀
    【S32K146 RT-Thread】之 使用SFUD組件<b class='flag-5'>驅動</b><b class='flag-5'>spi</b> <b class='flag-5'>flash</b>

    LuatOS入門課|Air201模組與SPI Flash的交互藝術

    今天我會把我了解的關于如何使用SPI讀寫外部Flash教給大家,本文將通過Air201+擴展板讀寫外部flash的演示,教你使用SPI示例,
    的頭像 發(fā)表于 11-17 09:51 ?275次閱讀
    LuatOS入門課|Air201模組與<b class='flag-5'>SPI</b> <b class='flag-5'>Flash</b>的交互藝術

    瀚海微SD NAND之SD 協(xié)議(42)SPI總線時序

    -卡已準備好 下面的時序描述了基本的命令響應(無數(shù)據(jù))SPI事務。 主機命令到卡響應卡忙 下面的時序描述了R1b響應的命令響應事務(例如
    的頭像 發(fā)表于 10-21 10:19 ?282次閱讀
    瀚海微SD NAND之SD 協(xié)議(42)<b class='flag-5'>SPI</b>總線<b class='flag-5'>時序</b>

    物聯(lián)網(wǎng)行業(yè)存儲方案詳解_SPI NOR Flash

    物聯(lián)網(wǎng)系統(tǒng)中為什么要使用SPI NOR FLASH 物聯(lián)網(wǎng)系統(tǒng)中使用SPI NOR FLASH的原因主要基于其獨特的性能特點和在嵌入式系統(tǒng)中的廣泛應用。以下是詳細的分析: 1、高可靠性
    的頭像 發(fā)表于 09-24 14:39 ?301次閱讀
    物聯(lián)網(wǎng)行業(yè)存儲方案詳解_<b class='flag-5'>SPI</b> NOR <b class='flag-5'>Flash</b>

    時序邏輯電路的五種描述方法

    時序邏輯電路是數(shù)字電路中的一種重要類型,它具有存儲和處理信息的能力。時序邏輯電路的描述方法有很多種,不同的方法適用于不同的設計和分析場景。以下是五種常見的時序邏輯電路
    的頭像 發(fā)表于 08-28 11:39 ?1389次閱讀

    時序邏輯電路的描述方法有哪些

    時序邏輯電路是數(shù)字電路中的一種重要類型,它具有存儲功能,能夠根據(jù)輸入信號和內部狀態(tài)的變化來改變其輸出。時序邏輯電路廣泛應用于計算機、通信、控制等領域。本文將介紹時序邏輯電路的描述方法,
    的頭像 發(fā)表于 08-28 11:37 ?643次閱讀

    使用SPI編程器將網(wǎng)盤文件燒錄到板上spi flash,2K0300燒錄報錯

    我這邊使用SPI編程器將網(wǎng)盤上面這個文件燒錄到板上spi flash, 開機也有信息打印,但是uboot運行過程報錯,錯誤信息如下 燒錄前是能夠正常啟動的,麻煩看下是不是固件有問題
    發(fā)表于 08-15 10:16

    spi_flash期間的計時器中斷導致崩潰怎么解決?

    spi_flash_erase_sector(...); spi_flash_write(...); 如果在閃存訪問期間發(fā)生計時器中斷,ESP 似乎會崩潰并重新啟動。 當然,這可以通過在訪問 Flash 時禁用中斷來
    發(fā)表于 07-12 11:54

    ESP32外部flashspi外設沖突怎么解決?

    硬件: ESP32 ,W25Q128 SPI顯示器 庫:IDF4.0.1 使用hspi掛載了外部16MB的W25Q128,并同時掛載了SPI的顯示器,使用兩不同IO口進行分時復用。 問題描述:分時
    發(fā)表于 06-25 06:19

    基于FPGA的SPI Flash控制器的設計方案

    、塊擦除、整體擦除、讀取數(shù)據(jù)、快速讀取數(shù)據(jù)、頁面編程)時所需指令時序,用戶只需要輸入對應操作的8位指令值及對應的操作地址值,SPI接口與SPI Fl
    發(fā)表于 06-03 10:13

    FATFS對SPI_FLASH新建文件、刪除文件或者修改文件后電腦無法識別,為什么?

    FATFS對SPI_FLASH新建文件、刪除文件或者修改文件后電腦無法識別,而且會斷開連接,需要重新插拔,這是什么問題呢
    發(fā)表于 04-09 07:06

    通用bootloader選“支持spi flash”,無論設定download為片內還是片外flash啟動都找不到at45db161,為什么?

    通用bootloader不選“支持spi flash”,download放于片內flash,正常啟動,ota正常,app驅動at45db161讀寫正常。通用bootloader選“支持
    發(fā)表于 03-22 07:45

    求助,關于SPI讀寫Flash的理解

    利用SPI讀寫Flash指令的過程中,當主機發(fā)送指令后,為什么還需要再發(fā)送“任意的數(shù)據(jù)”,才能夠獲取指令解釋后的返回值。 當讀取Flash的JEDEC_ID指令時,按FLASH的ID指
    發(fā)表于 03-20 06:06

    CYUSB3014燒錄SPI FLASH image時總是報錯的原因?可以通過USB直接更新SPI FLASH嗎?

    時,硬件PMOD設置為SPI boot模式,但SPI FLASH中是空的,想通過USB更新SPI FLASH,但是無法成功,這樣
    發(fā)表于 02-28 07:40

    想用FX3 SPI編程SPI Flash,頁面尾部隨機丟失了3個字節(jié)的數(shù)據(jù)是為什么?

    你好,我想用 FX3 SPI編程 SPI Flash。 通過 cyu3pspiReceiveWords 功能,閱讀頁面似乎沒問題。 當我用 cyu3pspitransmitWord
    發(fā)表于 02-26 07:34