CPU接口芯片GT-48330在網(wǎng)管交換機中的應用
2.2 工作原理
GT-48330作為CPU和G.Link接口的交換芯片間的橋梁,主要的工作就是將數據從交換芯片轉給CPU,這對GT-48330來(lái)講是一個(gè)接收過(guò)程;并將CPU發(fā)過(guò)來(lái)的數據轉給交換芯片,這對GT-48330來(lái)講是一個(gè)發(fā)送過(guò)程。
2.2.1 GT-48330的接收
GT-48330接收的數據分為4種:由交換芯片送過(guò)來(lái)的數據包、由交換芯片送過(guò)來(lái)的新地址消息(一個(gè)數據包只要通過(guò)交換芯片,包中的源地址信息就會(huì )被交換芯片記錄并傳送)、由交換芯片送過(guò)來(lái)的中斷消息和CPU要從交換芯片中讀取的消息。
(1)接收數據包過(guò)程 在GT-48330中存在2 kB的緩沖區(Buffer)用于接收來(lái)自交換芯片的包。由交換芯片產(chǎn)生的包發(fā)送結束消息(EOP)存在0x9E4 0x9EF中,當GT-48330接收到包,并監測到EOP后,他將發(fā)送相應的中斷給CPU,CPU從Interrput-cause寄存器中可以獲得中斷的原因,這樣CPU就可以從Buffer中讀取包。
當Buffer滿(mǎn)時(shí),如果GT-48330還沒(méi)有完成對先 前包的處理,又有新的包到來(lái),此時(shí)將會(huì )產(chǎn)生G.Link口的擁塞。GT-48330可以設置Disable PacketBlocking(DPB)bit來(lái)防止擁塞,當設為0時(shí),GT- 48330將通過(guò)發(fā)流控消息來(lái)防止G.Link口的擁塞;當設為1時(shí),GT-48330將通過(guò)拒絕這些包來(lái)防止擁塞,此時(shí)所有的包將被忽略。
(2)接收新地址消息的過(guò)程GT-48330中存在一個(gè)專(zhuān)用的新地址隊列(NA_Q),共可以存儲16個(gè)條目,對應的存儲地址為0x800~0x80F。當有新的地址到來(lái)時(shí),GT-48330將發(fā)送一個(gè)中斷給CPU,這樣CPU就可以到0x800~0x80F中提取新的地址消息,同時(shí)將Interrput-cause0寄存器清零;如果GT-48330還有新的地址,將會(huì )把新的地址消息放入到0x800~0x80F中,并再次發(fā)出中斷。
(3)對于新地址隊列溢出的情況,GT-48330可以通 過(guò)忽略或發(fā)流控消息來(lái)處理。這可以通過(guò)設置GT48330的Enable_register<DNAB>bit來(lái)實(shí)現,而CPU可以通過(guò)監測NAQOF中斷來(lái)獲得。如果<DNAB>bit設置為1時(shí),當NA_Q滿(mǎn)時(shí),GT-48330將忽略到來(lái)的新地址消息;如果為0時(shí),當NA_Q滿(mǎn)時(shí)則發(fā)流控信息,通知交換芯片,暫緩發(fā)送。
(4)CPU要從交換芯片中讀取消息的過(guò)程CPU發(fā)送消息給交換芯片,表示要獲取數據(例如一些端口狀態(tài)信息)。此時(shí),交換芯片會(huì )發(fā)送Block_write消息給CPU,在GT-48330中有一個(gè)專(zhuān)用的32B的Buffer用于存儲此消息,對應的存儲地址為:0x980~0x99F。當有block_write到來(lái)時(shí),GT-48330將發(fā)送中斷消息給CPU,CPU通過(guò)相關(guān)的中斷位獲取中斷,然后來(lái)讀取block_write消息。
2.2.2 GT-48330的發(fā)送
對于GT-48330來(lái)說(shuō)他具有2種發(fā)送方式:自動(dòng)DMA方式和CPU傳輸方式。對于自動(dòng)DMA的方式,不需要CPU進(jìn)行干涉,GT-48330可以自動(dòng)完成發(fā)送。對于CPU傳輸方式,則需要CPU對發(fā)送的過(guò)程進(jìn)行干涉。
(1)自動(dòng)DMA方式 CPU首先寫(xiě)傳輸數據(TD)寄存器,同時(shí)設置<TD>位,GT-48330根據TD來(lái)向交換芯片發(fā)送Buffer請求消息,在TD消息中包含了目的交換芯片號、端口號、CPU號及包的數量等消息。CPU寫(xiě)數據到GT-48330的32 b的包存儲空間8LWW Buffer中,如果GT-48330接收到交換芯片可以開(kāi)始傳送包的消息(SOP),他將把包發(fā)送給相應的交換芯片;如果收到交換芯片的拒絕消息(Buffer_rejecet),他將發(fā)送相應的中斷給CPU,告訴發(fā)數據被拒絕。
(2)CPU傳輸方式 CPU先直接通過(guò)GNT-A/B Buffer來(lái)發(fā)送Buffer請求消息,CPU等待接收到SOP消息,此消息將被GT-48330存儲在OGRBuffer中,然后再傳給CPU。一旦CPU收到SOP消息,就通過(guò)GT-48330的GNT-A/B通道來(lái)發(fā)送數據包,同時(shí)CPU還通過(guò)GNT-A/B來(lái)發(fā)送數據包傳送結束(EOP)消息給交換芯片。
3 電路設計
GT-48330的G.Link口的電路設計說(shuō)明:數據發(fā)送和接收線(xiàn)GTXD[15∶0]/GRXD[15∶0]與交換芯片的G.Link口的接收和發(fā)送線(xiàn)相連;GTXCMD/GRXCMD發(fā)送和接收與交換芯片的接收和發(fā)送命令線(xiàn)相連;GTXOCLK發(fā)送數據的參考時(shí)鐘,通過(guò)22Ω的匹配電阻接到交換芯片的G.Link口的接收時(shí)鐘;GRXCLK接收數據的參考時(shí)鐘,由時(shí)鐘模塊來(lái)提供;GTXCLK接收數據的參考時(shí)鐘,由時(shí)鐘模塊來(lái)提供;GTXCLK作為GT-48330的G.Link口的系統時(shí)鐘,同樣由時(shí)鐘模塊來(lái)提供。GTXCLK和GRXCLK的時(shí)鐘頻率為83.33 MHz。電路邏輯圖如圖2所示。
評論