|Publication number||US7454532 B1|
|Application number||US 10/410,657|
|Publication date||Nov 18, 2008|
|Filing date||Apr 8, 2003|
|Priority date||Apr 8, 2003|
|Publication number||10410657, 410657, US 7454532 B1, US 7454532B1, US-B1-7454532, US7454532 B1, US7454532B1|
|Original Assignee||Telairity Semiconductor, Inc.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (8), Referenced by (2), Classifications (14), Legal Events (3)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The present invention relates to processing systems that receive and transmit real-time or near real-time data, and more particularly, to processing systems that receive and transmit data without first storing the data in memory.
Computer processors typically include register files for storing data. A register file includes memory (e.g., registers) that stores the data. When data is input into a processor, the processor initially stores the data in the register file through one of the register file's write ports.
When the processor wants to process the data, the processor reads the data from the register file through one of the register file's read ports. The data read from the register file is then passed to one or more functional units using a multiplexer. The functional units process the data.
The output data of the functional units is stored back in the register file through a register file write port. The processor outputs data by reading the data from a read port of the register file and then transmitting the data outside the processor.
Because processors store data in the register file before and after processing the data, processors cannot process data quickly enough for real-time processing applications. Therefore, it would be desirable to provide processors that process data more quickly.
The present invention provides techniques for processing data in real-time or in near real time using a processor. Real-time input data is provided to the processor on an input data stream. The input data is not stored in memory in the processor before the data is processed. The input data is passed directly to functional units via a bypass multiplexer without being stored in a register file. Because input data bypasses the register file, input data can be loaded into functional units within a processor more quickly.
Data can also be transmitted outside a processor more quickly. Output data of the functional units is not stored in the register file (or any other memory unit) before being transmitted outside the processor. Input and output data that needs to be maintained in the processor for a period of time is stored in the register file.
Instruction codes are provided to the bypass multiplexer, the functional units, and the register file. The instruction codes can be temporarily stored in registers so that the most recent instruction codes are saved if the input data stream stops. These registers allow the instructions code to be synchronized with the real-time input data.
The present invention eliminates the need for extra write ports in the register file. Processors of the present invention are also more efficient and faster, because extra load and read instructions are not needed to store real-time data in the register file.
Other objects, features, and advantages of the present invention will become apparent upon consideration of the following detailed description and the accompanying drawings, in which like reference designations represent like features throughout the figures.
Input data that needs to be maintained by processor 100 for a period of time can be stored in register file 101. As shown in
Data can be accessed from register file 101 from its read port. Register file 101 retrieves data from its memory cells using a read instruction. Data is read out of register file 101 and provided to a first input of bypass multiplexer 102. Multiplexer 102 selects its first input and transmits the data from register file 101 to one or more of functional units 103.
The output data of functional units 103 can be stored in register file 101 through a write port using register file load instructions. The connections between the outputs of functional units 103 and the write port of register file 101 are shown in
Processors of the present invention can process data in real-time or near real-time as will now be discussed. Processor 100 receives input stream data at an external port as shown in
The input stream data is provided directly to a second input of bypass multiplexer 102 as shown in
Multiplexer 102 can pass the input stream data directly to one or more of functional units 103. Functional units 103 process the input stream data to provide output data. Functional units 103 can also process data received from register file 101 to provide output data. Functional units 103 can perform any processing operations on the data, such as arithmetic functions, Boolean functions, and logical operations. Functional units 103 can contain storage locations (e.g., latches or registers) that temporarily store data received from multiplexer 102 as the data is processed according to well known techniques.
Functional units 103 are also controlled by instructions codes. The instruction codes control the passage of data through functional units 103.
As shown in
By not storing the output stream data in memory in processor 100, extra load and read instructions used by register file 101 to store the output stream data are eliminated. Also, memory locations in register file 101 are not taken up by data that does not need to stored by processor 100.
Data can be transferred into and out of functional units 103 without being stored in memory in processor 100 (e.g., register file 101). By not storing data in memory, processor 100 can process data in real-time or in near real-time. According to one application of the present invention, a plurality of processors coupled in series can perform a variety of processing techniques on data in real-time or near real-time using the stream data processing techniques described herein.
The present invention is also advantageous, because fewer write ports are needed in register file 101 for receiving the input stream data. Therefore, techniques of the present invention reduce the input circuitry in file register 101. In addition, the present invention reduces the number of clock cycles in processor 100, because the input and output stream data is not loaded into or read out of register file 101. By not storing the input and output stream data in register file 101, the present invention also increases the available memory in register file 101. This is advantageous, because memory in register file 101 is limited.
Each of the circuit blocks shown in
The present invention also provides techniques for synchronizing the input stream data with the instruction codes. The input stream data is not stored in memory in processor 100 before the input stream data is passed to functional blocks 103 through bypass multiplexer 102.
The input stream data can be stalled periodically. When the input stream data is stalled, no input stream data is received at bypass multiplexer 102. When the input stream data begins to flow into processor 100 again after being stalled, the instruction codes would no longer match the correct input stream data bits, if the instruction code sequence continued to flow.
To solve this problem, processor 100 includes registers 111-114 as shown in
Registers 111-114 temporarily store instruction codes in the instruction sequence, before the instruction codes are passed to circuit blocks 101-103. Registers 111-114 each receive a control signal (not shown). The control signal may originate from outside processor 100. The control signal indicates to registers 111-114 when the input stream data signal has been stalled.
When the control signal indicates that the input stream data signal has stopped, registers 111-114 stop outputting instruction codes to circuits 101-103. When the input stream data is stalled, instruction codes can continue to be sent to inputs of registers 111-114. Registers 111-114 store the incoming instructions codes until the control signal indicates that the input stream data is flowing into processor 100 again. Registers 111-114 preferably have sufficient memory to store all the instruction codes that the registers receive during the longest possible pause in the input stream data signal.
When the control signal indicates that input stream data is again flowing into processor 100, registers 111-114 resume outputting instruction codes to circuits 101-103. Registers 111-114 allow the instruction codes to continue to be matched with the correct input stream data bits even after pauses in the input stream data signal. For example, instructions codes provided to multiplexer 102 are synchronized with the input stream data bits. Instruction codes that are provided to functional units 103 from registers 113-114 are synchronized with the output data of multiplexer 102.
The control signal also stops instruction codes from being passed to register file 101. Therefore, register file 101 stops functioning until the instructions codes are again received from register 111.
Alternatively, the control signal can connect to the circuitry in processor 100 that generates the instruction code sequence. When the input stream data signal is stalled, the control signal causes this circuitry to stop outputting instruction codes until input stream data is again received by processor 100. The instruction codes already generated are stored in registers 111-114 (or other memory) until they are needed.
Techniques of the present invention can be used in many different types of processors. For example, the techniques of the present invention can be used in desktop processors, embedded processors, special purpose processors, handheld processors. etc.
While the present invention has been described herein with reference to particular embodiments thereof, a latitude of modification, various changes, and substitutions are intended in the present invention. In some instances, features of the invention can be employed without a corresponding use of other features, without departing from the scope of the invention as set forth. Therefore, many modifications may be made to adapt a particular configuration or method disclosed, without departing from the essential scope and spirit of the present invention. It is intended that the invention not be limited to the particular embodiment disclosed, but that the invention will include all embodiments and equivalents falling within the scope of the claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4675836 *||Mar 8, 1985||Jun 23, 1987||Compagnie Industrielle Des Telecommunications Cit-Alcatel||Discrete cosine transform calculation processor|
|US4679163 *||Mar 8, 1985||Jul 7, 1987||Compagnie Industrielle Des Telecommunications Cit-Alcatel||Inverse discrete cosine transform calculation processor|
|US5305443 *||Jan 22, 1993||Apr 19, 1994||At&T Bell Laboratories||Microprocessor with low power bus|
|US6012137 *||May 30, 1997||Jan 4, 2000||Sony Corporation||Special purpose processor for digital audio/video decoding|
|US6377998 *||Aug 22, 1997||Apr 23, 2002||Nortel Networks Limited||Method and apparatus for performing frame processing for a network|
|US20020108026 *||Dec 8, 2000||Aug 8, 2002||Keith Balmer||Data processing apparatus with register file bypass|
|US20030145259 *||Jan 27, 2003||Jul 31, 2003||Kawasaki Microelectronics, Inc.||Test circuit and test method for communication system|
|US20040098570 *||Nov 19, 2002||May 20, 2004||Analog Devices, Inc.||Pipelined processor method and circuit|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US7734846 *||Dec 20, 2006||Jun 8, 2010||L3 Communications Integrated Systems, L.P.||Datapipe CPU register array|
|US20080155138 *||Dec 20, 2006||Jun 26, 2008||Jerry William Yancey||Datapipe cpu register array|
|U.S. Classification||710/20, 710/29, 710/36, 710/31, 710/5, 712/E09.035, 712/218|
|International Classification||G06F9/30, G06F13/00, G06F3/00|
|Cooperative Classification||G06F9/30181, G06F13/4243|
|European Classification||G06F9/30X, G06F13/42C3S|
|May 12, 2003||AS||Assignment|
Owner name: TELAIRITY SEMICONDUCTOR, INC., CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:DICKSON, RICHARD;REEL/FRAME:013647/0399
Effective date: 20030418
|Apr 25, 2012||FPAY||Fee payment|
Year of fee payment: 4
|May 5, 2016||FPAY||Fee payment|
Year of fee payment: 8