www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 單片機 > 單片機
[導讀]本文介紹的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 接口設計

1. 引言 AD7237A是美國AD公司推出的一種LC2MOS型雙路12位數(shù)模轉換器。它具有高速、低功耗、寬工作電壓等特點,在工業(yè)上得到了廣泛應用。本文簡要地介紹了AD7237A的基本

關鍵字: d/a轉換器 擴展卡 接口設計 電源技術解析 ad7237a ad公司

DS2450是DALLAS公司生產的單總線四通道逐次逼近式A/D轉換器芯片,它的輸入電壓范圍、轉換精度位數(shù)和報警門限電壓均可編程;每個通道均可用各自的存儲器來存儲電壓范圍設置

關鍵字: a/d轉換器 單總線 單片機 接口設計 電源技術解析 ds2450

單片機

21600 篇文章

關注

發(fā)布文章

編輯精選

技術子站

關閉