SPI、I2C、UART三種串行總線的區(qū)別
ISP:In SyestermProgram
AT89S52在系統(tǒng)編程(ISP)所用到的幾個(gè)引腳定義:
SPI簡(jiǎn)述(Serial Peripheral Interface--串行外設(shè)接口)總線系統(tǒng)是一種同步串行外設(shè)接口,它可以使MCU與各種外圍設(shè)備以串行方式進(jìn)行通信以交換信息。外圍設(shè)置FLASHRAM、網(wǎng)絡(luò)控制器、LCD顯示驅(qū)動(dòng)器、A/D轉(zhuǎn)換器和MCU等。SPI總線系統(tǒng)可直接與各個(gè)廠家生產(chǎn)的多種標(biāo)準(zhǔn)外圍器件直接接口,該接口一般使用4條線:串行時(shí)鐘線(SCK)、主機(jī)輸入/從機(jī)輸出數(shù)據(jù)線MISO、主機(jī)輸出/從機(jī)輸入數(shù)據(jù)線MOST和低電平有效的從機(jī)選擇線SS(有的SPI接口芯片帶有中斷信號(hào)線INT或INT、有的SPI接口芯片沒(méi)有主機(jī)輸出/從機(jī)輸入數(shù)據(jù)線MOSI)。由于SPI系統(tǒng)總線一共只需3~4位數(shù)據(jù)線和控制即可實(shí)現(xiàn)與具有SPI總線接口功能的各種I/O器件進(jìn)行接口,而擴(kuò)展并行總線則需要8根數(shù)據(jù)線、8~16位地址線、2~3位控制線,因此,采用SPI總線接口可以簡(jiǎn)化電路設(shè)計(jì),節(jié)省很多常規(guī)電路中的接口器件和I/O口線,提高設(shè)計(jì)的可靠性。由此可見(jiàn),在MCS51系列等不具有SPI接口的單片機(jī)組成的智能儀器和工業(yè)測(cè)控系統(tǒng)中,當(dāng)傳輸速度要求不是太高時(shí),使用SPI總線可以增加應(yīng)用系統(tǒng)接口器件的種類,提高應(yīng)用系統(tǒng)的性能。
SPI四線制引腳功能定義
小結(jié):AT89S52單片機(jī)的FLASH燒寫程序接口是ISP,所用為燒寫程序小板上主控芯片AVR的SPI通信引腳MOSI、MISO、SCLK。
什么是JTAG?
JTAG是一個(gè)通信標(biāo)準(zhǔn),用于計(jì)算機(jī)和單片機(jī)進(jìn)行實(shí)時(shí)快速通訊。
AVR
使用AVR studio軟件和JTAG硬件(
JTAG接口有四個(gè)引腳。以JTAG的術(shù)語(yǔ)來(lái)說(shuō),這些引腳組成了測(cè)試訪問(wèn)端口TAP。這些引腳是:
·TMS:測(cè)試模式選擇。此引腳用來(lái)實(shí)現(xiàn)TAP
·TCK:測(cè)試時(shí)鐘。JTAG
·TDI:
·TDO:測(cè)試數(shù)據(jù)輸出--
什么是ISP?
ISP是一種通用的程序下載方式,AVR單片機(jī)都有ISP下載接口??梢酝ㄟ^(guò)ISP下載線或者STK500把程序下載到單片機(jī)中。
ISP下載線成本低廉,制作簡(jiǎn)單,一個(gè)并口ISP下載線只需幾十元即可得到。開(kāi)發(fā)工具成本低也是AVR單片機(jī)的優(yōu)勢(shì)之一。
JTAG與ISP的區(qū)別和聯(lián)系
區(qū)別:JTAG可以調(diào)試程序,而ISP只能下載程序。
聯(lián)系:同作為AVR程序下載工具,都能把程序從電腦下載到單片機(jī)中。都能對(duì)芯片的熔絲位和鎖定位進(jìn)行編程。
JTAG調(diào)試與普通軟件仿真的區(qū)別和聯(lián)系
聯(lián)系:都可以在計(jì)算機(jī)調(diào)試程序終端看到程序的運(yùn)行效果,都可以設(shè)置斷點(diǎn),單步運(yùn)行,進(jìn)入循環(huán),跳出循環(huán),連續(xù)運(yùn)行等操作。還能實(shí)時(shí)觀察各寄存器的值,IO口狀態(tài)等。
區(qū)別:軟件仿真,用的是計(jì)算機(jī)來(lái)模仿單片機(jī)運(yùn)行,不是全真的環(huán)境,很多時(shí)候會(huì)出現(xiàn)偏差甚至錯(cuò)誤。而用JTAG在線調(diào)試,程序本身在單片機(jī)內(nèi)運(yùn)行,完全真實(shí)的硬件環(huán)境,更準(zhǔn)確的反映程序運(yùn)行的實(shí)際情況,有助于大型程序的調(diào)試。
第一個(gè)區(qū)別當(dāng)然是名字:
第二,區(qū)別在電氣信號(hào)線上:
第三,從第二點(diǎn)明顯可以看出,SPI和UART可以實(shí)現(xiàn)全雙工,但I(xiàn)2C不行;
第四,看看牛人們的意見(jiàn)吧!
1、SPI(Serial Peripheral Interface串行外圍接口):高速、全雙工、同步串行口。
三或四個(gè)信號(hào)用于數(shù)據(jù)交換:
SIMO:從進(jìn),主出
SOMI:從出,主進(jìn)
UCLK:時(shí)鐘,由主機(jī)驅(qū)動(dòng),從機(jī)用它發(fā)送和接收數(shù)據(jù)
STE:從機(jī)發(fā)送允許,用于四線模式中控制多主從系統(tǒng)中的多個(gè)從機(jī)
三線SPI組成:串行時(shí)鐘(SCLK)、串行數(shù)據(jù)輸出(SDO)、串行數(shù)據(jù)輸入(SDI);當(dāng)有多個(gè)從設(shè)備時(shí),還可以增加一條從設(shè)備選擇線。四線SPI模式用附加控制線,來(lái)允許從機(jī)數(shù)據(jù)的發(fā)送和接收,它由主機(jī)控制。
SPI總線可以實(shí)現(xiàn)多個(gè)SPI設(shè)備互相連接。
提供SPI串行時(shí)鐘的SPI設(shè)備為SPI主機(jī)或主設(shè)備(Master),其他設(shè)備為SPI從機(jī)或從設(shè)備(Slave)。
主從設(shè)備間可以實(shí)現(xiàn)全雙工通信,SPI接口是在CPU和外圍低速器件之間進(jìn)行同步串行數(shù)據(jù)傳輸,在主器件的移位脈沖下,數(shù)據(jù)按位傳輸,高位在前,地位在后,為全雙工通信。
UART需要固定的波特率,而SPI則無(wú)所謂,因?yàn)樗怯袝r(shí)鐘的協(xié)議。
SPI接口主要應(yīng)用在EEPROM,FLASH,實(shí)時(shí)時(shí)鐘,AD轉(zhuǎn)換器,還有數(shù)字信號(hào)處理器和數(shù)字信號(hào)解碼器之間。
2、I2C(Inter IC Bus)接口定義:
I2C總線是雙向兩線(SCL——串行時(shí)鐘、SDA——串行數(shù)據(jù)線)制同步串行總線,具有競(jìng)爭(zhēng)檢測(cè)和仲裁機(jī)制,可使多個(gè)主機(jī)任意同時(shí)發(fā)送數(shù)據(jù)而不破壞總線上的數(shù)據(jù)信息。非常適合在器件之間進(jìn)行近距離、非經(jīng)常性的數(shù)據(jù)通信。在它的協(xié)議體系中,傳輸數(shù)據(jù)時(shí)都會(huì)帶上目的設(shè)備的設(shè)備地址,因此可以實(shí)現(xiàn)設(shè)備組網(wǎng)。
特點(diǎn):
A、每個(gè)連到總線上的器件都可由軟件唯一的地址尋址,并建立簡(jiǎn)單的主從關(guān)系。主器件既可作為發(fā)送器,又可作為接收器。
B、同步時(shí)鐘允許器件通過(guò)總線以不同的波特率進(jìn)行通信
C、同步時(shí)鐘可以作為停止和重新啟動(dòng)串行口發(fā)送的握手方式
D、連接到同一總線上的集成電路器件數(shù)只受400PF的總大總線電容的限制
注:組成I2C總線的串行數(shù)據(jù)線SDA和串行時(shí)鐘線SCL必須經(jīng)過(guò)上拉電阻Rp接到正電源上,連接到總線上的器件的輸出極必須為“開(kāi)漏”或“開(kāi)集”的形式,以便完成“線與”的功能。
I2C需要有雙向IO的支持,而且使用上拉電阻,抗干擾能力較弱,一般用于同一板卡上芯片之間的通信,較少用于遠(yuǎn)距離通信。
各種接口之間的區(qū)別如下:
1、UART和USART兩個(gè)的區(qū)別是UART:universal asynchronous receiver and transmitter通用異步收發(fā)器USART:universal synchronous asynchronous receiver and transmitter通用同步異步收發(fā)器,USART是新出的,是復(fù)用功能,可以選擇SPI模式(同步串行通訊)也可以是UART模式(異步串行通訊),比UART功能跟強(qiáng)大。UART就是兩線,一根發(fā)送一根接收,可以全雙工通信,線數(shù)也比較少。數(shù)據(jù)是異步傳輸?shù)?,?duì)雙方的時(shí)序要求比較嚴(yán)格,通信速度也不是很快。在多機(jī)通信上面用的最多。
2、SPI接口和上面UART相比,多了一條同步時(shí)鐘線,上面UART的缺點(diǎn)也就是它的優(yōu)點(diǎn)了,對(duì)通信雙方的時(shí)序要求不嚴(yán)格不同設(shè)備之間可以很容易結(jié)合,而且通信速度非??臁R话阌迷诋a(chǎn)品內(nèi)部元件之間的高速數(shù)據(jù)通信上面,如大容量存儲(chǔ)器等。
3、I2C接口也是兩線接口,它是兩根線之間通過(guò)復(fù)雜的邏輯關(guān)系傳輸數(shù)據(jù)的,通信速度不高,程序?qū)懫饋?lái)也比較復(fù)雜。一般單片機(jī)系統(tǒng)里主要用來(lái)和24C02等小容易存儲(chǔ)器連接
評(píng)論