|
對(duì)于不帶spi串行總線接口的mcs51系列單片機(jī)來(lái)說(shuō),可以使用軟件來(lái)模擬spi的操作,包括串行時(shí)鐘、數(shù)據(jù)輸入和數(shù)據(jù)輸出。對(duì)于不同的串行接口外圍芯片,它們的時(shí)鐘時(shí)序是不同的。對(duì)于在sck的上升沿輸入(接收)數(shù)據(jù)和在下降沿輸出(發(fā)送)數(shù)據(jù)的器件,一般應(yīng)將其串行時(shí)鐘輸出口p1.1的初始狀態(tài)設(shè)置為1,而在允許接口后再置p1.1為0。這樣,mcu在輸出1位sck時(shí)鐘的同時(shí),將使接口芯片串行左移,從而輸出1位數(shù)據(jù)至mcs51單片機(jī)的p1.3口(模擬mcu的miso線),此后再置p1.1為1,使mcs51系列單片機(jī)從p1.0(模擬mcu的mosi線)輸出1位數(shù)據(jù)(先為高位)至串行接口芯片。至此,模擬1位數(shù)據(jù)輸入輸出便宣告完成。此后再置p1.1為0,模擬下1位數(shù)據(jù)的輸入輸出……,依此循環(huán)8次,即可完成1次通過(guò)spi總線傳輸8位數(shù)據(jù)的操作。對(duì)于在sck的下降沿輸入數(shù)據(jù)和上升沿輸出數(shù)據(jù)的器件,則應(yīng)取串行時(shí)鐘輸出的初始狀態(tài)為0,即在接口芯片允許時(shí),先置p1.1為1,以便外圍接口芯片輸出1位數(shù)據(jù)(mcu接收1位數(shù)據(jù)),之后再置時(shí)鐘為0,使外圍接口芯片接收1位數(shù)據(jù)(mcu發(fā)送1位數(shù)據(jù)),從而完成1位數(shù)據(jù)的傳送。 圖2所示為mcs51系列單片機(jī)與存儲(chǔ)器x25f008(e2prom)的硬件連接圖,圖2中,p1.0模擬mcu的數(shù)據(jù)輸出端(mosi),p1.1模擬spi的sck輸出端,p1.2模擬spi的從機(jī)選擇端,p1.3模擬spi的數(shù)據(jù)輸入端(miso)。下面介紹用mcs51單片機(jī)的匯編語(yǔ)言模擬spi串行輸入、串行輸出和串行輸入/輸出的3個(gè)子程序,實(shí)際上,這些子程序也適用于在串行時(shí)鐘的上升沿輸入和下降沿輸出的其它各種串行外圍接口芯片(如a/d轉(zhuǎn)換芯片、網(wǎng)絡(luò)控制器芯片、led顯示驅(qū)動(dòng)芯片等)。對(duì)于下降沿輸入、上升沿輸出的各種串行外圍接口芯片,只要改變p1.1的輸出電平順序,即先置p1.1為低電平,之后再次置p1.1為高電平,再置p1.1為低電平……,則這些子程序也同樣適用。 3.1 mcu串行輸入子程序spiin 從x25f008的spiso線上接收8位數(shù)據(jù)并放入寄存器r0中的應(yīng)用子程序如下: spiin:setb p1.1 ;使p1.1(時(shí)鐘)輸出為1 clr p1.2 ;選擇從機(jī) MOV r1,#08h ;置循環(huán)次數(shù) spiin1:clr p1.1 ;使p1.1(時(shí)鐘)輸出為0 nop ;延時(shí) nop MOV c,p1.3 ;從機(jī)輸出spiso送進(jìn)位c rlc a ;左移至累加器acc setb p1.1 ;使p1.0(時(shí)鐘)輸出為1 djnz r1,spiin1 ;判斷是否循環(huán)8次(8位數(shù)據(jù)) MOV r0,a ;8位數(shù)據(jù)送r0 ret 3.2 mcu串行輸出子程序spiout 將mcs51單片機(jī)中r0寄存器的內(nèi)容傳送到x25f008的spisi線上的程序如下: spiout:setb p1.1 ;使p1.1(時(shí)鐘)輸出為1 clr p1.2 ;選擇從機(jī) MOV r1,#08h ;置循環(huán)次數(shù) MOV a,r0 ;8位數(shù)據(jù)送累加器acc spiout1:clr p1.1 ;使p1.1(時(shí)鐘)輸出為0 nop ;延時(shí) nop rlc a ;左移至累加器acc最高位至c MOV p1.0,c ;進(jìn)位c送從機(jī)輸入spisi線上 setb p1.1 ;使p1.1(時(shí)鐘)輸出為1 djnz r1,spiout1 ;判是否循環(huán)8次(8位數(shù)據(jù)) ret 3.3 mcu串行輸入/輸出子程序spiio 將mcs51單片機(jī)r0寄存器的內(nèi)容傳送到x25f008的spisi中,同時(shí)從x25f008的spiso接收8位數(shù)據(jù)的程序如下: spiio:setb p1.1 ;使p1.1(時(shí)鐘)輸出為1 clr p1.2 ;選擇從機(jī) MOV r1,#08h ;置循環(huán)次數(shù) MOV a,r0 ;8位數(shù)據(jù)送累加器acc spiio1:clr p1.1 ;使p1.1(時(shí)鐘)輸出為0 nop ;延時(shí) nop MOV c,p1.3 ;從機(jī)輸出spiso送進(jìn)位c rlc a ;左移至累加器acc最高位至c MOV p1.0,c ;進(jìn)位c送從機(jī)輸入 setb p1.1 ;使p1.1(時(shí)鐘)輸出為1 djnz r1,spiio1 ;判斷是否循環(huán)8次(8位數(shù)據(jù)) ret |