Apparatus and method for setting routing path between routers in chip
An apparatus and a method for setting a routing path in System-on-a-Chip (SoC) having an n×n net topology-based structure comprising a plurality of intellectual properties (IPs), each with a unique address, and a plurality of switches forming one-to-one correspondence to the IPs, to transmit and receive data between the IPs by using at least one of the switches. Accordingly, an orthogonal code having orthogonality is assigned according to the direction of transmission of each data (that is, output port). Then, an output port where the data is transmitted is determined, and the data is spread based on an orthogonal code assigned to the output ports of the at least one of the switches.
Latest Samsung Electronics Patents:
- PHOTORESIST COMPOSITIONS AND METHODS OF MANUFACTURING INTEGRATED CIRCUIT DEVICES USING THE SAME
- LENS DRIVING DEVICE AND CAMERA MODULE INCLUDING THE SAME
- ELECTRONIC SYSTEM AND METHOD OF MANAGING ERRORS OF THE SAME
- SEALING STRUCTURE AND MATERIAL CONTAINING DEVICE INCLUDING THE SAME
- STORAGE DEVICE, METHOD OF OPERATING STORAGE CONTROLLER, AND UFS SYSTEM
This application claims priority benefit under 35 U.S.C. §§ 120 and 121 from U.S. patent application Ser. No. 10/998,571 filed on Nov. 30, 2004 in the U.S. Patent and Trademark Office, and this application claims priority benefit under 35 U.S.C. § 119 from Korean Patent Application No. 2004-7721 filed on Feb. 6, 2004, the disclosures of U.S. patent application Ser. No. 10/998,571 and Korean Patent Application No. 2004-7721 are incorporated herein by reference.
BACKGROUND OF THE INVENTION1. Field of the Invention
The present invention relates in general to a System-on-a-Chip (SoC), more particularly, to an apparatus and a method for setting a routing path between routers in a chip.
2. Description of the Related Art
To facilitate Internet access or computing functions of digital data equipment like cell phones, PDAs (Personal Digital Assistants), digital TVs, and smart phones, a number of semiconductor chips including a microprocessor, a network chip, and a memory are required. As the data equipment has become more complicated, integration among these products is already occurring and will become a necessity in the near future. If that happens, even more chips will be required within one single data device.
Developed as an answer to the above is a System-on-a-Chip (SoC) technology which integrates features of every component (even semiconductors) on a single chip. In general, the SoC system is constructed of a computing element, input and output (I/O), logic, and memory. The compact and high-integration SoC features high performance and low power consumption, so a majority of data equipment will benefit from the SoC technology. Intellectual property (IP) is also used to help designers to create the semiconductor chip much more rapidly. The IP is a design block that is specially developed as a ready-to-use application to the single chip.
Many studies on the SoC are in progress. In particular, a scheme for connecting IPs built in a chip is considered very important. For example, a bus architecture and a network architecture are currently used to connect IPs. Unfortunately however, the bus architecture already exposed its limit as the amount of data transmitted/received between IPs increases. This is because when a specific IP uses a bus, and other IPs cannot use the bus at all. That is, the bus is exclusively used for the specific IP.
Moreover, the bus architecture is not extendable but fixed, so that additional IPs of the chip cannot be connected to a bus. As an attempt to solve the performance drawback of the bus architecture, the network architecture is devised to connect IPs. The network architecture, compared to the bus structure, consumes less power. Hereinafter, the network architecture for the SoC will be called ‘NoC’ (Network-on-Chip).
It is assumed that a switch S5 generates data to be transferred to at least two adjacent switches at a certain point. The data is directly generated by the IP5 or is transferred from adjacent switches. For instance, provided that the switch S5 generates data to be transferred to the switches, S1, S4, S6, and S9, the S5 determines the priority of the data to be transferred to the adjacent switches. A user can change the priority as desired. For example, the priority levels can be designated according to data capacity. For convenience of explanation, it is assumed that the switch S5 determined the priority in order of the S1, S4, S6, and S9. However, it is to be understood that other priorities are possible.
The S5 transfers the data to the adjacent switches according to the priority. That is, the S5 transfers the data to the S1 first since it has the highest priority, and lastly to the S9 having the lowest priority. If there is data which is not transferred in real time mode (that is, low priority data), such data is stored in a buffer of the S5 to prevent the data loss.
Still a problem arises that under the NoC environment, the transmission of 100 packets per buffer is not possible. If the buffer is to transmit 100 packets of data as the existing network does, the buffer size will have to be increased also. If the buffer size increases, the chip size should be increased accordingly, and as a result of this, the SoC loses its own function. Moreover, as the number of IPs constructing one chip increases, the number of data packets being transmitted and received increases as well. The increase in data packets to be transmitted and received also causes problems including an increase in the buffer size, an increase in the complexity of a chip, and delay in data transfer.
SUMMARY OF THE INVENTIONIt is, therefore, an aspect of the present invention is to provide an apparatus and a method transferring corresponding data to adjacent switches in real-time mode by shortening storage time of a buffer for data to be transferred.
Another aspect of the present invention is to provide an apparatus and a method for reducing the size of SoC by reducing the amount of data stored in the buffer.
Still another aspect of the prevent invention is to provide an apparatus and a method for improving data reliability by reducing data distortion and data loss for the data to be transferred to adjacent switches.
Yet another aspect of the present invention is to provide a method for transferring corresponding data to adjacent switches by adopting code division method instead of TDM.
According to an aspect of the present invention, there is provided a method of setting a routing path in a System-on-a-Chip (SoC) including a plurality of intellectual properties (IPs), each IP being connected to at least one switch and having a unique address, to transmit and receive data between the IPs using at least one of the switches, including: assigning an orthogonal code featuring mutual orthogonality for each IP; spreading the data, via a destination IP, by using an assigned orthogonal code when the data is transmitted; and broadcasting the spread data to the IPs using at least one of the switches.
Another aspect of the present invention provides a method of setting a routing path in System-on-a-Chip (SoC) having an n×n net topology-based structure including a plurality of intelligent properties (IPs), each with a unique address, and a plurality of switches in one-to-one correspondence to the IPs, to transmit and receive data between the IPs using at least one of the switches, including: assigning an orthogonal code featuring orthogonality according to an output port of each data; and determining an output port to which data is to be transmitted and spreading the data using an orthogonal code assigned to the output port.
Still another aspect of the present invention provides an apparatus for setting a routing path in a System-on-a-Chip (SoC) including a plurality of intellectual properties (IPs), each IP being connected to at least one switch and having a unique address, to transmit and receive data between the IPs by using at least one of the switches, including: an intellectual property (IP) which spreads transferred data by using assigned orthogonal codes having mutual orthogonality; and switches which receive the spread data and which broadcast the data to the IPs.
Yet another aspect of the present invention provides an apparatus for setting a routing path in System-on-a-Chip (SoC) having an n×n net topology-based structure including a plurality of intellectual properties (IPs), each with a unique address, and a plurality of switches forming one-to-one correspondence to the IPs, to transmit and receive data between the IPs by using at least one of the switches, including: a routing path setting unit which determines an output to which data is transmitted; and spreaders which receive the data and spreading the data using assigned orthogonal codes corresponding to output ports of the at least one of the switches.
Still another aspect of the present invention provides a method of shortening transmission time in a System-on-a-Chip (SoC) including a plurality of intellectual properties (IPs) to transmit and receive data between the IPs using at least one switch, including: comparing a destination address included in data to be transmitted by a switch with a switch address of the switch; transferring the data to an IP connected to the switch when the destination address and the switch address are determined to be the same; calculating a value using a modulo operation when the destination address and the switch address are determined not to be the same; setting a routing path (port) of the data to be transmitted after the calculating; spreading the data by using an orthogonal code assigned to the set port; transferring the spread data to all of the ports of the switch; despreading the transferred data via each of the ports by using an orthogonal code assigned to each of the ports; and transferring the despread data to adjacent switches.
Yet another aspect of the present invention provides a method of setting a routing path so as to reduce a buffer size, including: calculating a difference of the destination address and the source address; determining whether a first condition is satisfied and setting a routing path of the data to a first side when it is determined that the first condition is satisfied; determining whether a second condition is satisfied when the first condition is determined not to be satisfied and setting the routing path of data to a second side when the second condition is determined to be satisfied; determining whether a third condition is satisfied when the second condition is not satisfied and setting the routing path of data to a third side when the third condition is determined to be satisfied; and setting the routing path of data to a fourth side.
Additional and/or other aspects and advantages of the present invention will be set forth in part in the description which follows and, in part, will be obvious from the description, or may be learned by practice of the invention.
These and/or other aspects and advantages of the present invention will become apparent and more readily appreciated from the following detailed description, taken in conjunction with the accompanying drawings of which:
Reference will now be made in detail to embodiments of the present invention, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to the like elements throughout. The embodiments are described below in order to explain the present invention by referring to the figures.
Each IP stores the data shown in <Table 1>. The address of an IP generating data to be transferred is called “source address,” and the address of an IP where data is eventually transmitted is called “destination address.” For instance, it is assumed that IP(0) generated data to be transferred to IP(3), and IP(6) generated data to be transferred to IP(9). The IP(0) spreads the data employing an orthogonal code assigned to the IP(3). Then, the IP(0) transfers the spread data to the shared switch “S”. Similarly, the IP(6) spreads the data employing an orthogonal code assigned to the IP(9), and later transfers the spread data to the switch. The switch adds the transferred data, and broadcasts them to adjacent IPs. That is, the switch transfers the data being added to IP(0) to IP(15).
Using the assigned orthogonal codes, the IP(0) to IP(15) despread the transferred data. Performing the despreading process, the IP(3) receives data from the IP(0), and the IP(9) receives data from the IP(6), respectively. Therefore, the code division method makes it possible for the switch to transmit a lot of data at the same point.
A spreader 300 receives data and an IP for transferring the data. The spreader 300 also receives an orthogonal code assigned to the IP for transferring the data. In other words, the spreader 300 receives an orthogonal code out of w(0) to w(15), which is specially assigned to the IP for transferring the data. Then, the spreader 300 spreads the data by using the orthogonal code, and transfers it to an adder 310. The other spreaders 302 to 304 also perform the same process as the spreader 300.
The adder 310 adds the transferred data and transfers them to the despreaders 320 to 324. The despreader 320 despreads the transferred data by using its assigned orthogonal code w(0), and transfers it to an accumulator 330. Then, the accumulator 330 accumulates the transferred data. In such a manner, the despreader 322 despreads the transferred data by using its assigned orthogonal code w(1), and transfers it to an accumulator 332. Then, the accumulator 332 accumulates the transferred data. The despreader 324 despreads the transferred data by using its assigned orthogonal code w(15), and transfers it to an accumulator 334. Then, the accumulator 334 accumulates the transferred data. By checking the accumulated data in the accumulators 330 to 334, a user is able to find out whether the data have been received.
The data is transmitted to the IP that uses the same orthogonal code as the one used by the spreader, and if the IP uses a different orthogonal code from the one used by the spreader, the IP cannot receive the data. This is because of the nature of the orthogonal code having no correlation between codes.
One drawback of the star topology-based structure illustrated in
As shown in the <Table 2>, the orthogonal code has a fixed length no matter how many IPs exist. Each switch included in the NoC stores the same data as shown in the <Table 2>. Described next is a method for transmitting data from an IP having a source address to an IP having a destination address, on the basis of the <Table 2>.
First, the switch determines whether there is data to be transmitted at operation S500. If the data to be transmitted has been generated, the switch proceeds with the next operation. However, if the data to be transmitted has not been generated, the switch does not proceed with the next operation but instead repeats operation S500. In operation 502, the switch compares the destination address included in the received data with its own address. If it turns out that the destination address is in coincidence with its own address (i.e., the same), the switch proceeds with operation 504, but if the addresses are not coincident with each other, the switch proceeds with operation 506. In operation 504, the switch transfers the transmitted data to an IP connected to the switch.
In operation 506, the switch calculates a value “a.” The “a” can be obtained from the following <Equation 1>, using source address and “n” values. Hereinafter, the address of an IP connected to the switch conducting the procedure of
a=source address % n. [Equation 1]
In Equation 1, % indicates a modulo operation. For example, provided that the source address is 2 and n equals to 4, a=2 % 4=2. After obtaining the value, the switch sets a routing path (port) of the data being generated at operation S508. This operation will be explained below in more detail. Then, the switch spreads the data by using an orthogonal code assigned to the port at operation S510. The spread data is transferred to four ports of the switch at operation S512. Each port despreads the transferred data by using its assigned orthogonal code at operation S514. Lastly, each port transfers the despread data to adjacent switches at operation S516.
As described above with reference to
For example, it is assumed that the source address is 2 and the destination address is 9, and n=4. Then, the switch sets the routing path of data to downward (south). Therefore, the switch spreads the data by using an orthogonal code assigned to the south, and the spread data is transferred to those four ports, respectively. Each port despreads the transmitted data. In this manner, only the port in the south can generate data and transfer the data.
Although it is assumed that data is transmitted and received in the embodiments of
Since the switch can receive data from four ports, it has four spreaders, as shown in
The routing path setting unit 700 uses the destination address included in the transferred data and its own address to determine an output port where the data needs to be transferred. If the destination address and its own address are same, the switch transfers the transferred data to the IP. The procedure involved in the determination of the output port by the routing path setting unit 700 is similar to the procedure described referring to
The spreader 710 spreads the transferred data by using an orthogonal code w0 and transfers it to the adder 720. In such a manner, the spreader 712 spreads the transferred data by using an orthogonal code w1, and transfers it to the adder 720. The spreader 714 spreads the transferred data by using an orthogonal code w2, and transfers it to the adder 720. Lastly, spreader 716 spreads the transferred data by using an orthogonal code w3, and transfers it to the adder 720. Then, the adder 720 performs the adding process on the spread data.
After adding the data, the adder 720 transfers the data to the despreaders 730 to 736, respectively. The despreader 730 despreads the transferred data by using the orthogonal code w0, and transfers it to an accumulator 740. Similarly, the despreader 732 despreads the transferred data by using the orthogonal code w1, and transfers it to an accumulator 742. Also, the despreader 734 despreads the transferred data by using the orthogonal code w2, and transfers it to an accumulator 744. Lastly, the despreader 736 despreads the transferred data by using the orthogonal code w3, and transfers it to an accumulator 746. After accumulating the data, each of the accumulators 740 to 746 transfers the data to adjacent switches via a corresponding output port.
Every output port can output data, but only the output port(s) chosen by the routing path setting unit 700 actually outputs data. For example, if the routing path setting unit 700 chooses the output port 0 and the output port 1, only the output ports 0 and 1 output data.
In conclusion, the code division-based routing setting can be advantageously used for reducing the size of the buffer included in the switch. Moreover, by setting the data routing path by using the orthogonal code, it is possible to shorten transmission time. Therefore, no matter how many IPs are used for constructing the SoC, the orthogonal code can be maintained at constant length.
Although a few embodiments of the present invention have been shown and described, the present invention is not limited to the described embodiments. Instead, it would be appreciated by those skilled in the art that changes may be made to these embodiments without departing from the principles and spirit of the invention, the scope of which is defined by the claims and their equivalents.
Claims
1. A method of setting a routing path so as to reduce a buffer size, comprising:
- calculating a difference of the destination address and the source address;
- determining whether a first condition is satisfied and setting a routing path of the data to a first side when the first condition is satisfied;
- determining whether a second condition is satisfied when the first condition is determined not to be satisfied and setting the routing path of data to a second side when the second condition is determined to be satisfied;
- determining whether a third condition is satisfied when the second condition is not satisfied and setting the routing path of data to a third side when the third condition is determined to be satisfied; and
- setting the routing path of data to a fourth side.
2. The method of claim 1, wherein at least two data having different destination addresses are generated in the switch.
3. The method of claim 1, wherein the switch spreads each data at the same point.
4. The method of claim 1, wherein the number of data packets and the number of spreaders are the same.
5. The method of claim 1, wherein the first condition is 1≦b≦(n−1−a), b being a difference between the source address and the destination address, n being a modulo, and a being the source address modulo n, and wherein the first side is the right side (east).
6. The method of claim 1, wherein the second condition is b≦(n−a), b being a difference between the source address and the destination address, n being a modulo, and a being the source address modulo n, and wherein the second side is the downward side (south).
7. The method of claim 1, wherein the third condition is −a≦b≦−1, b being a difference between the source address and the destination address, n being a modulo, and a being the source address modulo n, and wherein the third side is the left side (west).
8. The method of claim 1, wherein the fourth side is upward (north).
Type: Application
Filed: Apr 14, 2009
Publication Date: Aug 13, 2009
Applicant: Samsung Electronics Co., Ltd. (Suwon-si)
Inventors: Sang-Woo Rhim (Seoul), Beom-Hak Lee (Seoul), Jae-Kon Lee (Suwon-si), Eul-Seok Kim (Suwon-si)
Application Number: 12/385,622
International Classification: H04L 12/56 (20060101);