TWI603205B - Traffic control on an on-chip network - Google Patents

Traffic control on an on-chip network Download PDF

Info

Publication number
TWI603205B
TWI603205B TW101145909A TW101145909A TWI603205B TW I603205 B TWI603205 B TW I603205B TW 101145909 A TW101145909 A TW 101145909A TW 101145909 A TW101145909 A TW 101145909A TW I603205 B TWI603205 B TW I603205B
Authority
TW
Taiwan
Prior art keywords
packet
node
bit
network
determining
Prior art date
Application number
TW101145909A
Other languages
Chinese (zh)
Other versions
TW201342079A (en
Inventor
麥堤歐 蒙奇羅
賈維爾 卡瑞提羅卡薩度
安瑞科 赫雷羅阿貝拉納斯
塔那蘇 拉米雷斯
薩維爾 維拉
Original Assignee
英特爾股份有限公司
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 英特爾股份有限公司 filed Critical 英特爾股份有限公司
Publication of TW201342079A publication Critical patent/TW201342079A/en
Application granted granted Critical
Publication of TWI603205B publication Critical patent/TWI603205B/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/25Flow control; Congestion control with rate being modified by the source upon detecting a change of network conditions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/76Architectures of general purpose stored program computers
    • G06F15/78Architectures of general purpose stored program computers comprising a single central processing unit
    • G06F15/7807System on chip, i.e. computer system on a single chip; System in package, i.e. computer system on one or more chips in a single package
    • G06F15/7825Globally asynchronous, locally synchronous, e.g. network on chip
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/26Flow control; Congestion control using explicit feedback to the source, e.g. choke packets
    • H04L47/263Rate modification at the source after receiving feedback
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/30Flow control; Congestion control in combination with information about buffer occupancy at either end or at transit nodes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/10Packet switching elements characterised by the switching fabric construction
    • H04L49/109Integrated on microchip, e.g. switch-on-chip
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D30/00Reducing energy consumption in communication networks
    • Y02D30/50Reducing energy consumption in communication networks in wire-line communication networks, e.g. low power modes or reduced link rate

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computing Systems (AREA)
  • Microelectronics & Electronic Packaging (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Description

於晶載網路上之流量控制技術 Flow control technology on the crystal carrier network

本發明之實施例大致關於晶載網路上之流量,更特定地係關於控制晶載網路之流量。 Embodiments of the present invention generally relate to flow on a crystal-carrying network, and more particularly to controlling the flow of a crystal-carrying network.

發明背景 Background of the invention

一計算晶片上的元件可組織為節點的一晶載網路。舉例而言,多核心處理器可組織為核心的一晶載網路。高流量晶載網路(例如,由於突發流量)可導致效能降低、增加功率消耗、以及降低服務品質。 A component on a computing wafer can be organized into a network of nodes. For example, a multi-core processor can be organized as a core carrier network. High-flow crystalline network (eg, due to bursty traffic) can result in reduced performance, increased power consumption, and reduced quality of service.

依據本發明之一實施例,係特地提出一種控制於晶載網路上的流量之方法,該方法包含下列步驟:藉由耦接至該晶載網路的一第一節點,以一第一速率注入一封包進入該晶載網路;於耦接至該晶載網路的一第二節點處接收該封包;響應於判定封包注入該晶載網路之一速率應該改變,而藉該第二節點調整該封包中的一位元;藉該 第二節點將帶有已調整位元之該封包回傳至該第一節點;以及響應於偵測到該封包中的該位元已受調整,而藉該第一節點改變該第一速率。 In accordance with an embodiment of the present invention, a method of controlling traffic on a crystal-borne network is provided, the method comprising the steps of: coupling to a first node of the on-board network at a first rate Injecting a packet into the crystal carrier network; receiving the packet at a second node coupled to the crystal carrier network; responsive to determining that the rate at which the packet is injected into the crystal carrier network should change, and borrowing the second The node adjusts one bit in the packet; The second node returns the packet with the adjusted bit to the first node; and in response to detecting that the bit in the packet has been adjusted, the first node changes the first rate.

101‧‧‧晶載網路/晶載網狀網路 101‧‧‧Crystal Network/Crystal Mesh Network

102a...102p‧‧‧互連節點 102a...102p‧‧‧Interconnecting nodes

102a‧‧‧來源節點 102a‧‧‧ source node

102b‧‧‧架構狀態暫存器 102b‧‧‧Architecture Status Register

102c‧‧‧節點 102c‧‧‧ nodes

1021‧‧‧目的節點 1021‧‧‧ destination node

104‧‧‧初始路徑 104‧‧‧Initial path

106‧‧‧替代路徑 106‧‧‧Alternative path

108‧‧‧路徑 108‧‧‧ Path

200‧‧‧封包 200‧‧‧Package

202‧‧‧數據 202‧‧‧ data

204‧‧‧控制資訊 204‧‧‧Control Information

206‧‧‧「偏向」位元 206‧‧‧" biased" bit

208‧‧‧「向下節流」位元 208‧‧‧"Down Throttling" bit

300‧‧‧方塊圖 300‧‧‧block diagram

301‧‧‧網路 301‧‧‧Network

302a-302p‧‧‧節點 302a-302p‧‧‧ nodes

302a‧‧‧來源節點 302a‧‧‧ source node

302b、302c、302d、302h‧‧‧中間節點 302b, 302c, 302d, 302h‧‧‧ intermediate nodes

3021‧‧‧目的節點 3021‧‧‧ destination node

304‧‧‧路徑 304‧‧‧ Path

306‧‧‧路徑 306‧‧‧ Path

404‧‧‧路徑 404‧‧‧ Path

406‧‧‧路徑 406‧‧‧ Path

500‧‧‧節點 500‧‧‧ nodes

502‧‧‧處理單元 502‧‧‧Processing unit

504‧‧‧邏輯 504‧‧‧Logic

506‧‧‧邏輯 506‧‧‧Logic

508‧‧‧開關邏輯 508‧‧‧Switching Logic

510‧‧‧邏輯 510‧‧‧Logic

512‧‧‧邏輯 512‧‧‧Logic

514‧‧‧緩衝器 514‧‧‧buffer

516‧‧‧暫存器 516‧‧‧ register

518‧‧‧邏輯 518‧‧‧Logic

600‧‧‧流程圖 600‧‧‧ Flowchart

604‧‧‧方塊 604‧‧‧ square

606‧‧‧方塊 606‧‧‧ square

608‧‧‧方塊 608‧‧‧ square

610‧‧‧方塊 610‧‧‧ square

612‧‧‧方塊 612‧‧‧ square

614‧‧‧方塊 614‧‧‧ square

700‧‧‧流程圖 700‧‧‧Flowchart

702‧‧‧方塊 702‧‧‧ square

704‧‧‧方塊 704‧‧‧ squares

706‧‧‧方塊 706‧‧‧ square

708‧‧‧方塊 708‧‧‧ square

710‧‧‧方塊 710‧‧‧ square

712‧‧‧方塊 712‧‧‧ square

802‧‧‧方塊 802‧‧‧ square

804‧‧‧方塊 804‧‧‧ square

806‧‧‧方塊 806‧‧‧ square

808‧‧‧方塊 808‧‧‧ square

900‧‧‧系統/流程圖 900‧‧‧System/Flowchart

910‧‧‧匯流排 910‧‧ ‧ busbar

920‧‧‧處理器 920‧‧‧ processor

921a...921n‧‧‧處理器核心 921a...921n‧‧‧ processor core

930‧‧‧記憶體 930‧‧‧ memory

936‧‧‧操作系統(OS) 936‧‧‧ Operating System (OS)

940‧‧‧輸入/輸出(I/O)介面 940‧‧‧Input/Output (I/O) interface

950‧‧‧網路介面 950‧‧‧Internet interface

960‧‧‧儲存裝置 960‧‧‧Storage device

970‧‧‧週邊介面 970‧‧‧ peripheral interface

以下的詳細說明包括了圖式的討論,圖式具有透過範例的方式而給定例示本發明的實施例之實施。圖式應被理解為範例的方式而並非限制的方式。如在此之使用,參照一或多個「實施例」可以理解為描述本發明至少一實施所包括之一特定特徵、結構或特性。因此,在此出現諸如「於一實施例中」的片語描述本發明的各種實施例以及實施,且不一定指相同實施例。然而,他們也不一定是互斥的。 The following detailed description includes the discussion of the drawings, which are given by way of example only. The drawings are to be understood as illustrative and not restrictive. The use of one or more "embodiments", as used herein, may be understood to describe one of the specific features, structures, or characteristics of the at least one embodiment of the invention. Therefore, various embodiments and implementations of the present invention are described herein, such as "in an embodiment", and are not necessarily referring to the same embodiments. However, they are not necessarily mutually exclusive.

圖1為顯示一晶載網路的一方塊圖,以及在該網路上之一封包所採取的一示範性路由,該晶載網路藉由將受偏向封包改道至其目的而實施偏向。 1 is a block diagram showing a crystal-carrying network and an exemplary route taken by a packet on the network that is biased by diverting the biased packet to its intended purpose.

圖2為帶有一「偏向」位元以及一「向下節流」位元的之一封包的一方塊圖,其係用於根據一實施例之用以控制一晶載網路流量的路由演算法。 2 is a block diagram of a packet with a "biased" bit and a "down-throttle" bit for routing calculus to control a crystal-carrying network traffic according to an embodiment. law.

圖3為一晶載網路的一方塊圖,顯示由一受偏向封包所採用的一示範性路徑,該偏向封包係藉由根據一實施例之目的節點返回來源節點。 3 is a block diagram of a crystal-carrying network showing an exemplary path employed by a biased packet that is returned to the source node by a destination node in accordance with an embodiment.

圖4為一晶載網路的方塊圖,顯示由一受偏向封包所採用的一示範性路徑,該偏向封包係藉由根據一 實施例的中間節點返回該來源節點。 4 is a block diagram of a crystal-carrying network showing an exemplary path employed by a biased packet, the biased packet being The intermediate node of the embodiment returns the source node.

圖5為耦接至根據一實施例的一晶載網路的一節點的一方塊圖。 5 is a block diagram of a node coupled to a crystal carrier network in accordance with an embodiment.

圖6為用以控制根據一實施例的一晶載網路之流量的一程序的一流程圖。 6 is a flow diagram of a process for controlling the flow of a crystal-carrying network in accordance with an embodiment.

圖7為用以處理根據一實施例之位於一中間節點或一目的節點的一封包之一程序的一流程圖。 7 is a flow diagram of a process for processing a packet located at an intermediate node or a destination node in accordance with an embodiment.

圖8為用以處理根據一實施例返回其來源節點的一封包之一程序的一流程圖。 8 is a flow diagram of a process for processing a packet returned to its source node in accordance with an embodiment.

圖9為帶有核心組織為一晶載網路的之一多核心處理器的一計算系統之一方快圖,其中本發明的實施例可被運作、執行、整合、及/或組配。 9 is a block diagram of a computing system with a multi-core processor having a core organization that is a crystalline network, wherein embodiments of the present invention can be operated, executed, integrated, and/or assembled.

以下特定細節的描述以及實施,包括圖式描述,其可描述若干或所有以下描述的實施例,以及討論其他本發明在此呈現概念之潛在的實施例或實施。以下提供本發明實施例的概述,隨即為參照圖式之更詳細的描述。 The following description of the specific details and the implementations, including the drawings, may be described in some or all of the embodiments described below, as well as other potential embodiments or implementations of the present invention. An overview of embodiments of the invention is provided below, which is followed by a more detailed description with reference to the drawings.

較佳實施例之詳細說明 Detailed description of the preferred embodiment

本發明的實施例提供用於控制在一晶載網路(例如,帶有核心組織為一晶載網路的多核心處理器)流量的一種方法、裝置以及系統。在一晶載網路上的流量可包含,例如,自一來源節點發送至目的節點的封包(例如,異動封包),若干封包係經由耦接至該晶載網路的中間節 點指引路徑。 Embodiments of the present invention provide a method, apparatus, and system for controlling traffic on a crystalline network (e.g., a multi-core processor with a core organization that is a crystalline network). Traffic on a carrier network may include, for example, packets sent from a source node to a destination node (e.g., a transaction packet), and a plurality of packets are coupled to a midsection of the carrier network. Point the path.

根據一實施例,在該晶載網路上的流量可藉由使用於該封包格式中的額外位元,以及待於耦接至該網路的節點上執行之路由演算法來控制或受影響。於一實施例中,額外位元以及路由演算法可使封包偏向回他們攜帶有關於封包注入速率資訊的來源節點。於一個此等實施例中,經由耦接至一網路的節點間的偏向封包的此等資訊交換,提供了用於在晶載網路上控制流量的一機制。 According to an embodiment, traffic on the on-chip network may be controlled or affected by additional bits used in the packet format and routing algorithms to be executed on nodes coupled to the network. In one embodiment, the extra bits and routing algorithms may cause the packets to be biased back to the source node they carry information about the packet injection rate. In one such embodiment, such information exchange via a biased packet between nodes coupled to a network provides a mechanism for controlling traffic on the on-board network.

晶載網路可以各種方式實施,包括,例如,基於路由網狀網路。一基於路由網狀網路為一種節點的網路,其中互連的節點傳遞封包至他們的目的。在一基於路由網狀網路中,每一節點與晶載網路上來自一節點至另一節點的每一封包(亦即,來自一來源節點至一目的節點)具有獨特識別資料。為了於傳遞封包中輔助,可在該目的節點及/或在該中間節點兩者處提供緩衝,以連同他們到目的節點的方式而儲存封包。若干緩衝網路實施可使用分數來通知發送者節點在中間及/或目的節點的緩衝空間何時為可用的。 The on-board network can be implemented in a variety of ways including, for example, a routing mesh network. A route-based mesh network is a network of nodes in which interconnected nodes pass packets to their destination. In a route-based mesh network, each node and each packet from one node to another on the crystal-carrying network (i.e., from a source node to a destination node) have unique identification data. In order to pass the assistance in the packet, a buffer may be provided at the destination node and/or at both of the intermediate nodes to store the packet in a manner along with their way to the destination node. Several buffer network implementations may use a score to inform the sender node when the buffer space in the middle and/or destination node is available.

雖然緩衝、基於路由網狀網路可具有可擴充性的好處,也可能有缺點。舉例而言,具有緩衝資源的晶載網狀網路可能需要有效的晶片面積以及功率。一種最小化緩衝資源的方式(且因而需要較少的晶片面積以及降低功率消耗),係為實施一種帶有偏向路由的網路。使用偏向路由的網路允許封包的「彈跳」(亦即,偏向),該封包 於目的節點及/或在中間節點被拒絕。封包可由於各種理由被拒絕,包括,例如,於一節點處用於處理傳入封包的資源不足。通常受偏向的封包可使用不同的通道改道以到達他們的目的。偏向路由可允許減少緩衝尺寸,但當若干封包將偏向而非緩衝時,也可能導致增加晶載網路的流量。 While buffered, route-based mesh networks can have the benefits of scalability, they can also have disadvantages. For example, a crystalline mesh network with buffer resources may require efficient die area and power. One way to minimize buffering resources (and thus requiring less die area and lower power consumption) is to implement a network with biased routing. The network using biased routing allows the "bounce" (ie, bias) of the packet, the packet The destination node and/or the intermediate node are rejected. Packets may be rejected for various reasons, including, for example, insufficient resources for processing incoming packets at a node. Usually biased packets can be diverted using different channels to reach their purpose. Bias routing allows for a reduction in buffer size, but may also increase the traffic of the crystal-carrying network when several packets are biased rather than buffered.

本發明的實施例包括用以降低在一般性緩衝基於路由網狀網路之彈跳流量的一種機制,該網路在終端及/或在中間路徑處使用偏向。於一實施例中,一或多個位元係被含括在該封包格式中,該封包格式致能偏向封包以指出一封包注入速率應該改變(例如,一「向下節流」位元),且偏向封包回傳至他們的來源節點。根據一實施例,一來源節點響應於偵測到在一回傳封包中設置的位元,而調整其封包注入速率。 Embodiments of the present invention include a mechanism to reduce the bounce traffic based on a routed mesh network in a general buffer that uses bias at the terminal and/or at the intermediate path. In one embodiment, one or more bits are included in the packet format, and the packet format is enabled to bias the packet to indicate that a packet injection rate should be changed (eg, a "down throttle" bit) And biased packets back to their source node. According to an embodiment, a source node adjusts its packet injection rate in response to detecting a bit set in a backhaul packet.

圖1為一方塊圖,顯示藉由路徑重建偏向封包至他們的目的而實施改道的一晶載網路,以及於該網路上之一封包採取的一示範性路徑。晶載網狀網路101包括互連節點102a至102p。在此範例中,來源節點102a注入一封包進入該晶載網狀網路101且其耦接至該網路;該封包的最終目標為一目的節點1021,其亦耦接至該晶載網路101。 1 is a block diagram showing an on-board network that performs redirection by path reconstruction bias packets to their purpose, and an exemplary path taken by a packet on the network. The on-chip mesh network 101 includes interconnect nodes 102a through 102p. In this example, the source node 102a injects a packet into the crystal mesh network 101 and is coupled to the network; the final destination of the packet is a destination node 1021, which is also coupled to the crystal network. 101.

最初地,該封包係順一初始路徑104(以實線表示)從該來源節點102a傳至該該目的節點1021。然而,在此範例中,該封包藉由一中間節點(例如,節點102c)偏 向。一但該封包受偏向,偏向路徑可能涉及調整該中間路徑的該路由演算法,因此無法在一初始路徑(例如路徑104)上定路徑的一封包,係以一替代路徑(例如,路徑106,其由虛線表示)定路徑。在此範例中,該封包係藉由該目的節點1021偏向第二次。在於目的節點1021處偏向之後,該封包可採取諸如路徑108(以點線表示)的一路徑回到該目的節點。 Initially, the packet is passed from the source node 102a to the destination node 1021 along an initial path 104 (shown in solid lines). However, in this example, the packet is biased by an intermediate node (eg, node 102c) to. Once the packet is biased, the biased path may involve adjusting the routing algorithm of the intermediate path, so that a packet of the path cannot be determined on an initial path (eg, path 104), with an alternate path (eg, path 106, It is indicated by a broken line). In this example, the packet is biased a second time by the destination node 1021. After the destination node 1021 is biased, the packet can take a path such as path 108 (indicated by dotted lines) back to the destination node.

圖2為用以與控制一晶載網路流量之路由演算法使用之帶有附加位元之封包的一實施例的方塊圖。在一實施例中,該封包200包括數據202、控制資訊204、「偏向」位元206以及一「向下節流」位元208。該控制資訊204可包括,例如,識別該封包200的資訊、該封包的來源節點,以及該封包的目的節點。於一實施例中,該控制資訊204更包括了識別該封包自該來源節點所採用的路徑之識別資訊。 2 is a block diagram of an embodiment of a packet with additional bits for use with a routing algorithm that controls the flow of an on-chip network. In one embodiment, the packet 200 includes data 202, control information 204, a "biased" bit 206, and a "down throttle" bit 208. The control information 204 can include, for example, information identifying the packet 200, a source node of the packet, and a destination node of the packet. In an embodiment, the control information 204 further includes identification information identifying a path taken by the packet from the source node.

於一實施例中,該「偏向」位元206藉一偏向節點(例如,圖1中的節點102c或節點1021)調整,以指出該封包200係受偏向。於一實施例中,若該偏向節點判定該注入流量應該降低,該「向下節流」位元208係藉由一偏向節點設定。根據一實施例,在藉一中間或目的節點偏向之後,該封包回傳至其來源節點(例如,圖1中的節點102a),而非改道至他們的目的節點。一但封包到達其來源節點,該來源節點根據該「向下節流」位元208而改變其封包注入速率。舉例而言,若該「向下節流」位元 208受設定,該來源節點可延遲重新發送封包200至該目的節點。 In one embodiment, the "biased" bit 206 is adjusted by a biasing node (eg, node 102c or node 1021 in FIG. 1) to indicate that the packet 200 is biased. In one embodiment, if the biasing node determines that the injection flow rate should be reduced, the "down throttle" bit 208 is set by a biasing node. According to an embodiment, after an intermediate or destination node is biased, the packet is passed back to its source node (e.g., node 102a in Figure 1) instead of being redirected to their destination node. Once the packet arrives at its source node, the source node changes its packet injection rate based on the "down throttle" bit 208. For example, if the "down throttle" bit 208 is set, the source node may delay resending the packet 200 to the destination node.

圖3為一晶載網路的一方塊圖,顯示由一偏向封包所採用的一示範性路由,該偏向封包係藉由目的節點回傳至來源節點。根據一實施例,節點302a至302p發送具有包括一「向下節流」位元以及一「偏向位元」(例如圖2中的封包200)之格式的封包。於一實施例中,將帶有一或多個受調整位元之一偏向節點回傳至其來源節點而傳遞資訊,可幫助控制在該晶載網路上的流量。 3 is a block diagram of a crystal-carrying network showing an exemplary route employed by a biased packet that is passed back to the source node by the destination node. In accordance with an embodiment, nodes 302a through 302p transmit packets having a format that includes a "down throttle" bit and a "bias bit" (e.g., packet 200 in FIG. 2). In one embodiment, passing back information to one of the one or more adjusted bit elements back to its source node can help control traffic on the crystal network.

舉例而言,於一實施例中,一來源節點302a注入一封包進入網路301,且該封包係經由中間節點302b、302c、302d、302h(藉路線304顯示,以一實線表示)路由至其目的節點3021。於目的節點3021處,該目的節點3021判定是否要偏向該封包。如以上所述,封包可受若干原因偏向,包括該目的節點3021在其緩衝器中具有不足的使用空間。 For example, in one embodiment, a source node 302a injects a packet into the network 301, and the packet is routed to the network via intermediate nodes 302b, 302c, 302d, 302h (shown by route 304, indicated by a solid line). Its destination node 3021. At the destination node 3021, the destination node 3021 determines if the packet is to be biased. As described above, the packet may be biased for a number of reasons, including the destination node 3021 having insufficient usage space in its buffer.

除了決定是否要偏向該封包外,於一實施例中,該目的節點3021判定是否應改變在該晶載網路上的一封包注入速率。舉例而言,於一實施例中,該目的節點3021判定是否該來源節點302注入封包的速率應該降低(亦即,向下節流)。封包注入速率是否應該改變的該判定可基於若干因素。於一實施例中,基於微架構事件及/或資源使用的監測之一演算法,可用來判定是否該目的節點為忙碌且需要此動作。舉例而言,當被拒絕的封包之數目 已經超過一閥值時,計數器(例如,抗飢餓計數器)可用來發訊。在另一個實施例中,是否要改變一封包注入速率之判定,係基於於該節點(例如,一緩衝器)當中一些資源的填充級數。 In addition to deciding whether or not to bias the packet, in an embodiment, the destination node 3021 determines if a packet injection rate on the crystal network should be changed. For example, in an embodiment, the destination node 3021 determines whether the rate at which the source node 302 injects the packet should be reduced (ie, throttled down). This determination of whether the packet injection rate should be changed may be based on several factors. In one embodiment, one of the monitoring algorithms based on micro-architecture events and/or resource usage can be used to determine if the destination node is busy and requires this action. For example, when the number of rejected packets When a threshold has been exceeded, a counter (eg, an anti-hunger counter) can be used to signal. In another embodiment, the determination of whether to change a packet injection rate is based on the number of levels of padding of some of the nodes (e.g., a buffer).

一但該目的節點3021判定一封包數入速率是否應該改變,該目的節點3021可調整在該封包中的一或多個位元以所欲封包注入速率改變來通訊。舉例而言,於一實施例中,該目的節點3021可在回傳至該來源節點302a之封包中設定一「向下節流」位元。於一實施例中,不管該封包是否偏向(例如,一個「偏向」位元),該目的節點3021可調整一或多個附加位元以通訊。在一個此等實施例中,該「偏向」位元可與其來源節點及/或其他節點通訊附加資訊。舉例而言,除了使用一「向下節流」位元,使用一個「偏向」位元提供關於封包受偏向但在此判定不需要向下節流之情況的資訊(且因此,該偏向節點不會設定一「向下節流」位元)。 Once the destination node 3021 determines whether a packet number ingress rate should be changed, the destination node 3021 can adjust one or more bits in the packet to communicate at a desired packet injection rate change. For example, in an embodiment, the destination node 3021 can set a "down throttle" bit in the packet sent back to the source node 302a. In one embodiment, the destination node 3021 can adjust one or more additional bits for communication regardless of whether the packet is biased (eg, a "biased" bit). In one such embodiment, the "biased" bit can communicate additional information with its source node and/or other nodes. For example, in addition to using a "down-throttle" bit, a "biased" bit is used to provide information about the case where the packet is biased but the decision does not require a downward throttling (and therefore, the biasing node does not A "down throttle" bit will be set).

在圖3的範例中,該目的節點3021偏向該封包。於一實施例中,該偏向封包沒有受路由回到該目的節點3021(如參照至相對圖1的偏向封包),該封包係回傳至其來源節點302a。該偏向封包之路由回其來源節點302a,係由路徑306所顯示(由虛線表示)。 In the example of FIG. 3, the destination node 3021 is biased toward the packet. In one embodiment, the biased packet is not routed back to the destination node 3021 (as described with respect to the biased packet of FIG. 1), and the packet is passed back to its source node 302a. The route of the biased packet back to its source node 302a is shown by path 306 (indicated by the dashed line).

於一實施例中,一旦該來源節點302a接收了該偏向封包,該來源節點根據於該偏向封包中的資訊(例如,該「向下節流」位元),來調整其封包注入速率,且 重新發送該封包至該目的節點3021。調整該來源節點的封包注入速率可包括,例如,在重送該封包前等待若干週期。 In an embodiment, once the source node 302a receives the biased packet, the source node adjusts its packet injection rate according to information in the biased packet (eg, the "down-throttle" bit), and The packet is resent to the destination node 3021. Adjusting the packet injection rate of the source node may include, for example, waiting for several cycles before resending the packet.

根據一實施例,藉由在該來源節點302a與該目的節點3021之間產生此通訊回路,可使該目的節點3021附加額外資訊至該回傳封包(例如,向下節流發送者之封包注入速率的一請求),且降低於該晶載網路上之高比率偏向。 According to an embodiment, by generating the communication loop between the source node 302a and the destination node 3021, the destination node 3021 can add additional information to the backhaul packet (eg, packet injection to the downstream throttle sender). A request for rate) and a decrease in the high ratio bias on the on-chip network.

圖4為一晶載網路的一實施例之方塊圖,顯示由一偏向封包所採用的一示範性路由,該偏向封包係藉由一中間節點回傳至該來源節點。 4 is a block diagram of an embodiment of a crystal-carrying network showing an exemplary route employed by a biased packet that is transmitted back to the source node by an intermediate node.

類似於圖3所例示的實施例,一來源節點302a注入一封包進入該網路301鎖定目的節點3021(如路徑404所指示,以至該目的節點3021的一實線表示)。然而,在此實施例中,一中間節點302c將該封包偏向回到該來源節點302a(由路徑406所指示,以虛線表示)。 Similar to the embodiment illustrated in FIG. 3, a source node 302a injects a packet into the network 301 to lock the destination node 3021 (as indicated by path 404 to a solid line representation of the destination node 3021). However, in this embodiment, an intermediate node 302c biases the packet back to the source node 302a (indicated by path 406, indicated by the dashed line).

在一此等實施例中,該中間偏向節點判定是否偏向該封包,以及是否一封包注入速率(例如,該來源節點的封包注入速率)應該改變。類似於參照圖3所描述藉目的節點3021的判定,一中間節點302c可調整該封包中的一或多個位元(例如,用以指示該來源節點302a應受「向下節流」),且使用同樣的演算法以發送該封包回到該來源節點302a。於一實施例中,在該等中間節點處使用偏向,該實施包括用於避免「巢狀回彈」的機制。舉例 而言,此等機制可包括用以確保當一目的節點已將一封包偏向,該封包不會在一中間節點處再次偏向的邏輯。如上所述參照圖2,透過在該封包中一「偏向位元」的使用,為一種完成此機制的方式。 In one such embodiment, the intermediate biasing node determines whether the packet is biased toward the packet and whether a packet injection rate (e.g., the packet injection rate of the source node) should change. Similar to the determination of the destination node 3021 described with reference to FIG. 3, an intermediate node 302c may adjust one or more bits in the packet (eg, to indicate that the source node 302a should be "down-throttled"). And the same algorithm is used to send the packet back to the source node 302a. In one embodiment, a bias is used at the intermediate nodes, the implementation including a mechanism for avoiding "nested rebound." Example In this regard, such mechanisms may include logic to ensure that when a destination node has biased a packet, the packet will not be biased again at an intermediate node. Referring to Figure 2 as described above, the use of a "biased bit" in the packet is a way of accomplishing this mechanism.

例示於圖1、3及4中的該晶載網路為示範性的,且並非意欲作為限制。本發明的實施例可應用至晶載網路的其他組態。 The crystal-carrying network illustrated in Figures 1, 3 and 4 is exemplary and is not intended to be limiting. Embodiments of the invention are applicable to other configurations of the on-board network.

圖5為在一晶載網路上的一節點的一實施例之一方塊圖。於一實施例中,節點500為一多核心處理器的一核心,且包括了用於執行指令的處理單元502。於一實施例中,節點500更包括用以接收封包的邏輯504、用以發送封包的邏輯506(亦即,注入封包進入該網路)、用於判定一已接收封包目的之開關邏輯508、用以判定是否一封包注入速率應該改變的邏輯510、用以執行組態改變的邏輯512、用以持有封包的緩衝器514、以及暫存器516。暫存器516可包括獨特地識別節點500的資訊,及/或諸如該節點的封包注入速率的控制資訊。 Figure 5 is a block diagram of an embodiment of a node on a crystalline network. In one embodiment, node 500 is a core of a multi-core processor and includes processing unit 502 for executing instructions. In an embodiment, the node 500 further includes logic 504 for receiving a packet, logic 506 for transmitting a packet (that is, injecting a packet into the network), and switch logic 508 for determining a received packet. Logic 510 to determine if a packet injection rate should be changed, logic 512 to perform configuration changes, buffer 514 to hold the packet, and register 516. The register 516 can include information that uniquely identifies the node 500, and/or control information such as the packet injection rate of the node.

根據一實施例,用以接收封包之邏輯504可包括用以判定是否一已接收封包應該偏向的邏輯518,且該開關邏輯508包括用以判定一封包將受所偏向的一路徑的邏輯。於一實施例中,開關邏輯508根據一特定的策略來判定一偏向封包的路徑。舉例而言,一偏向封包可經由一預定義路徑(例如,其到達該偏向節點的同樣路徑)發送,或者透過使用一不同路徑演算法(例如,藉由使用諸 如壅塞的全面性考量)的一不同路徑。根據一實施例,一偏向封包的路徑係根據諸如循環(round-robin)或者隨機之策略所選定。一循環策略可包含根據一順序(每次一個通道受選定,下一個順序中的通道受選定)來選定下一個通道。在於一目的節點處偏向的狀況下,於一實施例中,用以選擇該偏向封包的路徑之一演算法,選擇一路徑以避免在該目的節點附近壅塞(例如,避免在目的節點附近緊密的迴圈)。 According to an embodiment, the logic 504 for receiving packets may include logic 518 to determine if a received packet should be biased, and the switch logic 508 includes logic to determine that a packet is subject to a biased path. In one embodiment, the switch logic 508 determines a path to the packet based on a particular policy. For example, a biased packet may be sent via a predefined path (eg, the same path that it reaches the biasing node), or by using a different path algorithm (eg, by using A different path, such as the comprehensive consideration of congestion. According to an embodiment, a path to the packet is selected according to a strategy such as round-robin or random. A looping strategy can include selecting the next channel according to an order (one channel at a time is selected and the channel in the next sequence is selected). In the case where a destination node is biased, in one embodiment, one of the paths for selecting the biased packet is algorithmic, and a path is selected to avoid congestion near the destination node (eg, avoiding close proximity near the destination node). Loop).

在發送待偏向之一封包前,邏輯510判定是否應該改變一封包注入速率。舉例而言,根據一實施例,邏輯510判定是否該偏向封包的來源節點之封包注入速率應該向下節流。若邏輯510判定一封包注入速率應該改變,在該封包中的一或多個位元係受調整,以將該判定傳達至另一節點(例如,該來源節點)。 Before sending a packet to be biased, logic 510 determines if a packet injection rate should be changed. For example, according to an embodiment, logic 510 determines if the packet injection rate of the source node of the biased packet should be throttled down. If logic 510 determines that a packet injection rate should change, one or more of the bits in the packet are adjusted to communicate the decision to another node (e.g., the source node).

圖6為用於控制一晶載網路流量的一實施例之一流程圖600。根據一實施例,於方塊604處,一封包藉由一第一節點以一第一速率注入該晶載網路。在該封包源自於該第一節點的狀況下,該第一節點為該封包的來源節點。在方塊606處,該封包藉由一第二節點所接收,其可為該封包的目的節點或一中間節點。在方塊608處,該第二節點判定是否該封包注入速率應該改變(例如,判定是否該封包的來源節點應該向下節流)。於一實施例中,是否一封包注入速率應該改變的該判定,僅在該節點判定該封包將受偏向之後發生。 6 is a flow chart 600 of an embodiment for controlling the flow of a crystal on-board network. According to an embodiment, at block 604, a packet is injected into the crystal-carrying network at a first rate by a first node. In the case where the packet originates from the first node, the first node is a source node of the packet. At block 606, the packet is received by a second node, which may be the destination node or an intermediate node of the packet. At block 608, the second node determines if the packet injection rate should change (eg, determines if the source node of the packet should throttle down). In one embodiment, the determination as to whether a packet injection rate should be changed occurs only after the node determines that the packet will be biased.

在方塊610處,該第二節點調整在該封包中的一位元,以指出一封包注入速率應該改變。舉例而言,該第二節點可在該封包中設定一位元,以指出該第二節點為忙碌且流量應該向下節流。 At block 610, the second node adjusts a bit in the packet to indicate that a packet injection rate should change. For example, the second node can set a bit in the packet to indicate that the second node is busy and traffic should be throttled down.

在方塊612處,該第二節點將該封包回傳至其來源節點(亦即,該第一節點)。該封包可使用根據一特定策略所判定(例如,該封包自該第一節點至該第二節點所採用的路徑,或回到該第一節點的一隨機路徑)的路徑而回傳。 At block 612, the second node passes the packet back to its source node (i.e., the first node). The packet may be returned using a path determined according to a particular policy (e.g., the path taken by the packet from the first node to the second node, or back to a random path of the first node).

在方塊614處,該第一節點響應於偵測到該封包中的該位元係受調整,而改變該第一速率(例如,該第一節點的封包注入速率)。舉例而言,該來源節點可降低其封包注入速率及/或延遲重送該偏向封包至其目的。於一實施例中,在流程圖600中所描述的方法提供了一種手段,透過該手段,藉由改變該第一節點的封包注入速率,該晶載網路上的流量可受控制。 At block 614, the first node changes the first rate (eg, the packet injection rate of the first node) in response to detecting that the bit in the packet is adjusted. For example, the source node may reduce its packet injection rate and/or delay resending the biased packet to its purpose. In one embodiment, the method described in flowchart 600 provides a means by which traffic on the on-board network can be controlled by varying the packet injection rate of the first node.

圖7為用於處理在一中間或目的節點處的一封包的一程序之一實施例的一流程圖。流程圖700自方塊702開始,在此一封包到達一中間或目的節點。在判定方塊704處,該節點判定是否要偏向該封包。若該封包未受偏向,該封包係於方塊706處的該節點處理。處理該封包可包括,例如,判定該封包的目的為另一節點,且轉發該封包至此節點,或者判定該封包的目的已經到達。若該封包的目的已經到達,該節點可接著根據該封包的內容來執 行指令。 7 is a flow diagram of one embodiment of a process for processing a packet at an intermediate or destination node. Flowchart 700 begins at block 702 where a packet arrives at an intermediate or destination node. At decision block 704, the node determines if the packet is to be biased. If the packet is not biased, the packet is processed by the node at block 706. Processing the packet may include, for example, determining that the packet is destined for another node, and forwarding the packet to the node, or determining that the purpose of the packet has arrived. If the purpose of the packet has arrived, the node can then proceed according to the content of the packet. Line instructions.

若該封包為待偏向,該節點亦可判定是否一封包注入速率應該改變。舉例而言,於一實施例中,該節點於判定方塊708處判定是否抗飢餓計數器超過一預設閥值。若該抗飢餓計數器超過該預設閥值,於方塊710處設定一「向下節流」位元,且該封包於方塊712處被送回其來源節點。根據一實施例,若該計數器未超過該閥值,該封包被送回其來源,而沒有於方塊712處在該封包中設定「向下節流」位元。 If the packet is to be biased, the node can also determine whether a packet injection rate should be changed. For example, in one embodiment, the node determines at decision block 708 whether the anti-starvation counter exceeds a predetermined threshold. If the anti-starvation counter exceeds the predetermined threshold, a "down throttle" bit is set at block 710 and the packet is sent back to its source node at block 712. According to an embodiment, if the counter does not exceed the threshold, the packet is sent back to its source without setting a "down throttle" bit in the packet at block 712.

圖8用於處理回傳至其來源節點(例如,如圖7的方塊712)的一封包之流程的一實施例的一流程圖。流程圖900於方塊802處開始,在此一封包到達其來源節點(亦即,該封包起源的該節點)。於判定方塊804處,該來源節點檢查在該封包中是否設定一「向下節流」位元。若該「向下節流」位元位已設定,該來源節點於方塊806處調整其封包注入策略,且接著根據其策略於方塊808處重新發送該封包。可使用不同的封包注入速率策略,以判定何時重發封包。舉例而言,該封包可立即地重發或者在若干時間延遲之後重發。 8 is a flow diagram of an embodiment of a process for processing a packet back to its source node (e.g., block 712 of FIG. 7). Flowchart 900 begins at block 802 where a packet arrives at its source node (i.e., the node from which the packet originated). At decision block 804, the source node checks if a "down throttle" bit is set in the packet. If the "down throttle" bit bit has been set, the source node adjusts its packet injection policy at block 806 and then resends the packet at block 808 according to its policy. Different packet injection rate policies can be used to determine when to resend the packet. For example, the packet can be retransmitted immediately or retransmitted after a number of time delays.

圖9為帶有核心組織為一晶載網路之多核心處理器的一電腦系統的一實施例的一方塊圖,其中本發明的實施例可操作、執行、整合及/或組配。系統900表示一計算裝置,且可為一膝上型電腦、一桌上型電腦、一伺服器、一徑賽或娛樂控制系統、一掃描器、一複印機、印 表機、一平板電腦或其他電子裝置。系統900包括處理器920,其提供對系統900的處理、運作管理以及指令的執行。處理器920可包括任何種類具有多處理器核心921a至921n的處理器硬體,以提供對系統900的處理。處理器核心921a至921n係組織為一互連晶載網路(例如,如一晶載基於路由網狀網路)。處理器921a至921n包括用以致能封包回到該封包來源節點的偏向與路由的邏輯,以降低回彈流量(亦即,偏向導致的流量)。如以上所描述,本發明的實施例可經由硬體、韌體及/或軟體在系統900中實施。 9 is a block diagram of an embodiment of a computer system with a multi-core processor having a core organization of a crystal-borne network, wherein embodiments of the present invention are operable, executed, integrated, and/or assembled. System 900 represents a computing device and can be a laptop computer, a desktop computer, a server, a track or entertainment control system, a scanner, a copy machine, a printer A watch, a tablet, or other electronic device. System 900 includes a processor 920 that provides processing, operational management, and execution of instructions for system 900. Processor 920 can include any type of processor hardware having multi-processor cores 921a through 921n to provide processing to system 900. Processor cores 921a through 921n are organized as an interconnected on-board network (e.g., as a crystal-based routing mesh network). The processors 921a through 921n include logic to enable the packet to be forwarded back to the packet source node to reduce the rebound traffic (i.e., the traffic caused by the bias). As described above, embodiments of the invention may be implemented in system 900 via hardware, firmware, and/or software.

記憶體930表示系統900的主記憶體,且提供以暫時儲存待由處理器920執行的碼,或者待於執行一路由時使用的數據數值。記憶體930可包括一或多個記憶體裝置,諸如僅讀記憶體(ROM)、快閃記憶體、一或多個種類的隨機存取記憶體(RAM)、或其他記憶體裝置、或此等裝置的一組合。記憶體930於其他物品之間儲存且作為主機,操作系統(OS)936用以提供用於在系統900中指令的執行之一軟體平台。OS936由處理器920所執行。 Memory 930 represents the main memory of system 900 and is provided to temporarily store the code to be executed by processor 920, or the value of the data to be used in performing a route. Memory 930 can include one or more memory devices, such as read only memory (ROM), flash memory, one or more types of random access memory (RAM), or other memory devices, or A combination of devices. Memory 930 is stored between other items and acts as a host, and operating system (OS) 936 is used to provide a software platform for execution of instructions in system 900. OS 936 is executed by processor 920.

處理器920與記憶體930係耦接至匯流排/匯流排系統910。匯流排910為一摘要,其表示任何一或多個分離的實體匯流排、通訊線路/介面,及/或點對點連接、藉由洽當橋接連接、轉接器、及/或控制器。因此,匯流排910可包括,例如一或多個系統匯流排、一週邊組件互連(PCI)匯流排、一超傳輸或工業標準架構(ISA) 匯流排,一小型電腦系統介面(SCSI)匯流排、一通用串列匯流排(USB)、或電子電機工程學會(IEEE)標準1394匯流排(通常被稱為「火線」)。匯流排910的該等匯流排亦可對應至網路介面950中的介面。 The processor 920 and the memory 930 are coupled to the bus/bus system 910. Bus 910 is a summary that represents any one or more separate physical busses, communication lines/interfaces, and/or point-to-point connections, by way of a bridge connection, an adapter, and/or a controller. Thus, bus 910 can include, for example, one or more system busses, a peripheral component interconnect (PCI) bus, an ultra-transmission or industry standard architecture (ISA). Busbars, a small computer system interface (SCSI) bus, a universal serial bus (USB), or the Institute of Electrical and Electronics Engineering (IEEE) standard 1394 bus (commonly referred to as "FireWire"). The bus bars of bus 910 may also correspond to interfaces in network interface 950.

於一實施例中,匯流排910包括一數據匯流排,處理器930可透過其自記憶體930讀取數值。顯示連接處理器920至記憶體子系統930的附加線,表示一命令匯流排,處理器920透過其提供指令與位址以存取記憶體930。 In one embodiment, the bus 910 includes a data bus through which the processor 930 can read values from the memory 930. An additional line connecting processor 920 to memory subsystem 930 is shown, representing a command bus through which processor 920 provides instructions and addresses to access memory 930.

系統900亦可包括一或多個輸入/輸出(I/O)介面940、網路介面950、一或多個內部大量儲存裝置960以及耦接至匯流排910的週邊介面970。I/O介面940可包括一或多個介面組件,使用者透過其與系統900互動(例如,視訊、音訊及/或文數字介接)。網路介面950提供系統900透過一或多個網路,與遠程裝置(例如,伺服器,其他計算裝置)通訊的能力。網路介面950可包括一乙太網路轉接器、無線互連組件、USB(通用串列匯流排)或其他基於標準之有線或無線或專屬介面。 System 900 can also include one or more input/output (I/O) interfaces 940, a network interface 950, one or more internal mass storage devices 960, and a peripheral interface 970 coupled to bus bar 910. The I/O interface 940 can include one or more interface components through which the user interacts with the system 900 (eg, video, audio, and/or textual interfacing). Network interface 950 provides the ability of system 900 to communicate with remote devices (e.g., servers, other computing devices) over one or more networks. The network interface 950 can include an Ethernet adapter, a wireless interconnect component, a USB (Universal Serial Bus), or other standards-based wired or wireless or proprietary interface.

儲存裝置960可為或包括用以在一非依電性方式儲存數據的任何傳統媒體,諸如一或多個磁性、固態、或光學基底的硬碟,或一組合。儲存裝置960可持有碼或指令以及在恆久狀態內的數據(亦即,不管對系統900的電力中斷,該數據係為維持)。儲存裝置960可包括一非過度性機器可讀或電腦可讀儲存媒體,在其上儲存有實 施任何一或多個在此描述的方法論或功能的指令(例如,軟體及/或韌體)。 Storage device 960 can be or include any conventional medium for storing data in a non-electrical manner, such as one or more hard disks of magnetic, solid state, or optical substrates, or a combination. Storage device 960 can hold code or instructions and data in a persistent state (i.e., the data is maintained regardless of power interruption to system 900). The storage device 960 can include a non-transitory machine readable or computer readable storage medium having stored thereon Any one or more of the methods or functional instructions (eg, software and/or firmware) described herein.

週邊介面970可包括任何沒有特別地在以上提及的硬體介面。週邊一般是指相依地連接至系統900的裝置。一相依連接為一個在系統900提供軟體及/或硬體平台處,在該平台上執行操作,且以該平台與一使用者互動。 Peripheral interface 970 can include any hardware interface not specifically mentioned above. Peripheral generally refers to a device that is connected to system 900 in a dependent manner. A dependent connection is one in which the system 900 provides a software and/or hardware platform on which operations are performed and with which a user interacts.

除了在此所描述者,可對本發明所揭露的實施例以及實施,在不脫離本發明的範圍之中達成各種改變。因此,在此所例示者以及範例應被解是為一例示性而非依限制性的意義。任何揭露的實施例可單獨使用、或連同另一者以任何組合使用。雖然各種實施例已經部分地由傳統技術以及途徑的缺失所引發動機,若干實施例在說明書內描述或暗示,該等實施例不必要處理或解決任何該等缺點,而是可以僅處理某些缺點,處理沒有該等缺點之處,或是朝向沒有直接地被討論的不同缺點以及問題。本發明的範圍應單獨地參照以下的申請專利範圍來量測。 Various modifications may be made to the embodiments and implementations of the invention disclosed herein without departing from the scope of the invention. Therefore, the exemplified and exemplary embodiments are to be construed as illustrative and not restrictive. Any disclosed embodiments can be used alone or in any combination with the other. While the various embodiments have been shown in part by the deficiencies of conventional techniques and approaches, several embodiments are described or suggested in the specification that the embodiments do not necessarily address or resolve any such disadvantages, but may only address certain disadvantages. , dealing with no such shortcomings, or facing different shortcomings and problems that are not directly discussed. The scope of the invention should be measured by reference to the following claims.

300‧‧‧方塊圖 300‧‧‧block diagram

301‧‧‧網路 301‧‧‧Network

302a-302p‧‧‧節點 302a-302p‧‧‧ nodes

302a‧‧‧來源節點 302a‧‧‧ source node

302b、302c、302d、302h‧‧‧中間節點 302b, 302c, 302d, 302h‧‧‧ intermediate nodes

3021‧‧‧目的節點 3021‧‧‧ destination node

304‧‧‧路徑 304‧‧‧ Path

306‧‧‧路徑 306‧‧‧ Path

Claims (30)

一種控制於晶載網路上的流量之方法,該方法包含下列步驟:藉由耦接至該晶載網路的第一節點,以第一速率將封包注入該晶載網路;於耦接至該晶載網路的第二節點處接收該封包;判定該已接收之封包係將被偏向(deflect)且不藉該第二節點緩衝;響應於判定封包注入該晶載網路之速率應該改變,而藉該第二節點調整該已接收之封包中的第一位元及該已接收之封包中不同於該第一位元的第二位元,以指示該已接收之封包係已偏向;藉該第二節點將帶有已調整的該第一位元與該第二位元之該封包回傳至該第一節點;以及響應於偵測到該封包中的該第一位元與該第二位元已受調整,而藉該第一節點改變該第一速率。 A method of controlling traffic on a crystal carrier network, the method comprising the steps of: injecting a packet into the crystal carrier network at a first rate by being coupled to a first node of the crystal carrier network; Receiving the packet at the second node of the crystal carrier network; determining that the received packet is deflected and not buffered by the second node; the rate of injecting the packet into the crystal network should be changed in response to determining that the packet is injected And the second node adjusts the first bit in the received packet and the second bit in the received packet different from the first bit to indicate that the received packet is biased; Passing, by the second node, the packet with the adjusted first bit and the second bit back to the first node; and in response to detecting the first bit in the packet and the The second bit has been adjusted, and the first node is changed by the first node. 如申請專利範圍第1項之方法,其中藉該第二節點判定將封包注入該晶載網路的速率應該改變之步驟包含判定該第一速率應該降低。 The method of claim 1, wherein the step of determining, by the second node, that the rate at which the packet is injected into the on-board network should be changed comprises determining that the first rate should be reduced. 如申請專利範圍第2項之方法,其中判定該第一速率應該降低之步驟包含判定該第二節點缺乏用以在該第二節點接收到該封包的時間處理該封包之資源。 The method of claim 2, wherein the step of determining that the first rate should be reduced comprises determining that the second node lacks resources to process the packet at a time when the second node receives the packet. 如申請專利範圍第2項之方法,其中判定該第一速率應降低之步驟包含判定藉由該第二節點所偏向 (deflect)的封包之數量超過閥值數量。 The method of claim 2, wherein the step of determining that the first rate should be reduced comprises determining that the second node is biased The number of (deflect) packets exceeds the threshold. 如申請專利範圍第1項之方法,其中該第二節點為該封包的目的節點。 The method of claim 1, wherein the second node is a destination node of the packet. 如申請專利範圍第1項之方法,其中該第二節點為將該封包轉發到目的節點的中間節點。 The method of claim 1, wherein the second node is an intermediate node that forwards the packet to the destination node. 如申請專利範圍第1項之方法,其中將封包回傳至該第一節點之步驟包含經由預定義路徑發送該封包至該第一節點。 The method of claim 1, wherein the step of transmitting the packet back to the first node comprises transmitting the packet to the first node via a predefined path. 如申請專利範圍第7項之方法,其中該預定義路徑為該封包自該第一節點至該第二節點所採取的路徑。 The method of claim 7, wherein the predefined path is a path taken by the packet from the first node to the second node. 如申請專利範圍第1項之方法,其中將封包回傳至該第一節點之步驟包含經由隨機路徑發送該封包至該第一節點。 The method of claim 1, wherein the step of transmitting the packet back to the first node comprises transmitting the packet to the first node via a random path. 如申請專利範圍第1項之方法,其中該晶載網路為受緩衝網路。 The method of claim 1, wherein the crystal network is a buffered network. 一種用以控制於晶載網路上的流量之設備,係包含:耦接至晶載網路的節點,其中該節點係用以進行下列動作自來源節點接收封包判定是否該來源節點將封包注入該晶載網路的速率應該改變,響應於判定該來源節點將封包注入該晶載網路的該速率應該改變,而調整該已接收之封包中的第一位元及 該已接收之封包中不同於該第一位元的第二位元,以指示該已接收之封包係已偏向,以及將帶有已調整的該第一位元與該第二位元的該已調整之封包發送至該來源節點。 An apparatus for controlling traffic on a crystal-borne network includes: a node coupled to the on-board network, wherein the node is configured to: receive a packet from the source node to determine whether the source node injects the packet into the node The rate of the on-board network should be changed. In response to determining that the source node should inject the packet into the crystal-carrying network, the rate should be changed, and the first bit in the received packet is adjusted and The received packet is different from the second bit of the first bit to indicate that the received packet has been biased, and the first bit with the adjusted second bit and the second bit The adjusted packet is sent to the source node. 如申請專利範圍第11項之設備,其中判定該來源節點將封包注入該晶載網路之速率是否應該改變之動作包含判定該來源節點將封包注入該晶載網路的該速率應該降低。 The apparatus of claim 11, wherein the act of determining whether the source node injects the packet into the on-board network should change comprises determining that the rate at which the source node injects the packet into the on-board network should be reduced. 如申請專利範圍第12項之設備,其中判定該來源節點將封包注入該晶載網路的該速率應該降低之動作包含判定接收該封包的該節點缺乏用以處理該封包的資源。 The apparatus of claim 12, wherein the act of determining that the source node injects the packet into the on-board network should be reduced comprises the act of determining that the node receiving the packet lacks resources for processing the packet. 如申請專利範圍第12項之設備,其中判定該來源節點將封包注入該晶載網路的該速率應該降低之動作包含判定藉由接收該封包的該節點所偏向的封包之數量超過閥值數量。 The apparatus of claim 12, wherein the act of determining that the source node injects the packet into the crystal carrier network should decrease comprises determining that the number of packets biased by the node receiving the packet exceeds a threshold amount . 如申請專利範圍第11項之設備,其中接收該封包的該節點為該封包的目的節點。 The device of claim 11, wherein the node receiving the packet is a destination node of the packet. 如申請專利範圍第11項之設備,其中接收該封包的該節點為用以轉發該封包至該封包的目的節點的中間節點。 The device of claim 11, wherein the node receiving the packet is an intermediate node for forwarding the packet to a destination node of the packet. 如申請專利範圍第11項之設備,其中發送帶有已調整位元的該封包至該來源節點之動作包含經由預定義路徑發送該封包至該來源節點。 The device of claim 11, wherein the act of transmitting the packet with the adjusted bit to the source node comprises transmitting the packet to the source node via a predefined path. 如申請專利範圍第17項之設備,其中該預定義 路徑為該封包自該來源節點至接收該封包之該節點所採取的路徑。 Such as the device of claim 17 of the patent scope, wherein the predefined The path is the path taken by the packet from the source node to the node that received the packet. 如申請專利範圍第11項之設備,其中發送帶有已調整位元的該封包至該來源節點之動作包含經由隨機路徑發送該封包至該來源節點。 The device of claim 11, wherein the act of transmitting the packet with the adjusted bit to the source node comprises transmitting the packet to the source node via a random path. 如申請專利範圍第11項之設備,其中該晶載網路為受緩衝網路。 The device of claim 11, wherein the crystal carrier network is a buffered network. 一種用以控制於晶載網路上的流量之系統,係包含:顯示器;以及多核心處理器,其包含組織為晶載受緩衝網路的複數個核心,包括核心用以進行下列動作自來源核心接收封包,判定該來源核心將封包注入該晶載網路的速率是否應該改變,響應於判定該來源核心封包注入該晶載網路的該速率應該改變,而調整已接收封包中的第一位元及該已接收之封包中不同於該第一位元的第二位元,以指示該已接收之封包係已偏向,以及發送帶有已調整的該第一位元與該第二位元的該已調整之封包至該來源核心。 A system for controlling traffic on a crystal-borne network includes: a display; and a multi-core processor including a plurality of cores organized as a crystal-loaded buffer network, including a core for performing the following actions from the source core Receiving a packet, determining whether the rate at which the source core injects the packet into the crystal carrier network should change, and adjusting the rate of the source core packet injected into the crystal network to change, and adjusting the first bit in the received packet And a second bit of the received packet different from the first bit to indicate that the received packet has been biased, and transmitting the adjusted first bit and the second bit The adjusted packet is to the source core. 如申請專利範圍第21項之系統,其中判定該來源核心將封包注入該晶載網路的該速率應該改變之動作包含判定該來源核心將封包注入該晶載網路的該速率應該降 低。 The system of claim 21, wherein the rate at which the source core injects the packet into the crystal carrier network should be changed includes determining that the source core injects the packet into the crystal carrier network. low. 如申請專利範圍第22項之系統,其中判定該來源核心將封包注入該晶載網路的該速率應該降低之動作包含判定接收該封包的該核心缺乏用以處理該封包的資源。 A system as claimed in claim 22, wherein the act of determining that the source core injects the packet into the crystal-carrying network should be reduced comprises the act of determining that the core receiving the packet lacks resources for processing the packet. 如申請專利範圍第22項之系統,其中判定該來源核心將封包注入該晶載網路的該速率應該降低之動作包含判定藉由接收該封包的該核心所偏向的封包之數量超過閥值數量。 The system of claim 22, wherein the act of determining that the source core injects the packet into the crystal carrier network should decrease comprises determining that the number of packets biased by the core receiving the packet exceeds a threshold amount . 如申請專利範圍第21項之系統,其中接收該封包的該核心為該封包的目的封包。 The system of claim 21, wherein the core receiving the packet is a destination packet of the packet. 如申請專利範圍第22項之系統,其中接收該封包的該核心為用以轉發該封包至該封包的目的核心的中間核心。 A system as claimed in claim 22, wherein the core receiving the packet is an intermediate core for forwarding the packet to a destination core of the packet. 如申請專利範圍第21項之系統,其中將帶有已調整之該位元的該封包發送至該來源核心之動作包含經由預定義路徑發送該封包至該來源核心。 A system of claim 21, wherein the act of transmitting the packet with the adjusted bit to the source core comprises transmitting the packet to the source core via a predefined path. 如申請專利範圍第27項之系統,其中該預定義路徑為該封包自該來源核心至接收該封包之該核心所採取的路徑。 A system as claimed in claim 27, wherein the predefined path is a path taken by the packet from the source core to the core receiving the packet. 如申請專利範圍第21項之系統,其中將帶有已調整之該位元的該封包發送至該來源核心之動作包含經由隨機路徑發送該封包至該來源核心。 A system of claim 21, wherein the act of transmitting the packet with the adjusted bit to the source core comprises transmitting the packet to the source core via a random path. 一種非過度性電腦可讀儲存媒體,其係具有內容儲存於其上,當其被執行時導致具有組織為晶載受緩衝網 路之節點的一或多個處理器進行下列動作:藉由耦接至該網路的第一節點,以第一速率將封包注入該網路;於耦接至該網路的第二節點處接收該封包;判定該已接收之封包係將被偏向(deflect)且不藉該第二節點緩衝;響應於判定封包注入該網路之速率應該改變,而藉該第二節點調整該已接收之封包中的第一位元及該已接收之封包中不同於該第一位元的第二位元,以指示該已接收之封包係已偏向;藉該第二節點將帶有已調整的該第一位元與該第二位元之該封包回傳至該第一節點;以及響應於偵測到該封包中的該第一位元與該第二位元已受調整,而藉該第一節點改變該第一速率。 A non-transitory computer readable storage medium having content stored thereon that, when executed, results in a tissue-loaded buffer network The one or more processors of the node of the path perform the following actions: injecting the packet into the network at a first rate by being coupled to the first node of the network; at a second node coupled to the network Receiving the packet; determining that the received packet is to be deflected and not buffered by the second node; in response to determining that the rate at which the packet is injected into the network should be changed, and adjusting the received by the second node a first bit in the packet and a second bit in the received packet different from the first bit to indicate that the received packet is biased; and the second node will have the adjusted Transmitting the packet of the first bit and the second bit to the first node; and in response to detecting that the first bit and the second bit in the packet have been adjusted A node changes the first rate.
TW101145909A 2011-12-23 2012-12-06 Traffic control on an on-chip network TWI603205B (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/US2011/067264 WO2013095664A1 (en) 2011-12-23 2011-12-23 Traffic control on an on-chip network

Publications (2)

Publication Number Publication Date
TW201342079A TW201342079A (en) 2013-10-16
TWI603205B true TWI603205B (en) 2017-10-21

Family

ID=48669302

Family Applications (1)

Application Number Title Priority Date Filing Date
TW101145909A TWI603205B (en) 2011-12-23 2012-12-06 Traffic control on an on-chip network

Country Status (3)

Country Link
US (2) US9608922B2 (en)
TW (1) TWI603205B (en)
WO (1) WO2013095664A1 (en)

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9419905B2 (en) 2014-04-04 2016-08-16 International Business Machines Corporation Data streaming scheduler for dual chipset architectures that includes a high performance chipset and a low performance chipset
US10136384B1 (en) * 2014-10-14 2018-11-20 Altera Corporation Methods and apparatus for performing buffer fill level controlled dynamic power scaling
US9891964B2 (en) 2014-11-19 2018-02-13 International Business Machines Corporation Network traffic processing
US11082347B2 (en) * 2018-03-26 2021-08-03 Nvidia Corporation Techniques for reducing congestion in a computer network
CN108694156B (en) * 2018-04-16 2021-12-21 东南大学 On-chip network traffic synthesis method based on cache consistency behavior
US11470004B2 (en) * 2020-09-22 2022-10-11 Advanced Micro Devices, Inc. Graded throttling for network-on-chip traffic
US12113712B2 (en) * 2020-09-25 2024-10-08 Advanced Micro Devices, Inc. Dynamic network-on-chip throttling
US11886938B2 (en) 2021-03-11 2024-01-30 Microsoft Technology Licensing, Llc Message communication between integrated computing devices
CN117640496B (en) * 2024-01-26 2024-05-17 之江实验室 On-chip network route relay method, equipment and medium for nerve mimicry calculation

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TW200637270A (en) * 2004-11-24 2006-10-16 Qualcomm Inc Systems and methods for digital data transmission rate control
US20080084864A1 (en) * 2006-10-06 2008-04-10 Charles Jens Archer Method and Apparatus for Routing Data in an Inter-Nodal Communications Lattice of a Massively Parallel Computer System by Semi-Randomly Varying Routing Policies for Different Packets
US20080313353A1 (en) * 2004-08-24 2008-12-18 Sap Aktiengesellschaft Web Console With Xml/Xsl Interface
US20090252171A1 (en) * 2008-04-02 2009-10-08 Amit Kumar Express virtual channels in a packet switched on-chip interconnection network
US7839777B2 (en) * 2007-09-27 2010-11-23 International Business Machines Corporation Method, system, and apparatus for accelerating resolution of network congestion
US8000242B2 (en) * 2006-07-06 2011-08-16 Alcatel Lucent Reducing packet loss for a packet data service during congestion in a transport network

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7920476B2 (en) 2003-10-08 2011-04-05 Hewlett-Packard Development Company, L.P. Network congestion control
US7512066B2 (en) * 2004-03-30 2009-03-31 Hewlett-Packard Development Company, L.P. Congestion control system

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080313353A1 (en) * 2004-08-24 2008-12-18 Sap Aktiengesellschaft Web Console With Xml/Xsl Interface
TW200637270A (en) * 2004-11-24 2006-10-16 Qualcomm Inc Systems and methods for digital data transmission rate control
US8000242B2 (en) * 2006-07-06 2011-08-16 Alcatel Lucent Reducing packet loss for a packet data service during congestion in a transport network
US20080084864A1 (en) * 2006-10-06 2008-04-10 Charles Jens Archer Method and Apparatus for Routing Data in an Inter-Nodal Communications Lattice of a Massively Parallel Computer System by Semi-Randomly Varying Routing Policies for Different Packets
US7839777B2 (en) * 2007-09-27 2010-11-23 International Business Machines Corporation Method, system, and apparatus for accelerating resolution of network congestion
US20090252171A1 (en) * 2008-04-02 2009-10-08 Amit Kumar Express virtual channels in a packet switched on-chip interconnection network

Also Published As

Publication number Publication date
WO2013095664A1 (en) 2013-06-27
US20140010079A1 (en) 2014-01-09
US9608922B2 (en) 2017-03-28
US20170201459A1 (en) 2017-07-13
TW201342079A (en) 2013-10-16

Similar Documents

Publication Publication Date Title
TWI603205B (en) Traffic control on an on-chip network
US11575609B2 (en) Techniques for congestion management in a network
US20200280518A1 (en) Congestion management techniques
US9013997B2 (en) System for performing distributed data cut-through
US9264371B2 (en) Router, method for controlling the router, and computer program
US8799741B2 (en) Method of transmitting ethernet frame in network bridge and the bridge
WO2019033857A1 (en) Packet control method and network device
CN118433113A (en) Receiver-based precise congestion control
WO2013042219A1 (en) Data communication apparatus, data transmission method, and computer system
WO2011046637A1 (en) Reliable communications in on-chip networks
WO2009074105A1 (en) Link state detection method and system thereof
US20200044976A1 (en) Flow Control Visibility
WO2019080866A1 (en) Data transmission method and device, and computer storage medium
US20220255872A1 (en) Dynamic network receiver-driven data scheduling over a datacenter network for managing endpoint resources and congestion mitigation
US11277342B2 (en) Lossless data traffic deadlock management system
JP5957318B2 (en) Network system, information relay device, and packet distribution method
WO2021083160A1 (en) Data transmission method and apparatus
CN115022227B (en) Data transmission method and system based on circulation or rerouting in data center network
JP4894736B2 (en) Layer 3 switch device and control method thereof
US9699072B2 (en) Packet handling in information centric networking networks
JP7544340B2 (en) COMMUNICATION DEVICE AND COMMUNICATION METHOD
US20090185575A1 (en) Packet switch apparatus and method
US11924106B2 (en) Method and system for granular dynamic quota-based congestion management
JPWO2007096983A1 (en) Data I / O controller
CN117880197A (en) Convergence to enable congestion management

Legal Events

Date Code Title Description
MM4A Annulment or lapse of patent due to non-payment of fees