日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 智能硬件 > 智能硬件
[導(dǎo)讀]提出了在TMS320C6000系列DSP上應(yīng)用McBSP實(shí)現(xiàn)I2C總線(xiàn)接口協(xié)議的方法。

  作者Email: dick_ligg@sohu.com

    摘 要:提出了在TMS320C6000系列DSP上應(yīng)用McBSP實(shí)現(xiàn)I2C總線(xiàn)接口協(xié)議的方法,使DSP可以接入其他需要I2C總線(xiàn)配置的智能器件,系統(tǒng)結(jié)構(gòu)簡(jiǎn)單,硬件設(shè)計(jì)容易,資源消耗小。

    關(guān)鍵字:I2C總線(xiàn)  GPIO  McBSP  DSP

    1 引 言

    TI公司的TMS320C6000[1,2]系列是高性能的DSP,可廣泛的用于XDSL、無(wú)線(xiàn)基站、數(shù)字圖像處理等方面。在進(jìn)行數(shù)字圖像處理時(shí),通常需要視頻解碼器諸如SAA7111A之類(lèi)的模擬視頻前端,而大多數(shù)的視頻解碼器進(jìn)行初始化通常是通過(guò)兩線(xiàn)的I2C總線(xiàn)接口,但是現(xiàn)在的DSP和MCU大部分都沒(méi)有I2C總線(xiàn)接口,在這種情況下我們可以應(yīng)用兩個(gè)通用的IO線(xiàn),通過(guò)軟件的方法來(lái)模擬I2C總線(xiàn)的協(xié)議,繼而完成I2C總線(xiàn)的接口。在TMS320C6000中通常都有兩個(gè)或兩個(gè)以上的多通道緩沖串行接口McBSP,McBSP不僅可以配制成串行接口還可以獨(dú)立的配制成通用的輸入(GPI)、輸出(GPO)和輸入輸出端口(GPIO)。

    I2C[3]串行總線(xiàn)是用雙向數(shù)據(jù)線(xiàn)(SDA)和串行時(shí)鐘線(xiàn)(SCL)兩根信號(hào)線(xiàn),在連接到該總線(xiàn)的器件之間傳送信息??偩€(xiàn)上的每個(gè)器件均可設(shè)置一個(gè)唯一地址,然后根據(jù)所設(shè)的功能進(jìn)行信息的發(fā)送或接收。除了作為發(fā)送器和接收器以外,在執(zhí)行數(shù)據(jù)傳輸時(shí),總線(xiàn)的器件還可以設(shè)定為主控器和受控器。通常由主控器啟動(dòng)總線(xiàn)上的數(shù)據(jù)傳輸,并產(chǎn)生數(shù)據(jù)傳輸所需的時(shí)鐘信號(hào)。而被其尋址的其它器件均為受控器,這意味著總線(xiàn)上可連接多個(gè)有控制總線(xiàn)的器件。

    I2C總線(xiàn)上的數(shù)據(jù)傳輸率為100kbit/s,快速方式下可達(dá)400kbit/s。連接到總線(xiàn)上的器件數(shù)僅受400pF的總線(xiàn)電容的限制。同時(shí),為了避免總線(xiàn)信號(hào)的混亂,要求連接到總線(xiàn)上的各器件輸出端必須是集電極開(kāi)路或漏極開(kāi)路,以便產(chǎn)生“線(xiàn)與”功能。I2C總線(xiàn)上的SDA和SCL線(xiàn)都是雙向傳輸線(xiàn),它們可通過(guò)一個(gè)電阻連接到正電源端,當(dāng)總線(xiàn)處于空閑狀態(tài)時(shí),兩條線(xiàn)均為高電平。

    2 硬件設(shè)計(jì)

    I2C總線(xiàn)的硬件設(shè)計(jì)非常方便,只需要將SDA 和SCL連接即可,在I2C總線(xiàn)上只允許有一個(gè)主控器,其余的都是受控器。當(dāng)節(jié)點(diǎn)的個(gè)數(shù)大于了400pF的限制時(shí),可以通過(guò)總線(xiàn)驅(qū)動(dòng)器如82B715來(lái)進(jìn)行總線(xiàn)擴(kuò)展。連接見(jiàn)圖1

    3 軟件設(shè)計(jì)

    3.1 McBSP的配置

    I2C總線(xiàn)應(yīng)用McBSP的兩個(gè)管腳,首先禁用McBSP功能以便將McBSP的管腳配制成GPI、GPO、GPIO。本文應(yīng)用McBSP0的CLKX0作為I2C總線(xiàn)的SCL,F(xiàn)SX0作為I2C總線(xiàn)的SDA,McBSP的DX,DR,通常不能配置成I2C的SDA,因?yàn)镾DA是雙向的,而DX,DR只能配制成單一的輸入或輸出。

    配置代碼如下:

McBSP0_SPCR=0x00000000;//McBSP0 發(fā)送和接收復(fù)位
McBSP0_PCR=0x00003F00;// McBSP0的所有的管腳都配置為GPIO,CLKX0和FSX0為輸出
對(duì)于主機(jī)來(lái)說(shuō)SCL總是輸出,所以它的方向是保持不變的,SCL應(yīng)該輸出0,1作為接口的時(shí)鐘,為了實(shí)現(xiàn)此功能我們定義一個(gè)宏(MACROS):SET_SCLHI( ) SET_SCLLO( )
#define Set_SCLHi( ) McBSP0_SPSA = PCR; McBSP0_SPSA |= 0x00000002
#define Set_SCLLo( ) McBSP0_SPSA = PCR; McBSP0_SPSA &= 0Xfffffffd
I2C總線(xiàn)的數(shù)據(jù)線(xiàn)SDA當(dāng)寫(xiě)的時(shí)候是輸入,讀的時(shí)候是輸出。為了改變SDA的方向可以定義Set_SDADirOut( ) Set_SDADirIn( )
#define Set_SDADirOut( ) McBSP0_SPSA = PCR; McBSP0_SPSA | = 0x00000800
#define Set_SDADirIn( ) McBSP0_SPSA = PCR; McBSP0_SPSA &= 0xFFFFF7FF
SDA應(yīng)該依照數(shù)據(jù)位的0,1來(lái)變化,為了輸出1,0定義Set_SDAHi( ) Set_SDALo( )
#define Set_SDAHi( ) McBSP0_SPSA = PCR; McBSP0_SPSA |= 0x00000008
#define Set_SDALo( ) McBSP0_SPSA = PCR; McBSP0_SPSA &= 0xFFFFFFF7
定義好之后可以模擬I2C總線(xiàn)的協(xié)議進(jìn)行傳送,例如在SAA7111A上的I2C總線(xiàn)接口是用來(lái)對(duì)SAA7111A進(jìn)行初始化用的,SCL的頻率可以從0到400KHZ,為了控制SCL的頻率可以應(yīng)用DSP的TIMER0來(lái)控制。
當(dāng)CPU為100MHZ時(shí):
TCR = 0x00000010; // 停止 TIMER0 and TDDR=0
PRD = 6249; // TIMER0 rate = CPU-Frequency/(PDR+1) = 100MHz/6250 = 16kHz
...
TCR &= 0xFFFFFFEF; // 開(kāi)始 TIMER0

    3.2 I2C總線(xiàn)協(xié)議編程

    3.2.1  I2C總線(xiàn)協(xié)議讀寫(xiě)數(shù)據(jù)流的編程

    為了進(jìn)行I2C總線(xiàn)的通訊,我們選用每位數(shù)據(jù)流4幀(FRAMES),以便延遲和噪聲干擾最小,4幀每位的數(shù)據(jù)流保證了SDA不會(huì)變化在SCL的邊沿處,僅僅允許數(shù)據(jù)變化在FRAME0,讀僅在FRAME2。如圖2所示

I2C總線(xiàn)的寫(xiě)程序如下

void I2CWrite(unsigned int WriteBit)
{Set_SDADirOut( ); // 設(shè)置SDA為輸出
switch(FrameCount)
{
case(0): // 起始幀
Set_SCLLo( ); // SCL 為 0
if (WriteBit == 0) // SDA = WriteBit
Set_SDALo( );
else
Set_SDAHi( );
break;
case(3): // 第4幀
Set_SCLLo( ); //
break;
default: // 在第2,3幀
Set_SCLHi( ); // SCL 為 1
}
FrameCount += 1; // 幀計(jì)數(shù)
if (FrameCount > 3)
{
FrameCount = 0;
BitIndex = (BitIndex >> 1); } // 準(zhǔn)備下一個(gè)發(fā)送位
}
I2C總線(xiàn)的讀程序與寫(xiě)程序很類(lèi)似,只需要改變SDA為輸入即可。

    3.2.2 I2C總線(xiàn)的開(kāi)始位和停止位的編程

    I2C總線(xiàn)的開(kāi)始位和停止位有3幀產(chǎn)生,在I2C總線(xiàn)傳輸過(guò)程中,僅當(dāng)總線(xiàn)空閑(SCL線(xiàn)和SDA線(xiàn)均為高電平)時(shí),數(shù)據(jù)傳送才能開(kāi)始,此時(shí)總線(xiàn)上的任何器件均可以控制總線(xiàn)。其中當(dāng)SCL線(xiàn)為高電平且SDA線(xiàn)由高變低時(shí)為開(kāi)始條件;而當(dāng)SCL線(xiàn)為高電平且SDA線(xiàn)由低變高時(shí)為結(jié)束條件。如圖3所示


開(kāi)始位:
void I2CSTA ( )
{ // I2C 開(kāi)始位
Set_SDADirOut ( );//定義SDA為輸出
switch ( FrameCount )
{
case (1): // 第2幀
Set_SCLHi ( );
Set_SDALo( );
break;
case (2): // 第三幀
Set_SCLLo ( );
Set_SDALo( );
break;
default: // 第一幀
Set_SCLHi ( );
Set_SDAHi ( );
}
FrameCount += 1; // 幀計(jì)數(shù)
if ( FrameCount > 2 )
{
FrameCount = 0;
BitIndex = 0x0080; } // 定義的低8位
}
停止位的編程方法只需要按照上面所說(shuō)的將SCL線(xiàn)為高電平且SDA線(xiàn)由低變高即可。
3.2.3 I2C總線(xiàn)的數(shù)據(jù)格式

起始位 受控器件地址 讀寫(xiě)控制位0/1 應(yīng)答位 數(shù)據(jù) 應(yīng)答位 … 停止位

    I2C總線(xiàn)數(shù)據(jù)傳輸格式[3]如圖4。其中第一部分為數(shù)據(jù)傳輸起始信號(hào),即由此開(kāi)始進(jìn)行數(shù)據(jù)傳送;第二部分為受控器地址,用來(lái)選擇向哪個(gè)受控器傳送數(shù)據(jù);第三部分為讀/寫(xiě)控制位,用于指示受控器的工作方式,0表示寫(xiě),1表示讀;第四部分是被主控器選中的受控器向主控器回傳的確認(rèn)信號(hào);第五部分是所傳送的數(shù)據(jù),每傳送一個(gè)字節(jié)數(shù)據(jù),都要求有一個(gè)應(yīng)答位;第六部分是數(shù)據(jù)傳輸?shù)慕Y(jié)束信號(hào)。每個(gè)具有I2C總線(xiàn)接口的受控器件都有唯一固定的地址,當(dāng)主控器發(fā)送數(shù)據(jù)時(shí),I2C總線(xiàn)上掛接的受控器件都會(huì)將主控器發(fā)出的、位于起始信號(hào)后的8位地址信息與自己的地址進(jìn)行比較,如果兩者相同,則認(rèn)為該受控器件被選中,然后按照讀/寫(xiě)位規(guī)定的工作方式接收或發(fā)送數(shù)據(jù)??梢詰?yīng)用上面的程序來(lái)按照I2C總線(xiàn)的數(shù)據(jù)格式進(jìn)行數(shù)據(jù)傳送。

    4 結(jié)論

    應(yīng)用DSP的McBSP來(lái)設(shè)計(jì)I2C總線(xiàn)接口,硬件接口簡(jiǎn)單,調(diào)試方便,并且可以節(jié)省硬件的花費(fèi),此方法已經(jīng)應(yīng)用在基于DSP的圖像匹配機(jī)中,方法可行,并運(yùn)行可靠。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶(hù)體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(chē)(EV)作為新能源汽車(chē)的重要代表,正逐漸成為全球汽車(chē)產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車(chē)的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車(chē)的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車(chē) 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車(chē)場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周?chē)娮釉O(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開(kāi)關(guān)電源具有效率高的特性,而且開(kāi)關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開(kāi)關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉