亚洲成年人黄色一级片,日本香港三级亚洲三级,黄色成人小视频,国产青草视频,国产一区二区久久精品,91在线免费公开视频,成年轻人网站色直接看

緊密耦合的分布式非核一致結構的制作方法

文檔序號:11530713閱讀:237來源:國知局
緊密耦合的分布式非核一致結構的制造方法與工藝
相關申請的交叉引用本申請主張對提交于2014年12月25日、題為“tightly-coupleddistributeduncorecoherentfabric”的美國非臨時專利申請no.14/583,156的優(yōu)先權及其權益,通過引用將該申請整體地并入本文中。本公開涉及計算系統(tǒng),并且特別地(而非排他性地)涉及緊密耦合的分布式非核一致結構。
背景技術
:在具有多個設備的許多計算機系統(tǒng)中,執(zhí)行仲裁來提供對諸如共享存儲器之類的共享資源的訪問。不同類型的仲裁機制被提供為使得能夠實現不同代理或請求方之間的仲裁。一些系統(tǒng)使用固定優(yōu)先級仲裁系統(tǒng),在其中不同代理被分配特定的優(yōu)先級。然而,這可能導致在一個或多個代理獲得對共享資源的訪問的能力的使用和饑餓(starvation)方面的不公平。其他仲裁系統(tǒng)提供基于輪詢(roundrobin-based)的方法來分配對共享資源的訪問。在某些實施例中,仲裁并不計及諸如功率狀態(tài)之類的共享資源因素。因此,在一個示例中,對訪問共享資源的請求準予并且該請求使該資源離開低功率狀態(tài),盡管該設備不需要立即訪問該共享資源。附圖說明圖1是根據本說明書的一個或多個示例的共享非核存儲器結構的一部分的框圖。圖2是根據本說明書的一個或多個示例的準許仲裁器的進一步細節(jié)的框圖。圖3是根據本說明書的一個或多個示例的在確定仲裁獲勝方時用于更新代理的年齡值的方法的流程圖。圖4是根據本說明書的一個或多個示例的準許仲裁器狀態(tài)機的框圖。圖5是根據本說明書的一個或多個示例的用于在準許仲裁器中執(zhí)行第一級別仲裁的方法的流程圖。圖6是根據本說明書的一個或多個示例的資源分配邏輯的一部分的框圖。圖7是根據本說明書的一個或多個示例的記分板索引生成邏輯的框圖。圖8是根據本說明書的一個或多個示例的用于調度器仲裁器的狀態(tài)機的框圖。圖9是根據本說明書的一個或多個示例的用于執(zhí)行存儲器調度的方法的流程圖。圖10是根據本說明書的一個或多個示例的soc的框圖。圖11是根據本說明書的一個或多個示例的存在于計算機系統(tǒng)中的部件的框圖。圖12是根據本說明書的一個或多個示例的用于控制受控系統(tǒng)的現場使用(insitu)的soc的框圖。圖13是根據本說明書的一個或多個示例的在非核結構內提供多個虛擬信道的方法的流程圖。具體實施方式在下面的描述中,闡述了許多具體細節(jié)(諸如特定類型的處理器和系統(tǒng)配置、具體硬件構造、具體架構和微架構細節(jié)、具體寄存器配置、具體指令類型、具體系統(tǒng)部件、具體測量結果/高度、具體處理器流水線級和操作等等的示例),以便提供對本發(fā)明的透徹理解。然而,對本領域技術人員來說顯而易見的是不需要采用這些具體細節(jié)來實踐本發(fā)明。在其他情況下,尚未詳細描述公知部件或方法(諸如具體和替代處理器架構、用于所描述算法的具體邏輯電路/代碼、具體固件代碼、具體互連操作、具體邏輯配置、具體制造技術和材料、具體編譯器實現方式、以代碼形式的算法具體表達、具體功率下降和選通技術/邏輯以及計算機系統(tǒng)的其他具體操作細節(jié)),以便避免非必要地使本發(fā)明變晦澀。在示例中,片上系統(tǒng)(soc)或其它嵌入式系統(tǒng)的非核結構的所選部分被劃分成兩個獨立的流水線。該結構可被稱為“非核”,其表明在結構中提供的互連、寄存器和其他資源不是包括“代理”的處理核心的一部分。非核結構可包括以上描述的存儲器結構、將“代理”連接至存儲器的各部分、以及還有將代理彼此連接以及特別地將處理器核心連接至其他“代理”的各部分。在一些實現方式中,每個流水線獨立于另一流水線進行操作,并且每個流水線僅訪問系統(tǒng)存儲器的一半,諸如交錯式存儲器(interleavedmemory)中的奇數或偶數地址。兩個流水線并不重新匯聚,直到已經返回存儲器值之后為止。然而,非核結構可能仍向請求設備呈現單個、單片接口。這允許系統(tǒng)設計者將非核結構看作“黑盒”而無需修改現有設計。每個進入的地址可以由確定性散列來處理、被分配給流水線中的一個、通過存儲器進行處理、以及然后傳遞至信用返回。在各種實施例中,共享存儲器結構將多個獨立設備(在本文中也被稱為“代理”)耦合至共享存儲器(例如,經由介于中間的存儲器控制器)。在一些實施例中,共享存儲器結構是單個管芯半導體設備的互連構造,其包括不同類型的知識產權(ip)邏輯塊。共享存儲器結構可被配置成使得能夠符合時間關鍵等時設備的服務質量(qos)要求,同時還為非等時設備(在本文中也被稱為“盡力而為”設備)提供存儲器帶寬比例劃分。發(fā)生存儲器帶寬的可靠且可預測分配和調度來支持連接至共享存儲器結構的多個設備和設備類型。通過將qos功能包括在公共共享存儲器結構中(而不是包括在存儲器控制器或其他非結構電路中),該設計可跨越多個半導體器件(諸如片上系統(tǒng)(soc))而被更容易地重用,因為該設計獨立于存儲器技術。因此實施例在共享存儲器結構中執(zhí)行資源分配、帶寬分派和時間感知qos屬性來提供可預測且可靠的存儲器帶寬和延時,以滿足連接至該結構的設備的要求。服務類種類被指派給耦合至共享存儲器結構的每個設備。在一個實施例中,可以使用該結構的配置寄存器來標識這種指派。該結構可支持多個服務類。在一個非限制性示例中,可存在兩個服務類種類的設備,包括用于延時敏感設備的等時服務類種類和用于可以忍受較長延時以服務于它們對存儲器的請求的設備的盡力而為服務類種類。在一些實施例中,延時敏感設備包括內容呈遞設備(諸如作為非限制示例的音頻或視頻播放器、相機設備等等),而較低優(yōu)先級設備包括處理器核心、圖形處理單元等等。將以請求最后期限形式的時間從等時設備傳達給結構,以向該結構指示完成對存儲器的請求所需的延時。為了使得能夠實現同步,該結構向所有等時請求代理廣播全局定時器。對來自結構的輸出連續(xù)驅動該全局定時器,因此它可用于通過等時設備進行采樣。響應于該時間值,代理確定用于完成請求的延時要求并將該延時值添加至全局定時器值以形成針對該請求的最后期限。作為示例,可以由代理通過緩沖器的流失率和代理的數據緩沖器中的數據量來確定對于讀取的延時。如果代理每250納秒(ns)消耗1個高速緩存數據線并且在緩沖器中具有8個高速緩存數據線,則在緩沖器變空之前對于新請求所需的最后期限將是8×250ns或2微秒(μs)。基于該傳達的延時或最后期限值,該結構可基于存儲器的當前功率狀態(tài)的知識和對于結構中未決的其他未調度存儲器請求所需的延時來做出更好的調度決定。該最后期限通信可改善存儲器帶寬并且還節(jié)省系統(tǒng)功率。請求最后期限的使用向結構提供了針對來自等時設備的每個請求的延時信息。在結構內編程的配置寄存器向該結構提供了關于存儲器配置的信息(諸如存儲器離開低功率(例如自刷新和狀態(tài))所需的延時)。該結構還通過向存儲器控制器(例如以狀態(tài)信道的形式)發(fā)送指示來控制存儲器控制器何時促使所附接的存儲器進入和離開自刷新狀態(tài)。該結構通過評估對于所有未決存儲器請求的延時需求來確定何時存儲器應該進入和離開自刷新。因為該結構了解對于所有未決存儲器請求所需的延時和離開自刷新所需的延時,所以存儲器的功率狀態(tài)轉變的更大管理可以導致附加的功率節(jié)省。實施例還可以通過允許存儲器請求被無序調度來提供存儲器帶寬中的效率,然而,這可能導致對于某些請求的長調度延時。為了解決此顧慮,結構向每個等時存儲器請求指派優(yōu)先級級別,例如高優(yōu)先級或低優(yōu)先級。當調度高優(yōu)先級等時請求時,所允許的無序調度的量小于當調度盡力而為或低優(yōu)先級等時請求時可接受的量。限制對于高優(yōu)先級請求的無序調度的量確保了滿足請求延時要求。因為根據請求的最后期限來確定請求優(yōu)先級,所以該結構可以在請求被調度之后立即確定對于等時設備來說其他未決請求的優(yōu)先級級別是什么。通過使用最后期限方法,所有未決請求的優(yōu)先級級別僅在全局定時器遞增時進行改變。實施例還可以改善跨越多個soc實現方式的復雜qos存儲器調度算法的可移植性和重用,因為智能存儲器調度邏輯被結合到該結構中,同時可以在存儲器控制器中實施技術特定的存儲器控制器邏輯。實施例還可以將抗饑餓算法結合到結構的多個仲裁點中。在一個實施例中,這些抗饑餓算法包括由準許仲裁器使用的加權的基于年齡的仲裁方法以及在存儲器調度器和請求跟蹤器中使用的可用調度隊列中的最舊一個。此外,相比于其中來自高優(yōu)先級等時設備的請求自動勝出的固定優(yōu)先級仲裁,請求權重可被用于在結構中的仲裁點處的不同優(yōu)先級級別之間進行切換以及用于從調度讀取請求切換至寫入請求。在一個實施例中,共享存儲器結構包括用于調度被發(fā)送至存儲器控制器的請求的兩個仲裁點。第一仲裁點被用來準許來自設備的請求進入共享存儲器結構中并且被稱為“準許仲裁器”。第二仲裁點被用來調度從共享存儲器結構發(fā)送至存儲器控制器的請求并且被稱為“調度器仲裁器”。被連接至共享存儲器結構的每個設備都具有連接在設備和結構之間的請求接口。該請求接口供應可以被用于qos存儲器調度的關于請求的信息。在一個實施例中,該信息包括存儲器地址、順序id字段和操作碼字段。對于等時設備,提供被稱為請求最后期限字段的附加字段,以指示完成該請求需要的所需延時。要指出,在soc的一些實現方式中,存儲器結構接口可被連接至允許多個設備共享公共請求接口的其他結構或切換設備(switch)。在一個示例中,如果共享存儲器結構被分割成彼此緊密耦合的n個并行流水線,那么共享存儲器結構可以更高效。每個并行流水線可以包括一個或多個功能塊,諸如請求跟蹤器或仲裁器,其獨立于每個其它流水線而運轉,但是雖然如此,其仍緊密耦合到每個其它流水線。例如,共享存儲器結構可以包括地址散列化和選擇邏輯,其向請求代理呈現單個、單片接口。這有利地保持了舊有接口,并且使請求代理擺脫需要使其自身涉及到“如何”處理存儲器請求,并且還使代理擺脫必須了解結構中存在“n”個流水線。還使用緊密耦合來保持用于代理的某些排序期望。在其中n=2的情況下,進入的存儲器訪問請求可以首先指向地址選擇和散列化塊。該塊將地址散列化以確定其是奇數還是偶數。如果地址是偶數,則其指向偶數流水線,而如果地址是奇數,則其指向奇數流水線。每個流水線然后獨立地處理存儲器訪問請求,直到且包括提供訪問單獨的存儲器庫的單獨的存儲器控制器。這在其中存儲器是“交錯式”的情況中可以是非常有效的,使得在與彼此分離的庫中找出奇數和偶數地址。一旦存儲器值從適當的存儲器庫返回到共享結構流水線,聚集器(諸如數據返回仲裁機制)在流水線之間進行仲裁并將數據返回至請求代理。為了確保不使一個流水線饑餓,可以將適當尺寸的隊列或緩沖器放置在流水線選擇和散列塊前面,使得每個流水線持續(xù)接收分組。在一個示例中,通過以流水線的時鐘頻率的兩倍進行操作的共享功能塊來緊密耦合兩個流水線。在兩個流水線并行工作的情況下,可以在兩個時鐘周期中成功地處理兩個存儲器訪問。為了允許請求代理繼續(xù)發(fā)送請求,共享功能塊可以聚集每個流水線的請求隊列的排隊和離隊操作并將信用返回至請求代理。圖1是根據本說明書的一個或多個示例的共享存儲器結構的一部分的框圖。如圖1中所示,共享存儲器結構100被耦合在多個代理115-0—115-3(統(tǒng)稱為代理115)和存儲器控制器170之間。要指出,在一些實施例中,存在多于一個存儲器控制器。盡管為了便于圖示沒有示出,但是存儲器控制器可被耦合至系統(tǒng)存儲器,諸如動態(tài)隨機存取存儲器(drom)或其他系統(tǒng)存儲器。在圖1中所示的實施例中,不同類型的代理被耦合至共享存儲器結構110。具體來說,不同代理包括第一服務類(cos)代理類型(即所謂的等時代理)和第二服務類代理類型(即所謂的盡力而為cos代理)。如所看到的,代理115中的每一個都可以將請求信息傳達至準許仲裁器120。進而,準許仲裁器120可將對應控制類型信息傳達回至代理。此外,等時代理(即在圖1的實施例中代理115-1和115-3)進一步包括附加鏈路來將請求最后期限信息傳達至準許仲裁器120。為此,這些代理可進一步被配置成從也耦合至準許仲裁器120和調度器仲裁器130二者的全局定時器150接收全局定時信息。在圖1的實施例中,準許仲裁器120可被配置成接收來自代理115的進入請求(以及來自等時代理的請求最后期限信息)并且選擇適當請求來準許去往調度器仲裁器130。為了幫助其仲裁過程,準許仲裁器120從進一步耦合至調度器仲裁器130的一組配置寄存器160接收配置信息。此外,請求和一致性跟蹤器140可被耦合至仲裁器120和130。一般來說,跟蹤器140可包括多個記分板142、數據緩沖器144和對應的地址標簽存儲裝置143、控制隊列146和其他資源(諸如各種緩沖器、諸如資源分配邏輯148的邏輯、等等)。在一些實現方式中,標簽陣列和數據緩沖器可被定位在除跟蹤器外的別處。應該指出,圖1的框圖意圖是非限制性的,并且其他元件可存在于各種實施例中。共享存儲器結構可包括在由準許仲裁器可以對來自請求代理的請求準予之前被首先分配的某些有限資源。這些資源包括內部數據緩沖器和地址標簽存儲裝置中的可用條目。其他有限資源包括存儲器調度器和請求跟蹤器記分板中的可用條目。在對于結構的內部數據緩沖器、標簽陣列和存儲器調度器記分板的資源中存在一對一對應性。在一個實施例中,這些資源被分配給存儲器的預定區(qū)域(例如諸如64字節(jié)的高速緩存線寬度)。每個有效請求也在請求和一致性跟蹤器中被分配其自己的條目,但是對存儲器中同一區(qū)域的多個請求共享數據緩沖器、標簽陣列和存儲器調度器記分板中的同一條目。盡管對于多于一個請求來說被分配給同一數據緩沖器、標簽陣列和調度器記分板條目是可能的,但是對于請求和一致性跟蹤器中的所有未完成讀取請求來說僅一個讀取請求被調度至存儲器控制器。用于所有設備的請求接口連接至結構的準許仲裁器。等時設備使用請求總線的最后期限字段來向結構指示完成該請求所需的延時。結構向被附接至該結構的所有等時設備發(fā)送全局定時器值。對于要被發(fā)送至結構的每個請求,等時設備(例如在最后期限邏輯中)確定完成請求需要的所需延時并且將該值添加至全局定時器的當前值,以便創(chuàng)建請求最后期限。不同方法可被不同等時設備用來確定對于請求所需的延時,但是所有等時設備使用請求接口的最后期限字段向結構指示請求延時。在一個實施例中,準許仲裁器具有兩個級別的優(yōu)先級。在仲裁器中存在用于緊急等時請求的高優(yōu)先級路徑。如果請求代理被配置為等時代理且請求的最后期限字段小于存儲在指定了閾值(被稱為“緊急閾值”)的配置寄存器中的值,則請求被視為緊急。準許仲裁器還具有用于盡力而為請求和用于不被視為緊急的等時請求的低優(yōu)先級路徑。使用在高優(yōu)先級仲裁的獲勝方和低優(yōu)先級仲裁的獲勝方之間進行選擇的優(yōu)先級選擇器來完成最終級別的仲裁。在一個實施例中,準許仲裁器最終選擇器具有可以使用配置寄存器選擇的兩個模式。第一模式是固定優(yōu)先級模式,在其中假設在準許仲裁器的輸入端處存在至少一個高優(yōu)先級請求,選擇器在選取低優(yōu)先級仲裁路徑的獲勝方之前選取高優(yōu)先級仲裁路徑的獲勝方。最終選擇器的第二模式是加權輪詢模式,在其中最終選擇器在對n個高優(yōu)先級請求準予之后在對高優(yōu)先級路徑準予到對低優(yōu)先級路徑準予之間進行切換。選擇器然后在切換回到對來自高優(yōu)先級路徑的請求準予之前對來自低優(yōu)先級路徑的獲勝方的m個低優(yōu)先級請求準予。在一個實施例中,n和m的值是使用配置寄存器來指定的。圖2是公開了根據本說明書的一個或多個示例的準許仲裁器的進一步細節(jié)的框圖。如圖2中所示,仲裁器120從請求代理接收進入請求。在該示圖中,請求代理115-0和115-1是非等時代理或盡力而為代理,而代理115-2和115-3是等時代理。要指出,等時代理可包括或被耦合至用來計算對于請求所需的延時的最后期限確定邏輯118。在其中代理中的至少一些是第三方ip塊的實施例中,該邏輯可以在將代理耦合至共享存儲器結構的包裝器或接口邏輯中實現。在所示的實施例中,準許仲裁器120包括第一基于年齡的仲裁器122和第二基于年齡的仲裁器124,其分別對應于低和高優(yōu)先級基于年齡的仲裁器。因此如所看到的,來自所有代理115的請求被首先提供給仲裁器122,而僅來自等時代理115-2和115-3的請求被提供給第二基于年齡的仲裁器124。為了確定來自等時代理之一的特定請求是否具有緊急狀態(tài),一對最后期限檢查器邏輯120-1和120-n均被耦合以從等時代理中的對應一個接收請求,以及從全局定時器150接收全局定時信息?;谟纱硖峁┑淖詈笃谙扌畔⑴c全局定時信息的比較,可以將針對對應請求的緊急狀態(tài)的指示提供給第二基于年齡的仲裁器124。在操作中,基于年齡的仲裁器122和124操作為從一組進入請求選擇仲裁獲勝方。在所示的示例中,該確定部分基于來自存儲針對每個代理的年齡值的年齡存儲裝置126的信息。來自每個仲裁器的對應獲勝方可被耦合至優(yōu)先級仲裁器選擇器125,其基于操作模式選擇對應請求以提供給調度器仲裁器130(圖1)。為此,優(yōu)先級仲裁器選擇器125可至少部分基于優(yōu)先級權重存儲裝置129中的信息來選擇針對對于調度器仲裁器的準許的請求。應該指出,圖2的框圖意圖是非限制性的,并且其他元件可存在于各種實施例中。加權的基于年齡的仲裁細節(jié)由準許仲裁器實現的基于年齡的算法是這樣的,以使得自從由仲裁器上一次準予以來已等待最長時間的請求代理將被給予最高優(yōu)先級級別。一旦代理已經接收到最高優(yōu)先級級別,針對該代理的優(yōu)先級級別將不會改變,除非該代理已經被仲裁器準予。以這種方式,通過確保針對請求代理的優(yōu)先級級別可以直到請求代理已經被仲裁器準予才在優(yōu)先級級別中增加,可以避免在輪詢仲裁的某些實施例中可能發(fā)生的饑餓問題。準許仲裁器還允許向所有請求代理指派代理權重。權重被用來為每個請求代理分配請求帶寬的百分比。在一個實施例中,經由存儲在代理權重配置寄存器中的值來為每個代理指定權重值。在一個非限制性示例中,被分配給代理的請求帶寬的百分比等于代理權重除以所有代理的權重和。加權的基于年齡的算法準許仲裁器加權的基于年齡的算法是基于由仲裁器上一次對請求代理準予時的相對年齡。對于連接至準許仲裁器的每個請求代理,存在實例化的一個年齡計數器和實例化的一個權重計數器。準許仲裁器中的高優(yōu)先級仲裁路徑和低優(yōu)先級仲裁路徑二者共享用于連接至該準許仲裁器的代理的公共年齡和權重計數器。由最終選擇器(即優(yōu)先級仲裁器選擇器125)在選取最終仲裁獲勝方之后確定對請求代理的年齡和權重寄存器的更新。在一個示例中,響應于接收到對準許仲裁器的重置輸入來首先初始化用于所有請求代理的年齡寄存器(例如年齡存儲裝置126的年齡寄存器)。當重置斷言(assert)時,年齡寄存器被初始化為在0處開始且在值n-1處結束的范圍中的唯一值,其中值n等于連接至準許仲裁器的請求接口的數目。在通過請求代理來斷言任何請求之前,根據結構的代理權重配置寄存器中的編程值來初始化代理權重計數器(例如權重存儲裝置128的代理權重計數器)。一旦權重計數器初始化,對于針對代理所準予的每個請求,使用于該代理的計數器遞減1。一旦代理的權重計數器到達零并且如果由準許仲裁器再次對該代理準予,則利用配置寄存器中針對該代理的權重所編程的值來重新加載計數器。在一個實施例中,在第一和第二基于年齡的仲裁器122和124中執(zhí)行的基于年齡的仲裁方法使用請求位向量(每個仲裁器具有其自己的向量)來確定仲裁的獲勝方。當針對代理斷言請求時,仲裁器使用針對請求代理的年齡值作為該請求的優(yōu)先級級別。針對仲裁器的優(yōu)先級級別以及因此的位向量寬度的范圍是從0至n-1。在一個實施例中,基于年齡的算法保證針對所有請求代理的年齡值是唯一的并且每個仲裁存在僅一個獲勝方。當用于請求仲裁的獲勝方的權重計數器已到達零時仲裁器更新用于所有代理的年齡寄存器。在一個實施例中,根據保證針對代理的年齡值是唯一的以下規(guī)則來更新用于所有代理的年齡寄存器:a.規(guī)則1:當代理的年齡等于仲裁的獲勝方的年齡時,用于該代理的年齡寄存器被設置成零以指示最年輕的請求年齡或最低優(yōu)先級。b.規(guī)則2:當代理的年齡小于仲裁的獲勝方時,代理的年齡寄存器遞增1。c.規(guī)則3:當代理的年齡大于仲裁的獲勝方時,代理的年齡寄存器不改變。圖3是根據本說明書的一個或多個示例的用于在確定仲裁獲勝方時更新針對代理的年齡值的方法的流程圖。該方法可在一個示例中被執(zhí)行,以在獲勝方的權重值等于零時更新年齡值。如所看到的,可由優(yōu)先級仲裁器選擇器執(zhí)行的方法200開始于確定代理的年齡值是否等于獲勝方值(判定塊210)。如果是這樣的話,控制傳遞到塊215,在那里針對該獲勝代理的年齡值可以被更新為最低優(yōu)先級級別,其在一個實施例中可等于零。根據塊215和判定塊210二者,控制傳遞到判定塊220,在那里可以確定年齡值是否小于獲勝方值(即對應于代理的年齡)。如果是這樣的話,控制傳遞到塊225,在那里代理的年齡值可以被更新,例如被遞增。如果這些狀況都沒有發(fā)生,則代理的年齡大于仲裁的獲勝方,并且照此針對該特定代理的年齡值不改變。要指出,當獲勝方被選擇時可以在每個仲裁回合的結論下針對每個代理執(zhí)行方法200。應該指出,圖3的流程圖意圖是非限制性的,并且其他操作可存在于各種實施例中。圖4是根據本說明書的一個或多個示例的準許仲裁器狀態(tài)機的框圖。如圖4中所示,可存在于圖1的準許仲裁器120內的狀態(tài)機250首先從重置斷言進入到初始化(init)狀態(tài)255中。根據該狀態(tài),控制傳遞到活動狀態(tài)260,其中只要沒有接收到請求就對其進行保持。當接收到請求并且經準予代理具有零的權重時,控制傳遞到更新年齡狀態(tài)270,其中年齡存儲裝置被更新并且用于仲裁獲勝方的權重計數器被重新加載為預定值(例如從配置寄存器獲得)??刂迫缓蟾鶕欠翊嬖诟郊诱埱蠛徒洔视璐淼臋嘀氐闹刀鴤鬟f到活動狀態(tài)260、遞減代理權重狀態(tài)280中的一個,或者保持在更新年齡狀態(tài)270。類似地,在遞減代理權重狀態(tài)280處,獲勝方仲裁權重計數器被遞減。但是在這里不執(zhí)行權重計數器重新加載。應該指出,圖4的流程圖意圖是非限制性的,并且其他狀態(tài)和操作可存在于各種實施例中。圖4的狀態(tài)機的狀態(tài)和描述包括以下內容:圖5是根據本說明書的一個或多個示例的用于在準許仲裁器中執(zhí)行第一級別仲裁的方法300的流程圖。如圖5中所示,方法300可在準許仲裁器內被執(zhí)行,其是出于執(zhí)行進入存儲器請求之間的仲裁以及基于仲裁來更新各種年齡和權重值這兩方面的目的。如圖5中所看到的,方法300可以開始于從耦合至結構的設備接收存儲器請求(塊310)。更具體地,為了說明與來自延時敏感設備的基于最后期限的請求有關的操作,我們可以在一個示例中假設該存儲器請求包括最后期限值或與最后期限值相關聯(lián),并因此從等時或延時敏感設備來提供該存儲器請求。作為一個此類示例,該延時敏感設備是媒體播放器。如看到的,控制傳遞到判定塊315,在那里可以確定最后期限值是否大于延時閾值。在一個示例中,該延時閾值是從請求被接收到的時間一直到其被完成為止的最小延時(例如通過將所請求的數據提供回至針對寫入請求提供寫入完成的請求設備)。要指出,在一個實施例中最后期限值是請求設備對于處理存儲器請求而言可以容忍的最大延時。如果確定最后期限值大于延時閾值,則控制傳遞到塊320b,在那里存儲器請求被轉發(fā)至低優(yōu)先級仲裁器。否則,控制傳遞到塊320a,在那里存儲器請求被轉發(fā)至高優(yōu)先級仲裁器。要指出,存在并行路徑以使得在塊325(塊325a和325b)處在對應仲裁器中執(zhí)行仲裁,其是基于與針對向對應仲裁器提供請求的設備的年齡值相關聯(lián)的位向量。接下來,在塊330(塊330a和330b)處,獲勝存儲器請求被轉發(fā)至最終仲裁器。在塊335處,執(zhí)行最終仲裁以選擇獲勝方存儲器請求。取決于用于該最終仲裁器的配置的模式,可以僅從高優(yōu)先級仲裁器選擇獲勝方請求,或者可發(fā)生高優(yōu)先級路徑和低優(yōu)先級路徑之間的加權。因此,在該點處,獲勝存儲器請求被轉發(fā)至存儲器調度器記分板,在那里該存儲器請求可被存儲在條目中以由此使存儲器調度器仲裁器中的仲裁能夠考慮該存儲器請求。此外,可響應于由最終仲裁器對獲勝方的選擇來執(zhí)行各種更新操作。具體來說,在判定塊340處,可以確定獲勝方代理的權重值是否等于零。如果是這樣的話,控制傳遞到塊345,在那里該權重值可以被更新為其配置值,例如被存儲在共享存儲器結構的配置寄存器中。控制接下來傳遞到塊350,在那里針對所有代理的年齡值可以被更新(塊350)。為此,所有非獲勝代理可使它們的年齡值遞增,同時獲勝代理可使其年齡值被設置成最低優(yōu)先級值(例如零)。如果作為代替在判定塊340處確定獲勝方代理的權重值不為零,則控制傳遞到塊355,在那里獲勝方代理的權重值被遞減。應該指出,圖5的流程圖意圖是非限制性的,并且其他操作可存在于各種實施例中。共享存儲器結構共享資源分配存儲器結構包括允許結構內共享資源的公平分配的邏輯,例如圖1的資源分配邏輯148。在一個實施例中,這些共享資源是結構的內部數據緩沖器、地址標簽存儲裝置和請求跟蹤器記分板。因為不存在用于請求代理中的任一個的專用資源,所以機制可以限制在結構中對于每個代理而言未決的未完成請求的數目,同時還例如通過在這些共享資源中預留虛擬條目來允許針對代理預留條目。該結構慮及代理限制的規(guī)定以防止任一個請求代理用光結構的所有可用共享資源。存儲器調度算法的一部分處理最小化讀取到寫入周轉時間對存儲器技術的性能影響。為了最小化存儲器調度器在調度讀取請求至調度寫入請求之間進行切換的次數,沖刷池(flushpool)被用于對寫入請求排隊。沖刷池允許以存儲器為目標的寫入請求在存儲器結構中被累加,直到已經接收到足夠的寫入請求以允許結構的存儲器調度器將寫入請求作為背靠背(back-to-back)請求的突發(fā)(burst)發(fā)送至存儲器控制器。為了防止結構中的所有可用資源被沖刷池用光,可以指定沖刷限制。當被指定時,沖刷限制使結構在準許仲裁器處阻止來自所有代理的新寫入請求,直到沖刷池中條目的數目小于為該沖刷池所編程的值。用于寫入請求的存儲器結構沖刷池當從請求代理接收到寫入請求時,結構將寫入數據從請求代理傳送至內部數據緩沖器。一旦新的數據被寫入到結構的內部數據緩沖器并且從代理的視角來看該請求被引退,緩沖器條目就被視為處于“沖刷池”中。對于一致存儲器業(yè)務,結構可從請求代理接收探聽(snoop)請求。探聽請求可以是對于存儲器的讀取請求或將請求寫入。當結構從請求代理接收探聽讀取或寫入請求時,它將探聽請求發(fā)送給耦合至結構的所有高速緩存代理。該高速緩存代理將對命中它們的高速緩存的探聽請求做出響應,并且將針對已經被高速緩存代理修改的高速緩存線返回寫回(wb)數據。wb數據然后被寫入到結構的內部數據緩沖器中并且然后被視為包括在以存儲器為目標的寫入請求的沖刷池中。當沖刷池中的條目的數目達到針對沖刷限制所編程的值時,在準許仲裁器處阻止例如如通過對請求操作碼字段的解碼所確定的新寫入請求。存儲器結構預留和限制存儲器結構允許使用代理預留配置寄存器針對任何代理指定預留。通過使用這些配置寄存器,用戶可以針對每個代理指定要預留的存儲器結構中條目的數目。針對代理預留的條目是分配給代理的第一條目和針對代理要被引退的最后條目。為了確定代理的預留條目是將被分配還是引退,每個代理具有與配置寄存器中指定的值進行比較的請求計數器。如果請求計數器中的值小于或等于配置寄存器中的值,則代理的預留條目將被使用。用于為代理提供預留條目的機制會隨著滿閾值限制而變化,因為針對請求代理而分配或釋放所預留的條目。最初,通過從記分板中的條目總數減去針對所有代理預留的條目的總數(例如,如由配置寄存器指定的)來計算針對所有代理的滿閾值。當預留條目被分配給代理時,累加器被用來基于已經被使用的預留條目的總數來調整滿閾值。當存儲器結構中未決請求的總數達到該經調整的滿閾值時,已使用它們的預留條目或沒有指定預留條目的代理被阻止。尚未使用它們的預留條目的代理不被準許仲裁器阻止,直到它們已經使用所有它們的預留條目并且未決請求的總數達到經調整的滿閾值限制。還可以在存儲器結構的配置寄存器中指定代理限制。在一個實施例中,可通過將用于代理的請求限制設置成零來禁用這些代理限制。當代理限制被禁用時,可向任何代理分配請求跟蹤器的所有現有條目。為了防止單個代理使用所有請求跟蹤器條目,可以針對代理指定請求限制。當代理的請求計數器達到針對代理所指定的請求限制時,禁用針對該代理輸入至準許仲裁器的請求。當請求跟蹤器引退針對代理的請求并且該代理的請求計數器變得小于代理的請求限制時,啟用針對該代理輸入至準許仲裁器的請求。圖6是根據本說明書的一個或多個示例的資源分配邏輯的一部分的框圖。如圖6中所示,邏輯360可被用于控制在所有代理之間共享的各種資源的分配。如所看到的,加法器368基于從配置存儲裝置365接收到的代理預留值來確定預留條目的總數。在減法器370處從該總預留條目值減去標簽條目的數目。通過觸發(fā)器372將結果得到的值提供給加法器375,該加法器375將該值與從觸發(fā)器374接收到的所使用的預留條目的數目進行組合,如下面進一步所述的基于遞增和遞減預留計數值來交替地遞增和遞減該預留條目的數目。照此,由加法器375生成的和對應于提供給比較器382的一個輸入端的經調整的滿閾值,該比較器382進一步接收來自觸發(fā)器376的所分配的標簽條目的數目。如果確定經調整的滿閾值小于或等于所分配的標簽條目的該數目,則滿標志被生成并用于掩蔽不具有預留條目或已使用它們的預留條目的代理的請求。如進一步所看到的,另一比較器380被配置成接收給定請求器的預留配置值和針對該請求器的請求計數器值(來自觸發(fā)器378)。比較器因此生成關于請求器是否具有任何自由預留條目的指示,其作為輸入被提供給進一步接收針對該信道的條目的信道準予和引退的指示的一對與(and)門384和385。照此,這些與門因此分別生成針對對應請求器的遞增值和遞減值。對其他請求器執(zhí)行相似的邏輯和操作,其中所有遞增和遞減預留值被提供給分別生成遞增預留計數值和遞減預留計數值的對應或(or)門386和387。最后,將針對請求器的請求計數值連同針對該請求器的經配置的限制值一起提供給另一比較器390,以由此確定該請求器是否已達到其限制。如果是這樣的話,該限制的指示被用來掩蔽掉用于進一步仲裁的來自該代理的請求。應該指出,圖6的框圖意圖是非限制性的,并且其他操作可存在于各種實施例中。共享存儲器結構調度器仲裁細節(jié)實施例可結合多個調度算法以增強跨越支持不同存儲器技術的多個soc的重用。結構的存儲器調度器邏輯包含高級qos調度算法,并且還被優(yōu)化以最小化通常在大多數存儲器技術中發(fā)現的性能瓶頸。使用例如dram存儲器而發(fā)生的典型性能瓶頸包括低功率存儲器狀態(tài)的進入和離開、讀取-寫入周轉時間、對同一dram庫但對存儲器的不同行的連續(xù)存儲器訪問、以及對不同dram存儲器庫的連續(xù)存儲器訪問。通過將復雜無序調度算法包括在共享存儲器結構調度邏輯中,可以通過將簡化的技術特定約束求解器附接于結構來使該結構適于許多不同soc,以便支持它們對存儲器技術或配置的獨特要求。除了改進存儲器調度邏輯的可移植性之外,實施例還提供存儲器請求延時的可預測性,因為高級無序調度算法和qos調度算法的組合導致了最大請求延時的改善的可預測性,因為存儲器控制器具有對于重新排序存儲器請求的少得多的靈活性。一旦請求被準許仲裁器準予,它就被排隊到調度器記分板中。調度器記分板存儲關于該請求的信息,調度器記分板使用該信息來將請求轉發(fā)至存儲器控制器以便執(zhí)行對存儲器的讀取或寫入。在一個實施例中,該信息包括請求地址、請求長度、命令類型(讀取或寫入)、服務類種類、存儲器信道、存儲器庫、存儲器等級和頁面命中/未命中狀態(tài)。存儲器調度器最舊可用隊列實施例提供基于發(fā)送至存儲器控制器的請求歷史的無序頁面感知調度,盡管該結構并不直接了解存儲器庫的真實狀態(tài)。更具體地,結構的存儲器調度器將調度器記分板用作已經被發(fā)送至存儲器的請求的歷史緩沖器。因為調度器記分板被用來反映請求的歷史,所以它試圖將針對請求的狀態(tài)信息盡可能長地保持在記分板中。存儲器調度器使用被稱為最舊可用隊列(theoldestofavailablequeue)的構造來確定可用于被再分配的最舊記分板條目。最舊可用隊列也被存儲器調度器用來避免可能由于對存儲器的請求的無序調度而引起的饑餓問題。結構的存儲器調度器使用最舊可用隊列來確定有多少個同一服務類種類和類型、讀取或寫入的請求已經繞過對存儲器的最舊未決請求。一旦已繞過最舊請求的請求數目達到預編程的限制(例如由軟件設置),結構的存儲器調度器就禁用請求的無序調度并且對最舊未決請求準予。如上文所提到的,調度器使用最舊可用隊列來對其記分板中的所有請求的相對年齡保持跟蹤。當由準許仲裁器對以新存儲器地址為目標的請求準予時,到調度器記分板中的索引指針被排隊到最舊可用隊列的尾條目中,該尾條目然后被視為最新請求。當所有未決請求已完成將數據從請求代理傳送至存儲器控制器/將數據從存儲器控制器傳送至請求代理時,記分板條目可用于被再分配并且可以被再分配用于由準許仲裁器準予的新請求。由于無序調度,最舊可用隊列中的最舊條目可能不可用于再分配。為了選擇要被再分配給新請求的記分板條目,調度器檢測對于記分板條目的所有未完成請求是否已經完成。在一個實施例中,該調度器使用具有與記分板條目的數目相等的長度的請求位向量來指示哪些條目可用于再分配。在請求位向量中設置為1的位指示與該位位置相對應的條目可用于再分配。然后將請求位向量發(fā)送至最舊可用隊列。最舊可用隊列使用存儲在隊列中的索引來選擇與針對隊列的該條目的請求相對應的請求向量中的位。隊列的每個條目都與請求向量中的唯一位相關聯(lián)并且從隊列中的最舊條目開始執(zhí)行“找到第一個(findfirst)”函數,以確定要被再分配的最舊可用請求。在確定要被再分配的最舊可用條目之后,從該最舊可用隊列輸出針對該條目的記分板索引。圖7是根據本說明書的一個或多個示例的記分板索引生成邏輯的框圖。如圖7中所示,邏輯400包括多個觸發(fā)器410-0—410-n,其以串行配置耦合來存儲對應記分板索引。如所看到的,觸發(fā)器410被配置成接收與到調度器的記分板中的索引指針相對應的記分板索引,其也是對于標簽陣列和數據緩沖器的索引。觸發(fā)器410可被配置在從最新(即觸發(fā)器410-0)到最舊(即觸發(fā)器410-n)的順序中。在非限制示例中,每個觸發(fā)器都可以是d型觸發(fā)器。在其他實施例中,可使用任何適當的存儲元件。如所看到的,每個觸發(fā)器410的輸出端都被耦合至對應的多個多路復用器420-0—420-n中的一個,該多個多路復用器420-0—420-n中的每一個都進一步被配置成接收記分板請求向量的位。照此,該位向量例如經由已設置位提供指示來指示對應的記分板條目可用于再分配。使用來自多路復用器420的輸出,可以從比較器輸出端(諸如從比較器420-n)直接地生成或者經由邏輯門430-0—430-n(在所示的實施例中其被配置為具有從對應的多路復用器420接收的第一輸入和與對應的或門425-0—425-(n-2)的逆輸出端相對應的第二輸入的與門)中的對應一個來生成準予信號。以這種方式,每次僅準予信號中的單個信號可以是有效的。如在圖7中進一步看到的,準予輸出信號可被耦合至多個與門435-0—435-n中的對應一個,該與門435-0—435-n還被配置成接收進入索引信號。進而,來自與門435的輸出可以被耦合至或門440以由此輸出與最舊可用條目相對應的記分板索引,以使得執(zhí)行“1熱(1-hot)”多路復用器功能來提供經準予請求的記分板索引的“1熱(onehot)”多路復用。應該指出,圖7的框圖意圖是非限制性的,并且其他元件可存在于各種實施例中。共享存儲器結構存儲器調度細節(jié)在一個示例中,結構存儲器調度器包含三個狀態(tài)機,它們一起工作來調度發(fā)送至存儲器控制器的請求。圖8是根據本說明書的一個或多個示例的用于調度器仲裁器的狀態(tài)機的框圖。如圖8中所示,狀態(tài)機500(其可以以硬件、軟件和/或固件來執(zhí)行,諸如圖1的調度器仲裁器130)可以開始于在系統(tǒng)的重置時進入初始化狀態(tài)init505中??刂平酉聛韨鬟f到自刷新狀態(tài)機510,其包括“進入”自刷新狀態(tài)512、“請求”自刷新狀態(tài)514和“離開”自刷新狀態(tài)516。如在圖8中看到的,控制從離開自刷新狀態(tài)516傳遞到“讀取/寫入”準予狀態(tài)機520,其進而包括“準予讀取請求”狀態(tài)522和“準予寫入請求”狀態(tài)524??刂茝倪@些狀態(tài)進而傳遞到“讀取”狀態(tài)機530,其包括多個狀態(tài),即“繞過準予”狀態(tài)532、“高優(yōu)先級讀取請求”準予狀態(tài)534、“盡力而為”準予讀取請求狀態(tài)536和“低優(yōu)先級”等時準予讀取請求狀態(tài)538。應該指出,圖8的框圖意圖是非限制性的,并且其他元件和修改可存在于各種實施例中。自刷新狀態(tài)機。實施例可控制何時允許存儲器進入和離開低功率存儲器狀態(tài),也被稱為自刷新狀態(tài)。自刷新狀態(tài)機負責控制何時將指示發(fā)送給存儲器控制器以進入或離開自刷新。對于盡力而為讀取請求,自刷新狀態(tài)機立即轉變至離開自刷新狀態(tài)。對于等時讀取請求,存儲器調度器檢查請求最后期限來確定是否要離開自刷新,以便滿足對于該請求所需的讀取延時。為了確定是否需要離開自刷新以便滿足等時請求要求,存儲器調度器從全局定時器的當前值減去請求的最后期限。針對結構中被編程為反映對于存儲器控制器離開自刷新且結構將數據返回至請求代理而言所需要的最差情況延時的配置寄存器來檢查減法的結果。對于寫入請求,結構對沖刷池中的臟(dirty)條目的數目計數并且針對可編程閾值(被稱為沖刷高水標)來檢查結果。如果臟條目的數目超過沖刷高水標的值,則自刷新狀態(tài)機將控制傳遞到離開自刷新狀態(tài)。此外,結構檢查對其中由準予仲裁器阻止請求的同一標簽地址的讀取/寫入沖突。當結構確定請求被地址沖突、代理限制阻止時或者如果請求跟蹤器或存儲器調度器記分板為滿時,控制從自刷新狀態(tài)機傳遞到離開自刷新狀態(tài)。在一個實施例中,結構還包含可以被編程為使進入自刷新禁用的配置寄存器。當存儲器寄存器將指示發(fā)送至存儲器控制器以離開自刷新時,請求可開始被發(fā)送至存儲器控制器。該存儲器調度器繼續(xù)將指示發(fā)送至存儲器控制器以在它主動將存儲器請求發(fā)送至存儲器控制器的同時保持離開自刷新。當存儲器調度器完成將所有讀取請求發(fā)送至存儲器控制器并且沖刷池中的寫入請求的數目低于臨時高水標限制時,存儲器調度器轉變至請求自刷新狀態(tài)。在請求自刷新狀態(tài)中,如果準許仲裁器沒有對新的請求準予,則在被稱為“進入自刷新延遲”的可編程延遲值被滿足之后狀態(tài)機轉變至“進入自刷新”狀態(tài)。在一個實施例中,該延遲被編程于結構中的配置寄存器中。如果由準許仲裁器對新的請求準予,則在某些情況下自刷新狀態(tài)機可轉變至“離開自刷新”狀態(tài)。如果接收到新的盡力而為讀取請求或者如果接收到導致沖刷池中條目的數目超過在沖刷高水標配置寄存器中編程的數目的寫入請求,則自刷新狀態(tài)機從請求自刷新狀態(tài)轉變回至離開自刷新狀態(tài)。如果在狀態(tài)機處于請求自刷新狀態(tài)時接收到等時讀取請求,則針對被稱為“進入自刷新”閾值的編程值來檢查請求的最后期限值。如果最后期限延時大于進入自刷新閾值,則狀態(tài)機繼續(xù)在請求自刷新狀態(tài)中。如果針對請求的最后期限延時小于進入自刷新閾值,則該狀態(tài)機將轉變至離開自刷新狀態(tài)。自刷新狀態(tài)機將狀態(tài)驅動至存儲器控制器以保持離開自刷新,直到狀態(tài)機轉變至進入自刷新狀態(tài)。一旦在進入自刷新狀態(tài)中,狀態(tài)機就將指示發(fā)送給存儲器控制器以進入自刷新。下面的表2是根據本說明書的實施例的自刷新狀態(tài)機的描述。當前狀態(tài)條件描述下一狀態(tài)輸出未知重置重置引腳被斷言進入自刷新結構將指示驅動至存儲器控制器以進入自刷新進入自刷新存儲器調度器ldl沖刷條目的數目小于沖刷hwm且沒有盡力而為讀取請求且沒有最后期限時間小于離開自刷新閾值的isoc讀取請求進入自刷新結構將指示驅動至存儲器控制器以進入自刷新進入自刷新離開自刷新1沖刷條目的數目大于沖刷hwm或盡力而為讀取請求或最后期限時間小于離開自刷新閾值的isoc讀取請求或isoc讀取請求被代理限制或結構記分板全指示阻止離開自刷新結構將指示驅動至存儲器控制器以進入自刷新離開自刷新存儲器調度器有效等時或盡力而為讀取請求未決或沖刷池條目的數目高于臨時hwm離開自刷新結構將指示驅動至存儲器控制器以離開自刷新離開自刷新請求自刷新沒有等時或盡力而為讀取請求未決且沖刷池條目的數目低于臨時hwm請求自刷新結構將指示驅動至存儲器控制器以離開自刷新請求自刷新離開自刷新2接收到最后期限小于進入自刷新閾值的等時讀取請求或接收到盡力而為讀取請求未決,沖刷池條目的數目現在高于沖刷hwm離開自刷新結構將指示驅動至存儲器控制器以離開自刷新請求自刷新請求自刷新沒有接收到盡力而為讀取請求且沖刷池條目的數目低于沖刷hwm且進入自刷新定時器大于進入自刷新延遲值進入自刷新結構將指示驅動至存儲器控制器以進入自刷新讀取/寫入準予狀態(tài)機在一個實施例中,存儲器調度器使用可配置的閾值來指定何時開始和停止將一連串寫入請求傳送至存儲器控制器。存儲器調度器可執(zhí)行不同類型的寫入數據向存儲器的傳送,例如高優(yōu)先級傳送和低優(yōu)先級傳送(在本文中也分別被稱為對存儲器的寫入請求的高優(yōu)先級沖刷和對存儲器的寫入請求的臨時沖刷)。當沖刷池中條目的數目達到或超過閾值(沖刷高水標)時,存儲器調度器開始調度對存儲器的高優(yōu)先級寫入沖刷并開始將寫入請求發(fā)送至存儲器控制器。存儲器控制器繼續(xù)使用高優(yōu)先級沖刷機制調度寫入請求,直到沖刷池中條目的數目達到或小于閾值(沖刷低水標)為止。臨時沖刷還可由結構存儲器調度器來執(zhí)行。當存儲器調度器已完成將所有讀取請求發(fā)送至存儲器控制器并且沖刷池中條目的數目超過閾值(臨時沖刷限制)時,觸發(fā)臨時沖刷。在一個實施例中,因為性能原因,臨時沖刷限制可以通常被設置成低于高水標,但是大于或等于低水標。在一些情況下,該臨時沖刷限制可以被設置成0,以將所有寫入數據沖刷到存儲器。一旦最后的讀取請求被發(fā)送至存儲器控制器,如果沖刷池中條目的數目高于臨時沖刷限制,被稱為臨時沖刷定時器的計數器每個時鐘周期開始遞增。如果結構沒有接收到對存儲器的新讀取請求并且臨時沖刷定時器達到由臨時沖刷延遲指定的值(其是存儲在配置寄存器中的閾值),則存儲器調度器開始將寫入請求發(fā)送至存儲器控制器。該臨時沖刷繼續(xù),直到沖刷池中條目的數目小于臨時沖刷限制為止或者直到結構接收到新讀取請求為止。讀取/寫入準予狀態(tài)機負責從準予讀取請求切換至準予寫入請求。在一個實施例中,存儲器調度器可被配置成允許寫入請求具有超過讀取請求的優(yōu)先級或者當在讀取請求和寫入請求之間進行切換時使用權重(以便防止當系統(tǒng)被寫入請求飽和時讀取的饑餓)。當權重被啟用時,存儲器結構使用配置寄存器來獨立地指定讀取和寫入權重。下面的表3是根據本說明書的實施例的讀取/寫入準予狀態(tài)機的描述。當前狀態(tài)條件描述下一狀態(tài)輸出未知重置重置引腳被斷言準予讀取請求存儲器調度器向存儲器控制器發(fā)送讀取請求準予讀取請求準予讀取請求沖刷條目的數目小于沖刷hwm且讀取/寫入權重被禁用或沖刷條目的數目大于hwm且讀取/寫入權重被啟用且讀取權重計數大于0準予讀取請求存儲器調度器向存儲器控制器發(fā)送讀取請求準予讀取請求準予寫入請求沖刷條目的數目大于沖刷hwm且讀取/寫入權重被禁用或沖刷條目的數目大于hwm且讀取/寫入權重被啟用且讀取權重計數等于0或沒有讀取請求未決且沖刷條目的數目大于臨時hwm且臨時定時器已到期準予寫入請求存儲器調度器向存儲器控制器發(fā)送寫入請求準予寫入請求準予寫入請求沖刷條目的數目大于沖刷hwm且讀取/寫入權重被禁用或沖刷條目的數目大于lwm且讀取/寫入權重被啟用且寫入計數大于0準予寫入請求存儲器調度器向存儲器控制器發(fā)送寫入請求準予寫入請求準予讀取請求未決讀取請求且沖刷條目的數目小于沖刷lwm或未決讀取請求且沖刷條目的數目大于lwm且讀取/寫入權重被啟用且寫入權重計數等于0準予讀取請求存儲器調度器向存儲器控制器發(fā)送讀取請求讀取狀態(tài)機讀取狀態(tài)機負責在高優(yōu)先級等時讀取請求、盡力而為讀取請求和低優(yōu)先級等時讀取請求之間進行切換。讀取狀態(tài)機可以被配置成以多個模式之一來操作。在一個實施例中,提供兩個這樣的模式。第一模式是固定優(yōu)先級模式,在其中讀取狀態(tài)機向高優(yōu)先級等時讀取給予最高優(yōu)先級、向盡力而為讀取請求給予中優(yōu)先級,并且向低優(yōu)先級等時讀取請求給予最低優(yōu)先級。第二模式是啟用用于在高優(yōu)先級等時讀取和盡力而為讀取請求之間進行切換的權重的使用。在該模式中,低優(yōu)先級等時請求僅在不再存在任何高優(yōu)先級等時或盡力而為讀取請求時被準予。表4是根據本說明書的讀取狀態(tài)機的描述。當前狀態(tài)條件描述下一狀態(tài)輸出未知重置重置引腳被斷言繞過準予啟用從準許仲裁器的輸出端至存儲器控制器的繞過路徑繞過準予沒有讀取請求在調度器中沒有讀取請求未決繞過準予啟用從準許仲裁器的輸出端至存儲器控制器的繞過路徑繞過準予高優(yōu)先級isoc請求無序自刷新且高優(yōu)先級isoc請求未決準予高優(yōu)先級isoc請求存儲器調度器向存儲器控制器發(fā)送高優(yōu)先級讀取請求繞過準予盡力而為請求無序自刷新且沒有高優(yōu)先級isoc請求且盡力而為請求未決準予盡力而為請求存儲器調度器向存儲器控制器發(fā)送盡力而為讀取請求繞過準予低優(yōu)先級isoc請求無序自刷新且沒有高優(yōu)先級isoc請求且沒有盡力而為請求且低優(yōu)先級isoc請求未決準予低優(yōu)先級isoc請求存儲器調度器向存儲器控制器發(fā)送低優(yōu)先級讀取請求準予高優(yōu)先級isoc請求高優(yōu)先級isoc請求無序自刷新且高優(yōu)先級isoc請求未決且isoc權重不等于0準予高優(yōu)先級isoc請求存儲器調度器向存儲器控制器發(fā)送高優(yōu)先級讀取請求準予高優(yōu)先級isoc請求盡力而為請求無序自刷新且沒有高優(yōu)先級isoc請求未決且isoc權重等于0且盡力而為請求未決準予盡力而為請求存儲器調度器向存儲器控制器發(fā)送盡力而為讀取請求準予高優(yōu)先級isoc請求低優(yōu)先級isoc請求無序自刷新且沒有高優(yōu)先級isoc請求且沒有盡力而為請求且低優(yōu)先級isoc請求未決準予低優(yōu)先級isoc請求存儲器調度器向存儲器控制器發(fā)送低優(yōu)先級讀取請求準予高優(yōu)先級isoc請求沒有讀取請求未決無序自刷新且沒有高優(yōu)先級isoc請求且沒有盡力而為請求且沒有低優(yōu)先級isoc請求繞過準予啟用從準許仲裁器的輸出端至存儲器控制器的繞過路徑準予盡力而為請求盡力而為請求無序自刷新且沒有高優(yōu)先級isoc請求或者isoc權重等于0且盡力而為請求未決準予盡力而為請求存儲器調度器向存儲器控制器發(fā)送盡力而為讀取請求準予盡力而為請求高優(yōu)先級isoc請求無序自刷新且高優(yōu)先級isoc請求未決且isoc權重不等于0或be權重等于0準予高優(yōu)先級isoc請求存儲器調度器向存儲器控制器發(fā)送高優(yōu)先級讀取請求準予盡力而為請求低優(yōu)先級isoc請求無序自刷新且沒有高優(yōu)先級isoc請求且沒有盡力而為請求且低優(yōu)先級isoc請求未決準予低優(yōu)先級isoc請求存儲器調度器向存儲器控制器發(fā)送低優(yōu)先級讀取請求準予盡力而為請求沒有讀取請求未決無序自刷新且沒有高優(yōu)先級isoc請求且沒有盡力而為請求且沒有低優(yōu)先級isoc請求繞過準予啟用從準許仲裁器的輸出端至存儲器控制器的繞過路徑準予低優(yōu)先級isoc請求高優(yōu)先級isoc請求無序自刷新且高優(yōu)先級isoc請求未決準予高優(yōu)先級isoc請求存儲器調度器向存儲器控制器發(fā)送高優(yōu)先級讀取請求準予低優(yōu)先級isoc請求盡力而為請求無序自刷新且沒有高優(yōu)先級isoc請求且盡力而為請求未決準予盡力而為請求存儲器調度器向存儲器控制器發(fā)送盡力而為讀取請求準予低優(yōu)先級isoc請求低優(yōu)先級isoc請求無序自刷新且沒有高優(yōu)先級isoc請求且沒有盡力而為請求且低優(yōu)先級isoc請求未決準予低優(yōu)先級isoc請求存儲器調度器向存儲器控制器發(fā)送低優(yōu)先級讀取請求準予低優(yōu)先級isoc請求沒有讀取請求未決無序自刷新且沒有高優(yōu)先級isoc請求且沒有盡力而為請求且沒有低優(yōu)先級isoc請求繞過準予啟用從準許仲裁器的輸出端至存儲器控制器的繞過路徑調度器代理權重存儲器調度器將代理權重用于在同一服務類種類內的代理之間按比例劃分存儲器帶寬。在一個實施例中,配置寄存器針對每個請求代理指定權重值,并且針對每個代理提供權重計數器。代理權重配置寄存器在準許仲裁器和存儲器調度器之間是公共的。當在用于連接至結構的代理中的任一個的存儲器調度器中不存在請求未決時,利用在代理權重配置寄存器中指定的值來加載代理權重計數器。當由準許仲裁器準予請求并且該請求排隊到存儲器調度器記分板中時,代理id字段連同請求信息一起被存儲在存儲器調度記分板中。當存儲器調度器準予其記分板中的請求時,代理id字段被用來確定請求的源并且用于該代理的權重計數器被遞減1。一旦代理的權重計數器已達到零,針對該代理的剩余請求被掩蔽且不再參與調度器仲裁。當由于代理的權重計數器達到零而掩蔽代理以免于仲裁時,存儲器調度器繼續(xù)調度來自剩余代理的請求。一旦用于所有代理的權重計數器已達到零或者如果代理的權重計數器是非零的但不存在針對該代理的剩余請求,則利用來自代理權重配置寄存器的值重新加載所有代理權重計數器。圖9是根據本說明書的一個或多個示例的用于執(zhí)行存儲器調度的方法的框圖。如圖9中所示,方法600可以由共享存儲器結構的調度器仲裁器來執(zhí)行。如所看到的,方法600可以開始于從存儲器調度器記分板選擇存儲器請求以用于遞送到存儲器控制器(塊610)。在確定適當條目時可以考慮到各種因素,包括存儲器的狀態(tài)、各種請求的狀態(tài)、未決請求的地址位置之間的關系,等等。接下來,在塊620處,更新針對所選代理的權重值。在一個實施例中,執(zhí)行權重值的遞減。要指出,盡管針對代理的初始權重值與從也被準許仲裁器使用的配置寄存器獲得的權重值相同,但是要理解的是,針對每個仲裁器提供不同的權重計數器以使得能夠實現對這些權重值的獨立控制。仍參考圖9,接下來在判定塊630處,可以確定所選代理的權重值是否等于零。要指出,在一個非限制性示例中,該確定在一個實施例中可以是其中零是最低優(yōu)先級值。如果確定權重值是零,則控制傳遞到塊640,在那里掩蔽該所選代理以免于存儲器調度器內的進一步仲裁??刂茝呐卸▔K630和640二者傳遞到判定塊650,在那里可以確定所有代理的權重值是否等于零。如果是這樣的話,控制傳遞到塊660,在那里針對所有代理的權重值可以被更新為例如從結構的配置寄存器獲得的它們的配置值。否則,控制從判定塊650傳遞到判定塊670以確定在用于具有非零權重值的代理的存儲器調度器中是否存在任何剩余的請求。如果是這樣的話,這些請求可以被處理(例如經由方法600的另一次迭代)。否則,如果沒有附加請求留下,則控制傳遞到塊660,在那里可以如所描述那樣更新權重值。應該指出,圖9的流程圖意圖是非限制性的,并且其他元件和修改可存在于各種實施例中。下面的表5提供基于如下針對三個代理的初始權重值而針對多個時鐘周期進行存儲器調度的示例操作:代理0權重=4代理1權重=2代理2權重=1。表5時鐘周期代理0請求代理0請求掩蔽代理0權重計數器代理1請求代理1請求掩蔽代理1權重計數器代理2請求代理2請求掩蔽代理2權重計數器重新加載代理權重代理準予1假假4假假2假假1真沒有準予2真假4真假2真假1假準予代理13真假4真假1真假1假準予代理24真假4真假1真真0假準予代理05真假3真假1真真0假準予代理06真假2真假1真真0假準予代理17真假2真真0真真0假準予代理08真假1真真0真真0真準予代理09真假4真假2真假1假準予代理010真假3真假2真假1假準予代理011真假2真假2真假1假準予代理112真假2真假1真假1假準予代理213真假2真假1真真0假準予代理014真假1真假1真真0假準予代理015真真0真假1真真0真準予代理116真假4真假2真假1假準予代理017真假3真假2真假1假準予代理118真假3真假2真假1假準予代理0無序頁面感知調度存儲器調度器對發(fā)送至存儲器控制器的請求重新排序并且尋求針對最大存儲器可能帶寬使優(yōu)化請求流。存儲器調度器包含被編程為向調度器提供關于其附接到的存儲器控制器的信息的配置寄存器。在一個實施例中,這些配置寄存器包括關于什么地址位被用于存儲器信道、庫、等級和行地址的信息。通過使用編程于配置寄存器中的存儲器配置信息,存儲器調度器確定調度器記分板中的每個請求的庫、等級、行和信道。存儲器調度器記分板還包含針對每個請求的頁面命中狀態(tài)位,其被用于優(yōu)化發(fā)送至存儲器控制器的請求,以使得在將請求發(fā)送至不同頁面之前將對存儲器中同一頁面的請求發(fā)送至存儲器控制器。在初始化之后且在任何請求被發(fā)送至存儲器控制器之前,存儲器調度器清除其記分板中的所有頁面命中狀態(tài)位。當請求被發(fā)送至存儲器控制器時,存儲器調度器更新記分板中的頁面命中狀態(tài)位以指示其他請求是針對存儲器中的同一頁面還是針對存儲器中的不同頁面。盡管調度器并不知曉給定存儲器庫中的頁面的實際狀態(tài),但是這些頁面命中狀態(tài)位可被用作關于哪些請求是針對最優(yōu)存儲器帶寬而要被發(fā)送至存儲器控制器的最佳候選的提示。當請求被發(fā)送至存儲器控制器時,存儲器調度器將比較針對記分板中未決的所有其他請求的信道、等級和庫信息。如果記分板條目的信道、等級和庫信息與發(fā)送至存儲器控制器的請求相匹配,則將該條目的行地址與發(fā)送至存儲器控制器的請求的行地址進行比較。如果記分板條目的行地址與請求相匹配,則頁面命中狀態(tài)位被設置成1;如果行地址與請求不匹配則頁面命中狀態(tài)位被設置成0,從而指示頁面未命中。對于其中信道、等級或庫位不同于發(fā)送至存儲器控制器的請求的記分板條目而言,不發(fā)生對頁面命中狀態(tài)的更新。當由準許仲裁器準予新請求并且該新請求排隊到調度器記分板中時,將行地址信息與當前處于記分板中的所有條目進行比較。如果新請求的行地址與調度器記分板中的一個或多個條目相匹配,且任何匹配條目的頁面命中狀態(tài)位被設置,則針對新請求的頁面命中狀態(tài)也被設置。如果行地址與記分板中的任何條目都不匹配或者與它相匹配的所有條目都具有設置成零的頁面命中狀態(tài),則針對新請求的頁面命中狀態(tài)也被設置成零。使用存儲在調度器記分板中的頁面命中和等級狀態(tài)信息,存儲器調度器基于已經被確定為針對大部分基于dram的存儲器技術提供最優(yōu)帶寬的優(yōu)先級編碼調度方案來對發(fā)送至存儲器控制器的請求重新排序。存儲器控制器在準予具有較低優(yōu)先級級別的請求之前準予較高優(yōu)先級請求。下面的表6示出根據本說明書的一個實施例的被存儲器調度器使用的不同優(yōu)先級級別。存儲器調度器頁面感知調度優(yōu)先級頁面命中狀態(tài)等級狀態(tài)優(yōu)先級級別頁面命中同一等級優(yōu)先級級別3(最高)頁面命中不同等級優(yōu)先級級別2頁面未命中同一等級優(yōu)先級級別1頁面未命中不同等級優(yōu)先級級別0(最低)基于年齡的存儲器調度和饑餓預防為了防止由于無序頁面感知調度算法而引起的請求饑餓,至少部分地將年齡概念用于調度請求。對于每個服務類(cos)種類,存儲器調度器包含指定無序(ooo)調度限制的配置寄存器。為了針對等時cos種類提供較短的最大讀取延時,ooo調度限制通常被設置成比盡力而為cos種類的ooo調度限制更小的值。存儲器調度器針對盡力而為和等時cos種類創(chuàng)建針對其記分板中的所有未決請求的請求命中向量。這些請求命中向量被發(fā)送至最舊可用隊列,這會確定仍未決的最舊請求。最舊可用隊列輸出一個熱編碼的位向量,其具有被設置成1來指示最舊請求的位。當存儲器調度器基于其頁面感知調度算法來準予請求ooo時,存儲器調度器對有多少個不是針對每個cos種類的最舊未決請求的請求被準予進行計數。一旦計數器達到針對cos種類的ooo調度限制(這可通過針對cos種類的最差情況可接受延時而完成的性能分析來確定),頁面感知調度邏輯被禁用并且由存儲器調度器準予針對cos種類的最舊請求。在針對cos種類的最舊請求被準予的任何時間,針對該cos種類的計數器被重置成零。為了提供針對cos種類的最低可能延時,ooo調度限制可以被編程為零,本質上禁用了針對該cos種類的頁面感知調度邏輯。當針對cos種類將ooo調度限制設置成零時,可使用請求年齡來調度對存儲器的請求,該請求年齡通過最舊可用隊列來確定。盡力而為最大延時饑餓預防對于盡力而為讀取請求而言,該結構利用調度器記分板中的最后期限存儲信息來存儲一個值,其被用于指定針對調度盡力而為請求的最大延時值。記分板是條目池并且存儲在記分板中的請求可以是通過也被存儲在用于每個請求的記分板中的請求的服務類種類所確定的盡力而為或等時請求。在記分板中的請求是盡力而為讀取請求的情況下,最大可允許延時(例如存儲在配置寄存器中的編程值)被用于調度該請求。當該請求在記分板中排隊并且是盡力而為讀取請求時,最大延時值被添加至全局定時器的當前值。一旦全局定時器達到針對盡力而為請求的最大延時所存儲的值,就針對該請求忽略頁面感知調度,并且導致當該請求是未決的最舊請求時(例如如通過最舊可用隊列確定)調度該請求。請求跟蹤器寫入優(yōu)先級和權重請求跟蹤器負責將數據從請求代理傳送至結構的內部存儲器緩沖器。被共享存儲器結構使用的寫入協(xié)議使所有寫入數據以請求順序從請求代理傳送至結構中的內部存儲器緩沖器。在一個實施例中,請求跟蹤器使用每個代理的單獨鏈表來保持寫入請求的排序。請求跟蹤器可在將數據從請求代理傳送至內部數據緩沖器之前執(zhí)行針對寫入請求的一致性檢查。對于寫入請求,請求跟蹤器可被配置成支持一個或多個優(yōu)先級級別。當請求被準許仲裁器準予時,針對該請求的最后期限信息被存儲在具有與請求跟蹤器中的條目數目相對應的長度的陣列中。該結構使用例如存儲在配置寄存器中的閾值來指定何時將請求最后期限值視為高優(yōu)先級。將針對請求的每個最后期限值與配置寄存器中編程的閾值進行比較。當最后期限延時小于配置寄存器中的值時,針對請求在跟蹤器的記分板條目中設置一個位,從而指示該請求是高優(yōu)先級。當被啟用用于兩個優(yōu)先級級別操作時,如果針對代理的寫入請求達到鏈表的首部并且針對請求設置高優(yōu)先級位,則該寫入請求被視為高優(yōu)先級。如果在代理鏈表中的任一個的首部處的任何寫入請求指示寫入請求是高優(yōu)先級請求,則在被輸入至寫入請求仲裁器之前,針對其他代理的其他鏈表的首部處的所有低優(yōu)先級寫入請求被掩蔽。如果在代理鏈表的首部處存在同一優(yōu)先級級別的多個請求,則執(zhí)行仲裁來選擇選取哪個代理來傳送寫入數據。請求跟蹤器寫入請求仲裁器寫入請求仲裁器使用基于加權優(yōu)先級的公平仲裁器來選擇哪個代理傳送寫入數據。用于寫入請求仲裁器的權重被編程于請求跟蹤器中的配置寄存器中。寫入仲裁器在重置時向每個代理指派唯一的優(yōu)先級。在每個周期上,仲裁器僅考慮具有準備好傳遞的數據的請求候選,并且準予請求器具有最高優(yōu)先級。當被準予時,使請求候選的權重遞減1.如果被準予的候選已經具有為零的權重,則仲裁器還如下更新請求候選優(yōu)先級:被準予的候選的優(yōu)先級被設置成最低優(yōu)先級(例如零):具有比被準予的候選更低的優(yōu)先級的所有候選遞增其優(yōu)先級,并且具有比被準予的候選更高的優(yōu)先級的所有候選保留其優(yōu)先級不變。請求跟蹤器讀取數據返回請求代理支持有序數據返回或者無序數據返回。為了支持無序數據返回,使用順序id字段。從具有每個請求的代理發(fā)送順序id并且將該順序id存儲在請求跟蹤記分板中。按請求順序返回來自同一代理的具有同一順序id的請求。針對來自同一代理的具有不同順序id的請求的數據不需要按請求順序返回。在一個實施例中,請求跟蹤器使用用于確保當讀取數據被返回至請求代理時被正確排序的鏈表。在請求被準許仲裁器準予之前,選取數據要被寫入其中的內部數據緩沖器的條目。當請求被準許仲裁器準予時,包括到內部數據緩沖器中的索引的請求信息被轉發(fā)至請求跟蹤器。當數據從存儲器控制器返回時,存儲器調度器向請求跟蹤器轉發(fā)讀取完成指示,其包括到數據正被寫入其中的內部數據緩沖器中的索引字段和存儲器地址的哪些數據塊(chunk)已經完成存儲器讀取的指示。當請求跟蹤器接收到讀取完成時,它將索引字段與用于存儲在請求跟蹤器記分板中的所有請求的索引字段進行比較。如果記分板條目的索引字段與針對請求的讀取完成相匹配并且針對讀取完成設置用于請求的所有數據塊位,則在請求跟蹤器記分板中設置一個位,從而指示已完成讀取請求。如果讀取請求已達到鏈表的首部并且設置請求跟蹤器中的讀取完成狀態(tài)位并且已完成針對請求的所有一致性檢查,則該請求可用于將讀取數據返回至代理。類似于寫入請求,請求跟蹤器使用用于記分板條目的請求最后期限信息來指示請求優(yōu)先級。在一個實施例中,請求跟蹤器針對具有準備好返回至請求代理的數據的記分板條目創(chuàng)建兩個請求位向量。一個位向量用于低優(yōu)先級讀取請求并且另一個位向量用于高優(yōu)先級讀取請求。請求位向量被輸入至請求跟蹤器最舊可用隊列。最舊可用隊列確定對于兩個請求命中向量來說哪個請求是最舊的。請求跟蹤器具有一個配置模式,當啟用該配置模式時將促使在返回用于任何低優(yōu)先級請求的數據之前從由最舊可用隊列選擇的最舊高優(yōu)先級請求返回數據。當不啟用高優(yōu)先級數據返回的支持時,請求跟蹤器處理準備好返回具有同一優(yōu)先級級別的讀取數據的所有記分板條目。在該模式中,僅低優(yōu)先級位向量被用作對最舊可用隊列的輸入,該輸入進而在記分板中確定最舊讀取請求。然后將用于被確定為最舊的記分板條目的讀取數據返回至請求代理??稍谠趯⒏鞣Nip集成到單個管芯上以經由存儲器結構將這些ip連接至存儲器的許多不同soc或者其他半導體器件中使用實施例。更進一步,根據本說明書的實施例的存儲器結構可被用來提供用于滿足這些ip中的至少一些的等時要求的qos級別。圖10是根據本說明書的一個或多個示例的soc的框圖。如圖10中所示,soc700是包括多個ip塊以及如上所述的共享存儲器仲裁器的單個管芯半導體器件。在圖10的實施例中,提供多個核心710-0—710-n,它們中的每一個都可以獨立地執(zhí)行指令。在一個實施例中,所有這些核心都具有單個設計(諸如有序核心設計),例如具有英特爾架構tm(諸如基于coretm的設計)。在其他實施例中,核心可以是無序處理器,諸如英特爾架構tm(ia)32核心,諸如英特爾基于coretm的設計。在其他實施例中,可提供異構核心的混合。此外,可提供多個圖形引擎(即獨立的圖形單元720-0—720-n),它們中的每一個獨立地執(zhí)行圖形操作。如所看到的,多個核心被耦合至共享高速緩存存儲器715(諸如2級(l2)高速緩存),并且類似地,圖形引擎被耦合至另一共享高速緩存存儲器725。系統(tǒng)代理730經由對應的管芯內互連728和729耦合至這些核心和圖形引擎。如所看到的,系統(tǒng)代理730包括共享存儲器結構735,其可如本文所描述的那樣來配置。各種其他邏輯、控制器和其他單元(諸如功率管理單元)也可存在于系統(tǒng)代理730內。如所看到的,共享存儲器結構735與存儲器控制器740通信,該存儲器控制器740進而耦合至片外存儲器(諸如被配置為dram的系統(tǒng)存儲器)。此外,系統(tǒng)代理730經由一組互連744耦合至一個或多個內部代理780(諸如各種外圍設備)。在一個實施例中,互連744可包括優(yōu)先級信道互連、邊帶信道互連和存儲器信道互連。類似配置的互連746提供系統(tǒng)代理730和一個或多個片外代理(在圖10的實施例中為了易于說明而沒有被示出)之間的通信。應該指出,圖10的框圖意圖是非限制性的,并且其他元件和修改可存在于各種實施例中。圖11是根據本說明書的一個或多個示例的存在于計算機系統(tǒng)中的部件的框圖。如圖11中所示,系統(tǒng)800可以包括許多不同部件。這些部件可以被實施為ic、其部分、分立電子設備、或適用于電路板(諸如計算機系統(tǒng)的母板或添加卡)的其他模塊,或者被實施為以其他方式并入計算機系統(tǒng)的機殼內的部件。還要指出,圖11的框圖意圖示出計算機系統(tǒng)的許多部件的高級視圖,然而,要理解的是,可在某些實現方式中存在附加部件并且此外可在其他示例實現方式中出現所示部件的不同布置。如圖11中所示,處理器810(其可以是低功率多核心處理器插座(諸如超低電壓處理器))可充當用于與系統(tǒng)的各種部件通信的主處理單元和中央中樞。此類處理器可以被實施為如本文所述的soc。在一個實施例中,處理器810可以是英特爾?架構基于coretm的處理器(諸如i3、i5、i7)或者可從加利福尼亞州圣克拉拉市英特爾公司得到的另一種此類處理器(諸如將一個或多個基于coretm的核心與一個或多個英特爾?基于atom?的核心組合以由此在單個soc中實現高功率和低功率核心的處理器)。然而,要理解,其他低功率處理器(諸如可從以下得到:加利福尼亞州森尼韋爾的高級微設備公司(amd)和來自arm控股有限公司的基于arm的設計或來自加利福尼亞州森尼韋爾的mips技術公司的基于mips的設計或其他被許可方或采用方)作為替代可存在于其他實施例中,諸如蘋果(apple)a5或a6處理器。在又一其他實施例中,處理器810可以是在虛擬機中實現為硬件和/或軟件的組合的虛擬處理器。處理器810可與系統(tǒng)存儲器815通信,該系統(tǒng)存儲器815在一個實施例中可以經由多個存儲器設備來實施以便提供給定量的系統(tǒng)存儲器。為了提供諸如數據、應用、一個或多個操作系統(tǒng)等等之類的信息的持久存儲,大容量存儲裝置820還可經由串行ata(sata)協(xié)議耦合至處理器810。在圖11中還示出,閃存設備822可例如經由串行外圍接口(spi)耦合至處理器810。該閃存設備可提供對系統(tǒng)軟件(包括基本輸入/輸出軟件(bios))以及系統(tǒng)的其他固件的非易失性存儲。各種輸入/輸出(對設備的各種輸入/輸出)設備可存在于系統(tǒng)800內。在圖11的實施例中具體示出顯示器824,其可以是在機殼的蓋部分內配置的高清晰度lcd或led面板。該顯示器面板還可提供觸摸屏825,例如在顯示器面板上外部適配以使得經由用戶與該觸摸屏的交互,用戶輸入可以被提供給系統(tǒng)以啟用例如關于信息的顯示、信息的訪問等等的期望操作。在一個實施例中,顯示器824可以經由顯示器互連被耦合至處理器810,該顯示器互連可以被實施為高性能圖形互連。觸摸屏825可經由另一互連被耦合至處理器810,在一個實施例中該另一互連可以是i2c互連。如圖11中進一步所示的,除了觸摸屏825結構,借助于觸摸,用戶輸入還可以經由觸摸板830來發(fā)生,該觸摸板830可被配置在機殼內并且還可被耦合至與觸摸屏825相同的i2c互連。為了感知計算和其他目的,各種傳感器可存在于系統(tǒng)中并且可以以不同方式被耦合至處理器810。某些慣性和環(huán)境傳感器可通過傳感器中樞840(例如經由i2c互連)耦合至處理器810。在圖11中示出的實施例中,這些傳感器可包括加速度計841、環(huán)境光傳感器(als)842、指南針843和陀螺儀844。其他環(huán)境傳感器可包括一個或多個熱傳感器846,其在一個實施例中可經由系統(tǒng)管理總線(smbus)總線耦合至處理器810。還在圖11中看到,各種外圍設備可經由低引腳數(lpc)互連耦合至處理器810。在所示的實施例中,各種部件可以通過嵌入式控制器835被耦合。此類部件可以包括(例如經由ps2接口耦合的)鍵盤836、風扇837、和熱傳感器839(例如,經由smbus接口耦合)。在一些實施例中,觸摸板830還可經由ps2接口耦合至ec835。此外,諸如根據2003年10月2日發(fā)布的可信計算組(tcg)tpm規(guī)范版本1.2的可信平臺模塊(tpm)838的安全性處理器也可經由該lpc互連耦合至處理器810。系統(tǒng)800可以以各種各樣的方式(包括無線地)與外部設備通信。在圖11中所示的實施例中,存在各種無線模塊,其中的每一個都可以對應于針對特定無線通信協(xié)議所配置的無線電設備。用于短程(諸如近場)中的無線通信的一種方式可以是經由近場通信(nfc)單元845,在一個實施例中其可經由smbus與處理器810通信。要指出,經由該nfc單元845,彼此緊密接近的設備可以通信。例如,用戶可以使系統(tǒng)800能夠通過將兩個設備緊密相關地適配在一起并且使得能夠實現諸如標識信息支付信息之類的信息、諸如圖像數據之類的數據等等的傳送來與另一(例如)便攜式設備(諸如用戶的智能電話)進行通信。還可使用nfc系統(tǒng)來執(zhí)行無線功率傳送。如在圖11中進一步看到的,附加無線單元可以包括其他短程無線引擎,包括wlan單元850和藍牙單元852。通過使用wlan單元850,可以實現根據給定電氣與電子工程師協(xié)會(ieee)802.11標準的wi-fitm通信,同時經由藍牙單元852,可以發(fā)生經由藍牙協(xié)議的短程通信。這些單元可經由例如usb鏈路或通用異步接收器發(fā)送器(uart)鏈路與處理器810通信?;蛘咂渌麊卧山浻苫ミB經由根據(2007年1月17日公布的)pci快速規(guī)范基礎規(guī)范版本3.0的外圍部件互連快速tm(pcietm)協(xié)議、或另一此類協(xié)議(諸如串行數據輸入/輸出(sdio)標準)耦合至處理器810。當然,這些外圍設備之間的實際物理連接(其可被配置在一個或多個附加卡上)可以借助于適合于母板的下一代形狀因子(ngff)連接器。此外,無線廣域通信(例如根據蜂窩協(xié)議或其他無線廣域協(xié)議)可以經由無線廣域網絡(wwan)單元856來發(fā)生,該無線廣域網絡(wwan)單元856進而可耦合至訂戶身份模塊(sim)857。此外,為了能夠實現位置信息的接收和使用,還可存在gps模塊855。要指出,在圖11中示出的實施例中,wwan單元856和諸如相機模塊854的集成捕獲設備可經由給定usb協(xié)議(諸如usb2.0或3.0鏈路)或uart或i2c協(xié)議來通信。再次地,這些單元的實際物理連接可以經由將ngff添加卡適配至配置在母板上的ngff連接器。為了提供音頻輸入和輸出,可以經由數字信號處理器(dsp)860來實現音頻處理器,該數字信號處理器(dsp)860可經由高清晰度音頻(had)鏈路耦合至處理器810。類似地,dsp860可與集成編碼器/解碼器(codec)和放大器862通信,該放大器862進而可耦合至輸出揚聲器863,其可被實現于機殼內。類似地,放大器和codec862可以被耦合以從麥克風865接收音頻輸入,在一個實施例中該麥克風865可以經由雙陣列麥克風來實現,以提供高質量音頻輸入來使得能夠實現對系統(tǒng)內各種操作的語音激活控制。還要指出,可以將音頻輸出從放大器/codec862提供至耳機插孔864。圖12是在示例控制系統(tǒng)中現場使用的soc的框圖。然而,應該指出,僅作為非限制性示例來提供控制系統(tǒng)以及該特定控制系統(tǒng)。在圖12的示例中,soc1200包括多核心處理器,包括rt代理115-0和輔助代理115-1。rt代理115-0充當實時(等時)代理,而輔助代理115-1充當盡力而為代理。rt代理115-0和輔助代理115-1共享存儲器控制器170-0和存儲器控制器170-1,它們分別控制存儲器庫1220-0和1220-1。在某些示例中,存儲器庫1220-0和存儲器庫1220-1彼此完全獨立,并且可被交錯以使得偶數編號的存儲器地址通過存儲器控制器170-0到達庫1220-0,而奇數編號的存儲器位置被通過存儲器控制器170-1路由至存儲器庫1220-1。這僅作為示例來提供,并且其他存儲器配置和交錯方法是可用的。還應該指出,在該示例中,存儲器控制器170和存儲器庫1220被示為在單獨的存儲器總線上。這也作為非限制性示例來公開。在其他示例中,可使用其他存儲器架構,諸如共享總線或片上網絡。rt代理115-0可被配置成與用于控制被控設備1292的控制子系統(tǒng)1290接口連接。在一個實施例中,被控設備1292可以是任務關鍵或安全關鍵設備,作為非限制性示例諸如是制造機器人、壽命支持系統(tǒng)、環(huán)境控制系統(tǒng)、交通控制系統(tǒng)或線控(drive-by-wire)系統(tǒng)??刂谱酉到y(tǒng)1290向rt代理115-0提供控制被控設備1292所必要的所有軟件、固件和硬件。受控系統(tǒng)1290的要求可以是使得所保證的qos對于保持實時操作是必要的。然而,還可能期望的是提供輔助功能(諸如用戶接口),以使得用戶可以提供必要的輸入。輔助代理115-1還可提供諸如監(jiān)視和用戶反饋之類的功能。因此,期望設計soc1200以使得向rt代理115-0保證其對于實時功能而言的必要qos,但是不會完全獨占系統(tǒng)資源以使得輔助代理115-1不能執(zhí)行其功能,或反之亦然。為此,可提供具有使實時和輔助業(yè)務量分開的多個虛擬信道和相關聯(lián)優(yōu)先級方案的共享非核結構1230,以對實時業(yè)務量準予較高優(yōu)先級,同時為輔助代理115-1留下充足的帶寬以正確地起作用。在該示例中,rt代理115-0經由適當的裝置(諸如網絡接口、專用總線或其他鏈接)通信耦合至受控系統(tǒng)1290。在該圖中,rt代理115-0還經由共享非核結構1230通信耦合至rt外圍設備1210-0。在某些實施例中,為了簡化設計,共享非核結構1230可被提供為單個或多個模塊化ip塊。為了簡化附圖,以及為了說明許多不同樣式的互連是可能的,在這里沒有圖示rt外圍設備1210-0和控制子系統(tǒng)1290之間的物理或邏輯連接。但是這不意圖排除此類連接。在一些示例中,rt外圍設備1210-1可以是形成控制子系統(tǒng)1290的一部分的控制接口,或去往被控設備1292的物理和邏輯接口(在這種情況下可提供邏輯和/或物理連接)。在其他實施例中,rt外圍設備1210-0可提供其他實時功能,其可以或者可以不與被控設備1292直接邏輯相關。類似地,輔助代理115-1作為示例通信耦合至用戶接口1270或任何其他適當的輔助系統(tǒng)或子系統(tǒng)。類似于控制子系統(tǒng)1290,用戶接口1270可提供任何適當的軟件、固件和硬件的集合以用于提供用戶接口。輔助代理1150-1還經由共享非核結構1230通信耦合至輔助外圍設備1210-1。與實時外圍設備1210-0一樣,輔助外圍設備1210-1可以或不可以通信耦合至用戶接口1270。為了簡化繪圖,以及為了說明許多不同的連接選項是可能的,在該圖中沒有示出輔助外圍設備1210-1和用戶接口1270之間的物理或邏輯連接,但是在一些實施例中,可提供此類連接。在一個非限制性示例中,共享非核結構1230的所選元件包括共享i/o結構1232、共享存儲器結構100和系統(tǒng)代理730。共享i/o結構1232向外圍設備1210提供互連、調度和其他通信服務。在一個示例中,共享i/o結構1232基本上類似于共享存儲器結構100,包括實現與本說明書中描述的那些類似的優(yōu)先級方案。結合圖1-9更詳細地描述共享存儲器結構100。系統(tǒng)代理730包括控制器以向共享非核結構100提供智能,包括本文中所述的方法。在一個示例中,附加硬件、固件或軟件可包括為系統(tǒng)代理730提供指令以執(zhí)行本文所公開的功能的可執(zhí)行指令或微代碼。外圍設備1210、存儲器庫1220和經由非核結構1230連接至請求代理的任何類似設備可統(tǒng)稱為“數據終端”,從而指示它們最終將數據發(fā)送至代理115或從代理115接收數據。在一個示例中,共享非核結構1230僅包括一組物理總線、互連、寄存器和其他資源,其可以被實時代理115-0和輔助代理115-1(連同任何其他代理)用來通信耦合至外圍設備1210以及耦合至存儲器控制器170。因此,為了確保針對實時代理115-0的所保證的qos,可能需要共享互連資源1230來提供代理115、外圍設備1210和存儲器控制器170之間的優(yōu)先級方案。共享非核結構的某些實施例可采用在所有代理之間共享的僅一個虛擬信道。然而,本說明書還描述了一種提供多個虛擬信道以使得共享非核結構1230可以在用于實時代理115-0的業(yè)務量和用于輔助代理115-1的業(yè)務量之間進行辨別、分離和優(yōu)先化的方法。該分離可能是期望的,以使得在其必需的情況下來自實時代理115-0的業(yè)務量可接收優(yōu)先級(包括超過來自輔助代理115-1的業(yè)務量的搶先優(yōu)先級)。在一個示例中,定義兩個虛擬信道:即虛擬信道vc_aux1240和虛擬信道vc_rt1242。vc_aux1240可被提供用于盡力而為事務,而vc_rt1242被專用于實時或等時事務。業(yè)務模式可包括代理至外圍設備(經由共享i/o結構1232)、代理至存儲器(經由共享存儲器結構100)、外圍設備至代理(經由共享i/o結構1232)、外圍設備至存儲器(經由共享i/o結構1232和共享存儲器結構100)、以及存儲器至外圍設備(經由共享i/o結構1232和共享存儲器結構100)。可在一個示例中通過對用于源自于代理115的分組的資源代理進行解碼來完成劃分成虛擬信道。應該指出,在某些已知實施例中,為了路由目的,對每個分組的目的地進行解碼,并且每個分組的目的地可基于分組的屬性(諸如存儲器地址和/或操作碼)。在該示例中,仍可提供目的地解碼,并且目的地解碼可以是對源代理的解碼的附加。一旦源代理被解碼,就可向分組指派“業(yè)務量類”,其可具有對虛擬信道的一對一對應性。例如,業(yè)務量類0可對應于vc_aux,而業(yè)務量類1可對應于vc_rt。有利地,業(yè)務量類可被編碼為報頭中的字段或用于分組的元數據以使得諸如外圍設備1210之類的端點不需要知曉虛擬信道架構來保持端對端虛擬信道功能。這可保持舊有互操作性。在一個示例中,系統(tǒng)代理730可以向每個分組預加(prepend)報頭數據,從而標識分組要被在其上載送的虛擬信道或業(yè)務量類。根據本文所述的qos方案,某些虛擬信道可被給予某些優(yōu)先級權重。優(yōu)先級方案可包括為高優(yōu)先級業(yè)務量提供高“準予計數”數目和/或向vc_rt上的業(yè)務量指派到期的最后期限以加快該業(yè)務量。在源自于外圍設備1210的分組(諸如響應分組)的情況下,外圍設備1210可能不知曉虛擬信道結構。然而,良好配置的外圍設備1210應該回應(echoback)與其所響應于的分組相附接的業(yè)務量類字段。因此,舊有外圍設備1210可以能夠成功地將分組指引至其合適的虛擬信道,盡管在共享非核結構1230內多個虛擬信道的存在是不可知的。在源自于外圍設備1210并被指引至存儲器1220(而不是對代理115的響應)的分組的情況下,可基于外圍設備1210自身的性質來指派業(yè)務量類。例如,如果已知rt外圍設備1210通常被用于實時事務,則從rt外圍設備1210至存儲器1220的分組可被指引至vc_rt。類似地,源自于輔助外圍設備1210-1并被指引至存儲器1220的分組可被指引至vc_aux。在一個示例中,還可以例如根據每個分組的目的地將虛擬信道進一步細分。因此,例如,從實時代理115-0至任何存儲器控制器170的業(yè)務量可被給予非常高的優(yōu)先級或甚至搶先優(yōu)先級以保證qos。然而,從實時代理115-0至實時外圍設備1210-0的業(yè)務量可能是較不時間關鍵的。因此,該業(yè)務量可被指派稍稍更低(盡管可能仍被加快)的優(yōu)先級。在一個示例中,可基于哪個共享資源正被考慮來對vc_rt和vc_aux不同地進行優(yōu)先化。例如,從外圍設備至存儲器的vc_rt和vc_aux路徑可使用針對不同優(yōu)先化的最后期限,而核心和外圍設備之間的vc_rt和vc_aux路徑可使用準予計數。當然,這些配置僅作為非限制性示例來提供。本領域技術人員將根據特定實施例的設計約束來選擇合適的優(yōu)先級方案。圖13是根據本說明書的一個或多個示例的非核結構100的所選元件的框圖。在圖13的示例中,非核結構將某些功能劃分到多個流水線中,其中某些功能被劃分到針對每個流水線的“片段(slice)”中。作為圖示和示例,所公開的實施例具有兩個單獨的流水線,其中每個流水線包含請求跟蹤器(“t單元”)和調度器仲裁器(“b單元”)。在更一般的情況中,非核結構可以包含n個流水線,并且每個流水線可以包含任何適當功能塊的分立的片段。在一個示例中,為了保持舊有的互操作性并且使得系統(tǒng)設計者能夠使用“現成的”現有ip塊,非核結構100呈現出到請求代理115的僅單個單片電路接口。因此,設計者無需知曉或設計非核結構100的流水線。這可以簡化芯片設計,從而允許系統(tǒng)設計者將非核結構100看作“黑盒”。在圖13的示例中,請求方(其為代理115的示例)向非核結構100提供請求1302。請求1302可以例如是針對到存儲器位置或到存儲器映射的設備(諸如外圍設備)的讀取或寫入訪問的請求。非核結構100接收請求1302,并將請求1302提供給地址散列和選擇邏輯1320。在其中請求1302是存儲器請求的示例中,地址散列和選擇邏輯1320將地址散列化,例如以確定其是奇數還是偶數。在本文中,奇偶散列化被示為非限制性示例,而在一般情況中,可以使用確定性地導致將每個分組指派到n個流水線中的一個的任何適當的散列化算法。在一個實施例中散列化算法的確定性是重要的,因為流水線完全獨立于彼此進行操作,而不會進一步沿著流水線向下重新匯聚。而是,流水線0并且僅有流水線0能夠訪問(例如)偶數存儲器地址,而流水線1并且僅有流水線1能夠訪問奇數存儲器地址。因此,流水線不重新匯聚,直到存儲器訪問事件完成之后為止。在該示例中,它們在聚集器1350處重新匯聚。取決于地址散列和選擇邏輯1320的散列結果,選擇邏輯1320將請求1302提供給緩沖器01322-0或緩沖器11322-1中的一個。值得注意的是,在一個示例中,緩沖器01322-0和緩沖器11322-1在物理上分離并且在邏輯上不彼此耦合。換言之,當且僅當分組指向偶數存儲器位置時緩沖器01322-0才將接收該分組,而當且僅當分組指向奇數存儲器地址時緩沖器1才將接收該分組。在該示例中,緩沖器01322-0及其接著發(fā)生的流水線不具有處理奇數編號的地址的能力,而緩沖器11322-1及其接著發(fā)生的流水線不具有處理偶數編號的地址的能力。緩沖器1322和聚集器1350可以一起被配置成提供先入先出(fifo)存儲器隊列。在該情況下,信用返回可以組織來自兩個流水線的返回以確保它們以正確的順序出現。這給出了在存儲器結構中的單個接收fifo的顯現,其保持了存儲器結構的不同實現方式(其可以或可以不實現多個流水線)中的相同ip塊的“即插即用”能力。在一個示例中,請求跟蹤器1370、調度器仲裁器130、存儲器控制器170和存儲器庫1340從時鐘分頻器1380接收時鐘信號。時鐘分頻器1380可以例如接收用于非核結構100的子系統(tǒng)時鐘信號,并將頻率除以2以計及兩個流水線。在更一般的情況中,非核結構可以具有一種時鐘,該時鐘具有頻率f和周期t。從時鐘分頻器1380接收其時鐘的每個流水線化功能塊具有頻率f/n和周期nt。地址散列和選擇邏輯1320、緩沖器1322和準許仲裁器120全部都接收(頻率f的)未分頻的時鐘。聚集器/解聚集器1350和排序邏輯1330接收已分頻時鐘和未分頻時鐘兩者。在圖示出的實施例中,時鐘分頻器1380將一半的時鐘提供給每個流水線,使得每個流水線以用于非核結構100的基準時鐘信號的頻率的精確的1/2來操作。在該示例中,有效地對操作進行并行化,使得在理論上,可以在非核結構100的兩個時鐘周期中并行地處理兩個單獨的存儲器請求(一個偶數、一個奇數)。有利地,并行的請求處理可以有助于避免以全時鐘速度串行處理請求時可能出現的設計挑戰(zhàn)。然而,作為實際問題,存儲器訪問請求可能不以有序的奇偶序列到達。例如,在某些大型陣列運算中,陣列可能被構造成使得每個連續(xù)的存儲器訪問落在奇數或者偶數邊界上。因此,一個流水線可能被淹沒而另一個完全閑置。大型緩沖器減小了該顧慮。另一方面,大型緩沖器占據了附加的芯片有效面積(realestate)。因此,緩沖器1322的尺寸應被選為提供下述競爭目標之間的適當折衷:最小化由緩沖器1322所消耗的芯片有效面積,以及使得緩沖器1322足夠大以避免緩沖器中的一個或另一個頻繁被“榨干”(從而導致非核結構100時常在其最佳速度的僅一半下進行操作)的情況。使用流水線0作為示例,緩沖器01322-0接收到散列化為“偶數”的存儲器訪問請求。這被提供給流水線0,包括請求跟蹤器0140-0和仲裁器0130-0。這些執(zhí)行它們的預期功能,并最終將請求提供給存儲器控制器0170-0,其通信地耦合至存儲器庫01340-0。在該示例中,庫01340-0精確地包含soc1200的可用存儲器的一半。存儲器可以是交錯式的,使得在邏輯上庫01340-0包含全部偶數存儲器地址。包括請求跟蹤器1140-1、仲裁器1130-1和被耦合到庫11340-1的存儲器控制器1170-1的流水線1可以針對奇數地址執(zhí)行本質上相同的操作。值得注意的是,流水線0和流水線1在到達存儲器控制器170之前不會匯聚。而是,流水線0控制庫01340-0,而完全獨立于控制庫11340-1的流水線1。流水線在聚集器1350之前并不匯聚。聚集器1350對來自兩個流水線的存儲器值進行仲裁并將它們返回至請求核心。因此,地址散列和選擇邏輯1320和聚集器1350一起允許代理115將非核結構100視為具有單片數據接口的單片塊。在一個實施例中,每個流水線提供fifo,并且排序邏輯1330提供如下進行操作的信用返回機制:a.根據c2u請求,信用針對代理115的角度返回。b.仲裁器130可以僅在其在用于代理115的兩個每片段的fifo中都具有保證點時才通告一個信用。如下實現針對代理115的信用返回:i.在從片段fifo彈出之后,如果其具有最大的占用度(預彈出):如果彈出fifo比另一fifo具有更多的請求,那么其具有覆蓋信用環(huán)路的最小能力,因此必須返回信用。c.在推送到片段fifo中之后,如果其具有小于最大片段fifo占用度的占用度的話(預推送)。如果推送fifo具有比另一fifo更小的占用度,那么另一fifo具有覆蓋信用環(huán)路的最小能力,并且推送fifo可以立即將其信用返回至代理115。盡管已經關于有限數目的實施例描述了本發(fā)明,但是本領域技術人員將會從其認識到許多修改和變化。所意圖的是,所附權利要求覆蓋如落入該本發(fā)明的真實精神和范圍內的所有此類修改和變化。設計可經歷各個階段,從創(chuàng)建到模擬到制造。表示設計的數據可表示處于許多方式的設計。首先,如在模擬中有用的,可使用硬件描述語言(hdl)或另一功能描述語言來表示硬件。另外地,可在設計過程的某些階段產生具有邏輯和/或晶體管門的電路級模型。此外,在某些階段大多數設計達到表示硬件模型中的各種設備的物理放置的數據級。在使用常規(guī)半導體制造技術的情況下,表示硬件模型的數據可以是指定各種特征在針對用于產生集成電路的掩模的不同掩模層上的存在或不存在的數據。在一些實現中,基于軟件的硬件模型以及hdl和其他功能描述語言對象除了其他示例之外可包括寄存器傳遞語言(rtl)文件。此類對象可以是機器可解析的,以使得設計工具可以接受hdl對象(或模型),針對所描述硬件的屬性解析hdl對象,以及從對象確定物理電路和/或片上布局。設計工具的輸出可以被用來制造物理設備。例如,設計工具可以根據hdl對象確定各種硬件和/或固件元件的配置,除了將被實施以便實現以hdl對象建模的系統(tǒng)的其他屬性之外,hdl對象諸如是總線寬度、寄存器(包括尺寸和類型)、存儲器塊、物理鏈路路徑、結構拓撲。設計工具可以包括用于確定片上系統(tǒng)(soc)的拓撲和結構配置以及其他硬件設備的工具。在一些實例中,hdl對象可以被用作用于開發(fā)可以被制造設備用來制造所描述的硬件的模型和設計文件的基礎。的確,hdl對象自身可以被提供為對制造系統(tǒng)軟件的輸入以導致所描述的硬件。在設計的任何表示中,可以以任何形式的機器可讀介質來存儲數據。諸如盤之類的存儲器或者磁性或光學存儲裝置可以是機器可讀介質,以存儲經由光波或電波傳送的信息,該光波或電波被調制或以其他方式被生成以傳送此類信息。當指示或載送代碼或設計的電學載波被傳送時,在電信號的拷貝、緩沖或重傳被執(zhí)行的程度上,制作新的拷貝。因此,通信提供商或網絡提供商可將物品(諸如被編碼成載波的信息)至少暫時存儲在有形的機器可讀介質上,從而體現本公開的實施例的技術。如本文所使用的模塊指的是硬件、軟件和/或固件的任何組合。作為一個示例,模塊包括與非瞬時介質相關聯(lián)的硬件(諸如微控制器),以存儲被適配成要由微控制器執(zhí)行的代碼。因此,在一個實施例中,對模塊的引用指的是具體被配置成識別和/或執(zhí)行要被保持在非瞬時介質上的代碼的硬件。此外,在另一實施例中,模塊的使用指的是包括代碼的非瞬時介質,其被具體適配成要由微控制器來實行以執(zhí)行預定操作。并且如可以被推斷的,在又一實施例中,術語模塊(在該示例中)可指的是微控制器和非瞬時介質的組合。通常,被圖示為分離的模塊邊界一般會變化并且潛在地重疊。例如,第一和第二模塊可在潛在地保留某些獨立硬件、軟件或固件的同時共享硬件、軟件、固件或其組合。在一個實施例中,術語邏輯的使用包括硬件,諸如晶體管、寄存器或其他硬件(諸如可編程邏輯設備)。在一個實施例中,短語“用以”或“被配置成”的使用指的是布置、放在一起、制造、供應來銷售、引進和/或設計一種裝置、硬件、邏輯或元件來執(zhí)行指定任務或確定任務。在該示例中,如果未正在操作的裝置或其元件被設計、耦合和/或互連以執(zhí)行所述指定任務,則該裝置或其元件仍“被配置成”執(zhí)行所述指定任務。作為純粹說明性的示例,邏輯門可在操作期間提供0或1。但是“被配置成”向時鐘提供使能信號的邏輯門不包括可提供1或0的每個潛在邏輯門。而是,邏輯門是以在操作期間1或0輸出要啟用時鐘的某一方式耦合的一種邏輯門。再一次要指出,術語“被配置成”的使用不需要操作,而是作為代替著重于裝置、硬件和/或元件的潛在狀態(tài),在這種情況下在該潛在狀態(tài)中裝置、硬件和/或元件被設計成當該裝置、硬件和/或元件正在操作時執(zhí)行特定任務。此外,在一個實施例中,短語‘能夠/能夠用以’、和或‘可操作為’的使用指的是某種裝置、邏輯、硬件和/或元件以能夠實現該裝置、邏輯、硬件和/或元件以具體方式的使用的這種方式被設計。如上文指出的,在一個實施例中,“用以”、“能夠用以”或“可操作為”的使用指的是裝置、邏輯、硬件和/或元件的潛在狀態(tài),在這種情況下該裝置、邏輯、硬件和/或元件并沒有正在操作,而是以能夠實現裝置以具體方式的使用的這種方式被設計。如本文所使用的,值包括數字、狀態(tài)、邏輯型狀態(tài)或二進制邏輯型狀態(tài)的任何已知表示。通常,邏輯電平、邏輯值或邏輯學值的使用也指的是1和0,其僅表示二進制邏輯狀態(tài)。例如,1指的是高邏輯電平并且0指的是低邏輯電平。在一個實施例中,存儲單元(諸如晶體管或閃存單元)可以能夠保持單個邏輯值或多個邏輯值。然而,已經使用計算機系統(tǒng)中的值的其他表示。例如,十進制數10也可被表示為1010的二進制值以及十六進制字母a。因此,值包括能夠在計算機系統(tǒng)中保持的信息的任何表示。此外,狀態(tài)可以由值或值的部分來表示。作為一個示例,第一值(諸如邏輯一)可表示默認或初始狀態(tài),而第二值(諸如邏輯零)可表示非默認狀態(tài)。另外,在一個實施例中,術語重置和設置分別指的是默認和經更新的值或狀態(tài)。例如,默認值潛在地包括高邏輯值(即重置),而經更新的值潛在包括低邏輯值(即設置)。要指出,值的任何組合可被用來表示任何數目的狀態(tài)。上面闡述的方法、硬件、軟件、固件或代碼的實施例可經由存儲在可由處理元件執(zhí)行的機器可訪問介質、機器可讀介質、計算機可訪問介質或計算機可讀介質上的指令或代碼來實施。非瞬時機器可訪問/可讀介質包括提供(即存儲和/或傳送)處于由機器(諸如計算機或電子系統(tǒng))可讀的形式的信息的任何機構。例如,非瞬時機器可訪問介質包括隨機存取存儲器(ram)(諸如靜態(tài)ram(sram)或動態(tài)ram(dram));rom;磁或光學存儲介質;閃速存儲器設備;電存儲設備;光學存儲設備;聲學存儲設備;用于保持從瞬時(傳播的)信號(例如載波、紅外線信號、數字信號)接收的信息的其他形式的存儲設備;等等,它們將與可從其接收信息的非瞬時介質相區(qū)分。用于對邏輯編程以執(zhí)行本發(fā)明的實施例的指令可被存儲在系統(tǒng)的存儲器(諸如dram、高速緩存、閃速存儲器或其他存儲裝置)內。此外,可以經由網絡或借助于其他計算機可讀介質來分配該指令。因此,機器可讀介質可包括用于存儲或傳送以由機器(例如計算機)可讀的形式的信息的任何機構,但不限于軟盤、光盤、壓縮盤、只讀存儲器(cd-rom)、以及磁光盤、只讀存儲器(rom)、隨機存取存儲器(ram)、可擦除可編程只讀存儲器(eprom)、電可擦除可編程只讀存儲器(eeprom)、磁卡或光卡、閃速存儲器、或在通過因特網經由電、光、聲或其他形式的傳播信號(例如載波、紅外線信號、數字信號等等)的信息傳輸中使用的有形機器可讀存儲裝置。因此,計算機可讀介質包括適于存儲或傳送以由機器(例如計算機)可讀的形式的信息或電子指令的任何類型的有形機器可讀介質。以下示例涉及根據本說明書的實施例。一個或多個實施例可以提供方法、裝置、系統(tǒng)、機器可讀存儲裝置、機器可讀介質、基于硬件和/或軟件的邏輯,其用以提供一種結構,所述結構用以向請求代理提供資源訪問。所述結構包括n個并行流水線以及一個或多個功能塊。所述功能塊中的至少一個被劃分成n個流水線化的塊,并且所述流水線化的塊要獨立于彼此進行操作并且彼此被緊密地耦合。在至少一個示例中,n=2。在至少一個示例中,所述結構包括n個存儲器控制接口,其用以控制n個獨立的存儲器塊,其中每個存儲器控制接口要通信耦合到確切一個并行流水線。在至少一個示例中,提供多路分用器以從請求代理接收請求并且使其指向流水線。在至少一個示例中,提供聚集器來從每個流水線接收資源,并且使所述資源指向請求代理。在至少一個示例中,提供流水線跟蹤器來指示哪個流水線向請求代理提供資源。在至少一個示例中,所述流水線跟蹤器用以指示哪個流水線要從請求代理接收請求。在至少一個示例中,提供選擇邏輯來從請求代理接收存儲器訪問請求并且將所述請求確定性地指派到一個并行流水線。在至少一個示例中,所述結構要接收頻率f的時鐘,并且所述多個流水線化塊中的至少一個接收頻率f/n的時鐘。在至少一個示例中,所述結構包括非核結構。一個或多個實施例可以提供裝置、系統(tǒng)、機器可讀存儲裝置、機器可讀介質、基于硬件和/或軟件的邏輯以及方法以從請求代理接收存儲器訪問請求,并且使所述存儲器訪問請求指向共享存儲器結構的n個并行流水線中的一個的功能塊,所述n個并行流水線獨立于彼此且彼此緊密耦合。遍及該說明書對“一個實施例”或“實施例”的引用意指結合該實施例描述的特定特征、結構或特性被包括在本發(fā)明的至少一個實施例中。因此,短語“在一個實施例中”或“在實施例中”在遍及本說明書的各個位置中的出現不一定都指的是同一實施例。此外,在一個或多個實施例中可以以任何適當方式來組合特定特征、結構或特性。在前述說明書中,已經參考具體示例性實施例而給出詳細描述。然而,將明顯的是,可以在不偏離如所附權利要求中闡述的本發(fā)明的較廣闊精神和范圍的情況下對實施例做出各種修改和改變。相應地,要以說明性意義而非限制性意義來考慮說明書和附圖。此外,實施例以及其他示例性語言的前述使用不一定指的是相同的實施例或相同的示例,而是可指代不同且有區(qū)別的實施例,以及潛在相同的實施例。當前第1頁12
當前第1頁1 2 
網友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1