<del id="dhfrq"></del>

    1. <tr id="dhfrq"></tr>
      成人午夜激情在线观看,国产精品一线天粉嫩av,99精品国产综合久久久久五月天 ,一卡2卡三卡4卡免费网站,国产高清在线男人的天堂,五月天国产成人AV免费观看,67194熟妇在线观看线路,成人无码潮喷在线观看
      現在位置:范文先生網>理工論文>電子通信論文>SPI總線在51系列單片機系統中的實現

      SPI總線在51系列單片機系統中的實現

      時間:2023-02-21 00:11:44 電子通信論文 我要投稿
      • 相關推薦

      SPI總線在51系列單片機系統中的實現

      摘要:MCS51系列、MCS96系列等單片機由于都不帶SPI串行總線接口而限制了其在SPI總線接口器件的使用。文中介紹了SPI串行總線的特征和時序,并以串行E2PROM為例,給出了在51系列單片機上利用I/O口線實現SPI串行總線接口的方法和軟件設計程序。
        關鍵詞:單片機SPI串行總線總線接口
        
        1引言
        
        SPI(SerialPeripheralInterface--串行外設接口)總線系統是一種同步串行外設接口,它可以使MCU與各種外圍設備以串行方式進行通信以交換信息。外圍設置FLASHRAM、網絡控制器、LCD顯示驅動器、A/D轉換器和MCU等。SPI總線系統可直接與各個廠家生產的多種標準外圍器件直接接口,該接口一般使用4條線:串行時鐘線(SCK)、主機輸入/從機輸出數據線MISO、主機輸出/從機輸入數據線MOST和低電平有效的從機選擇線SS(有的SPI接口芯片帶有中斷信號線INT或INT、有的SPI接口芯片沒有主機輸出/從機輸入數據線MOSI)。由于SPI系統總線一共只需3~4位數據線和控制即可實現與具有SPI總線接口功能的各種I/O器件進行接口,而擴展并行總線則需要8根數據線、8~16位地址線、2~3位控制線,因此,采用SPI總線接口可以簡化電路設計,節省很多常規電路中的接口器件和I/O口線,提高設計的可靠性。由此可見,在MCS51系列等不具有SPI接口的單片機組成的智能儀器和工業測控系統中,當傳輸速度要求不是太高時,使用SPI總線可以增加應用系統接口器件的種類,提高應用系統的性能。
        
        2SPI總線的組成
        
        利用SPI總線可在軟件的控制下構成各種系統。如1個主MCU和幾個從MCU、幾個從MCU相互連接構成多主機系統(分布式系統)、1個主MCU和1個或幾個從I/O設備所構成的各種系統等。在大多數應用場合,可使用1個MCU作為控機來控制數據,并向1個或幾個從外圍器件傳送該數據。從器件只有在主機發命令時才能接收或發送數據。其數據的傳輸格式是高位(MSB)在前,低位(LSB)在后。SPI總線接口系統的典型結構如圖1所示。
        
        當一個主控機通過SPI與幾種不同的串行I/O芯片相連時,必須使用每片的允許控制端,這可通過MCU的I/O端口輸出線來實現。但應特別注意這些串行I/O芯片的輸入輸出特性:首先是輸入芯片的串行數據輸出是否有三態控制端。平時未選中芯片時,輸出端應處于高阻態。若沒有三態控制端,則應外加三態門。否則MCU的MISO端只能連接1個輸入芯片。其次是輸出芯片的串行數據輸入是否有允許控制端。因此只有在此芯片允許時,SCK脈沖才把串行數據移入該芯片;在禁止時,SCK對芯片無影響。若沒有允許控制端,則應在外圍用門電路對SCK進行控制,然后再加到芯片的時鐘輸入端;當然,也可以只在SPI總線上連接1個芯片,而不再連接其它輸入或輸出芯片。
        
        3在MCS51系列單片機中的實現方法
        
        對于不帶SPI串行總線接口的MCS51系列單片機來說,可以使用軟件來模擬SPI的操作,包括串行時鐘、數據輸入和數據輸出。對于不同的串行接口外圍芯片,它們的時鐘時序是不同的。對于在SCK的上升沿輸入(接收)數據和在下降沿輸出(發送)數據的器件,一般應將其串行時鐘輸出口P1.1的初始狀態設置為1,而在允許接口后再置P1.1為0。這樣,MCU在輸出1位SCK時鐘的同時,將使接口芯片串行左移,從而輸出1位數據至MCS51單片機的P1.3口(模擬MCU的MISO線),此后再置P1.1為1,使MCS51系列單片機從P1.0(模擬MCU的MOSI線)輸出1位數據(先為高位)至串行接口芯片。至此,模擬1位數據輸入輸出便宣告完成。此后再置P1.1為0,模擬下1位數據的輸入輸出……,依此循環8次,即可完成1次通過SPI總線傳輸8位數據的操作。對于在SCK的下降沿輸入數據和上升沿輸出數據的器件,則應取串行時鐘輸出的初始狀態為0,即在接口芯片允許時,先置P1.1為1,以便外圍接口芯片輸出1位數據(MCU接收1位數據),之后再置時鐘為0,使外圍接口芯片接收1位數據(MCU發送1位數據),從而完成1位數據的傳送。
        
        圖2所示為MCS51系列單片機與存儲器X25F008(E2PROM)的硬件連接圖,圖2中,P1.0模擬MCU的數據輸出端(MOSI),P1.1模擬SPI的SCK輸出端,P1.2模擬SPI的從機選擇端,P1.3模擬SPI的數據輸入端(MISO)。下面介紹用MCS51單片機的匯編語言模擬SPI串行輸入、串行輸出和串行輸入/輸出的3個子程序,實際上,這些子程序也適用于在串行時鐘的上升沿輸入和下降沿輸出的其它各種串行外圍接口芯片(如A/D轉換芯片、網絡控制器芯片、LED顯示驅動芯片等)。對于下降沿輸入、上升沿輸出的各種串行外圍接口芯片,只要改變P1.1的輸出電平順序,即先置P1.1為低電平,之后再次置P1.1為高電平,再置P1.1為低電平……,則這些子程序也同樣適用。
        
        3.1MCU串行輸入子程序SPIIN
        
        從X25F008的SPISO線上接收8位數據并放入寄存器R0中的應用子程序如下:
        
        
        
        
        SPIIN:SETBP1.1;使P1.1(時鐘)輸出為1
        
        CLRP1.2;選擇從機
        
        MOVR1,#08H;置循環次數
        
        SPIIN1:CLRP1.1;使P1.1(時鐘)輸出為0
        
        NOP;延時
        
        NOP
        
        MOVC,P1.3;從機輸出SPISO送進位C
        
        RLCA;左移至累加器ACC
        
        SETBP1.1;使P1.0(時鐘)輸出為1
        
        DJNZR1,SPIIN1;判斷是否循環8次(8位數據)
        
        MOVR0,A;8位數據送R0
        
        RET
        
        3.2MCU串行輸出子程序SPIOUT
        
        將MCS51單片機中R0寄存器的內容傳送到X25F008的SPISI線上的程序如下:
        
        SPIOUT:SETBP1.1;使P1.1(時鐘)輸出為1
        
        CLRP1.2;選擇從機
        
        MOVR1,#08H;置循環次數
        
        MOVA,R0;8位數據送累加器ACC
        
        SPIOUT1:CLRP1.1;使P1.1(時鐘)輸出為0
        
        NOP;延時
        
        NOP
        
        RLCA;左移至累加器ACC最高位至C
        
        MOVP1.0,C;進位C送從機輸入SPISI線上
        
        SETBP1.1;使P1.1(時鐘)輸出為1
        
        DJNZR1,SPIOUT1;判是否循環8次(8位數據)
        
        RET
        
        3.3MCU串行輸入/輸出子程序SPIIO
        
        將MCS51單片機R0寄存器的內容傳送到X25F008的SPISI中,同時從X25F008的SPISO接收8位數據的程序如下:
        
        SPIIO:SETBP1.1;使P1.1(時鐘)輸出為1
        
        CLRP1.2;選擇從機
        
        MOVR1,#08H;置循環次數
        
        MOVA,R0;8位數據送累加器ACC
        
        SPIIO1:CLRP1.1;使P1.1(時鐘)輸出為0
        
        NOP;延時
        
        NOP
        
        MOVC,P1.3;從機輸出SPISO送進位C
        
        RLCA;左移至累加器ACC最高位至C
        
        MOVP1.0,C;進位C送從機輸入
        
        SETBP1.1;使P1.1(時鐘)輸出為1
        
        DJNZR1,SPIIO1;判斷是否循環8次(8位數據)
        
        RET
        
        4結束語
        
        本文介紹了通過SPI總線接口實現數據傳輸的實現方法,給出了用MCS51單片機匯編語言模擬SPI串行總線的輸入、輸出,輸入/輸出以傳送8位數據的子程序。實際上,也可以根據SPI串行總線的操作時序特點來在MCS96系列、ATMEL89系列等單片機上實現SPI總線的接口。
        
        
        
        
        

      【SPI總線在51系列單片機系統中的實現】相關文章:

      MCS51系列單片機雙機并行互連的實現方法08-06

      單片機系統中的多任務多線程機制的實現08-06

      用CPLD實現單片機與ISA總線接口的并行通信08-06

      基于USB總線的實時數據采集系統設計與實現08-06

      分時操作系統思想在單片機編程中的實現08-06

      基于串行外設接口(SPI)的CAN總線隔離擴展設計08-06

      PCI總線仲裁器的設計與實現08-06

      單片機系統中的漢字顯示08-06

      基于CPLD的系統中I2C總線的設計08-06

      主站蜘蛛池模板: 国产日产免费高清欧美一区| 亚洲乱码国产乱码精品精| 亚洲欧洲日产国产 最新| 四虎永久在线精品免费看| 十八禁国产精品一区二区| 澳门永久av免费网站| 综合激情亚洲丁香社区| 真实单亲乱l仑对白视频| 成人无码区在线观看| 久久中文字幕av第二页| 久久精品国产99国产精品严洲| 国产午夜精品福利91| 国产精品久久久久无码网站| 国产精品国产亚洲区久久| 91亚洲一线产区二线产区| 欧洲美熟女乱av在免费| 40岁大乳的熟妇在线观看| 精品国产一区二区三区国产区| 亚洲国内精品一区二区| 成年女人喷潮免费视频| 亚洲超碰97无码中文字幕 | 久久亚洲精品中文字幕波多野结衣 | 午夜福利宅福利国产精品| 亚洲中文字幕伊人久久无码| 东京热无码国产精品| 国产首页一区二区不卡| 国产精品亚洲色婷婷99久久精品| 精品亚洲国产成人痴汉av| 亚洲中文一区二区av| 国产精品高清视亚洲乱码| 国产激情文学亚洲区综合| 极品少妇的粉嫩小泬看片| 久久人体视频| 毛多水多高潮高清视频| caoporn免费视频公开| 人妻少妇久久中文字幕| 日韩丝袜亚洲国产欧美一区| 污网站在线观看视频| 亚洲综合天堂一区二区三区| 一亚洲一区二区中文字幕| 国产偷自视频区视频|