當(dāng)前位置:首頁(yè) > 通信技術(shù) > 通信網(wǎng)絡(luò)
[導(dǎo)讀] 1 引 言 交換機(jī)是局域網(wǎng)最重要的網(wǎng)絡(luò)連通設(shè)備,局域網(wǎng)的管理大多會(huì)涉及交換機(jī)的管理。交換機(jī)分為可網(wǎng)管交換機(jī)和不可網(wǎng)管交換機(jī),這兩種交換機(jī)的區(qū)別主要在是否能被管理。這里的管理是指通過(guò)管理端

1 引 言

交換機(jī)是局域網(wǎng)最重要的網(wǎng)絡(luò)連通設(shè)備,局域網(wǎng)的管理大多會(huì)涉及交換機(jī)的管理。交換機(jī)分為可網(wǎng)管交換機(jī)和不可網(wǎng)管交換機(jī),這兩種交換機(jī)的區(qū)別主要在是否能被管理。這里的管理是指通過(guò)管理端口執(zhí)行監(jiān)控交換機(jī)端口狀態(tài)、劃分VLAN、設(shè)置Trunk等操作,可以被管理的交換機(jī)就是網(wǎng)管交換機(jī)。網(wǎng)管交換機(jī)可以通過(guò)串口、Web(網(wǎng)絡(luò)瀏覽器)和網(wǎng)管軟件來(lái)管理。

網(wǎng)管交換機(jī)的內(nèi)部大致結(jié)構(gòu)如圖1所示。

其工作原理:端口進(jìn)來(lái)的數(shù)據(jù)包先到交換芯片,交換芯片判定是否是管理包,若不是則通過(guò)其他端口轉(zhuǎn)發(fā)出去;若是,則傳送給接口芯片,由接口芯片傳給CPU進(jìn)行處理。同時(shí),一些由CPU產(chǎn)生的管理包要通過(guò)接口芯片傳給交換芯片,用來(lái)控制交換芯片,或者通過(guò)端口發(fā)送出去??偟貋?lái)說(shuō),接口芯片主要起到了CPU和交換機(jī)芯片間的橋梁作用。

接口芯片和CPU之間通常是通過(guò)PCI總線或一 般的數(shù)據(jù)/地址總線相連的,和交換芯片間的接口形式主要看交換芯片的接口,不同廠家的交換芯片具有不 同的接口。本文主要討論如何使用低功耗的接口芯片GT-48330來(lái)實(shí)現(xiàn)對(duì)具有G.Link接口的交換芯片的控制和管理。

2 芯片介紹

GT-48330是美國(guó)Marvell公司的低功耗G.Link 和CPU的接口芯片。他在8/16 b CPU總線和Marvell公司的具有G.Link接口的交換芯片的G.Link總線之間提供了一個(gè)硬件接口。他支持多種嵌入式CPU和微處理器,如80C186,8051,Motorola Coldfire,Inteli960等,CPU可以直接通過(guò)他實(shí)現(xiàn)對(duì)交換芯片的管理。GT-48330作為低價(jià)的G.Link到CPU的接口芯片,代替了在高端管理系統(tǒng)的PCI接口芯片。

他可以與多種不同的CPU和微控制器相連接,其CPU的接口數(shù)據(jù)寬度為8/16 b,具有片內(nèi)包緩沖器,能夠在片內(nèi)緩存整個(gè)完整長(zhǎng)度的包,CPU能夠通過(guò)簡(jiǎn)單的讀寫操作進(jìn)入包緩存器。具有中斷控制器,能夠接收來(lái)自交換芯片產(chǎn)生的中斷并可以對(duì)本地的CPU或微控制器產(chǎn)生中斷。提供屏蔽和觸發(fā)寄存器。采用3.3 V的核心電壓,功耗較低。G.Link口的時(shí)鐘可達(dá)

2.1 接口說(shuō)明

(1)和交換芯片間的接口GT-48330提供了16根發(fā)送數(shù)據(jù)線GTXD[15∶0],16根的接收數(shù)據(jù)線GRXD[15∶0],用來(lái)和交換芯片進(jìn)行數(shù)據(jù)傳輸;一根發(fā)送命令線GTXCMD,他只在第一個(gè)時(shí)鐘周期為高,表示傳輸線上為命令類型,其他的周期將為低電平,表示傳輸線上為數(shù)據(jù);一根接收命令線GRXCMD;一根G.Link時(shí)鐘輸入線GTXCLK;一根發(fā)送數(shù)據(jù)的參考時(shí)鐘線GTXOCLK;一根接收數(shù)據(jù)的參考時(shí)鐘線GRXCLK,需由外部的時(shí)鐘來(lái)提供。一根用于說(shuō)明其G.Link口是否連接的GUNCC線。

(2)和CPU間的接口GT-48330的CPU接口提供了16 b的數(shù)據(jù)線AD[15∶0],用于與CPU的數(shù)據(jù)線相接;12 b數(shù)據(jù)線Add[11∶0],用于與CPU的地址線相接;一根片選線CS;讀、寫信號(hào)線RD與WR各一根;一根工作模式選擇線Endian,用以設(shè)置其輸出的數(shù)據(jù)高低字節(jié)是否交換;一根地址存信號(hào)線ALE;一根數(shù)據(jù)返回有效線DTACK;一根中斷線INT,用來(lái)和CPU的中斷管腳相接;一根DTACK模式選擇線DTACKMODE,用以確定何時(shí)DTACK有效;一根配置線MB,用來(lái)決定數(shù)據(jù)、地址線是否復(fù)用;一根模式選擇線ASM,用以選擇異步或同步模式;一根時(shí)鐘線CLK,為GT-48330提供CPU接口的參考時(shí)鐘;一根復(fù)位線RST,用以復(fù)位GT-48330[page]

2.2 工作原理

GT-48330作為CPU和G.Link接口的交換芯片間的橋梁,主要的工作就是將數(shù)據(jù)從交換芯片轉(zhuǎn)給CPU,這對(duì)GT-48330來(lái)講是一個(gè)接收過(guò)程;并將CPU發(fā)過(guò)來(lái)的數(shù)據(jù)轉(zhuǎn)給交換芯片,這對(duì)GT-48330來(lái)講是一個(gè)發(fā)送過(guò)程。

2.2.1 GT-48330的接收

GT-48330接收的數(shù)據(jù)分為4種:由交換芯片送過(guò)來(lái)的數(shù)據(jù)包、由交換芯片送過(guò)來(lái)的新地址消息(一個(gè)數(shù)據(jù)包只要通過(guò)交換芯片,包中的源地址信息就會(huì)被交換芯片記錄并傳送)、由交換芯片送過(guò)來(lái)的中斷消息和CPU要從交換芯片中讀取的消息。

(1)接收數(shù)據(jù)包過(guò)程 在GT-48330中存在2 kB的緩沖區(qū)(Buffer)用于接收來(lái)自交換芯片的包。由交換芯片產(chǎn)生的包發(fā)送結(jié)束消息(EOP)存在0x9E4 0x9EF中,當(dāng)GT-48330接收到包,并監(jiān)測(cè)到EOP后,他將發(fā)送相應(yīng)的中斷給CPU,CPU從Interrput-cause寄存器中可以獲得中斷的原因,這樣CPU就可以從Buffer中讀取包。

當(dāng)Buffer滿時(shí),如果GT-48330還沒(méi)有完成對(duì)先 前包的處理,又有新的包到來(lái),此時(shí)將會(huì)產(chǎn)生G.Link口的擁塞。GT-48330可以設(shè)置Disable PacketBlocking(DPB)bit來(lái)防止擁塞,當(dāng)設(shè)為0時(shí),GT- 48330將通過(guò)發(fā)流控消息來(lái)防止G.Link口的擁塞;當(dāng)設(shè)為1時(shí),GT-48330將通過(guò)拒絕這些包來(lái)防止擁塞,此時(shí)所有的包將被忽略。

(2)接收新地址消息的過(guò)程GT-48330中存在一個(gè)專用的新地址隊(duì)列(NA_Q),共可以存儲(chǔ)16個(gè)條目,對(duì)應(yīng)的存儲(chǔ)地址為0x800~0x80F。當(dāng)有新的地址到來(lái)時(shí),GT-48330將發(fā)送一個(gè)中斷給CPU,這樣CPU就可以到0x800~0x80F中提取新的地址消息,同時(shí)將Interrput-cause0寄存器清零;如果GT-48330還有新的地址,將會(huì)把新的地址消息放入到0x800~0x80F中,并再次發(fā)出中斷。

(3)對(duì)于新地址隊(duì)列溢出的情況,GT-48330可以通 過(guò)忽略或發(fā)流控消息來(lái)處理。這可以通過(guò)設(shè)置GT48330的Enable_register<DNAB>bit來(lái)實(shí)現(xiàn),而CPU可以通過(guò)監(jiān)測(cè)NAQOF中斷來(lái)獲得。如果<DNAB>bit設(shè)置為1時(shí),當(dāng)NA_Q滿時(shí),GT-48330將忽略到來(lái)的新地址消息;如果為0時(shí),當(dāng)NA_Q滿時(shí)則發(fā)流控信息,通知交換芯片,暫緩發(fā)送。

(4)CPU要從交換芯片中讀取消息的過(guò)程CPU發(fā)送消息給交換芯片,表示要獲取數(shù)據(jù)(例如一些端口狀態(tài)信息)。此時(shí),交換芯片會(huì)發(fā)送Block_write消息給CPU,在GT-48330中有一個(gè)專用的32B的Buffer用于存儲(chǔ)此消息,對(duì)應(yīng)的存儲(chǔ)地址為:0x980~0x99F。當(dāng)有block_write到來(lái)時(shí),GT-48330將發(fā)送中斷消息給CPU,CPU通過(guò)相關(guān)的中斷位獲取中斷,然后來(lái)讀取block_write消息。

2.2.2 GT-48330的發(fā)送

對(duì)于GT-48330來(lái)說(shuō)他具有2種發(fā)送方式:自動(dòng)DMA方式和CPU傳輸方式。對(duì)于自動(dòng)DMA的方式,不需要CPU進(jìn)行干涉,GT-48330可以自動(dòng)完成發(fā)送。對(duì)于CPU傳輸方式,則需要CPU對(duì)發(fā)送的過(guò)程進(jìn)行干涉。

(1)自動(dòng)DMA方式 CPU首先寫傳輸數(shù)據(jù)(TD)寄存器,同時(shí)設(shè)置<TD>位,GT-48330根據(jù)TD來(lái)向交換芯片發(fā)送Buffer請(qǐng)求消息,在TD消息中包含了目的交換芯片號(hào)、端口號(hào)、CPU號(hào)及包的數(shù)量等消息。CPU寫數(shù)據(jù)到GT-48330的32 b的包存儲(chǔ)空間8LWW Buffer中,如果GT-48330接收到交換芯片可以開始傳送包的消息(SOP),他將把包發(fā)送給相應(yīng)的交換芯片;如果收到交換芯片的拒絕消息(Buffer_rejecet),他將發(fā)送相應(yīng)的中斷給CPU,告訴發(fā)數(shù)據(jù)被拒絕。

(2)CPU傳輸方式 CPU先直接通過(guò)GNT-A/B Buffer來(lái)發(fā)送Buffer請(qǐng)求消息,CPU等待接收到SOP消息,此消息將被GT-48330存儲(chǔ)在OGRBuffer中,然后再傳給CPU。一旦CPU收到SOP消息,就通過(guò)GT-48330的GNT-A/B通道來(lái)發(fā)送數(shù)據(jù)包,同時(shí)CPU還通過(guò)GNT-A/B來(lái)發(fā)送數(shù)據(jù)包傳送結(jié)束(EOP)消息給交換芯片。

3 電路設(shè)計(jì)

GT-48330的G.Link口的電路設(shè)計(jì)說(shuō)明:數(shù)據(jù)發(fā)送和接收線GTXD[15∶0]/GRXD[15∶0]與交換芯片的G.Link口的接收和發(fā)送線相連;GTXCMD/GRXCMD發(fā)送和接收與交換芯片的接收和發(fā)送命令線相連;GTXOCLK發(fā)送數(shù)據(jù)的參考時(shí)鐘,通過(guò)22Ω的匹配電阻接到交換芯片的G.Link口的接收時(shí)鐘;GRXCLK接收數(shù)據(jù)的參考時(shí)鐘,由時(shí)鐘模塊來(lái)提供;GTXCLK接收數(shù)據(jù)的參考時(shí)鐘,由時(shí)鐘模塊來(lái)提供;GTXCLK作為GT-48330的G.Link口的系統(tǒng)時(shí)鐘,同樣由時(shí)鐘模塊來(lái)提供。GTXCLK和GRXCLK的時(shí)鐘頻率為83.33 MHz。電路邏輯圖如圖2所示。

GT-48330的CPU接口的電路設(shè)計(jì)說(shuō)明:此設(shè)計(jì) 使用的CPU是Motorola公司的Coldfire 5206E。由于在16 b接口時(shí),MCF5205E的數(shù)據(jù)線數(shù)據(jù)是交換的,即D[31∶24]表示BYTE0;D[23∶16]表示BYTE1。同時(shí)在設(shè)計(jì)中將GT-48330的Endian管腳下拉,這樣GT-48330將工作在Little Endian模式下,其數(shù)據(jù)是 不進(jìn)行交換的,因此在外部需要將數(shù)據(jù)線進(jìn)行交換,即將GT-48330的AD[15:18]與CPU的D[23:16]相接,將GT-48330的AD[7:0]與CPU的D[31:24]相連接;GT-48330的地址線Add[11:0]與CPU的地址線A[11∶0]直接相接;片選信號(hào)CS與MCF5206E的CS1管腳相接;GT-48330的讀/寫信號(hào)RD和WR相連接后,再與MCF5206E的R/W信號(hào)相接。當(dāng)R/W為高電平時(shí),GT-48330的讀信號(hào)RD有效;當(dāng)R/W為低電平時(shí),GT-48330的寫信號(hào)WR有效;地址鎖存信號(hào)ALE與MCF5206E的TS信號(hào)相接,低電平有效;中斷管腳INT與MCF5206E的中斷管腳IRQ4相接,提供中斷信號(hào),低電平有效;GT-48330的DTACK與MCF5206E的TA相接,低電平有效,表示數(shù)據(jù)傳輸結(jié)束;RST信號(hào)直接與復(fù)位模塊的DSP1832(或MAX811)的輸出信號(hào)相連接,用于對(duì)GT-48330GT-48330的復(fù)位,低電平有效;CLK時(shí)鐘則由時(shí)鐘模塊提供,其頻率為54MHz。復(fù)位時(shí)GT-48330將對(duì)某些管腳進(jìn)行抽樣,以決定系統(tǒng)的工作狀態(tài)。在配置中拉高通過(guò)4.7 kΩ的電阻接3.3 V來(lái)實(shí)現(xiàn),拉低通過(guò)4.7kΩ的電阻接地來(lái)實(shí)現(xiàn)。

4 軟件實(shí)現(xiàn)

軟件分引導(dǎo)層(BOOT)和CTRL層。MCF5206E上電復(fù)位后從BOOT開始執(zhí)行,BOOT層程序功能包括上電初始化,引導(dǎo)或下裝CTRL層程序及上裝整片F(xiàn)lash的內(nèi)容。軟件總體框架如圖3所示。

首先對(duì)硬件進(jìn)行配置:包括片選、DRAM參數(shù)、初始化定時(shí)器、I/O等,然后進(jìn)行DRAM/CPU ISRAM自檢,若自檢失敗則從超級(jí)終端上輸出相應(yīng)的錯(cuò)誤信息,然后停機(jī)。若自檢通過(guò)則檢測(cè)CTRL層程序的完整性,若CTRL層程序完整則將其拷貝到DRAM的相應(yīng)位置并將控制權(quán)交給CTRL層程序;若CTRL層程序不完整則通過(guò)超級(jí)終端輸出相應(yīng)信息并允許下裝CTRL層程序或上裝整片F(xiàn)lash的內(nèi)容。

CTRL層程序提供一個(gè)超級(jí)終端界面,進(jìn)行各項(xiàng)功能模塊的設(shè)置及測(cè)試。界面設(shè)置的內(nèi)容如下:初始化設(shè)置及配置的讀取,GT48330寄存器的操作,交換芯片寄存器的操作,Switch各功能模塊操作:幀收發(fā)、VLAN設(shè)置、TRUNK操作、端口配置、MIB采集等。

在系統(tǒng)上電后,由電源模塊為整個(gè)系統(tǒng)提供電源支持,然后復(fù)位模塊將向整個(gè)系統(tǒng)提供復(fù)位信號(hào),時(shí)鐘模塊向系統(tǒng)提供參考時(shí)鐘。在MCF5206E和GT48330模塊復(fù)位之后,MCF5205E將從存儲(chǔ)模塊Flash中讀取程序進(jìn)行運(yùn)行,根據(jù)程序運(yùn)行的結(jié)果,MCF5205E模塊將通過(guò)GT-48330模塊對(duì)系統(tǒng)中的所有的交換芯片進(jìn)行初始化,完成對(duì)系統(tǒng)的配置。在以后的過(guò)程中MCF5206E將通過(guò)GT-48330模塊來(lái)進(jìn)行對(duì)系統(tǒng)的管理及包的接收和發(fā)送。而存儲(chǔ)模塊中的EDODRAM則用于存放在運(yùn)行過(guò)程中所需的程序及數(shù)據(jù)和包的臨時(shí)存放。

5 對(duì)于擁塞控制的分析

由于GT-48330的構(gòu)架對(duì)于接收的G.Link口采用共同的FIFO,然后通過(guò)Out Messager Detecter來(lái)判別FIFO中的數(shù)據(jù)應(yīng)該送到哪個(gè)通道中,這樣就有可能產(chǎn)生擁塞。如果某個(gè)通道滿了,他將不再接受OutMessager Detecter判定要發(fā)送給他的數(shù)據(jù)或消息,這樣將使得數(shù)據(jù)聚集在FIFO中,從而使得FIFO滿而產(chǎn)生擁塞。

對(duì)于新地址、包接收、中斷接收3個(gè)通道,可以通過(guò)一個(gè)可選的模式來(lái)防止擁塞,也就是他們?cè)诓荒芙邮諘r(shí),將通過(guò)丟棄新到的消息來(lái)防止其聚集在FIFO中導(dǎo)致?lián)砣?/p>

如果有許多的數(shù)據(jù)同時(shí)發(fā)給包Buffer的話,會(huì)使Buffer是滿的,同時(shí)如果此時(shí)<DPB>設(shè)為0(沒(méi)有丟棄包),這時(shí)G.Link口將產(chǎn)生流控消息,造成G.Link口的堵塞。如果這時(shí)CPU對(duì)某個(gè)設(shè)備發(fā)送了LW_WRITE消息時(shí),他將一直等待Buffer請(qǐng)求確認(rèn)(BFR)的到來(lái),在沒(méi)有收到此消息時(shí),將不會(huì)進(jìn)行其他的數(shù)據(jù)處理。而由于G.Link口的擁塞將導(dǎo)致BFR無(wú)法送出,因此包Buffer中的數(shù)據(jù)也將一直得不到CPU的處理,這樣將導(dǎo)致CPU的死鎖。死鎖的解決方法:

(1)可以將交換芯片設(shè)置成單包模式(SignalPacket Mode),使其只有在一個(gè)包被處理完后,才送下一個(gè)包。

(2)使用包擁塞失效位(Disable PacketBlocking),采用對(duì)新地址、包接收、中斷消息的丟棄來(lái)防止。同時(shí)CPU也可以通過(guò)某些方法來(lái)判斷潛在的擁塞,從而使得該寄存器置位。例如,可以限制發(fā)往CPU的包的類型和數(shù)量來(lái)控制。

由上可知,采用相關(guān)通道的丟棄功能可以防止CPU的死鎖問(wèn)題,同時(shí),他只對(duì)本身的通道有影響;如果僅采用流控功能則有可能導(dǎo)致死鎖問(wèn)題的產(chǎn)生,對(duì)整個(gè)G.Link口產(chǎn)生影響。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉