[導讀]本文介紹的M25P16與PIC16F877A的接口已應用于自來水流量數(shù)據(jù)采集的本地存儲中。運行穩(wěn)定可靠,未發(fā)現(xiàn)數(shù)據(jù)丟失現(xiàn)象,對其他應用有一定的參考價值。
引 言
PIC單片機以性能穩(wěn)定、品種眾多等特點在工業(yè)控制、儀器儀表、家電、通信等領域得到廣泛應用。雖然很多型號自身集成了存儲器,但在很多情況下難以滿足系統(tǒng)對大容量存儲的要求,需要外擴非易失性的存儲器。與并行Flash存儲器相比,串行Flash存儲器占用MCU引腳少,體積小,易于擴展,接線簡單,工作可靠,故而越來越多地應用在各類電子產品和工業(yè)測控系統(tǒng)中。本文主要討論PIC16F877A單片機與串行閃存M25P16之間的SPI通信,在要求大容量數(shù)據(jù)存儲且MCU引腳資源有限的情況下具有實用價值。
1 SPI工作原理
SPI(Serial Peripheral Interface)是一種常用的串行通信協(xié)議,用于MCU系統(tǒng)與外圍設備的通信,可用來連接存儲器、A/D轉換器、D/A轉換器、實時時鐘、LCD驅動器、傳感器,甚至其他處理器。SPI主要使用4個信號:MOSI(主機輸出/從機輸人)、MISO(主機輸入/從機輸出)、SCK(串行時鐘)和CS(片選)。其中,SCK由主機產生,作為傳輸?shù)耐綍r鐘,控制所有數(shù)據(jù)傳輸。主機通過觸發(fā)從設備的CS決定二者之間的SPI傳輸是否能夠進行。主機和外設都包含1個串行移位寄存器。主機通過向自己的SPI串行寄存器寫入1個字節(jié)來發(fā)起1次傳輸,然后通過MOSI信號線將數(shù)據(jù)傳給外設,同時外設將自己移位寄存器中的內容通過MISO信號線返回給主機,如圖1所示。這樣,兩個移位寄存器中的內容就交換了。也就是說,外設的寫操作和讀操作是同步完成的。在實際應用中,如果只進行寫操作,則主機只需忽略收到的字節(jié)即可;如果主機要讀外設的數(shù)據(jù),必須發(fā)送1個字節(jié)來引發(fā)從機的傳輸,發(fā)送的這個字節(jié)可以是任意數(shù)據(jù)。
2 M25P16簡介
M25P16是16 Mb的串行閃存,具有先進的寫保護機制,支持速度高達50 MHz的SPI總線的存取操作。該存儲器有32個扇區(qū),每個扇區(qū)256頁,每頁256字節(jié)。工作電壓范圍2.7~3.6 V,工作溫度范圍-40~+85℃。數(shù)據(jù)保存長達20年,每個扇區(qū)可擦寫/編程100 000次。
M25P16支持的操作指令共有12條。指令格式為:
其中,8位的命令字是必需的,地址、啞元以及數(shù)據(jù)字節(jié)的有無和長度會因指令的不同而有所差別,詳情如表1所列。所有的命令碼、地址、串行輸入/輸出的數(shù)據(jù),均是高位在前,低位在后。
對M25P16操作時,先選中芯片(即片選信號S拉低),然后串行輸入操作指令字節(jié),緊接著串行輸入地址字節(jié)(0或3字節(jié)),必要時還要加入啞讀字節(jié),最后串行輸入/輸出數(shù)據(jù)字節(jié),然后把片選信號拉高,之后M25P16啟動內部控制邏輯,自行完成相應的操作。
3 SPI硬件設計
PIC16F877A單片機具有非常完善的SPI接口(RC3/SCK、RC4/SDI、RC5/SDO、RA5/SS),只有PIC16F877A作為從機時,RA5/SS引腳才作為SPI腳,PIC16F877A為主機時,SS可作為普通I/O使用。通過該接口,可比較容易地實現(xiàn)PIC16F877A與SPI Flash的通信。PIC16F877A與M25P16的硬件接口如圖2所示。其中,SCK、SDI、SDO為MCU的SPI專用引腳,分別與存儲器的對應引腳相連,可選MCU的任意I/O腳作為存儲器的片選信號,圖中選取RC2腳與存儲器的片選S相連,這樣,在SPI通信時只涉及MCU的C口,便于操作。M25P16的HOLD和W直接接高電平,表示不允許在S有效的情況下暫停SPI通信且整個存儲區(qū)都沒有寫保護。
圖2中,VDD為+5 V,由于PIC16F877A工作在5 V電壓下,而M25P16的工作電壓范圍為2.7~3.6 V,二者不能直接相連。這里采用電阻分壓的方式,保證輸入M25P16的S、C、D腳的電壓在存儲器能承受且能識別的范圍內,通過在M25P16向PIC16F877A輸入數(shù)據(jù)的SDO腳加上拉電阻,保證MCU可以識別M25P16輸出的高電壓,從而保證正常的SPI通信。如果MCU工作于3.3 V,則直接將二者的對應引腳相連即可。
4 SPI軟件設計
在硬件連線正確的基礎上,要進行SPI通信,還要對M25P16編寫驅動程序,包括SPI初始化、讀M25P16的數(shù)據(jù)、向M25P16寫人數(shù)據(jù)、數(shù)據(jù)的擦除等,這里使用C語言編程,編譯器選擇PICC,開發(fā)環(huán)境為MPLAB IDE8.10。
PIC16F877A的SPI通信涉及4個寄存器:控制寄存器SSPCON、狀態(tài)寄存器SSPSTAT串行接收/發(fā)送緩沖器SSPBUF和移位寄存器SSPSR。其中,SSPCON的8位都是可讀可寫的,用于設置SSP處于主/從模式、時鐘頻率、時鐘極性、SSP使能以及寫沖突檢測;SSPSTAT只有高2位可讀寫,低6位是只讀的。PIC16F877A處于接收模式時,SSPSR和SSPBUF構成2級緩沖的接收器,SSPSR每收到1個完整的字節(jié),就將該字節(jié)傳給SSPBUF,并將中斷標志位SSPIF置1,可通過讀SSPBUF得到數(shù)據(jù);877A處于發(fā)送模式時,寫SSPBUF操作會同時將數(shù)據(jù)寫入SSPSR,觸發(fā)傳輸。下面結合具體的代碼進行詳細闡述。
(1)SPI初始化與讀寫函數(shù)
從SendByte和RcvByte函數(shù)的代碼中,可以看出數(shù)據(jù)發(fā)送和接收是否完成,都是通過判斷STAT_BF標志位(SSPSTAT寄存器的BF位,STAT_BF是在頭文件pic1687x.h中定義的名稱)來實現(xiàn)的,而數(shù)據(jù)手冊中關于BF位的描述僅用于接收模式。這是由于PIC16F877A通過SDO發(fā)送數(shù)據(jù)的同時,會通過SDI讀人數(shù)據(jù),當1字節(jié)發(fā)送完成時,剛好接收1字節(jié)到SSPBUF,這時SSPBUF滿,BY被置為1,故可通過STAT_BF標志判斷1字節(jié)是否發(fā)送完成。
(2)連續(xù)寫函數(shù)
M25P16的PP指令允許1次連續(xù)寫入不超過1頁(256字節(jié))的數(shù)據(jù)。寫人數(shù)據(jù)之前,首先要發(fā)出寫允許命令,然后才能執(zhí)行數(shù)據(jù)寫入操作。數(shù)據(jù)寫入函數(shù)參數(shù)包括address(32位地址)、block(寫入數(shù)據(jù)緩沖區(qū)指針)、n(一次連續(xù)寫入的字節(jié)數(shù),n<256)。如果address的低8位不全為0,即不是從頁起始處寫,并且需要寫入的數(shù)據(jù)超出該頁剩余空間,則超出部分被丟棄。代碼如下:
其中,delay()為延時子函數(shù),參數(shù)為ms級,delay(1)即延時1ms。加入延時,是為了保證存儲器在準備好的情況下才進行讀寫操作。
(3)連續(xù)讀函數(shù)
M25P16允許發(fā)出讀指令后,連續(xù)讀取數(shù)據(jù),這一模式極大提高了總線效率。數(shù)據(jù)讀取函數(shù)的參數(shù)包括address:32位地址;block:讀數(shù)據(jù)緩沖區(qū)指針;n:一次連續(xù)讀取的字節(jié)數(shù),代碼如下:
M25P16的連續(xù)讀操作與連續(xù)寫不同的是,無論READ還是FAST_READ,在起始地址處1字節(jié)的數(shù)據(jù)讀出后,會自動尋址更高地址處的數(shù)據(jù),故程序中無需address++語句。
除了對M25P16的初始化、讀寫之外,經常還要對其進行擦除操作,擦除有扇區(qū)擦除和整體擦除2種方式,執(zhí)行數(shù)據(jù)擦除將使內部所有數(shù)據(jù)變?yōu)镕FH。擦除操作與寫操作類似,在此不再贅述。
結 語
本文介紹的M25P16與PIC16F877A的接口已應用于自來水流量數(shù)據(jù)采集的本地存儲中。運行穩(wěn)定可靠,未發(fā)現(xiàn)數(shù)據(jù)丟失現(xiàn)象,對其他應用有一定的參考價值。
本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
摘 要 :視頻監(jiān)控系統(tǒng)是計算機應用中的重要領域之一。數(shù)字化攝像頭網(wǎng)絡化之后,監(jiān)控系統(tǒng)正在不斷引入新的功能,為使現(xiàn)有監(jiān)控系統(tǒng)能更好地應對復雜環(huán)境,滿足不同監(jiān)控要求,就需要追加新功能,在系統(tǒng)架構與設計上進行調整。因此,如何將...
關鍵字:
智能監(jiān)控
系統(tǒng)架構
模塊化設計
接口設計
數(shù)據(jù)傳輸
深度相機
原文鏈接:https://www.analog.com/cn/analog-dialogue/articles/introduction-to-spi-interface.html之前詳細介紹過SPI協(xié)議,今天分享一篇A...
關鍵字:
ADI
SPI接口
Xilinx FPGA 提供可簡化接口設計的 I/O 模塊和邏輯資源。盡管如此,這些 I/O 模塊以及額外的邏輯仍需設計人員在源 RTL 代碼中配置、驗證、執(zhí)行,并正確連接到系統(tǒng)的其余部分
關鍵字:
FPGA
Xilinx
存儲器
接口設計
電源技術解析
引 言
PCI 總線(Peripheral Component Interconnect)是Intel公司推出的一種高性能32/64位局部總線,最大數(shù)據(jù)傳輸速率為132~264MB/s,是目前使用較為廣泛的一種總...
關鍵字:
pci總線
接口設計
數(shù)據(jù)采集
電源技術解析
雷達視頻
實際上,每個產品設計必須經歷數(shù)字提取和真實模擬世界。設計前期的一些考慮將焦點放在接口設計上。
20世紀后半葉的技術創(chuàng)新達到空前的速度。不像以前,這個時期的許多進
關鍵字:
接口設計
電源技術解析
建立橋路
隨著工業(yè)技術進步,對數(shù)字控制伺服系統(tǒng)中執(zhí)行效率和集成化程度的要求越來越高。比如用單處理器控制多個伺服系統(tǒng)時,對多通道A/D轉換的效率要求較高。以往較多地使用多路模
關鍵字:
ad7890
DSP
接口設計
電源技術解析
轉換器
引 言 Flash存儲器又稱閃速存儲器,是20世紀80年代末逐漸發(fā)展起來的一種新型半導體不揮發(fā)存儲器。它兼有RAM和ROM的特點,既可以在線擦除、改寫,又能夠在掉電后保持數(shù)據(jù)不丟失?! OR Flash是Flas...
關鍵字:
8位單片機
Flash
nor
接口設計
由于NAND Flash具有非易失性、大容量、低成本、接口簡單等優(yōu)點。在組合導航數(shù)據(jù)存儲設備,激光慣導單元及紅外導引頭的圖像采集等智能儀器中得到廣泛應用。詳細介紹了大容量閃存K9KAG08UOM與TMS320C6713B...
關鍵字:
DSP
k9kag08uom
存儲技術
接口設計
閃存器件
自動化控制要求實時采集數(shù)據(jù),快速控制,多樣分析,通信靈活,雖然采用單個處理器構成的硬件平臺不能滿足要求。采用以MCU+DSP雙處理器為核心的硬件平臺則是較合理的設計方案。利用DSP實現(xiàn)數(shù)
關鍵字:
DSP
MCU
存儲技術
引導
接口設計
在許多應用系統(tǒng)中,數(shù)字信號處理器(DSP)必須從多路模數(shù)轉換器(ADC)通道獲取信息,才能將經DSP處理后的數(shù)字信號傳送到多路數(shù)模轉換器(DAC)通道進行。關鍵問題是怎樣在DSP系統(tǒng)中十
關鍵字:
DSP
tlc320ac01
存儲技術
接口設計
當前,有一些微處理器將CAN控制器嵌入到系統(tǒng)之中,但是仍有大量人們比較熟悉的微處理器并不帶有CAN控制器。采用微處理器和CAN控制器組合的設計成為必要,而且,CAN控制器具有完成CAN總線通信協(xié)議。
關鍵字:
can總線
DSP
sharc
sja1000
總線與接口
接口設計
作為上世紀80年代早期批準的一個平衡傳輸標準,RS-485似乎已成為產業(yè)界永不過期的接口標準。關于它的文獻有很多,但對于很少接觸接口設計的系統(tǒng)工程師而言,如此海量的文獻
關鍵字:
總線與接口
指南
接口設計
rs-485產業(yè)
PIC單片機(Peripheral Interface Controller)是一種用來開發(fā)去控制外圍設備的集成電路(IC)?,F(xiàn)在PIC單片機應用領域已經相當廣泛,為了方便廣大工程師能夠很好的學習 PIC單
關鍵字:
pic單片機
總線與接口
接口設計
HSIC介面在硬體接線式晶片互連應用上的效能遠勝于USB,因此愈來愈受歡迎。該雙訊號源同步介面提供媲美USB的480Mbit/s高速資料傳輸能力;負責傳輸資料的主機驅動器與傳統(tǒng)USB拓
關鍵字:
技術前沿
接口設計
hsic