專利名稱:一種類ahb總線及其實現(xiàn)方法
技術領域:
本發(fā)明涉及一種總線及其方法,尤其涉及一種類AHB總線及其實 現(xiàn)方法。
背景技術:
隨著SOC技術的發(fā)展, 一顆芯片內集成的功能模塊越來越多。而 各個模塊對于存儲器的訪問要求也越來越高,因此片內內存的訪問總 線在芯片架構中顯得非常重要。 一定程度上說,片內內存的訪問總線是 決定后續(xù)其他設計的基礎。
目前很多芯片設計采用AMBA芯片內總線協(xié)議中的AHB協(xié)議。但對 于32位總線的芯片來說, 一般設計會采用AHB或者AHBJJTE協(xié)議作為 片內互連總線協(xié)議,這存在一定問題,主要體現(xiàn)在以下兩個方面
其一,由于AHB協(xié)議需要地址,讀數(shù)據(jù),寫數(shù)據(jù)各32位(共96bit), 以及其他一些控制信號,從而導致芯片內總線總裁模塊上星型連接的 線太多,給后端布線帶來一定的困難。
其二,AHB協(xié)議中,地址線(Haddr)會隨著每一個Hready的有效^f直 更改為下一個地址,這在實際中基本是沒有任何用處的。因為從模塊端 為了實現(xiàn)流水線訪問機制,會實現(xiàn)自動計算下一個地址,而不是從地址 總線上去獲得下一個地址。
因此,如何減少片內總線數(shù)并充分利用流水線訪問機制,成為優(yōu)化 AHB協(xié)議所需解決的問題。
發(fā)明內容
有鑒于此,本發(fā)明著眼于減少片內總線數(shù)量并充分利用流水線訪 問機制以優(yōu)化AHB協(xié)議,提供了一種全新的類AHB總線及其信號處理方
法o
根據(jù)本發(fā)明的第一方面,提供了一種類AHB總線。
該類AHB總線包括至少一個主模塊端、至少一個從模塊端、總線仲裁器和讀數(shù)據(jù)多路器以及讀數(shù)據(jù)總線連接線,其特征在于還包括
地址和寫數(shù)據(jù)多路器,對主模塊端和從模塊端之間的地址和寫數(shù) 據(jù)信號在總線仲裁器的控制下進行選通;和
地址和寫數(shù)據(jù)所復用的總線連接線,對主模塊端和從模塊端與地址 和寫數(shù)據(jù)多路器進行連接,所述地址和寫數(shù)據(jù)信號在選通和傳遞時對
該連接線進行復用。
優(yōu)選地,所述地址和寫數(shù)據(jù)信號對連接線的復用具體為
當一次寫數(shù)據(jù)請求開始時,地址和寫數(shù)據(jù)多路器對主模塊端和從 模塊端的地址和寫數(shù)據(jù)所復用的總線連接線進行選通,所述地址和寫 數(shù)據(jù)所復用的總線連接線在該次寫數(shù)據(jù)請求的第 一 個周期內給出此次 傳輸?shù)钠鹗嫉刂罚?br>
此次傳輸請求余下的時鐘周期內,根據(jù)連接線提前一個時鐘周期 給出的寫數(shù)據(jù)地址進行寫數(shù)據(jù)橾作,直到此次傳輸請求結束。
根據(jù)本發(fā)明的第二方面,提供了一種類AHB總線信號處理方法。 該方法包括以下步驟
步驟1:當Hsel信號狀態(tài)發(fā)生變化時, 一次傳輸請求開始;
步驟2:判斷Hwrite信號為寫操作時,Haddr需要在Hse I信號有 效的第一個周期給出此次傳輸?shù)钠鹗嫉刂?,并在第二個周期給出第一 個寫數(shù)據(jù);
步驟3:當Hready信號在此次傳輸請求余下的時鐘周期內每次為 有效時,Haddr線上都要給出下一個寫數(shù)據(jù),直到此次傳輸請求結束。
優(yōu)選地,在所述步驟2中,判斷Hwrite信號為讀搡作時,Haddr 信號為讀數(shù)據(jù),并在Hsel信號狀態(tài)發(fā)生變化的第一個周期內給出此次 傳輸?shù)钠鹗嫉刂?;Haddr在第二個周期開始無任何意義,直至該周期結 束并不再執(zhí)行步驟3。
本發(fā)明提供的類AHB總線及其總線信號處理方法,通過對地址線和 寫數(shù)據(jù)線的復用,有效減少了片內總線的物理連接線,降低了 , ^線星形 連接的布線難度。
下面將參照附圖對本發(fā)明的具體實施方案進行更詳細的說明,其
中圖1是現(xiàn)有AHB總線結構圖2是本發(fā)明類AHB總線結構圖3是本發(fā)明類AHB總線信號處理波形圖;以及
圖4是本發(fā)明類AHB總線信號處理流程圖。
具體實施例方式
為了實現(xiàn)利用流水線訪問機制以對地址線和寫數(shù)據(jù)線的復用,本 發(fā)明提供了一種類AHB總線及其總線信號處理方法。接下來具體說明 該類AHB總線及其總線信號處理方法。
圖2示出本發(fā)明類AHB總線結構圖。如圖2所示,該類AHB總線 包括至少一個主模塊端、至少一個從模塊端、總線仲裁器和讀數(shù)據(jù)多 路器以及讀數(shù)據(jù)總線連接線、地址和寫數(shù)據(jù)多路器和地址和寫數(shù)據(jù)所 復用的總線連接線。
地址和寫數(shù)據(jù)多路器對主模塊端和從模塊端之間的地址和寫數(shù)據(jù) 信號在總線仲裁器的控制下進行選通。
地址和寫數(shù)據(jù)所復用的總線連接線對主模塊端和從模塊端與地址 和寫數(shù)據(jù)多路器進行連接,所述地址和寫數(shù)據(jù)信號在選通和傳遞時對 該連接線進行復用。
結合圖1并與圖2作比較,不難看出,本發(fā)明的總線的連接線明顯 減少。其地址和寫數(shù)據(jù)共用一個多路選擇器,并在仲裁器的仲裁控制下 對地址和寫數(shù)據(jù)進行復用,這樣可減少地址或寫數(shù)據(jù)的連線。
需補充說明的是,圖1和圖2中的除仲裁控制和譯碼連接線之外, 其他的連接線都表示一定寬度的總線,它們不只是一條,其可為16位或 32位,也可為64位或128位。其代表多少位的連接線,其就有多少根實 際的物理連接線。以圖2中地址和寫數(shù)據(jù)多路器與從模塊3之間的連 接線來說,圖中只顯示一條,以32位為例的話,其表示有32根物理的連 接線。
接下來將以3 2位的連接線為例,說明基于上述復用結構的類AH B 總線信號處理的過程。
圖3示出本發(fā)明類AHB總線信號處理波形圖。如圖3所示,包括 信號Hclk、 Hsel、 Hwrite、 Hsize、 Haddr、 Hrdata和Hready的各自波形。
上述的各信號具備各自的信號特性和相互關系,接下來分別加以說明(1表示高電平,o表示低電平,方向為總線的主模塊端的方向)。
① Hclk,位寬為1,為總線的時鐘信號,其每個時鐘周期包括一 個1和0信號。
② Hsel,位寬為1,從0到1表示一次請求開始,可以只持續(xù)1 個周期,方向為輸出。
③ Hwrite,位寬為1,讀寫信號,1表示寫,0為讀,方向為輸出。
④ Hsize,位寬為3,讀寫字節(jié)數(shù)為2Hsi"個,只支持Hsize >= 2 的情況,方向為輸出。
Haddr,位寬為32,地址及寫數(shù)據(jù)復用線,如果為寫搡作,Hse I 為高的第一個周期給出地址,之后為寫數(shù)據(jù),如果為讀操作,Hsel為 高的第一個周期給出地址,那么Haddr在第二個周期開始后無任何意 義,方向為f敘出。
⑥ Hrdata,位寬為32,讀數(shù)據(jù),方向為輸入。
⑦ Hready,位寬為1,讀寫數(shù)據(jù)有效信號,方向為輸入。
這7組信號構成了本發(fā)明類AHB總線的協(xié)議。針對這些信號,分別 構成了該協(xié)議的特征要素,具體如下
1Hsel可以持續(xù)最少1個周期,但必須在該次請求的所有數(shù)據(jù) 結束前更改為0;否則當所有數(shù)據(jù)傳輸結束時會被從模塊認為一次新的 請求開始了。
2Hsize從2到7,表示該協(xié)議可支持1, 2, 4, 8, 16, 32個 word(4byte二32bit)這6種突發(fā)傳輸方式
Hsize 2 對應 1 word;
3Haddr在Hsel為高的第一個周期表示傳輸?shù)钠鹗嫉刂贰?如果該次操作為寫,那么從第二個周期開始Haddr必須為第一個 寫數(shù)據(jù);從寫操作開始第二個周期后每當收到 一個Hready為高的信號, Haddr更改為下一個寫數(shù)據(jù),直到該次傳輸結束。
如果該搡作為讀,那么Haddr在第二個周期開始后無任何意義。4Hrdata為從模塊給出的讀數(shù)據(jù)。當從模塊準備好數(shù)據(jù)時,會
3
4
5
6
2 wo r d; 4 wordj 8 word; 16 word; 32 word。
7同時將Hready置高,并給出Hrdata。
5Hready為從模塊的讀寫數(shù)據(jù)有效信號;當該橾作為寫操作, 那么Hready每次為高時,Haddr上都必須給出下一個寫數(shù)據(jù);
當該操作為讀操作,那么Hready每次為高時,Hrdata上都為有效
的讀數(shù)據(jù)。
下面對相關信號的相互關系和相互作用以圖3的實例為例,分時鐘 段的加以分析和說明。
在第0時鐘周期起,Hclk信號作為時鐘信號輸入。
在第1時鐘周期,Hsel信號從0到1,說明一次請求開始。同時, Hwrite信號從0到1,說明該請求為寫數(shù)據(jù)請求;Hsize信號同時為4, 并持續(xù)到第9時鐘周期,也即給出了寫數(shù)據(jù)的字節(jié)數(shù)為4個word。
Hsize為4對應的內容為WD1,WD2, WD3,WD4,其中WD為WriteData 的縮寫。
4對應的4個word分別是WD1,WD2,WD3,WD4,每個均是32bit,共 16byte。
3對應的2個word分別是RD1,RD2 (Read Data的縮寫),每個均 是32bit,共8byte。
與此同時,在第1時鐘周期內,也即在Hsel信號為1的第一個周 期,在Haddr上給出此次傳輸?shù)钠鹗嫉刂稺A1 。
在第2個時鐘周期內,所述Haddr給出第一個寫數(shù)據(jù)WD1,所述從 模塊在寫數(shù)據(jù)WD1的有效時鐘周期內將所述Haddr給出的第一個寫數(shù) 據(jù)WD1寫入所述起始地址WA1,在第4個時鐘周期,所述Hready由O 變1。
由于Hready為1,在第5個時鐘周期,所述Haddr給出第二個寫 數(shù)據(jù)WD2,所述從模塊根據(jù)起始地址WA1計算出下一個地址WA2,并在 寫數(shù)據(jù)WD2的有效時鐘周期內將所述Haddr給出的第二個寫數(shù)據(jù)WD2 寫入所述下一個地址WA2,在第6個時鐘周期,所述Hready再次由0 變1。
從寫搡作開始第2個周期后每當收到一個Hready為高的信號, Haddr更改為下一個寫數(shù)據(jù),直到該次傳輸結束。這樣,在第7個周期, 所述Haddr給出的第三個寫數(shù)據(jù)WD3,在第8個周期所述Haddr給出的 第四個寫數(shù)據(jù)WD4。所述從模塊則把所述第三個寫數(shù)據(jù)WD3和第四個寫 數(shù)據(jù)WD4寫入指定的地址內。所述從模塊可以實現(xiàn)流水線訪問機制,其會實現(xiàn)自動計算下一個
地址,比如WD1對應起始地址WA1 ,則WD2對應WA1的下一個地址(一 般為WA1+1,也可以為地址WA1+1繞回)。也就是說,在Slave從模塊 端獲得WD2的時候,所述從模塊已經(jīng)可以根據(jù)WD1的地址計算出WD2的 地址WD2,之后還會自動計算出WD3和WD4。
在第9時鐘周期內,Hsel信號又從0到1,說明一次新的請求開始; 同時,Hwrite信號從1到0,說明該請求為讀數(shù)據(jù)請求。
Hsize信號同時為3,并持續(xù)到第9時鐘周期,也即給出了讀數(shù)據(jù)的 字節(jié)數(shù)為2個word。
與此同時,在第9時鐘周期內,也即在Hsel信號重新為1的第一 個周期,在Haddr給出此次讀數(shù)據(jù)傳輸?shù)钠鹗嫉刂稲A2。
在第12至13時鐘周期內,根據(jù)這個地址,讀出數(shù)據(jù)RD1。
同理,在第13至14時鐘周期內Haddr線由流水線訪問機制自動 計算得到并提前給出地址,以供讀出數(shù)據(jù)RD2。
關于流水線機制,需補充說明的是
對于Master主模塊端來說,它知道讀寫地址應該是多少,可以理解 為不需要計算,也就是說WA1, RA2都是Master發(fā)出來的,無需計算。因 此當寫入WD4并且Hready為高的下一個周期,如果需要有新的總線搡 作,比如讀搡作,需要在下一個周期把讀地址寫入,也就是這里的RA2。
綜上所述,本發(fā)明充分利用流水線訪問機制,并通過有效的信號控 制處理,實現(xiàn)了地址和寫數(shù)據(jù)的復用,同時不影響讀數(shù)據(jù)的操作。
圖4示出本發(fā)明類AHB總線信號處理流程圖。如圖4所示,該類 AHB總線信號處理方法包括以下步驟
步驟1:當Hsel信號從0到1時, 一次傳輸請求開始。
步驟2:判斷Hwrite信號是否為1,如果為1時,表明此次傳輸 請求是寫請求,Haddr需要在Hsel信號為1的第一個周期給出此次傳 輸?shù)钠鹗嫉刂?,并在第二個周期給出第一個寫數(shù)據(jù)。
步驟3:當Hready信號在此次傳輸請求余下的時鐘周期內每次為 1時,Haddr線上都要給出下一個寫數(shù)據(jù),直到此次傳輸請求結束。
在一個實施例中,進一步包括所述步驟2中,判斷Hwrite信號是 否為1,如果為0時,表明此次傳輸請求是讀請求,并在Hsel信號為 1的第一個周期內給出此次傳輸?shù)钠鹗嫉刂?;Haddr在第二個周期開始 無任何意義,直至該周期結束并不再執(zhí)行步驟3。
9如圖4所示的 一個實施例中其類AHB總線信號的完整處理流程如
下
步驟400中,處理流程開始。
接下來,步驟402中,Hsel信號從0到1變化時, 一次傳輸請求 開始。
需說明的是,每次傳輸請求包括至少一個的寫數(shù)據(jù)或讀數(shù)據(jù)操作, 以Haddr位寬為32來說,每個寫數(shù)據(jù)或讀數(shù)據(jù)搡作對應一個word。也 就是說,在包括多個寫數(shù)據(jù)或讀數(shù)據(jù)操作時,即對應多個word,當完成 多個word的操作時,該次請求才算完成。
然后,進入步驟404中,判斷Hwrite信號是否為1。 如果為0時,緊跟著進入步驟408中,表明此次傳輸請求是讀請 求,并在Hsel信號為1的第一個周期內給出此次讀數(shù)據(jù)傳輸?shù)钠鹗嫉?址。然后在步驟412中,Haddr在第二個周期開始無任何意義,Hrdata 給出讀數(shù)據(jù),直至該周期結束,并進入步驟418中結束此次請求的處 理過程。
如果為1時,緊跟著進入步驟406中,表明此次傳輸請求是寫請 求,在Hsel信號為1的第一個周期內,Haddr需要給出此次寫數(shù)據(jù)傳 輸?shù)钠鹗嫉刂贰?br>
在步驟407中,Haddr在第二個周期給出第 一個寫數(shù)據(jù),也即此次 寫數(shù)據(jù)傳輸請求的起始地址對應寫數(shù)據(jù)。
然后進入步驟410中,在每個時鐘周期內,判斷Hready信號是否為1。
如果否,則進入步驟416中,判斷此次傳輸請求是否已經(jīng)完成,完成 與否主要看此次所傳輸?shù)臄?shù)據(jù)是否都進行完了,以Hsize為4例,那就 是所對應的4個w o r d都傳輸完了才表明該次傳輸請求已經(jīng)完成。
如果是,則進入步驟414中,Haddr線上必須給出下一個寫數(shù)據(jù), 并進行寫地址的搡作。該地址是結合上一個地址并通過流水線機制計 算得到。
接下來,進入步驟416中,判斷此次傳輸請求是否已經(jīng)完成。如 果仍有效,需返回步驟410中,循環(huán)判斷并執(zhí)行后續(xù)的操作。
當此次傳輸請求已完成時,進入步驟418中,結束整個處理流程。
在實際芯片中,由于通過總線讀寫內存一般都有一定的延遲時間, 因此,通過將地址和寫數(shù)據(jù)復用,可以充分利用該延遲時間;但在做 了一定優(yōu)化的系統(tǒng)中(尤其是從模塊端有較大讀寫緩沖時),就失去了AHB總線可以每個時鐘讀寫一個數(shù)據(jù)的高帶寬能力,相應的每次請求的 第一個周期一定無法讀寫數(shù)據(jù)。
本發(fā)明雖然喪失了一定的帶寬,但不同程度上簡化了片內總線的互 連,適合對帶寬要求不高的片內互連的技術方案。
以上對本發(fā)明的具體描述旨在說明具體實施方案的實現(xiàn)方式,不 能理解為是對本發(fā)明的限制。本領域普通技術人員在本發(fā)明的教導下, 可以在詳述的實施方案的基礎上做出各種變體,這些變體均應包含在 本發(fā)明的構思之內。本發(fā)明所要求保護的范圍僅由所述的權利要求書 進行限制。
權利要求
1. 一種類AHB總線,包括至少一個主模塊端、至少一個從模塊端、總線仲裁器和讀數(shù)據(jù)多路器以及讀數(shù)據(jù)總線連接線,其特征在于還包括地址和寫數(shù)據(jù)多路器,對主模塊端和從模塊端之間的地址和寫數(shù)據(jù)信號在總線仲裁器的控制下進行選通;和地址和寫數(shù)據(jù)所復用的總線連接線,對主模塊端和從模塊端與地址和寫數(shù)據(jù)多路器進行連接,所述地址和寫數(shù)據(jù)信號在選通和傳遞時對該連接線進行復用。
2. 如權利要求1所述的類AHB總線,其特征在于, 所述地址和寫數(shù)據(jù)信號對連接線的復用具體為當一次寫數(shù)據(jù)請求開始時,地址和寫數(shù)據(jù)多路器對主模塊端和從 模塊端的地址和寫數(shù)據(jù)所復用的總線連接線進行選通,所述地址和寫 數(shù)據(jù)所復用的總線連接線在該次寫數(shù)據(jù)請求的第一個周期內給出此次 傳輸?shù)钠鹗嫉刂?;此次傳輸請求余下的時鐘周期內,根據(jù)連接線提前一個時鐘周期 給出的寫數(shù)據(jù)地址進行寫數(shù)據(jù)操作,直到此次傳輸請求結束。
3. 如權利要求1所述的類AHB總線,其特征在于所述地址和寫數(shù)據(jù)所復用的總線連接線及讀數(shù)據(jù)總線連接線均為 32根。
4. 如權利要求3所述的類AHB總線,其特征在于所述總線的傳輸字節(jié)數(shù)支持1, 2, 4, 8, 16, 32個word中任何一 種突發(fā)傳輸模式。
5. 如權利要求1至4任一項所述的類AHB總線,其特征在于 所述地址和寫數(shù)據(jù)所復用的總線連接線選通傳遞中,需要在每次選通或請求的第 一個周期給出 一個地址。
6. 如權利要求5所述的類AHB總線,其特征在于 所述地址和寫數(shù)據(jù)所復用的總線連接線,會根據(jù)訪問有效值利用流水線訪問機制自動計算下一個地址(每次請求的第一個周期所要給 出的地址除外)。
7. —種類AHB總線信號處理方法,包括以下步驟步驟1:當Hsel信號狀態(tài)發(fā)生變化時, 一次傳輸請求開始;步驟2:判斷Hwrite信號為寫操作時,Haddr需要在HseI信號狀態(tài)發(fā)生變化的第一個周期給出此次傳輸?shù)钠鹗嫉刂?,并在第二個周期 給出第一個寫數(shù)據(jù);步驟3:當Hready信號在此次傳輸請求余下的時鐘周期內每次為 有效時,Haddr線上都要給出下一個寫數(shù)據(jù),直到此次傳輸請求結束。
8. 如權利要求7所述的類AHB總線信號處理方法,其特征在于在所述步驟2中,判斷Hwrite信號為讀操作時,Haddr在Hsel信 號狀態(tài)發(fā)生變化的第一個周期內給出此次傳輸?shù)钠鹗嫉刂罚籋addr在第 二個周期開始無任何意義,直至該周期結束并不再執(zhí)行步驟3。
9. 如權利要求8所述的類AHB總線信號處理方法,其特征在于所迷步驟3中,Haddr線上給出下一個寫數(shù)據(jù),其方式是通過根據(jù) 每次請求的第 一 個周期所要給出的地址并利用流水線訪問機制自動計 算下一個地址的。
10. 如權利要求7至8任一項所述的類AHB總線信號處理方法, 其特征在于所述Haddr信號的帶寬均為32位。
全文摘要
本發(fā)明披露了一種類AHB總線及其總線信號處理方法。該類AHB總線包括至少一個主模塊端、至少一個從模塊端、總線仲裁器和讀數(shù)據(jù)多路器以及讀數(shù)據(jù)總線連接線,其特征在于還包括地址和寫數(shù)據(jù)多路器,對主模塊端和從模塊端之間的地址和寫數(shù)據(jù)信號在總線仲裁器的控制下進行選通;地址和寫數(shù)據(jù)所復用的總線連接線,對主模塊端和從模塊端與地址和寫數(shù)據(jù)多路器進行連接,所述地址和寫數(shù)據(jù)信號在選通和傳遞時對該連接線進行復用。本發(fā)明有效實現(xiàn)了地址和寫數(shù)據(jù)的復用,簡化了片內總線的互連難度,在對帶寬要求不高的片內互連產品有較強的實用性。
文檔編號G06F13/40GK101533381SQ200910080750
公開日2009年9月16日 申請日期2009年3月27日 優(yōu)先權日2009年3月27日
發(fā)明者李曉強, 馬鳳翔 申請人:北京中星微電子有限公司