TMS320F2812的SPI接口設(shè)計(jì)
1.2.1 讀時(shí)序
當(dāng)片選信號(hào)為低時(shí),向25LC040傳送8位的讀指令(0000 A8011),緊接著傳送需要讀取數(shù)據(jù)的低8位地址。當(dāng)正確的讀寫(xiě)指令和地址被識(shí)別后,EEPROM中對(duì)應(yīng)地址的數(shù)據(jù)將會(huì)由輸出引腳順次傳出,若繼續(xù)提供時(shí)鐘信號(hào),下一位地址對(duì)應(yīng)的數(shù)據(jù)也會(huì)依次讀出。當(dāng)片選信號(hào)為高時(shí),讀數(shù)據(jù)的操作將會(huì)被終止。其具體操作如圖1所示。圖中,CS為片選信號(hào),SCK為時(shí)鐘信號(hào),SI為輸入引腳信號(hào),SO為輸出引腳信號(hào)。本文引用地址:http://www.ex-cimer.com/article/157474.htm
1.2.2 寫(xiě)時(shí)序
在對(duì)25LC040進(jìn)行任何寫(xiě)操作之前,必須先執(zhí)行WREN(寫(xiě)使能)指令。寫(xiě)使能指令的操作如圖2所示。先使片選信號(hào)為低,然后傳送寫(xiě)使能指令到25LC040中,指令傳送完畢后,必須將片選信號(hào)設(shè)置為高以完成寫(xiě)使能操作。如果寫(xiě)指令傳送結(jié)束后沒(méi)有拉高片選信號(hào),直接進(jìn)行寫(xiě)操作,那么數(shù)據(jù)將不會(huì)寫(xiě)入到存儲(chǔ)陣列中。
寫(xiě)使能操作完成后,片選信號(hào)應(yīng)該被拉低以進(jìn)行寫(xiě)操作,時(shí)序如圖3所示。寫(xiě)指令、寫(xiě)入地址以及寫(xiě)入的數(shù)據(jù)會(huì)被依次傳送到25LC040中。若要使數(shù)據(jù)正確地寫(xiě)入到存儲(chǔ)陣列中,片選信號(hào)應(yīng)該在最后一個(gè)有效字節(jié)的D0位傳送完畢后被拉高。
2 TMS320F2812的SPI接口設(shè)計(jì)
TMS320F2812與25LC040的硬件連接如圖4所示。TMS320F2812工作在主模式,SPISIMO為主模式下的數(shù)據(jù)輸出接口,連接到25LC040的數(shù)據(jù)接收端口;SPISOMI為主模式下的數(shù)據(jù)輸入接口,連接到25LC040的數(shù)據(jù)發(fā)送端口;時(shí)鐘信號(hào)SPICLK和片選信號(hào)SPISTE均由TMS320F2812產(chǎn)生。寫(xiě)保護(hù)引腳直接接高電平以確保25LC040總是可以被寫(xiě)入。
2.1 SPI模塊的設(shè)置
SPI模塊的波特率可由如下兩種情況計(jì)算得出:
①SPIBRR=3~127,波特率的計(jì)算公式為:
SPI波特率=LSPCLK/(SPIBRR+1)
②SPIBRR=O~2,波特率的計(jì)算公式為:
SPI波特率=LSPCLK/4
LSPCLK是TMS320F2812的低速外設(shè)時(shí)鐘頻率;SPIBRR是SPIBRR寄存器的值。將LSPCLK設(shè)置成37.5 MHz,25LC040的最大時(shí)鐘頻率為2 MHz,SPI的波特率應(yīng)該小于2 MHz,即37.5/(SPIBRR+1)≤2,SPIBRR的取值范圍為SPIBRR≥18。
通信中將SPISIMO、SPISOMI和SPICLK設(shè)置為基本功能SPI口,SPISTE設(shè)置為一般I/O口。作為25LC040的片選信號(hào),當(dāng)主/從控制器進(jìn)行數(shù)據(jù)交換時(shí),SPISTE配置成低電平,數(shù)據(jù)傳輸結(jié)束后再配置成高電平。
TMS320F2812的數(shù)據(jù)寄存器都是16位的,且接收和發(fā)送都是雙緩沖的,而25LC040的地址和數(shù)據(jù)寄存器都是8位的,因此將SPI模塊的數(shù)據(jù)長(zhǎng)度設(shè)置成8位。發(fā)送緩沖寄存器SPITXBUF中的數(shù)據(jù)以左對(duì)齊的方式發(fā)送,先發(fā)送數(shù)據(jù)的最高位,因此在發(fā)送數(shù)據(jù)前必須將等待發(fā)送的數(shù)據(jù)放在SPITXBUF的高8位。當(dāng)要對(duì)25LC2040進(jìn)行寫(xiě)使能操作時(shí),寫(xiě)入SPITXBUF的數(shù)據(jù)應(yīng)為Ox0600。TMS320F2812則是以右對(duì)齊的方式來(lái)接收數(shù)據(jù)的,8位的數(shù)據(jù)被放在SPITXBUF的低8位上。
評(píng)論