US20060112260A1 - Method and apparatus of instruction execution for signal processors - Google Patents
Method and apparatus of instruction execution for signal processors Download PDFInfo
- Publication number
- US20060112260A1 US20060112260A1 US11/323,253 US32325305A US2006112260A1 US 20060112260 A1 US20060112260 A1 US 20060112260A1 US 32325305 A US32325305 A US 32325305A US 2006112260 A1 US2006112260 A1 US 2006112260A1
- Authority
- US
- United States
- Prior art keywords
- instruction
- dsp
- instructions
- data
- execution
- Prior art date
- Legal status (The legal status 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 status listed.)
- Abandoned
Links
- 238000000034 method Methods 0.000 title claims description 30
- 230000015654 memory Effects 0.000 claims description 70
- 230000004044 response Effects 0.000 claims description 2
- 238000012545 processing Methods 0.000 abstract description 80
- 239000013598 vector Substances 0.000 description 18
- 238000004891 communication Methods 0.000 description 17
- 230000006870 function Effects 0.000 description 16
- 238000010586 diagram Methods 0.000 description 15
- 235000019800 disodium phosphate Nutrition 0.000 description 10
- 230000008569 process Effects 0.000 description 10
- 230000006837 decompression Effects 0.000 description 7
- 230000005540 biological transmission Effects 0.000 description 6
- 238000004364 calculation method Methods 0.000 description 6
- 230000008901 benefit Effects 0.000 description 5
- 238000007906 compression Methods 0.000 description 5
- 230000006835 compression Effects 0.000 description 5
- 230000006978 adaptation Effects 0.000 description 3
- 238000012360 testing method Methods 0.000 description 3
- 102000020897 Formins Human genes 0.000 description 2
- 108091022623 Formins Proteins 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 238000013144 data compression Methods 0.000 description 2
- 238000001914 filtration Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000001133 acceleration Effects 0.000 description 1
- 238000009825 accumulation Methods 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 230000004075 alteration Effects 0.000 description 1
- 230000015556 catabolic process Effects 0.000 description 1
- 150000001875 compounds Chemical class 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 238000006731 degradation reaction Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- RPOCQUTXCSLYFJ-UHFFFAOYSA-N n-(4-ethylphenyl)-2-(2-methyl-3,5-dioxothiomorpholin-4-yl)acetamide Chemical compound C1=CC(CC)=CC=C1NC(=O)CN1C(=O)C(C)SCC1=O RPOCQUTXCSLYFJ-UHFFFAOYSA-N 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 230000003252 repetitive effect Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 230000001629 suppression Effects 0.000 description 1
- 230000002123 temporal effect Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3877—Concurrent instruction execution, e.g. pipeline or look ahead using a slave processor, e.g. coprocessor
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/76—Architectures of general purpose stored program computers
- G06F15/80—Architectures of general purpose stored program computers comprising an array of processing units with common control, e.g. single instruction multiple data processors
- G06F15/8007—Architectures of general purpose stored program computers comprising an array of processing units with common control, e.g. single instruction multiple data processors single instruction multiple data [SIMD] multiprocessors
- G06F15/8015—One dimensional arrays, e.g. rings, linear arrays, buses
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/3001—Arithmetic instructions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30072—Arrangements for executing specific machine instructions to perform conditional operations, e.g. using predicates or guards
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30145—Instruction analysis, e.g. decoding, instruction word fields
- G06F9/30149—Instruction analysis, e.g. decoding, instruction word fields of variable length instructions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30181—Instruction operation extension or modification
- G06F9/30189—Instruction operation extension or modification according to execution mode, e.g. mode flag
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3802—Instruction prefetching
- G06F9/3808—Instruction prefetching for instruction reuse, e.g. trace cache, branch target cache
- G06F9/381—Loop buffering
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3818—Decoding for concurrent execution
- G06F9/382—Pipelined decoding, e.g. using predecoding
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3836—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
- G06F9/3853—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution of compound instructions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3885—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units
Definitions
- This invention relates generally to the instruction set architectures (ISA) of processors. More particularly, the invention relates to instruction set architectures for the execution of operations within a signal processing integrated circuit.
- ISA instruction set architectures
- DSPs Single chip digital signal processing devices
- DSPs generally are distinguished from general purpose microprocessors in that DSPs typically support accelerated arithmetic operations by including a dedicated multiplier and accumulator (MAC) for performing multiplication of digital numbers.
- the instruction set for a typical DSP device usually includes a MAC instruction for performing multiplication of new operands and addition with a prior accumulated value stored within an accumulator register.
- a MAC instruction is typically the only instruction provided in prior art digital signal processors where two DSP operations, multiply followed by add, are performed by the execution of one instruction.
- DSP operations multiply followed by add
- DSPs digital filtering
- a DSP is typically programmed with instructions to implement some filter function in the digital or time domain.
- the equation Y n may be evaluated by using a software program. However in some applications, it is necessary that the equation be evaluated as fast as possible.
- One way to do this is to perform the computations using hardware components such as a DSP device programmed to compute the equation Y n .
- the multiple DSPs operate in parallel to speed the computation process.
- the multiplication of terms is spread across the multipliers of the DSPs equally for simultaneous computations of terms.
- the adding of terms is similarly spread equally across the adders of the DSPs for simultaneous computations.
- the order of processing terms is unimportant since the combination is associative. If the processing order of the terms is altered, it has no effect on the final result expected in a vectorized processing of a function.
- a MAC operation would require a multiply instruction and an add instruction to perform both multiplication and addition. To perform these two instructions would require two processing cycles. Additionally, a program written for the typical micro processor would require a larger program memory in order to store the extra instructions necessary to perform the MAC operation.
- a DSP operation other than a MAC DSP instruction need be performed, the operation requires separate arithmetic instructions programmed into program memory. These separate arithmetic instructions in prior art DSPs similarly require increased program memory space and processing cycles to perform the operation when compared to a single MAC instruction. It is desirable to reduce the number of processing cycles when performing DSP operations. It is desirable to reduce program memory requirements as well.
- DSPs are often programmed in a loop to continuously perform accelerated arithmetic functions including a MAC instruction using different operands. Often times, multiple arithmetic instructions are programmed in a loop to operate on the same data set. The same arithmetic instruction is often executed over and over in a loop using different operands. Additionally, each time one instruction is completed, another instruction is fetched from the program stored in memory during a fetch cycle. Fetch cycles require one or more cycle times to access a memory before instruction execution occurs. Because circuits change state during a fetch cycle, power is consumed and thus it is desirable to reduce the number of fetch cycles. Typically, approximately twenty percent of power consumption may be utilized in the set up and clean up operations of a loop in order to execute DSP instructions.
- the loop execution where signal processing of data is performed consumes approximately eighty percent of power consumption with a significant portion being due to instruction fetching. Additionally, because data sets that a DSP device process are usually large, it is also desirable to speed instruction execution by avoiding frequent fetch cycles to memory.
- the quality of service over a telephone system often relates to the processing speed of signals. That is particularly the case when a DSP is to provide voice processing, such as voice compression, voice decompression, and echo cancellation for multiple channels. More recently, processing speed has become even more important because of the desire to transmit voice aggregated with data in a packetized form for communication over packetized networks. Delays in processing the packetized voice signal tend to result in the degradation of signal quality on receiving ends.
- ASSP application specific signal processor
- Each ASSP includes a serial interface, a buffer memory, and four core processors for each to simultaneously process multiple channels of voice or data.
- Each core processor preferably includes a reduced instruction set computer (RISC) processor and four signal processing units (SPs).
- RISC reduced instruction set computer
- SPs signal processing units
- Each SP includes multiple arithmetic blocks to simultaneously process multiple voice and data communication signal samples for communication over IP, ATM, Frame Relay or other packetized network.
- the four signal processing units can execute the digital signal processing algorithms in parallel.
- Each ASSP is flexible and can be programmed to perform many network functions or data/voice processing functions, including voice and data compression/decompression in telecommunications systems (such as CODECs) particularly packetized telecommunication networks, simply by altering the software program controlling the commands executed by the ASSP.
- telecommunications systems such as CODECs
- An instruction set architecture for the ASSP is tailored to digital signal processing applications including audio and speech processing such as compression/decompression and echo cancellation.
- the instruction set architecture implemented with the ASSP is adapted to DSP algorithmic structures. This adaptation of the ISA of the present invention to DSP algorithmic structures balances the ease of implementation, processing efficiency, and programmability of DSP algorithms.
- the instruction set architecture may be viewed as being two component parts, one (RISC ISA) corresponding to the RISC control unit and another (DSP ISA) to the DSP datapaths of the signal processing units 300 .
- the RISC ISA is a register based architecture including 16-registers within the register file 413
- the DSP ISA is a memory based architecture with efficient digital signal processing instructions.
- the instruction word for the ASSP is typically 20 bits but can be expanded to 40-bits to control two instructions to be executed in series or parallel, such as two RISC control instructions and extended DSP instructions.
- the instruction set architecture of the ASSP has four distinct types of instructions to optimize the DSP operational mix. These are (1) a 20-bit DSP instruction that uses mode bits in control registers (i.e. mode registers), (2) a 40-bit DSP instruction having control extensions that can override mode registers, (3) a 20-bit dyadic DSP instruction, and (4) a 40 bit dyadic DSP instruction.
- All DSP instructions of the instruction set architecture of the ASSP are dyadic DSP instructions to execute two operations in one instruction with one cycle throughput.
- a dyadic DSP instruction is a combination of two basic DSP operations in one instruction and includes a main DSP operation (MAIN OP) and a sub DSP operation (SUB OP).
- the instruction set architecture of the present invention can be generalized to combining any pair of basic DSP operations to provide very powerful dyadic instruction combinations.
- the DSP arithmetic instructions or operations in the preferred embodiment include a multiply instruction (MULT), an addition instruction (ADD), a minimize/maximize instruction (MIN/MAX) also referred to as an extrema instruction, and a no operation instruction (NOP) each having an associated operation code (“opcode”).
- MULT multiply instruction
- ADD addition instruction
- MIN/MAX minimize/maximize instruction
- NOP no operation instruction
- the present invention efficiently executes these dyadic DSP instructions by means of the instruction set architecture and the hardware architecture of the application specific signal processor.
- the DSP instructions can process vector data or scalar data automatically using a single instruction and provide the appropriate vector or scalar output results.
- FIG. 1A is a block diagram of a system utilizing the present invention.
- FIG. 1B is a block diagram of a printed circuit board utilizing the present invention within the gateways of the system in FIG. 1A .
- FIG. 2 is a block diagram of the Application Specific Signal Processor (ASSP) of the present invention.
- ASSP Application Specific Signal Processor
- FIG. 3 is a block diagram of an instance of the core processors within the ASSP of the present invention.
- FIG. 4 is a block diagram of the RISC processing unit within the core processors of FIG. 3 .
- FIG. 5A is a block diagram of an instance of the signal processing units within the core processors of FIG. 3 .
- FIG. 5B is a more detailed block diagram of FIG. 5A illustrating the bus structure of the signal processing unit.
- FIG. 6A is an exemplary instruction sequence illustrating a program model for DSP algorithms employing the instruction set architecture of the present invention.
- FIG. 6B is a chart illustrating the permutations of the dyadic DSP instructions.
- FIG. 6C is an exemplary bitmap for a control extended dyadic DSP instruction.
- FIG. 6D is an exemplary bitmap for a non-extended dyadic DSP instruction.
- FIG. 6E and 6F list the set of 20-bit instructions for the ISA of the present invention.
- FIG. 6G lists the set of extended control instructions for the ISA of the present invention.
- FIG. 6H lists the set of 40-bit DSP instructions for the ISA of the present invention.
- FIG. 6I lists the set of addressing instructions for the ISA of the present invention.
- FIG. 7 is a block diagram illustrating the instruction decoding and configuration of the functional blocks of the signal processing units.
- Each ASSP includes a serial interface, a buffer memory and four core processors in order to simultaneously process multiple channels of voice or data.
- Each core processor preferably includes a reduced instruction set computer (RISC) processor and four signal processing units (SPs).
- RISC reduced instruction set computer
- SPs signal processing units
- Each SP includes multiple arithmetic blocks to simultaneously process multiple voice and data communication signal samples for communication over IP, ATM, Frame Relay, or other packetized network.
- the four signal processing units can execute digital signal processing algorithms in parallel.
- Each ASSP is flexible and can be programmed to perform many network functions or data/voice processing functions, including voice and data compression/decompression in telecommunication systems (such as CODECs), particularly packetized telecommunication networks, simply by altering the software program controlling the commands executed by the ASSP.
- telecommunication systems such as CODECs
- CODECs telecommunication systems
- packetized telecommunication networks simply by altering the software program controlling the commands executed by the ASSP.
- An instruction set architecture for the ASSP is tailored to digital signal processing applications including audio and speech processing such as compression/decompression and echo cancellation.
- the instruction set architecture implemented with the ASSP is adapted to DSP algorithmic structures. This adaptation of the ISA of the present invention to DSP algorithmic structures balances the ease of implementation, processing efficiency, and programmability of DSP algorithms.
- the instruction set architecture may be viewed as being two component parts, one (RISC ISA) corresponding to the RISC control unit and another (DSP ISA) to the DSP datapaths of the signal processing units 300 .
- the RISC ISA is a register based architecture including 16-registers within the register file 413
- the DSP ISA is a memory based architecture with efficient digital signal processing instructions.
- the instruction word for the ASSP is typically 20 bits but can be expanded to 40-bits to control two instructions to the executed in series or parallel, such as two RISC control instruction and extended DSP instructions.
- the instruction set architecture of the ASSP has four distinct types of instructions to optimize the DSP operational mix. These are (1) a 20-bit DSP instruction that uses mode bits in control registers (i.e. mode registers), (2) a 40-bit DSP instruction having control extensions that can override mode registers, (3) a 20-bit dyadic DSP instruction, and (4) a 40 bit dyadic DSP instruction.
- All DSP instructions of the instruction set architecture of the ASSP are dyadic DSP instructions to execute two operations in one instruction with one cycle throughput.
- a dyadic DSP instruction is a combination of two DSP instructions or operations in one instruction and includes a main DSP operation (MAIN OP) and a sub DSP operation (SUB OP).
- MAIN OP main DSP operation
- SUB OP sub DSP operation
- the instruction set architecture of the present invention can be generalized to combining any pair of basic DSP operations to provide very powerful dyadic instruction combinations.
- the DSP arithmetic operations in the preferred embodiment include a multiply instruction (MULT), an addition instruction (ADD), a minimize/maximize instruction (MIN/MAX) also referred to as an extrema instruction, and a no operation instruction (NOP) each having an associated operation code (“opcode”).
- MULT multiply instruction
- ADD addition instruction
- MIN/MAX minimize/maximize instruction
- NOP no operation instruction
- the present invention efficiently executes these dyadic DSP instructions by means of the instruction set architecture and the hardware architecture of the application specific signal processor.
- the system 100 includes a network 101 which is a packetized or packet-switched network, such as IP, ATM, or frame relay.
- the network 101 allows the communication of voice/speech and data between endpoints in the system 100 , using packets. Data may be of any type including audio, video, email, and other generic forms of data.
- the voice or data requires packetization when transceived across the network 101 .
- the system 100 includes gateways 104 A, 104 B, and 104 C in order to packetize the information received for transmission across the network 101 .
- a gateway is a device for connecting multiple networks and devices that use different protocols.
- Voice and data information may be provided to a gateway 104 from a number of different sources in a variety of digital formats.
- analog voice signals are transceived by a telephone 108 .
- digital voice signals are transceived at public branch exchanges (PBX) 112 A and 112 B which are coupled to multiple telephones, fax machines, or data modems.
- Digital voice signals are transceived between PBX 112 A and PBX 112 B with gateways 104 A and 104 C, respectively.
- Digital data signals may also be transceived directly between a digital modem 114 and a gateway 104 A.
- Digital modem 114 may be a Digital Subscriber Line (DSL) modem or a cable modem.
- DSL Digital Subscriber Line
- Data signals may also be coupled into system 100 by a wireless communication system by means of a mobile unit 118 transceiving digital signals or analog signals wirelessly to a base station 116 .
- Base station 116 converts analog signals into digital signals or directly passes the digital signals to gateway 104 B.
- Data may be transceived by means of modem signals over the plain old telephone system (POTS) 107 B using a modem 110 .
- POTS plain old telephone system
- modem signals communicated over POTS 107 B are traditionally analog in nature and are coupled into a switch 106 B of the public switched telephone network (PSTN).
- PSTN public switched telephone network
- analog signals from the POTS 107 B are digitized and transceived to the gateway 104 B by time division multiplexing (TDM) with each time slot representing a channel and one DS0 input to gateway 104 B.
- TDM time division multiplexing
- incoming signals are packetized for transmission across the network 101 .
- Signals received by the gateways 104 A, 104 B and 104 C from the network 101 are depacketized and transcoded for distribution to the appropriate destination.
- a network interface card (NIC) 130 of a gateway 104 is illustrated.
- the NIC 130 includes one or more application-specific signal processors (ASSPs) 150 A- 150 N.
- ASSPs application-specific signal processors
- Line interface devices 131 of NIC 130 provide interfaces to various devices connected to the gateway, including the network 101 . In interfacing to the network 101 , the line interface devices packetize data for transmission out on the network 101 and depacketize data which is to be received by the ASSP devices.
- Line interface devices 131 process information received by the gateway on the receive bus 134 and provides it to the ASSP devices. Information from the ASSP devices 150 is communicated on the transmit bus 132 for transmission out of the gateway.
- a traditional line interface device is a multi-channel serial interface or a UTOPIA device.
- the NIC 130 couples to a gateway backplane/network interface bus 136 within the gateway 104 .
- Bridge logic 138 transceives information between bus 136 and NIC 130 .
- Bridge logic 138 transceives signals between the NIC 130 and the backplane/network interface bus 136 onto the host bus 139 for communication to either one or more of the ASSP devices 150 A- 150 N, a host processor 140 , or a host memory 142 .
- Optionally coupled to each of the one or more ASSP devices 150 A through 150 N are optional local memory 145 A through 145 N (generally referred to as optional local memory 145 ), respectively.
- Digital data on the receive bus 134 and transmit bus 132 is preferably communicated in bit wide fashion. While internal memory within each ASSP may be sufficiently large to be used as a scratchpad memory, optional local memory 145 may be used by each of the ASSPs 150 if additional memory space is necessary.
- Each of the ASSPs 150 provide signal processing capability for the gateway.
- the type of signal processing provided is flexible because each ASSP may execute differing signal processing programs.
- Typical signal processing and related voice packetization functions for an ASSP include (a) echo cancellation; (b) video, audio, and voice/speech compression/decompression (voice/speech coding and decoding); (c) delay handling (packets, frames); (d) loss handling; (e) connectivity (LAN and WAN); (f) security (encryption/decryption); (g) telephone connectivity; (h) protocol processing (reservation and transport protocols, RSVP, TCP/IP, RTP, UDP for IP, and AAL2, AAL1, AAL5 for ATM); (i) filtering; (j) Silence suppression; (k) length handling (frames, packets); and other digital signal processing functions associated with the communication of voice and data over a communication system.
- Each ASSP 150 can perform other functions in order to transmit voice and data to the various endpoints of the system 100 within
- FIG. 2 a block diagram of the ASSP 150 is illustrated.
- Each of the core processors 200 A- 200 D is respectively coupled to a data memory 202 A- 202 D and a program memory 204 A- 204 D.
- Each of the core processors 200 A- 200 D communicates with outside channels through the multi-channel serial interface 206 , the multi-channel memory movement engine 208 , buffer memory 210 , and data memory 202 A- 202 D.
- the ASSP 150 further includes an external memory interface 212 to couple to the external optional local memory 145 .
- the ASSP 150 includes an external host interface 214 for interfacing to the external host processor 140 of FIG.
- the ASSP 150 further includes a microcontroller 223 to perform process scheduling for the core processors 200 A- 200 D and the coordination of the data movement within the ASSP as well as an interrupt controller 224 to assist in interrupt handling and the control of the ASSP 150 .
- Core processor 200 is the block diagram for each of the core processors 200 A- 200 D.
- Data memory 202 and program memory 204 refers to a respective instance of data memory 202 A- 202 D and program memory 204 A- 204 D, respectively.
- the core processor 200 includes four signal processing units SP 0 300 A, SP 1 300 B, SP 2 300 C and SP 3 300 D.
- the core processor 200 further includes a reduced instruction set computer (RISC) control unit 302 and a pipeline control unit 304 .
- RISC reduced instruction set computer
- the signal processing units 300 A- 300 D perform the signal processing tasks on data while the RISC control unit 302 and the pipeline control unit 304 perform control tasks related to the signal processing function performed by the SPs 300 A- 300 D.
- the control provided by the RISC control unit 302 is coupled with the SPs 300 A- 300 D at the pipeline level to yield a tightly integrated core processor 200 that keeps the utilization of the signal processing units 300 at a very high level.
- the signal processing tasks are performed on the datapaths within the signal processing units 300 A- 300 D.
- the nature of the DSP algorithms are such that they are inherently vector operations on streams of data, that have minimal temporal locality (data reuse). Hence, a data cache with demand paging is not used because it would not function well and would degrade operational performance. Therefore, the signal processing units 300 A- 300 D are allowed to access vector elements (the operands) directly from data memory 202 without the overhead of issuing a number of load and store instructions into memory resulting, in very efficient data processing.
- the instruction set architecture of the present invention having a 20 bit instruction word which can be expanded to a 40 bit instruction word, achieves better efficiencies than VLIW architectures using 256-bits or higher instruction widths by adapting the ISA to DSP algorithmic structures.
- the adapted ISA leads to very compact and low-power hardware that can scale to higher computational requirements.
- the operands that the ASSP can accommodate are varied in data type and data size.
- the data type may be real or complex, an integer value or a fractional value, with vectors having multiple elements of different sizes.
- the data size in the preferred embodiment is 64 bits but larger data sizes can be accommodated with proper instruction coding.
- RISC control unit 302 includes a data aligner and formatter 402 , a memory address generator 404 , three adders 406 A- 406 C, an arithmetic logic unit (ALU) 408 , a multiplier 410 , a barrel shifter 412 , and a register file 413 .
- the register file 413 points to a starting memory location from which memory address generator 404 can generate addresses into data memory 202 .
- the RISC control unit 302 is responsible for supplying addresses to data memory so that the proper data stream is fed to the signal processing units 300 A- 300 D.
- the RISC control unit 302 is a register to register organization with load and store instructions to move data to and from data memory 202 .
- Data memory addressing is performed by RISC control unit using a 32-bit register as a pointer that specifies the address, post-modification offset, and type and permute fields.
- the type field allows a variety of natural DSP data to be supported as a “first class citizen” in the architecture. For instance, the complex type allows direct operations on complex data stored in memory removing a number of bookkeeping instructions. This is useful in supporting QAM demodulators in data modems very efficiently.
- FIG. 5A a block diagram of a signal processing unit 300 is illustrated which represents an instance of the SPs 300 A- 300 D.
- Each of the signal processing units 300 includes a data typer and aligner 502 , a first multiplier M 1 504 A, a compressor 506 , a first adder A 1 510 A, a second adder A 2 510 B, an accumulator register 512 , a third adder A 3 510 C, and a second multiplier M 2 504 B.
- Adders 510 A- 510 C are similar in structure and are generally referred to as adder 510 .
- Multipliers 504 A and 504 B are similar in structure and generally referred to as multiplier 504 .
- Each of the multipliers 504 A and 504 B have a multiplexer 514 A and 514 B respectively at its input stage to multiplex different inputs from different busses into the multipliers.
- Each of the adders 510 A, 510 B, 510 C also have a multiplexer 520 A, 520 B, and 520 C respectively at its input stage to multiplex different inputs from different busses into the adders.
- These multiplexers and other control logic allow the adders, multipliers and other components within the signal processing units 300 A- 300 C to be flexibly interconnected by proper selection of multiplexers.
- multiplier M 1 504 A, compressor 506 , adder A 1 510 A, adder A 2 510 B and accumulator 512 can receive inputs directly from external data buses through the data typer and aligner 502 .
- adder 510 C and multiplier M 2 504 B receive inputs from the accumulator 512 or the outputs from the execution units multiplier M 1 504 A, compressor 506 , adder A 1 510 A, and adder A 2 510 B.
- Program memory 204 couples to the pipe control 304 which includes an instruction buffer that acts as a local loop cache.
- the instruction buffer in the preferred embodiment has the capability of holding four instructions.
- the instruction buffer of the pipe control 304 reduces the power consumed in accessing the main memories to fetch instructions during the execution of program loops.
- FIG. 5B a more detailed block diagram of the functional blocks and the bus structure of the signal processing unit is illustrated.
- Dyadic DSP instructions are possible because of the structure and functionality provided in each signal processing unit.
- Output signals are coupled out of the signal processor 300 on the Z output bus 532 through the data typer and aligner 502 .
- Input signals are coupled into the signal processor 300 on the X input bus 531 and Y input bus 533 through the data typer and aligner 502 .
- the data typer and aligner 502 has a different data bus to couple to each of multiplier M 1 504 A, compressor 506 , adder A 1 510 A, adder A 2 510 B, and accumulator register AR 512 .
- Output data is coupled from the accumulator register AR 512 into the data typer and aligner 502 .
- Multiplier M 1 504 A has buses to couple its output into the inputs of the compressor 506 , adder A 1 510 A, adder A 2 510 B, and the accumulator registers AR 512 .
- Compressor 506 has buses to couple its output into the inputs of adder A 1 510 A and adder A 2 510 B.
- Adder A 1 510 A has a bus to couple its output into the accumulator registers 512 .
- Adder A 2 510 B has buses to couple its output into the accumulator registers 512 .
- Accumulator registers 512 has buses to couple its output into multiplier M 2 504 B, adder A 3 510 C, and data typer and aligner 502 .
- Adder A 3 510 C has buses to couple its output into the multiplier M 2 504 B and the accumulator registers 512 .
- Multiplier M 2 504 B has buses to couple its output into the inputs of the adder A 3 510 C and the accumulator registers AR 512 .
- the instruction set architecture of the ASSP 150 is tailored to digital signal processing applications including audio and speech processing such as compression/decompression and echo cancellation.
- the instruction set architecture implemented with the ASSP 150 is adapted to DSP algorithmic structures.
- the adaptation of the ISA of the present invention to DSP algorithmic structures is a balance between ease of implementation, processing efficiency, and programmability of DSP algorithms.
- the ISA of the present invention provides for data movement operations, DSP/arithmetic/logical operations, program control operations (such as function calls/returns, unconditional/conditional jumps and branches), and system operations (such as privilege, interrupt/trap/hazard handling and memory management control).
- an exemplary instruction sequence 600 is illustrated for a DSP algorithm program model employing the instruction set architecture of the present invention.
- the instruction sequence 600 has an outer loop 601 and an inner loop 602 . Because DSP algorithms tend to perform repetitive computations, instructions 60 S within the inner loop 602 are executed more often than others.
- Instructions 603 are typically parameter setup code to set the memory pointers, provide for the setup of the outer loop 601 , and other 2 ⁇ 20 control instructions.
- Instructions 607 are typically context save and function return instructions or other 2 ⁇ 20 control instructions. Instructions 603 and 607 are often considered overhead instructions which are typically infrequently executed.
- Instructions 604 are typically to provide the setup for the inner loop 602 , other control through 2 ⁇ 20 control instructions, or offset extensions for pointer backup.
- Instructions 606 typically provide tear down of the inner loop 602 , other control through 2 ⁇ 20 control instructions, and combining of datapath results within the signal processing units.
- Instructions 605 within the inner loop 602 typically provide inner loop execution of DSP operations, control of the four signal processing units 300 in a single instruction multiple data execution mode, memory access for operands, dyadic DSP operations, and other DSP functionality through the 20/40 bit DSP instructions of the ISA of the present invention. Because instructions 605 are so often repeated, significant improvement in operational efficiency may be had by providing the DSP instructions, including general dyadic instructions and dyadic DSP instructions, within the ISA of the present invention.
- the instruction set architecture of the ASSP 150 can be viewed as being two component parts, one (RISC ISA) corresponding to the RISC control unit and another (DSP ISA) to the DSP datapaths of the signal processing units 300 .
- the RISC ISA is a register based architecture including sixteen registers within the register file 413
- the DSP ISA is a memory based architecture with efficient digital signal processing instructions.
- the instruction word for the ASSP is typically 20 bits but can be expanded to 40-bits to control two RISC or DSP instructions to be executed in series or parallel, such as a RISC control instruction executed in parallel with a DSP instruction, or a 40 bit extended RISC or DSP instruction.
- the ISA of the ASSP 150 which accelerates these calculations allows efficient chaining of different combinations of operations. Because these type of operations require three operands, they must be available to the processor. However, because the device size places limits on the bus structure, bandwidth is limited to two vector reads and one vector write each cycle into and out of data memory 202 . Thus one of the operands, such as B or C, needs to come from another source within the core processor 200 . The third operand can be placed into one of the registers of the accumulator 512 or the RISC register file 413 .
- the ISA of the ASSP 150 is fully predicated providing for execution prediction.
- a 6-bit specifier is used in the DSP extended instructions to access operands in memory and registers.
- the MSB (Bit 5 ) indicates whether the access is a memory access or register access. In the preferred embodiment, if Bit 5 is set to logical one, it denotes a memory access for an operand. If Bit 5 is set to a logical zero, it denotes a register access for an operand.
- Bit 5 If Bit 5 is set to 1, the contents of a specified register (rX where X: 0-7) are used to obtain the effective memory address and post-modify the pointer field by one of two possible offsets specified in one of the specified rX registers. If Bit 5 is set to 0, Bit 4 determines what register set has the contents of the desired operand. If Bit- 4 is set to 0, then the remaining specified bits 3:0 control access to the registers within the register file 413 or to registers within the signal processing units 300 .
- rX where X: 0-7
- Multiply Controls the execution of the main multiplier connected to data buses from memory. Controls: Rounding, sign of multiply Operates on vector data specified through type field in address register
- Second operation Add, Sub, Min, Max in vector or scalar mode
- the ASSP 150 can execute these DSP arithmetic operations in vector or scalar fashion. In scalar execution, a reduction or combining operation is performed on the vector results to yield a scalar result. It is common in DSP applications to perform scalar operations, which are efficiently performed by the ASSP 150 .
- the 20-bit DSP instruction words have 4-bit operand specifiers that can directly access data memory using 8 address registers (r 0 -r 7 ) within the register file 413 of the RISC control unit 302 .
- the method of addressing by the 20 bit DSP instruction word is regular indirect with the address register specifying the pointer into memory, post-modification value, type of data accessed and permutation of the data needed to execute the algorithm efficiently. All of the DSP instructions control the multipliers 504 A- 504 B, adders 510 A- 510 C, compressor 506 and the accumulator 512 , the functional units of each signal processing unit 300 A- 300 D.
- Offset extensions that can replace or extend the offsets specified in the address registers
- DSP extensions that control the lower rows of functional units within a signal processing unit 300 to accelerate block processing.
- the 40-bit control instructions with the 20 bit extensions further allow a large immediate value (16 to 20 bits) to be specified in the instruction and powerful bit manipulation instructions.
- Efficient DSP execution is provided with 2 ⁇ 20-bit DSP instructions with the first 20-bits controlling the top functional units (adders 501 A and 510 B, multiplier 504 A, compressor 506 ) that interface to data buses from memory and the second 20 bits controlling the bottom functional units (adder 510 C and multiplier 504 B) that use internal or local data as operands.
- the top functional units also referred to as main units, reduce the inner loop cycles in the inner loop 602 by parallelizing across consecutive taps or sections.
- the bottom functional units cut the outer loop cycles in the outer loop 601 in half by parallelizing block DSP algorithms across consecutive samples.
- Efficient DSP execution is also improved by the hardware architecture of the present invention. In this case, efficiency is improved in the manner that data is supplied to and from data memory 202 to feed the four signal processing units 300 and the DSP functional units therein.
- the data highway is comprised of two buses, X bus 531 and Y bus 533 , for X and Y source operands, and one Z bus 532 for a result write. All buses, including X bus 531 , Y bus 533 , and Z bus 532 , are preferably 64 bits wide. The buses are uni-directional to simplify the physical design and reduce transit times of data.
- the parallel load field can only access registers within the register file 413 of the RISC control unit 302 .
- the four signal processing units 300 A- 300 D in parallel provide four parallel MAC units (multiplier 504 A, adder 510 A, and accumulator 512 ) that can make simultaneous computations. This reduces the cycle count from 4 cycles ordinarily required to perform four MACs to only one cycle.
- All DSP instructions of the instruction set architecture of the ASSP 150 are dyadic DSP instructions within the 20 bit or 40 bit instruction word.
- a dyadic DSP instruction informs the ASSP in one instruction and one cycle to perform two operations.
- FIG. 6B is a chart illustrating the permutations of the dyadic DSP instructions.
- the dyadic DSP instruction 610 includes a main DSP operation 611 (MAIN OP) and a sub DSP operation 612 (SUB OP), a combination of two DSP instructions or operations in one dyadic instruction.
- the instruction set architecture of the present invention can be generalized to combining any pair of basic DSP operations to provide very powerful dyadic instruction combinations.
- Compound DSP operational instructions can provide uniform acceleration for a wide variety of DSP algorithms not just multiply-accumulate intensive filters.
- the DSP instructions or operations in the preferred embodiment include a multiply instruction (MULT), an addition instruction (ADD), a minimize/maximize instruction (MIN/MAX) also referred to as an extrema instruction, and a no operation instruction (NOP) each having an associated operation code (“opcode”). Any two DSP instructions can be combined together to form a dyadic DSP instruction.
- the NOP instruction is used for the MAIN OP or SUB OP when a single DSP operation is desired to be executed by the dyadic DSP instruction.
- There are variations of the general DSP instructions such as vector and scalar operations of multiplication or addition, positive or negative multiplication, and positive or negative addition (i.e. subtraction)
- FIG. 6C illustrates bitmap syntax for a control extended dyadic DSP instruction
- FIG. 6D illustrates bitmap syntax for a non-extended dyadic DSP instruction.
- the instruction word is the twenty most significant bits of a forty bit word while the extended bitmap syntax has an instruction word of forty bits.
- the three most significant bits (MSBs), bits numbered 37 through 39 in each indicate the MAIN OP instruction type while the SUB OP is located near the middle or end of the instruction bits at bits numbered 20 through 22 .
- the MAIN OP instruction codes are 000 for NOP, 101 for ADD, 110 for MIN/MAX, and 100 for MULT.
- the SUB OP code for the given DSP instruction varies according to what MAIN OP code is selected. In the case of MULT as the MAIN OP, the SUB OPs are 000 for NOP, 001 or 010 for ADD, 100 or 011 for a negative ADD or subtraction, 101 or 110 for MIN, and 111 for MAX.
- the MAIN OP and the SUB OP are not the same DSP instruction although alterations to the hardware functional blocks could accommodate it.
- the bitmap syntax of the dyadic DSP instruction can be converted into text syntax for program coding.
- its text syntax for multiplication or MULT is (vmul
- vmuln” field refers to either positive vector multiplication or negative vector multiplication being selected as the MAIN OP.
- smax”, refers to either vector add, vector subtract, vector maximum, scalar add, scalar subtraction, or scalar maximum being selected as the SUB OP.
- the next field, “da”, refers to selecting one of the registers within the accumulator for storage of results.
- the field “sx” refers to selecting a register within the RISC register file 413 which points to a memory location in memory as one of the sources of operands.
- the field “sa” refers to selecting the contents of a register within the accumulator as one of the sources of operands.
- the field “sy” refers to selecting a register within the RISC register file 413 which points to a memory location in memory as another one of the sources of operands.
- ps1)]” refers to pair selection of keyword PS 0 or PS 1 specifying which are the source-destination pairs of a parallel-store control register.
- FIG. 6E and 6F lists of the set of 20-bit DSP and control instructions for the ISA of the present invention is illustrated.
- FIG. 6G lists the set of extended control instructions for the ISA of the present invention.
- FIG. 6H lists the set of 40-bit DSP instructions for the ISA of the present invention.
- FIG. 6I lists the set of addressing instructions for the ISA of the present invention.
- the signal processor 300 includes the final decoders 704 A through 704 N, and multiplexers 720 A through 720 N.
- the multiplexers 720 A through 720 N are representative of the multiplexers 514 , 516 , 520 , and 522 in FIG. 5B .
- the predecoding 702 is provided by the RISC control unit 302 and the pipe control 304 .
- An instruction is provided to the predecoding 702 such as a dyadic DSP instruction 600 .
- the predecoding 702 provides preliminary signals to the appropriate final decoders 704 A through 704 N on how the multiplexers 720 A through 720 N are to be selected for the given instruction.
- the MAIN OP generally, if not a NOP, is performed by the blocks of the multiplier M 1 504 A, compressor 506 , adder A 1 510 A, and adder A 2 510 B.
- the result is stored in one of the registers within the accumulator register AR 512 .
- the SUB OP generally, if not a NOP, is performed by the blocks of the adder A 3 510 C and the multiplier M 2 504 B.
- the dyadic DSP instruction is to perform is an ADD and MULT
- the ADD operation of the MAIN OP is performed by the adder A 1 510 A
- the SUB OP is performed by the multiplier M 1 504 A.
- the predecoding 720 and the final decoders 704 A through 704 N appropriately select the respective multiplexers 720 A through 720 B to select the MAIN OP to be performed by the adder A 1 510 A and the SUB OP to be performed by the multiplier M 2 504 B.
- multiplexer 520 A selects inputs from the data typer and aligner 502 in order for adder A 1 510 A to perform the ADD operation
- multiplexer 522 selects the output from adder 510 A for accumulation in the accumulator 512
- multiplexer 514 B selects outputs from the accumulator 512 as its inputs to perform the MULT SUB OP.
- the MAIN OP and SUB OP can be either executed sequentially (i.e. serial execution on parallel words) or in parallel (i.e. parallel execution on parallel words). If implemented sequentially, the result of the MAIN OP may be an operand of the SUB OP.
- the final decoders 704 A through 704 N have their own control logic to properly time the sequence of multiplexer selection for each element of the signal processor 300 to match the pipeline execution of how the MAIN OP and SUB OP are executed, including sequential or parallel execution.
- the RISC control unit 302 and the pipe control 304 in conjunction with the final decoders 704 A through 704 N pipelines instruction execution by pipelining the instruction itself and by providing pipelined control signals. This allows for the data path to be reconfigured by the software instructions each cycle.
- the present invention has many advantages.
- One advantage of the present invention is that the ISA is adapted to DSP algorithmic structures providing compact hardware to consume low-power which can be scaled to higher computational requirements.
- Another advantage of the present invention is that the signal processing units have direct access to operands in memory to reduce processing overhead associated with load and store instructions.
- Another advantage of the present invention is that pipelined instruction execution is provided so that instructions may be issued every cycle.
- Another advantage of the present invention is that the signal processing units can be configured cycle by cycle.
- the present invention has been described in particular embodiments, it may be implemented in hardware, software, firmware or a combination thereof and utilized in systems, subsystems, components or sub-components thereof.
- the elements of the present invention are essentially the code segments to perform the necessary tasks.
- the program or code segments can be stored in a processor readable medium or transmitted by a computer data signal embodied in a carrier wave over a transmission medium or communication link.
- the “processor readable medium” may include any medium that can store or transfer information.
- Examples of the processor readable medium include an electronic circuit, a semiconductor memory device, a ROM, a flash memory, an erasable ROM (EROM), a floppy diskette, a CD-ROM, an optical disk, a hard disk, a fiber optic medium, a radio frequency (RF) link, etc.
- the computer data signal may include any signal that can propagate over a transmission medium such as electronic network channels, optical fibers, air, electromagnetic, RF links, etc.
- the code segments may be downloaded via computer networks such as the Internet, Intranet, etc. In any case, the present invention should not be construed as limited by such embodiments, but rather construed according to the claims that follow below.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Computational Mathematics (AREA)
- Pure & Applied Mathematics (AREA)
- Mathematical Optimization (AREA)
- Computing Systems (AREA)
- Mathematical Analysis (AREA)
- Advance Control (AREA)
- Executing Machine-Instructions (AREA)
- Complex Calculations (AREA)
Abstract
An instruction set architecture (ISA) for application specific signal processor (ASSP) is tailored to digital signal processing applications. The instruction set architecture implemented with the ASSP, is adapted to DSP algorithmic structures. The instruction word of the ISA is typically 20 bits but can be expanded to 40-bits to control two instructions to be executed in series or parallel. All DSP instructions of the ISA are dyadic DSP instructions performing two operations with one instruction in one cycle. The DSP instructions or operations in the preferred embodiment include a multiply instruction (MULT), an addition instruction (ADD), a minimize/maximize instruction (MIN/MAX) also referred to as an extrema instruction, and a no operation instruction (NOP) each having an associated operation code (“opcode”). The present invention efficiently executes DSP instructions by means of the instruction set architecture and the hardware architecture of the application specific signal processor.
Description
- This invention relates generally to the instruction set architectures (ISA) of processors. More particularly, the invention relates to instruction set architectures for the execution of operations within a signal processing integrated circuit.
- Single chip digital signal processing devices (DSP) are relatively well known. DSPs generally are distinguished from general purpose microprocessors in that DSPs typically support accelerated arithmetic operations by including a dedicated multiplier and accumulator (MAC) for performing multiplication of digital numbers. The instruction set for a typical DSP device usually includes a MAC instruction for performing multiplication of new operands and addition with a prior accumulated value stored within an accumulator register. A MAC instruction is typically the only instruction provided in prior art digital signal processors where two DSP operations, multiply followed by add, are performed by the execution of one instruction. However, when performing signal processing functions on data it is often desirable to perform other DSP operations in varying combinations.
- An area where DSPs may be utilized is in telecommunication systems. One use of DSPs in telecommunication systems is digital filtering. In this case a DSP is typically programmed with instructions to implement some filter function in the digital or time domain. The mathematical algorithm for a typical finite impulse response (FIR) filter may look like the equation Yn=h0x0+h1X1+h2X2+ . . . +hNXN where hn are fixed filter coefficients numbering from 1 to N and Xn are the data samples. The equation Yn may be evaluated by using a software program. However in some applications, it is necessary that the equation be evaluated as fast as possible. One way to do this is to perform the computations using hardware components such as a DSP device programmed to compute the equation Yn. In order to further speed the process, it is desirable to vectorize the equation and distribute the computation amongst multiple DSPs such that the final result is obtained more quickly. The multiple DSPs operate in parallel to speed the computation process. In this case, the multiplication of terms is spread across the multipliers of the DSPs equally for simultaneous computations of terms. The adding of terms is similarly spread equally across the adders of the DSPs for simultaneous computations. In vectorized processing, the order of processing terms is unimportant since the combination is associative. If the processing order of the terms is altered, it has no effect on the final result expected in a vectorized processing of a function.
- In typical micro processors, a MAC operation would require a multiply instruction and an add instruction to perform both multiplication and addition. To perform these two instructions would require two processing cycles. Additionally, a program written for the typical micro processor would require a larger program memory in order to store the extra instructions necessary to perform the MAC operation. In prior art DSP devices, if a DSP operation other than a MAC DSP instruction need be performed, the operation requires separate arithmetic instructions programmed into program memory. These separate arithmetic instructions in prior art DSPs similarly require increased program memory space and processing cycles to perform the operation when compared to a single MAC instruction. It is desirable to reduce the number of processing cycles when performing DSP operations. It is desirable to reduce program memory requirements as well.
- DSPs are often programmed in a loop to continuously perform accelerated arithmetic functions including a MAC instruction using different operands. Often times, multiple arithmetic instructions are programmed in a loop to operate on the same data set. The same arithmetic instruction is often executed over and over in a loop using different operands. Additionally, each time one instruction is completed, another instruction is fetched from the program stored in memory during a fetch cycle. Fetch cycles require one or more cycle times to access a memory before instruction execution occurs. Because circuits change state during a fetch cycle, power is consumed and thus it is desirable to reduce the number of fetch cycles. Typically, approximately twenty percent of power consumption may be utilized in the set up and clean up operations of a loop in order to execute DSP instructions. Typically, the loop execution where signal processing of data is performed consumes approximately eighty percent of power consumption with a significant portion being due to instruction fetching. Additionally, because data sets that a DSP device process are usually large, it is also desirable to speed instruction execution by avoiding frequent fetch cycles to memory.
- Additionally, the quality of service over a telephone system often relates to the processing speed of signals. That is particularly the case when a DSP is to provide voice processing, such as voice compression, voice decompression, and echo cancellation for multiple channels. More recently, processing speed has become even more important because of the desire to transmit voice aggregated with data in a packetized form for communication over packetized networks. Delays in processing the packetized voice signal tend to result in the degradation of signal quality on receiving ends.
- It is desirable to provide improved processing of voice and data signals to enhance the quality of voice and data communication over packetized networks. It is desirable to improve the efficiency of using computing resources when performing signal processing functions.
- Briefly, the present invention includes a method, apparatus and system as described in the claims. Multiple application specific signal processor (ASSP) having the instruction set architecture of the present invention, including the dyadic DSP instructions, are provided within gateways in communication systems to provide improved voice and data communication over a packetized network. Each ASSP includes a serial interface, a buffer memory, and four core processors for each to simultaneously process multiple channels of voice or data. Each core processor preferably includes a reduced instruction set computer (RISC) processor and four signal processing units (SPs). Each SP includes multiple arithmetic blocks to simultaneously process multiple voice and data communication signal samples for communication over IP, ATM, Frame Relay or other packetized network. The four signal processing units can execute the digital signal processing algorithms in parallel. Each ASSP is flexible and can be programmed to perform many network functions or data/voice processing functions, including voice and data compression/decompression in telecommunications systems (such as CODECs) particularly packetized telecommunication networks, simply by altering the software program controlling the commands executed by the ASSP.
- An instruction set architecture for the ASSP is tailored to digital signal processing applications including audio and speech processing such as compression/decompression and echo cancellation. The instruction set architecture implemented with the ASSP, is adapted to DSP algorithmic structures. This adaptation of the ISA of the present invention to DSP algorithmic structures balances the ease of implementation, processing efficiency, and programmability of DSP algorithms. The instruction set architecture may be viewed as being two component parts, one (RISC ISA) corresponding to the RISC control unit and another (DSP ISA) to the DSP datapaths of the
signal processing units 300. The RISC ISA is a register based architecture including 16-registers within theregister file 413, while the DSP ISA is a memory based architecture with efficient digital signal processing instructions. The instruction word for the ASSP is typically 20 bits but can be expanded to 40-bits to control two instructions to be executed in series or parallel, such as two RISC control instructions and extended DSP instructions. The instruction set architecture of the ASSP has four distinct types of instructions to optimize the DSP operational mix. These are (1) a 20-bit DSP instruction that uses mode bits in control registers (i.e. mode registers), (2) a 40-bit DSP instruction having control extensions that can override mode registers, (3) a 20-bit dyadic DSP instruction, and (4) a 40 bit dyadic DSP instruction. These instructions are for accelerating calculations within the core processor of the type where D=[(A op1 B) op2 C ] and each of “op1” and “op2” can be a multiply, add, extremum (min/max) or other primitive DSP class of operation on the three operands A, B, and C. The ISA of the ASSP which accelerates these calculations allows efficient chaining of different combinations of operations. All DSP instructions of the instruction set architecture of the ASSP are dyadic DSP instructions to execute two operations in one instruction with one cycle throughput. A dyadic DSP instruction is a combination of two basic DSP operations in one instruction and includes a main DSP operation (MAIN OP) and a sub DSP operation (SUB OP). Generally, the instruction set architecture of the present invention can be generalized to combining any pair of basic DSP operations to provide very powerful dyadic instruction combinations. The DSP arithmetic instructions or operations in the preferred embodiment include a multiply instruction (MULT), an addition instruction (ADD), a minimize/maximize instruction (MIN/MAX) also referred to as an extrema instruction, and a no operation instruction (NOP) each having an associated operation code (“opcode”). The present invention efficiently executes these dyadic DSP instructions by means of the instruction set architecture and the hardware architecture of the application specific signal processor. For example, the DSP instructions can process vector data or scalar data automatically using a single instruction and provide the appropriate vector or scalar output results. -
FIG. 1A is a block diagram of a system utilizing the present invention. -
FIG. 1B is a block diagram of a printed circuit board utilizing the present invention within the gateways of the system inFIG. 1A . -
FIG. 2 is a block diagram of the Application Specific Signal Processor (ASSP) of the present invention. -
FIG. 3 is a block diagram of an instance of the core processors within the ASSP of the present invention. -
FIG. 4 is a block diagram of the RISC processing unit within the core processors ofFIG. 3 . -
FIG. 5A is a block diagram of an instance of the signal processing units within the core processors ofFIG. 3 . -
FIG. 5B is a more detailed block diagram ofFIG. 5A illustrating the bus structure of the signal processing unit. -
FIG. 6A is an exemplary instruction sequence illustrating a program model for DSP algorithms employing the instruction set architecture of the present invention. -
FIG. 6B is a chart illustrating the permutations of the dyadic DSP instructions. -
FIG. 6C is an exemplary bitmap for a control extended dyadic DSP instruction. -
FIG. 6D is an exemplary bitmap for a non-extended dyadic DSP instruction. -
FIG. 6E and 6F list the set of 20-bit instructions for the ISA of the present invention. -
FIG. 6G lists the set of extended control instructions for the ISA of the present invention. -
FIG. 6H lists the set of 40-bit DSP instructions for the ISA of the present invention. -
FIG. 6I lists the set of addressing instructions for the ISA of the present invention. -
FIG. 7 is a block diagram illustrating the instruction decoding and configuration of the functional blocks of the signal processing units. - Like reference numbers and designations in the drawings indicate like elements providing similar functionality. A letter after a reference designator number represents an instance of an element having the reference designator number.
- In the following detailed description of the present invention, numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will be obvious to one skilled in the art that the present invention may be practiced without these specific details. In other instances well known methods, procedures, components, and circuits have not been described in detail so as not to unnecessarily obscure aspects of the present invention. Furthermore, the present invention will be described in particular embodiments but may be implemented in hardware, software, firmware or a combination thereof
- Multiple application specific signal processors (ASSPs) having the instruction set architecture of the present invention, including dyadic DSP instructions, are provided within gateways in communication systems to provide improved voice and data communication over a packetized network. Each ASSP includes a serial interface, a buffer memory and four core processors in order to simultaneously process multiple channels of voice or data. Each core processor preferably includes a reduced instruction set computer (RISC) processor and four signal processing units (SPs). Each SP includes multiple arithmetic blocks to simultaneously process multiple voice and data communication signal samples for communication over IP, ATM, Frame Relay, or other packetized network. The four signal processing units can execute digital signal processing algorithms in parallel. Each ASSP is flexible and can be programmed to perform many network functions or data/voice processing functions, including voice and data compression/decompression in telecommunication systems (such as CODECs), particularly packetized telecommunication networks, simply by altering the software program controlling the commands executed by the ASSP.
- An instruction set architecture for the ASSP is tailored to digital signal processing applications including audio and speech processing such as compression/decompression and echo cancellation. The instruction set architecture implemented with the ASSP, is adapted to DSP algorithmic structures. This adaptation of the ISA of the present invention to DSP algorithmic structures balances the ease of implementation, processing efficiency, and programmability of DSP algorithms. The instruction set architecture may be viewed as being two component parts, one (RISC ISA) corresponding to the RISC control unit and another (DSP ISA) to the DSP datapaths of the
signal processing units 300. The RISC ISA is a register based architecture including 16-registers within theregister file 413, while the DSP ISA is a memory based architecture with efficient digital signal processing instructions. The instruction word for the ASSP is typically 20 bits but can be expanded to 40-bits to control two instructions to the executed in series or parallel, such as two RISC control instruction and extended DSP instructions. The instruction set architecture of the ASSP has four distinct types of instructions to optimize the DSP operational mix. These are (1) a 20-bit DSP instruction that uses mode bits in control registers (i.e. mode registers), (2) a 40-bit DSP instruction having control extensions that can override mode registers, (3) a 20-bit dyadic DSP instruction, and (4) a 40 bit dyadic DSP instruction. These instructions are for accelerating calculations within the core processor of the type where D=[(A op1 B) op2 C] and each of “op1” and “op2” can be a multiply, add or extremum (min/max) class of operation on the three operands A, B, and C. The ISA of the ASSP which accelerates these calculations allows efficient chaining of different combinations of operations. - All DSP instructions of the instruction set architecture of the ASSP are dyadic DSP instructions to execute two operations in one instruction with one cycle throughput. A dyadic DSP instruction is a combination of two DSP instructions or operations in one instruction and includes a main DSP operation (MAIN OP) and a sub DSP operation (SUB OP). Generally, the instruction set architecture of the present invention can be generalized to combining any pair of basic DSP operations to provide very powerful dyadic instruction combinations. The DSP arithmetic operations in the preferred embodiment include a multiply instruction (MULT), an addition instruction (ADD), a minimize/maximize instruction (MIN/MAX) also referred to as an extrema instruction, and a no operation instruction (NOP) each having an associated operation code (“opcode”).
- The present invention efficiently executes these dyadic DSP instructions by means of the instruction set architecture and the hardware architecture of the application specific signal processor.
- Referring now to
FIG. 1A , a voice anddata communication system 100 is illustrated. Thesystem 100 includes anetwork 101 which is a packetized or packet-switched network, such as IP, ATM, or frame relay. Thenetwork 101 allows the communication of voice/speech and data between endpoints in thesystem 100, using packets. Data may be of any type including audio, video, email, and other generic forms of data. At each end of thesystem 100, the voice or data requires packetization when transceived across thenetwork 101. Thesystem 100 includesgateways 104A, 104B, and 104C in order to packetize the information received for transmission across thenetwork 101. A gateway is a device for connecting multiple networks and devices that use different protocols. Voice and data information may be provided to agateway 104 from a number of different sources in a variety of digital formats. Insystem 100, analog voice signals are transceived by atelephone 108. Insystem 100, digital voice signals are transceived at public branch exchanges (PBX) 112A and 112B which are coupled to multiple telephones, fax machines, or data modems. Digital voice signals are transceived betweenPBX 112A and PBX 112B withgateways 104A and 104C, respectively. Digital data signals may also be transceived directly between adigital modem 114 and agateway 104A.Digital modem 114 may be a Digital Subscriber Line (DSL) modem or a cable modem. Data signals may also be coupled intosystem 100 by a wireless communication system by means of amobile unit 118 transceiving digital signals or analog signals wirelessly to abase station 116.Base station 116 converts analog signals into digital signals or directly passes the digital signals to gateway 104B. Data may be transceived by means of modem signals over the plain old telephone system (POTS) 107B using amodem 110. Modem signals communicated over POTS 107B are traditionally analog in nature and are coupled into aswitch 106B of the public switched telephone network (PSTN). At theswitch 106B, analog signals from the POTS 107B are digitized and transceived to the gateway 104B by time division multiplexing (TDM) with each time slot representing a channel and one DS0 input to gateway 104B. At each of thegateways 104A, 104B and 104C, incoming signals are packetized for transmission across thenetwork 101. Signals received by thegateways 104A, 104B and 104C from thenetwork 101 are depacketized and transcoded for distribution to the appropriate destination. - Referring now to
FIG. 1B , a network interface card (NIC) 130 of agateway 104 is illustrated. TheNIC 130 includes one or more application-specific signal processors (ASSPs) 150A-150N. The number of ASSPs within a gateway is expandable to handle additional channels.Line interface devices 131 ofNIC 130 provide interfaces to various devices connected to the gateway, including thenetwork 101. In interfacing to thenetwork 101, the line interface devices packetize data for transmission out on thenetwork 101 and depacketize data which is to be received by the ASSP devices.Line interface devices 131 process information received by the gateway on the receivebus 134 and provides it to the ASSP devices. Information from theASSP devices 150 is communicated on the transmitbus 132 for transmission out of the gateway. A traditional line interface device is a multi-channel serial interface or a UTOPIA device. TheNIC 130 couples to a gateway backplane/network interface bus 136 within thegateway 104.Bridge logic 138 transceives information betweenbus 136 andNIC 130.Bridge logic 138 transceives signals between theNIC 130 and the backplane/network interface bus 136 onto thehost bus 139 for communication to either one or more of theASSP devices 150A-150N, ahost processor 140, or ahost memory 142. Optionally coupled to each of the one ormore ASSP devices 150A through 150N (generally referred to as ASSP 150) are optional local memory 145A through 145N (generally referred to as optional local memory 145), respectively. Digital data on the receivebus 134 and transmitbus 132 is preferably communicated in bit wide fashion. While internal memory within each ASSP may be sufficiently large to be used as a scratchpad memory, optional local memory 145 may be used by each of theASSPs 150 if additional memory space is necessary. - Each of the
ASSPs 150 provide signal processing capability for the gateway. The type of signal processing provided is flexible because each ASSP may execute differing signal processing programs. Typical signal processing and related voice packetization functions for an ASSP include (a) echo cancellation; (b) video, audio, and voice/speech compression/decompression (voice/speech coding and decoding); (c) delay handling (packets, frames); (d) loss handling; (e) connectivity (LAN and WAN); (f) security (encryption/decryption); (g) telephone connectivity; (h) protocol processing (reservation and transport protocols, RSVP, TCP/IP, RTP, UDP for IP, and AAL2, AAL1, AAL5 for ATM); (i) filtering; (j) Silence suppression; (k) length handling (frames, packets); and other digital signal processing functions associated with the communication of voice and data over a communication system. EachASSP 150 can perform other functions in order to transmit voice and data to the various endpoints of thesystem 100 within a packet data stream over a packetized network. - Referring now to
FIG. 2 , a block diagram of theASSP 150 is illustrated. At the heart of theASSP 150 are fourcore processors 200A-200D. Each of thecore processors 200A-200D is respectively coupled to a data memory 202A-202D and aprogram memory 204A-204D. Each of thecore processors 200A-200D communicates with outside channels through the multi-channel serial interface 206, the multi-channelmemory movement engine 208,buffer memory 210, and data memory 202A-202D. TheASSP 150 further includes anexternal memory interface 212 to couple to the external optional local memory 145. TheASSP 150 includes anexternal host interface 214 for interfacing to theexternal host processor 140 ofFIG. 1B .—Further included within theASSP 150 aretimers 216, clock generators and a phase-lock loop 218,miscellaneous control logic 220, and a Joint Test Action Group (JTAG)test access port 222 for boundary scan testing. The multi-channel serial interface 206 may be replaced with a UTOPIA parallel interface for some applications such as ATM. TheASSP 150 further includes amicrocontroller 223 to perform process scheduling for thecore processors 200A-200D and the coordination of the data movement within the ASSP as well as an interruptcontroller 224 to assist in interrupt handling and the control of theASSP 150. - Referring now to
FIG. 3 , a block diagram of thecore processor 200 is illustrated coupled to itsrespective data memory 202 andprogram memory 204.Core processor 200 is the block diagram for each of thecore processors 200A-200D.Data memory 202 andprogram memory 204 refers to a respective instance of data memory 202A-202D andprogram memory 204A-204D, respectively. Thecore processor 200 includes four signalprocessing units SP0 300A,SP1 300B, SP2 300C and SP3 300D. Thecore processor 200 further includes a reduced instruction set computer (RISC)control unit 302 and a pipeline control unit 304. Thesignal processing units 300A-300D perform the signal processing tasks on data while theRISC control unit 302 and the pipeline control unit 304 perform control tasks related to the signal processing function performed by theSPs 300A-300D. The control provided by theRISC control unit 302 is coupled with theSPs 300A-300D at the pipeline level to yield a tightly integratedcore processor 200 that keeps the utilization of thesignal processing units 300 at a very high level. - The signal processing tasks are performed on the datapaths within the
signal processing units 300A-300D. The nature of the DSP algorithms are such that they are inherently vector operations on streams of data, that have minimal temporal locality (data reuse). Hence, a data cache with demand paging is not used because it would not function well and would degrade operational performance. Therefore, thesignal processing units 300A-300D are allowed to access vector elements (the operands) directly fromdata memory 202 without the overhead of issuing a number of load and store instructions into memory resulting, in very efficient data processing. Thus, the instruction set architecture of the present invention having a 20 bit instruction word which can be expanded to a 40 bit instruction word, achieves better efficiencies than VLIW architectures using 256-bits or higher instruction widths by adapting the ISA to DSP algorithmic structures. The adapted ISA leads to very compact and low-power hardware that can scale to higher computational requirements. The operands that the ASSP can accommodate are varied in data type and data size. The data type may be real or complex, an integer value or a fractional value, with vectors having multiple elements of different sizes. The data size in the preferred embodiment is 64 bits but larger data sizes can be accommodated with proper instruction coding. - Referring now to
FIG. 4 , a detailed block diagram of theRISC control unit 302 is illustrated.RISC control unit 302 includes a data aligner andformatter 402, amemory address generator 404, threeadders 406A-406C, an arithmetic logic unit (ALU) 408, amultiplier 410, abarrel shifter 412, and aregister file 413. Theregister file 413 points to a starting memory location from whichmemory address generator 404 can generate addresses intodata memory 202. TheRISC control unit 302 is responsible for supplying addresses to data memory so that the proper data stream is fed to thesignal processing units 300A-300D. TheRISC control unit 302 is a register to register organization with load and store instructions to move data to and fromdata memory 202. Data memory addressing is performed by RISC control unit using a 32-bit register as a pointer that specifies the address, post-modification offset, and type and permute fields. The type field allows a variety of natural DSP data to be supported as a “first class citizen” in the architecture. For instance, the complex type allows direct operations on complex data stored in memory removing a number of bookkeeping instructions. This is useful in supporting QAM demodulators in data modems very efficiently. - Referring now to
FIG. 5A , a block diagram of asignal processing unit 300 is illustrated which represents an instance of theSPs 300A-300D. Each of thesignal processing units 300 includes a data typer andaligner 502, afirst multiplier M1 504A, acompressor 506, afirst adder A1 510A, a second adder A2 510B, an accumulator register 512, a third adder A3 510C, and asecond multiplier M2 504B.Adders 510A-510C are similar in structure and are generally referred to as adder 510.Multipliers multipliers multiplexer adders 510A, 510B, 510C also have amultiplexer signal processing units 300A-300C to be flexibly interconnected by proper selection of multiplexers. In the preferred embodiment,multiplier M1 504A,compressor 506,adder A1 510A, adder A2 510B and accumulator 512 can receive inputs directly from external data buses through the data typer andaligner 502. In the preferred embodiment, adder 510C andmultiplier M2 504B receive inputs from the accumulator 512 or the outputs from the executionunits multiplier M1 504A,compressor 506,adder A1 510A, and adder A2 510B. -
Program memory 204 couples to the pipe control 304 which includes an instruction buffer that acts as a local loop cache. The instruction buffer in the preferred embodiment has the capability of holding four instructions. The instruction buffer of the pipe control 304 reduces the power consumed in accessing the main memories to fetch instructions during the execution of program loops. - Referring now to
FIG. 5B , a more detailed block diagram of the functional blocks and the bus structure of the signal processing unit is illustrated. Dyadic DSP instructions are possible because of the structure and functionality provided in each signal processing unit. Output signals are coupled out of thesignal processor 300 on theZ output bus 532 through the data typer andaligner 502. Input signals are coupled into thesignal processor 300 on theX input bus 531 andY input bus 533 through the data typer andaligner 502. Internally, the data typer andaligner 502 has a different data bus to couple to each ofmultiplier M1 504A,compressor 506,adder A1 510A, adder A2 510B, and accumulator register AR 512. While the data typer andaligner 502 could have data busses coupling to the adder A3 510C and themultiplier M2 504B, in the preferred embodiment it does not in order to avoid extra data lines and conserve area usage of an integrated circuit. Output data is coupled from the accumulator register AR 512 into the data typer andaligner 502.Multiplier M1 504A has buses to couple its output into the inputs of thecompressor 506,adder A1 510A, adder A2 510B, and the accumulator registers AR 512.Compressor 506 has buses to couple its output into the inputs ofadder A1 510A and adder A2 510B.Adder A1 510A has a bus to couple its output into the accumulator registers 512. Adder A2 510B has buses to couple its output into the accumulator registers 512. Accumulator registers 512 has buses to couple its output intomultiplier M2 504B, adder A3 510C, and data typer andaligner 502. Adder A3 510C has buses to couple its output into themultiplier M2 504B and the accumulator registers 512.Multiplier M2 504B has buses to couple its output into the inputs of the adder A3 510C and the accumulator registers AR 512. - The instruction set architecture of the
ASSP 150 is tailored to digital signal processing applications including audio and speech processing such as compression/decompression and echo cancellation. In essence, the instruction set architecture implemented with theASSP 150, is adapted to DSP algorithmic structures. The adaptation of the ISA of the present invention to DSP algorithmic structures is a balance between ease of implementation, processing efficiency, and programmability of DSP algorithms. The ISA of the present invention provides for data movement operations, DSP/arithmetic/logical operations, program control operations (such as function calls/returns, unconditional/conditional jumps and branches), and system operations (such as privilege, interrupt/trap/hazard handling and memory management control). - Referring now to
FIG. 6A , anexemplary instruction sequence 600 is illustrated for a DSP algorithm program model employing the instruction set architecture of the present invention. Theinstruction sequence 600 has anouter loop 601 and aninner loop 602. Because DSP algorithms tend to perform repetitive computations, instructions 60S within theinner loop 602 are executed more often than others.Instructions 603 are typically parameter setup code to set the memory pointers, provide for the setup of theouter loop 601, and other 2×20 control instructions.Instructions 607 are typically context save and function return instructions or other 2×20 control instructions.Instructions Instructions 604 are typically to provide the setup for theinner loop 602, other control through 2×20 control instructions, or offset extensions for pointer backup. Instructions 606 typically provide tear down of theinner loop 602, other control through 2×20 control instructions, and combining of datapath results within the signal processing units. Instructions 605 within theinner loop 602 typically provide inner loop execution of DSP operations, control of the foursignal processing units 300 in a single instruction multiple data execution mode, memory access for operands, dyadic DSP operations, and other DSP functionality through the 20/40 bit DSP instructions of the ISA of the present invention. Because instructions 605 are so often repeated, significant improvement in operational efficiency may be had by providing the DSP instructions, including general dyadic instructions and dyadic DSP instructions, within the ISA of the present invention. - The instruction set architecture of the
ASSP 150 can be viewed as being two component parts, one (RISC ISA) corresponding to the RISC control unit and another (DSP ISA) to the DSP datapaths of thesignal processing units 300. The RISC ISA is a register based architecture including sixteen registers within theregister file 413, while the DSP ISA is a memory based architecture with efficient digital signal processing instructions. The instruction word for the ASSP is typically 20 bits but can be expanded to 40-bits to control two RISC or DSP instructions to be executed in series or parallel, such as a RISC control instruction executed in parallel with a DSP instruction, or a 40 bit extended RISC or DSP instruction. - The instruction set architecture of the
ASSP 150 has 4 distinct types of instructions to optimize the DSP operational mix. These are (1) a 20-bit DSP instruction that uses mode bits in control registers (i.e. mode registers), (2) a 40-bit DSP instruction having control extensions that can override mode registers, (3) a 20-bit dyadic DSP instruction, and (4) a 40 bit dyadic DSP instruction. These instructions are for accelerating calculations within thecore processor 200 of the type where D=[(A op1 B) op2 C] and each of “op1” and “op2” can be a multiply, add or extremum (min/max) class of operation on the three operands A, B, and C. The ISA of theASSP 150 which accelerates these calculations allows efficient chaining of different combinations of operations. Because these type of operations require three operands, they must be available to the processor. However, because the device size places limits on the bus structure, bandwidth is limited to two vector reads and one vector write each cycle into and out ofdata memory 202. Thus one of the operands, such as B or C, needs to come from another source within thecore processor 200. The third operand can be placed into one of the registers of the accumulator 512 or theRISC register file 413. In order to accomplish this within thecore processor 200 there are two subclasses of the 20-bit DSP instructions which are (1) A and B specified by a 4-bit specifier, and C and D by a 1-bit specifier and (2) A and C specified by a 4-bit specifier, and B and D by a 1 bit specifier. - Instructions for the ASSP are always fetched 40-bits at a time from program memory with
bit bit 39=0,bit 19=0), the two 20-bit sections are control instructions that are executed simultaneously. In the case of 20-bit control instructions for serial execution (bit 39=0,bit 19=1), the two 20-bit sections are control instructions that are executed serially. In the case of 20-bit DSP instructions for serial execution (bit 39=1,bit 19=1), the two 20-bit sections are DSP instructions that are executed serially. In the case of 40-bit DSP instructions (bit 39=1,bit 19=0), the two 20 bit sections form one extended DSP instruction which are executed simultaneously. - The ISA of the
ASSP 150 is fully predicated providing for execution prediction. Within the 20-bit RISC control instruction word and the 40-bit extended DSP instruction word there are 2 bits of each instruction specifying one of four predicate registers within theRISC control unit 302. Depending upon the condition of the predicate register, instruction execution can conditionally change base on its contents. - In order to access operands within the
data memory 202 or registers within the accumulator 512 or registerfile 413, a 6-bit specifier is used in the DSP extended instructions to access operands in memory and registers. Of the six bit specifier used in the extended DSP instructions, the MSB (Bit 5) indicates whether the access is a memory access or register access. In the preferred embodiment, ifBit 5 is set to logical one, it denotes a memory access for an operand. IfBit 5 is set to a logical zero, it denotes a register access for an operand. IfBit 5 is set to 1, the contents of a specified register (rX where X: 0-7) are used to obtain the effective memory address and post-modify the pointer field by one of two possible offsets specified in one of the specified rX registers. IfBit 5 is set to 0,Bit 4 determines what register set has the contents of the desired operand. If Bit-4 is set to 0, then the remaining specified bits 3:0 control access to the registers within theregister file 413 or to registers within thesignal processing units 300. - There are four major classes of DSP instructions for the
ASSP 150 these are - 1) Multiply (MULT): Controls the execution of the main multiplier connected to data buses from memory. Controls: Rounding, sign of multiply Operates on vector data specified through type field in address register
- Second operation: Add, Sub, Min, Max in vector or scalar mode
- 2) Add (ADD): Controls the execution of the main-adder Controls: absolute value control of the inputs, limiting the result
- Second operation: Add, add-sub, mult, mac, min, max
- 3) Extremum (MIN/MAX): Controls the execution of the main-adder Controls: absolute value control of the inputs, Global or running max/min with T register, TR register recording control
- Second operation: add, sub, mult, mac, min, max
- 4) Misc: type-match and permute operations.
- The
ASSP 150 can execute these DSP arithmetic operations in vector or scalar fashion. In scalar execution, a reduction or combining operation is performed on the vector results to yield a scalar result. It is common in DSP applications to perform scalar operations, which are efficiently performed by theASSP 150. - The 20-bit DSP instruction words have 4-bit operand specifiers that can directly access data memory using 8 address registers (r0-r7) within the
register file 413 of theRISC control unit 302. The method of addressing by the 20 bit DSP instruction word is regular indirect with the address register specifying the pointer into memory, post-modification value, type of data accessed and permutation of the data needed to execute the algorithm efficiently. All of the DSP instructions control themultipliers 504A-504B,adders 510A-510C,compressor 506 and the accumulator 512, the functional units of eachsignal processing unit 300A-300D. - In the 40 bit instruction word, the type of extension from the 20 bit instruction word falls into five categories:
- 1) Control and Specifier extensions that override the control bits in mode registers
- 2) Type extensions that override the type specifier in address registers
- 3) Permute extensions that override the permute specifier for vector data in address registers
- 4) Offset extensions that can replace or extend the offsets specified in the address registers
- 5) DSP extensions that control the lower rows of functional units within a
signal processing unit 300 to accelerate block processing. - The 40-bit control instructions with the 20 bit extensions further allow a large immediate value (16 to 20 bits) to be specified in the instruction and powerful bit manipulation instructions.
- Efficient DSP execution is provided with 2×20-bit DSP instructions with the first 20-bits controlling the top functional units (adders 501A and 510B,
multiplier 504A, compressor 506) that interface to data buses from memory and the second 20 bits controlling the bottom functional units (adder 510C andmultiplier 504B) that use internal or local data as operands. The top functional units, also referred to as main units, reduce the inner loop cycles in theinner loop 602 by parallelizing across consecutive taps or sections. The bottom functional units cut the outer loop cycles in theouter loop 601 in half by parallelizing block DSP algorithms across consecutive samples. - Efficient DSP execution is also improved by the hardware architecture of the present invention. In this case, efficiency is improved in the manner that data is supplied to and from
data memory 202 to feed the foursignal processing units 300 and the DSP functional units therein. The data highway is comprised of two buses,X bus 531 andY bus 533, for X and Y source operands, and oneZ bus 532 for a result write. All buses, includingX bus 531,Y bus 533, andZ bus 532, are preferably 64 bits wide. The buses are uni-directional to simplify the physical design and reduce transit times of data. In the preferred embodiment when in a 20 bit DSP mode, if the X and Y buses are both carrying operands read from memory for parallel execution in asignal processing unit 300, the parallel load field can only access registers within theregister file 413 of theRISC control unit 302. Additionally, the foursignal processing units 300A-300D in parallel provide four parallel MAC units (multiplier 504A, adder 510A, and accumulator 512) that can make simultaneous computations. This reduces the cycle count from 4 cycles ordinarily required to perform four MACs to only one cycle. - All DSP instructions of the instruction set architecture of the
ASSP 150 are dyadic DSP instructions within the 20 bit or 40 bit instruction word. A dyadic DSP instruction informs the ASSP in one instruction and one cycle to perform two operations. Referring now toFIG. 6B is a chart illustrating the permutations of the dyadic DSP instructions. Thedyadic DSP instruction 610 includes a main DSP operation 611 (MAIN OP) and a sub DSP operation 612 (SUB OP), a combination of two DSP instructions or operations in one dyadic instruction. Generally, the instruction set architecture of the present invention can be generalized to combining any pair of basic DSP operations to provide very powerful dyadic instruction combinations. Compound DSP operational instructions can provide uniform acceleration for a wide variety of DSP algorithms not just multiply-accumulate intensive filters. The DSP instructions or operations in the preferred embodiment include a multiply instruction (MULT), an addition instruction (ADD), a minimize/maximize instruction (MIN/MAX) also referred to as an extrema instruction, and a no operation instruction (NOP) each having an associated operation code (“opcode”). Any two DSP instructions can be combined together to form a dyadic DSP instruction. The NOP instruction is used for the MAIN OP or SUB OP when a single DSP operation is desired to be executed by the dyadic DSP instruction. There are variations of the general DSP instructions such as vector and scalar operations of multiplication or addition, positive or negative multiplication, and positive or negative addition (i.e. subtraction) - Referring now to
FIG. 6C andFIG. 6D , bitmap syntax for an exemplary dyadic DSP instruction is illustrated.FIG. 6C illustrates bitmap syntax for a control extended dyadic DSP instruction whileFIG. 6D illustrates bitmap syntax for a non-extended dyadic DSP instruction. In the non-extended bitmap syntax the instruction word is the twenty most significant bits of a forty bit word while the extended bitmap syntax has an instruction word of forty bits. The three most significant bits (MSBs), bits numbered 37 through 39, in each indicate the MAIN OP instruction type while the SUB OP is located near the middle or end of the instruction bits at bits numbered 20 through 22. In the preferred embodiment, the MAIN OP instruction codes are 000 for NOP, 101 for ADD, 110 for MIN/MAX, and 100 for MULT. The SUB OP code for the given DSP instruction varies according to what MAIN OP code is selected. In the case of MULT as the MAIN OP, the SUB OPs are 000 for NOP, 001 or 010 for ADD, 100 or 011 for a negative ADD or subtraction, 101 or 110 for MIN, and 111 for MAX. In the preferred embodiment, the MAIN OP and the SUB OP are not the same DSP instruction although alterations to the hardware functional blocks could accommodate it. The lower twenty bits of the control extended dyadic DSP instruction, the extended bits, control the signal processing unit to perform rounding, limiting, absolute value of inputs for SUB OP, or a global MIN/MAX operation with a register value. - The bitmap syntax of the dyadic DSP instruction can be converted into text syntax for program coding. Using the multiplication or MULT non-extended instruction as an example, its text syntax for multiplication or MULT is
(vmul|vmuln).(vadd|vsub|vmax|sadd|ssub|smax) da, sx, sa, sy[,(ps0)|ps1)]
The “vmul|vmuln” field refers to either positive vector multiplication or negative vector multiplication being selected as the MAIN OP. The next field, “vadd|vsub|vmax|sadd|ssub|smax”, refers to either vector add, vector subtract, vector maximum, scalar add, scalar subtraction, or scalar maximum being selected as the SUB OP. The next field, “da”, refers to selecting one of the registers within the accumulator for storage of results. The field “sx” refers to selecting a register within theRISC register file 413 which points to a memory location in memory as one of the sources of operands. The field “sa” refers to selecting the contents of a register within the accumulator as one of the sources of operands. The field “sy” refers to selecting a register within theRISC register file 413 which points to a memory location in memory as another one of the sources of operands. The field of “[,(ps0)|ps1)]” refers to pair selection of keyword PS0 or PS1 specifying which are the source-destination pairs of a parallel-store control register. Referring now toFIG. 6E and 6F , lists of the set of 20-bit DSP and control instructions for the ISA of the present invention is illustrated.FIG. 6G lists the set of extended control instructions for the ISA of the present invention.FIG. 6H lists the set of 40-bit DSP instructions for the ISA of the present invention.FIG. 6I lists the set of addressing instructions for the ISA of the present invention. - Referring now to
FIG. 7 , a block diagram illustrates the instruction decoding for configuring the blocks of thesignal processing unit 300. Thesignal processor 300 includes thefinal decoders 704A through 704N, and multiplexers 720A through 720N. The multiplexers 720A through 720N are representative of themultiplexers FIG. 5B . Thepredecoding 702 is provided by theRISC control unit 302 and the pipe control 304. An instruction is provided to thepredecoding 702 such as adyadic DSP instruction 600. Thepredecoding 702 provides preliminary signals to the appropriatefinal decoders 704A through 704N on how the multiplexers 720A through 720N are to be selected for the given instruction. Referring back toFIG. 5B , in a dyadic DSP instruction the MAIN OP generally, if not a NOP, is performed by the blocks of themultiplier M1 504A,compressor 506,adder A1 510A, and adder A2 510B. The result is stored in one of the registers within the accumulator register AR 512. In the dyadic DSP instruction the SUB OP generally, if not a NOP, is performed by the blocks of the adder A3 510C and themultiplier M2 504B. For example, if the dyadic DSP instruction is to perform is an ADD and MULT, then the ADD operation of the MAIN OP is performed by theadder A1 510A and the SUB OP is performed by themultiplier M1 504A. The predecoding 720 and thefinal decoders 704A through 704N appropriately select the respective multiplexers 720A through 720B to select the MAIN OP to be performed by theadder A1 510A and the SUB OP to be performed by themultiplier M2 504B. In the exemplary case, multiplexer 520A selects inputs from the data typer andaligner 502 in order foradder A1 510A to perform the ADD operation,multiplexer 522 selects the output fromadder 510A for accumulation in the accumulator 512, andmultiplexer 514B selects outputs from the accumulator 512 as its inputs to perform the MULT SUB OP. The MAIN OP and SUB OP can be either executed sequentially (i.e. serial execution on parallel words) or in parallel (i.e. parallel execution on parallel words). If implemented sequentially, the result of the MAIN OP may be an operand of the SUB OP. Thefinal decoders 704A through 704N have their own control logic to properly time the sequence of multiplexer selection for each element of thesignal processor 300 to match the pipeline execution of how the MAIN OP and SUB OP are executed, including sequential or parallel execution. TheRISC control unit 302 and the pipe control 304 in conjunction with thefinal decoders 704A through 704N pipelines instruction execution by pipelining the instruction itself and by providing pipelined control signals. This allows for the data path to be reconfigured by the software instructions each cycle. - As those of ordinary skill will recognize, the present invention has many advantages. One advantage of the present invention is that the ISA is adapted to DSP algorithmic structures providing compact hardware to consume low-power which can be scaled to higher computational requirements. Another advantage of the present invention is that the signal processing units have direct access to operands in memory to reduce processing overhead associated with load and store instructions.
- Another advantage of the present invention is that pipelined instruction execution is provided so that instructions may be issued every cycle. Another advantage of the present invention is that the signal processing units can be configured cycle by cycle.
- The preferred embodiments of the present invention are thus described. While the present invention has been described in particular embodiments, it may be implemented in hardware, software, firmware or a combination thereof and utilized in systems, subsystems, components or sub-components thereof. When implemented in software, the elements of the present invention are essentially the code segments to perform the necessary tasks. The program or code segments can be stored in a processor readable medium or transmitted by a computer data signal embodied in a carrier wave over a transmission medium or communication link. The “processor readable medium” may include any medium that can store or transfer information. Examples of the processor readable medium include an electronic circuit, a semiconductor memory device, a ROM, a flash memory, an erasable ROM (EROM), a floppy diskette, a CD-ROM, an optical disk, a hard disk, a fiber optic medium, a radio frequency (RF) link, etc. The computer data signal may include any signal that can propagate over a transmission medium such as electronic network channels, optical fibers, air, electromagnetic, RF links, etc. The code segments may be downloaded via computer networks such as the Internet, Intranet, etc. In any case, the present invention should not be construed as limited by such embodiments, but rather construed according to the claims that follow below.
Claims (14)
1-20. (canceled)
21. A method of instruction execution for a signal processor, the method comprising:
writing a dyadic DSP instruction having a main operation and a sub operation into a memory;
reading the dyadic DSP instruction from the memory to begin execution of the main operation and the sub operation; and
addressing at least three operands for execution with the main operation and the sub operation.
22. The method of claim 21 , further comprising:
executing the main operation and the sub operation using the at least three operands.
23. The method of claim 22 , further comprising:
storing the results of the execution of the dyadic DSP instruction.
24. The method of claim 21 , wherein,
the addressing addresses a register for one source of one of the at least three operands.
25. The method of claim 21 , wherein,
the addressing addresses a register that contains a pointer to an address into the memory for one source of one of the at least three operands.
26. The method of claim 21 , wherein,
the addressing addresses the memory for one source of one of the at least three operands.
27. The method of claim 21 , wherein,
the main operation and the sub operation are two operations selected from the set of multiplication, addition, comparison with a minimum or maximum value, and no operation.
28. A method in a signal processor, the method comprising: in response to a dyadic DSP instruction,
selecting input and output data paths between a plurality of DSP functional blocks;
executing a main operation of the dyadic DSP instruction on a first pair of operands using the plurality of DSP functional blocks;
executing a sub operation of the dyadic DSP instruction on a second pair of operands using the plurality of DSP functional blocks; and
storing the results of the execution of the main operation and the sub operation of the dyadic DSP instruction.
29. The method of claim 28 , further comprising:
prior to the executing, addressing at least three operands for execution with the main operation and the sub operation.
30. The method of claim 29 , wherein,
one of the at least three operands for execution is a result of the execution of the main operation or the sub operation.
31. The method of claim 28 , wherein,
the execution of the main operation and the sub operation are performed in parallel during the same cycle.
32. The method of claim 28 , wherein,
the execution of the main operation and the sub operation are performed sequentially during different cycles.
33. The method of claim 28 , wherein,
the main operation and the sub operation are two operations selected from the set of multiplication, addition, comparison with a minimum or maximum value, and no operation.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/323,253 US20060112260A1 (en) | 2000-01-31 | 2005-12-30 | Method and apparatus of instruction execution for signal processors |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/494,608 US6446195B1 (en) | 2000-01-31 | 2000-01-31 | Dyadic operations instruction processor with configurable functional blocks |
US10/211,387 US6988184B2 (en) | 2000-01-31 | 2002-08-02 | Dyadic DSP instruction predecode signal selective multiplexing data from input buses to first and second plurality of functional blocks to execute main and sub operations |
US11/323,253 US20060112260A1 (en) | 2000-01-31 | 2005-12-30 | Method and apparatus of instruction execution for signal processors |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/211,387 Division US6988184B2 (en) | 2000-01-31 | 2002-08-02 | Dyadic DSP instruction predecode signal selective multiplexing data from input buses to first and second plurality of functional blocks to execute main and sub operations |
Publications (1)
Publication Number | Publication Date |
---|---|
US20060112260A1 true US20060112260A1 (en) | 2006-05-25 |
Family
ID=23965180
Family Applications (8)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/494,608 Expired - Fee Related US6446195B1 (en) | 1999-10-25 | 2000-01-31 | Dyadic operations instruction processor with configurable functional blocks |
US10/211,387 Expired - Fee Related US6988184B2 (en) | 2000-01-31 | 2002-08-02 | Dyadic DSP instruction predecode signal selective multiplexing data from input buses to first and second plurality of functional blocks to execute main and sub operations |
US10/215,721 Expired - Fee Related US6772319B2 (en) | 2000-01-31 | 2002-08-08 | Dyadic instruction processing instruction set architecture with 20-bit and 40-bit DSP and control instructions |
US10/216,575 Expired - Fee Related US6631461B2 (en) | 2000-01-31 | 2002-08-08 | Dyadic DSP instructions for digital signal processors |
US10/216,044 Expired - Fee Related US6643768B2 (en) | 2000-01-31 | 2002-08-09 | Dyadic DSP instruction processor with main and sub-operation functional blocks selected from each set of multiplier and adder |
US10/666,570 Abandoned US20040093481A1 (en) | 2000-01-31 | 2003-09-19 | Method and apparatus for instruction set architecture having dyadic digital signal processing instructions |
US11/323,253 Abandoned US20060112260A1 (en) | 2000-01-31 | 2005-12-30 | Method and apparatus of instruction execution for signal processors |
US11/323,078 Abandoned US20060112259A1 (en) | 2000-01-31 | 2005-12-30 | Method and apparatus for instruction set architecture with control instructions for signal processors |
Family Applications Before (6)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/494,608 Expired - Fee Related US6446195B1 (en) | 1999-10-25 | 2000-01-31 | Dyadic operations instruction processor with configurable functional blocks |
US10/211,387 Expired - Fee Related US6988184B2 (en) | 2000-01-31 | 2002-08-02 | Dyadic DSP instruction predecode signal selective multiplexing data from input buses to first and second plurality of functional blocks to execute main and sub operations |
US10/215,721 Expired - Fee Related US6772319B2 (en) | 2000-01-31 | 2002-08-08 | Dyadic instruction processing instruction set architecture with 20-bit and 40-bit DSP and control instructions |
US10/216,575 Expired - Fee Related US6631461B2 (en) | 2000-01-31 | 2002-08-08 | Dyadic DSP instructions for digital signal processors |
US10/216,044 Expired - Fee Related US6643768B2 (en) | 2000-01-31 | 2002-08-09 | Dyadic DSP instruction processor with main and sub-operation functional blocks selected from each set of multiplier and adder |
US10/666,570 Abandoned US20040093481A1 (en) | 2000-01-31 | 2003-09-19 | Method and apparatus for instruction set architecture having dyadic digital signal processing instructions |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/323,078 Abandoned US20060112259A1 (en) | 2000-01-31 | 2005-12-30 | Method and apparatus for instruction set architecture with control instructions for signal processors |
Country Status (8)
Country | Link |
---|---|
US (8) | US6446195B1 (en) |
EP (1) | EP1257911B1 (en) |
CN (1) | CN1246771C (en) |
AT (1) | ATE450000T1 (en) |
AU (1) | AU2001231182A1 (en) |
DE (1) | DE60140603D1 (en) |
HK (1) | HK1051244A1 (en) |
WO (1) | WO2001055843A1 (en) |
Families Citing this family (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
DE10045546A1 (en) * | 2000-09-14 | 2002-04-04 | Infineon Technologies Ag | Method for the system-independent digital evaluation of mobile communication reception signals of various mobile radio standards |
US6883165B1 (en) | 2000-09-28 | 2005-04-19 | International Business Machines Corporation | Apparatus and method for avoiding deadlocks in a multithreaded environment |
US6779106B1 (en) * | 2000-09-28 | 2004-08-17 | International Business Machines Corporation | Apparatus and method for an enhanced integer divide in an IA64 architecture |
US6912647B1 (en) | 2000-09-28 | 2005-06-28 | International Business Machines Corportion | Apparatus and method for creating instruction bundles in an explicitly parallel architecture |
US6799262B1 (en) | 2000-09-28 | 2004-09-28 | International Business Machines Corporation | Apparatus and method for creating instruction groups for explicity parallel architectures |
DE60123823T2 (en) * | 2000-11-17 | 2007-09-06 | Infineon Technologies North America Corp., San Jose | Devices and methods for handling RTP and TCP traffic |
JP2002182693A (en) * | 2000-12-13 | 2002-06-26 | Nec Corp | Audio ending and decoding apparatus and method for the same and control program recording medium for the same |
US7055019B2 (en) * | 2001-02-13 | 2006-05-30 | Ellipsis Digital Systems, Inc. | Matched instruction set processor systems and method, system, and apparatus to efficiently design and implement matched instruction set processor systems by mapping system designs to re-configurable hardware platforms |
US7075976B1 (en) * | 2001-03-19 | 2006-07-11 | Cisco Technology, Inc. | Tri-state transmitter |
US7024441B2 (en) * | 2001-10-03 | 2006-04-04 | Intel Corporation | Performance optimized approach for efficient numerical computations |
US20030167460A1 (en) * | 2002-02-26 | 2003-09-04 | Desai Vipul Anil | Processor instruction set simulation power estimation method |
KR100550697B1 (en) * | 2002-06-24 | 2006-02-08 | 엘지전자 주식회사 | Recording medium having data structure for managing reproduction of multiple title video data recorded thereon and recording and reproducing methods and apparatuses |
US7024544B2 (en) * | 2003-06-24 | 2006-04-04 | Via-Cyrix, Inc. | Apparatus and method for accessing registers in a processor |
US9465611B2 (en) * | 2003-10-02 | 2016-10-11 | Broadcom Corporation | Processor execution unit with configurable SIMD functional blocks for complex number operations |
US7437401B2 (en) * | 2004-02-20 | 2008-10-14 | Altera Corporation | Multiplier-accumulator block mode splitting |
CN1658152B (en) * | 2004-02-20 | 2012-06-13 | 阿尔特拉公司 | Multiplier-accumulator block mode dividing |
US7660841B2 (en) * | 2004-02-20 | 2010-02-09 | Altera Corporation | Flexible accumulator in digital signal processing circuitry |
US7933405B2 (en) * | 2005-04-08 | 2011-04-26 | Icera Inc. | Data access and permute unit |
TW200808067A (en) * | 2006-07-31 | 2008-02-01 | Univ Nat Cheng Kung | Prediction module |
US7543013B2 (en) * | 2006-08-18 | 2009-06-02 | Qualcomm Incorporated | Multi-stage floating-point accumulator |
CN100450937C (en) * | 2007-01-11 | 2009-01-14 | 常州爱思特净化设备有限公司 | Liquid treatment module |
US20100153100A1 (en) * | 2008-12-11 | 2010-06-17 | Electronics And Telecommunications Research Institute | Address generator for searching algebraic codebook |
CN101562594B (en) * | 2009-05-25 | 2011-09-07 | 哈尔滨工业大学 | Phase factor combined circuit based on stream line operation |
WO2012104674A1 (en) | 2011-01-31 | 2012-08-09 | Freescale Semiconductor, Inc. | Integrated circuit device and method for determining an index of an extreme value within an array of values |
EP2737972A1 (en) * | 2012-11-28 | 2014-06-04 | Sandvik Intellectual Property AB | Welding material for weld cladding |
US9880842B2 (en) * | 2013-03-15 | 2018-01-30 | Intel Corporation | Using control flow data structures to direct and track instruction execution |
US10001995B2 (en) * | 2015-06-02 | 2018-06-19 | Intel Corporation | Packed data alignment plus compute instructions, processors, methods, and systems |
US10089078B2 (en) | 2016-09-23 | 2018-10-02 | Stmicroelectronics S.R.L. | Circuit for performing a multiply-and-accumulate operation |
US10509651B2 (en) * | 2016-12-22 | 2019-12-17 | Intel Corporation | Montgomery multiplication processors, methods, systems, and instructions |
US10379854B2 (en) * | 2016-12-22 | 2019-08-13 | Intel Corporation | Processor instructions for determining two minimum and two maximum values |
US10467324B2 (en) * | 2017-05-24 | 2019-11-05 | Microsoft Technology Licensing, Llc | Data packing techniques for hard-wired multiplier circuits |
US11809798B2 (en) | 2019-12-13 | 2023-11-07 | Intel Corporation | Implementing large multipliers in tensor arrays |
US11520584B2 (en) | 2019-12-13 | 2022-12-06 | Intel Corporation | FPGA specialist processing block for machine learning |
CN112256330B (en) * | 2020-11-03 | 2021-11-09 | 中国人民解放军军事科学院国防科技创新研究院 | RISC-V instruction set extension method for accelerating digital signal processing |
CN112491282B (en) * | 2020-11-06 | 2021-10-01 | 东北电力大学 | Y-source two-stage matrix converter modulation method based on carrier PWM |
Citations (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3594732A (en) * | 1966-08-16 | 1971-07-20 | Scient Data Systems Inc | General purpose digital computer |
US4080648A (en) * | 1975-06-06 | 1978-03-21 | Hitachi, Ltd. | Micro program control system |
US4969118A (en) * | 1989-01-13 | 1990-11-06 | International Business Machines Corporation | Floating point unit for calculating A=XY+Z having simultaneous multiply and add |
US5163139A (en) * | 1990-08-29 | 1992-11-10 | Hitachi America, Ltd. | Instruction preprocessor for conditionally combining short memory instructions into virtual long instructions |
US5204828A (en) * | 1989-02-10 | 1993-04-20 | Intel Corporation | Bus apparatus having hold registers for parallel processing in a microprocessor |
US5241492A (en) * | 1991-05-06 | 1993-08-31 | Motorola, Inc. | Apparatus for performing multiply and accumulate instructions with reduced power and a method therefor |
US5371860A (en) * | 1990-03-30 | 1994-12-06 | Matsushita Electric Works, Ltd. | Programmable controller |
US5452428A (en) * | 1988-01-18 | 1995-09-19 | Kabushiki Kaisha Toshiba | Processor having different operand source information temporarily stored in plural holding registers to avoid using microprogram ROM capacity for such information |
US5522085A (en) * | 1993-12-20 | 1996-05-28 | Motorola, Inc. | Arithmetic engine with dual multiplier accumulator devices |
US5530663A (en) * | 1994-11-14 | 1996-06-25 | International Business Machines Corporation | Floating point unit for calculating a compound instruction A+B×C in two cycles |
US5680578A (en) * | 1995-06-07 | 1997-10-21 | Advanced Micro Devices, Inc. | Microprocessor using an instruction field to specify expanded functionality and a computer system employing same |
US5692207A (en) * | 1994-12-14 | 1997-11-25 | International Business Machines Corporation | Digital signal processing system with dual memory structures for performing simplex operations in parallel |
US5761470A (en) * | 1995-07-12 | 1998-06-02 | Mitsubishi Denki Kabushiki Kaisha | Data processor having an instruction decoder and a plurality of executing units for performing a plurality of operations in parallel |
US5768553A (en) * | 1995-10-30 | 1998-06-16 | Advanced Micro Devices, Inc. | Microprocessor using an instruction field to define DSP instructions |
US5825658A (en) * | 1995-09-14 | 1998-10-20 | Vlsi Technology, Inc. | Method and a system for specifying and automatically analyzing multiple clock timing constraints in a VLSI circuit |
US5880984A (en) * | 1997-01-13 | 1999-03-09 | International Business Machines Corporation | Method and apparatus for performing high-precision multiply-add calculations using independent multiply and add instruments |
US5901301A (en) * | 1996-02-07 | 1999-05-04 | Mitsubishi Denki Kabushiki Kaisha | Data processor and method of processing data |
US5909698A (en) * | 1997-03-17 | 1999-06-01 | International Business Machines Corporation | Cache block store instruction operations where cache coherency is achieved without writing all the way back to main memory |
US5923871A (en) * | 1996-08-07 | 1999-07-13 | Elbrus International | Multifunctional execution unit having independently operable adder and multiplier |
US5940785A (en) * | 1996-04-29 | 1999-08-17 | International Business Machines Corporation | Performance-temperature optimization by cooperatively varying the voltage and frequency of a circuit |
US5946004A (en) * | 1996-02-19 | 1999-08-31 | Sega Enterprises, Ltd. | Enhanced function board for use in processing image data and image processing apparatus using the same |
US6029267A (en) * | 1997-11-25 | 2000-02-22 | Lucent Technologies Inc. | Single-cycle, soft decision, compare-select operation using dual-add processor |
US6058410A (en) * | 1996-12-02 | 2000-05-02 | Intel Corporation | Method and apparatus for selecting a rounding mode for a numeric operation |
US6088785A (en) * | 1998-04-15 | 2000-07-11 | Diamond Multimedia Systems, Inc. | Method of configuring a functionally redefinable signal processing system |
US6115803A (en) * | 1994-05-17 | 2000-09-05 | Fujitsu Limited | Parallel computer which verifies direct data transmission between local memories with a send complete flag |
US6119216A (en) * | 1994-12-02 | 2000-09-12 | Intel Corporation | Microprocessor capable of unpacking packed data in response to a unpack instruction |
US6121998A (en) * | 1992-02-19 | 2000-09-19 | 8×8, Inc. | Apparatus and method for videocommunicating having programmable architecture permitting data revisions |
US6138136A (en) * | 1996-06-26 | 2000-10-24 | U.S. Philips Corporation | Signal processor |
US6154831A (en) * | 1996-12-02 | 2000-11-28 | Advanced Micro Devices, Inc. | Decoding operands for multimedia applications instruction coded with less number of bits than combination of register slots and selectable specific values |
US6154828A (en) * | 1993-06-03 | 2000-11-28 | Compaq Computer Corporation | Method and apparatus for employing a cycle bit parallel executing instructions |
US6247036B1 (en) * | 1996-01-22 | 2001-06-12 | Infinite Technology Corp. | Processor with reconfigurable arithmetic data path |
US6282633B1 (en) * | 1998-11-13 | 2001-08-28 | Tensilica, Inc. | High data density RISC processor |
US6360312B1 (en) * | 1998-03-30 | 2002-03-19 | Matsushita Electric Industrial Co., Ltd. | Processor for making more efficient use of idling components and program conversion apparatus for the same |
US6425070B1 (en) * | 1998-03-18 | 2002-07-23 | Qualcomm, Inc. | Variable length instruction decoder |
US6560694B1 (en) * | 2000-01-14 | 2003-05-06 | Advanced Micro Devices, Inc. | Double prefix overrides to provide 16-bit operand size in a 32/64 operating mode |
Family Cites Families (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5420809A (en) * | 1993-11-30 | 1995-05-30 | Texas Instruments Incorporated | Method of operating a data processing apparatus to compute correlation |
US6088783A (en) * | 1996-02-16 | 2000-07-11 | Morton; Steven G | DPS having a plurality of like processors controlled in parallel by an instruction word, and a control processor also controlled by the instruction word |
US5949762A (en) * | 1996-01-24 | 1999-09-07 | Telebit Corporation | Apparatus and method for processing multiple telephone calls |
US5890013A (en) * | 1996-09-30 | 1999-03-30 | Intel Corporation | Paged memory architecture for a single chip multi-processor with physical memory pages that are swapped without latency |
US6247113B1 (en) * | 1998-05-27 | 2001-06-12 | Arm Limited | Coprocessor opcode division by data type |
US6041400A (en) * | 1998-10-26 | 2000-03-21 | Sony Corporation | Distributed extensible processing architecture for digital signal processing applications |
EP1297612A4 (en) * | 1998-12-21 | 2003-04-02 | N2Power Inc | Boost converter with reduced switching loss |
US6675376B2 (en) * | 2000-12-29 | 2004-01-06 | Intel Corporation | System and method for fusing instructions |
-
2000
- 2000-01-31 US US09/494,608 patent/US6446195B1/en not_active Expired - Fee Related
-
2001
- 2001-01-25 WO PCT/US2001/002627 patent/WO2001055843A1/en active Application Filing
- 2001-01-25 CN CN01804361.5A patent/CN1246771C/en not_active Expired - Fee Related
- 2001-01-25 AU AU2001231182A patent/AU2001231182A1/en not_active Abandoned
- 2001-01-25 EP EP01903354A patent/EP1257911B1/en not_active Expired - Lifetime
- 2001-01-25 DE DE60140603T patent/DE60140603D1/en not_active Expired - Lifetime
- 2001-01-25 AT AT01903354T patent/ATE450000T1/en not_active IP Right Cessation
-
2002
- 2002-08-02 US US10/211,387 patent/US6988184B2/en not_active Expired - Fee Related
- 2002-08-08 US US10/215,721 patent/US6772319B2/en not_active Expired - Fee Related
- 2002-08-08 US US10/216,575 patent/US6631461B2/en not_active Expired - Fee Related
- 2002-08-09 US US10/216,044 patent/US6643768B2/en not_active Expired - Fee Related
-
2003
- 2003-05-14 HK HK03103418.5A patent/HK1051244A1/en not_active IP Right Cessation
- 2003-09-19 US US10/666,570 patent/US20040093481A1/en not_active Abandoned
-
2005
- 2005-12-30 US US11/323,253 patent/US20060112260A1/en not_active Abandoned
- 2005-12-30 US US11/323,078 patent/US20060112259A1/en not_active Abandoned
Patent Citations (36)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3594732A (en) * | 1966-08-16 | 1971-07-20 | Scient Data Systems Inc | General purpose digital computer |
US4080648A (en) * | 1975-06-06 | 1978-03-21 | Hitachi, Ltd. | Micro program control system |
US5452428A (en) * | 1988-01-18 | 1995-09-19 | Kabushiki Kaisha Toshiba | Processor having different operand source information temporarily stored in plural holding registers to avoid using microprogram ROM capacity for such information |
US4969118A (en) * | 1989-01-13 | 1990-11-06 | International Business Machines Corporation | Floating point unit for calculating A=XY+Z having simultaneous multiply and add |
US5204828A (en) * | 1989-02-10 | 1993-04-20 | Intel Corporation | Bus apparatus having hold registers for parallel processing in a microprocessor |
US5371860A (en) * | 1990-03-30 | 1994-12-06 | Matsushita Electric Works, Ltd. | Programmable controller |
US5163139A (en) * | 1990-08-29 | 1992-11-10 | Hitachi America, Ltd. | Instruction preprocessor for conditionally combining short memory instructions into virtual long instructions |
US5241492A (en) * | 1991-05-06 | 1993-08-31 | Motorola, Inc. | Apparatus for performing multiply and accumulate instructions with reduced power and a method therefor |
US6121998A (en) * | 1992-02-19 | 2000-09-19 | 8×8, Inc. | Apparatus and method for videocommunicating having programmable architecture permitting data revisions |
US6154828A (en) * | 1993-06-03 | 2000-11-28 | Compaq Computer Corporation | Method and apparatus for employing a cycle bit parallel executing instructions |
US5522085A (en) * | 1993-12-20 | 1996-05-28 | Motorola, Inc. | Arithmetic engine with dual multiplier accumulator devices |
US6115803A (en) * | 1994-05-17 | 2000-09-05 | Fujitsu Limited | Parallel computer which verifies direct data transmission between local memories with a send complete flag |
US5530663A (en) * | 1994-11-14 | 1996-06-25 | International Business Machines Corporation | Floating point unit for calculating a compound instruction A+B×C in two cycles |
US6119216A (en) * | 1994-12-02 | 2000-09-12 | Intel Corporation | Microprocessor capable of unpacking packed data in response to a unpack instruction |
US5692207A (en) * | 1994-12-14 | 1997-11-25 | International Business Machines Corporation | Digital signal processing system with dual memory structures for performing simplex operations in parallel |
US5680578A (en) * | 1995-06-07 | 1997-10-21 | Advanced Micro Devices, Inc. | Microprocessor using an instruction field to specify expanded functionality and a computer system employing same |
US6115806A (en) * | 1995-07-12 | 2000-09-05 | Mitsubishi Denki Kabushiki Kaisha | Data processor having an instruction decoder and a plurality of executing units for performing a plurality of operations in parallel |
US5761470A (en) * | 1995-07-12 | 1998-06-02 | Mitsubishi Denki Kabushiki Kaisha | Data processor having an instruction decoder and a plurality of executing units for performing a plurality of operations in parallel |
US5825658A (en) * | 1995-09-14 | 1998-10-20 | Vlsi Technology, Inc. | Method and a system for specifying and automatically analyzing multiple clock timing constraints in a VLSI circuit |
US5768553A (en) * | 1995-10-30 | 1998-06-16 | Advanced Micro Devices, Inc. | Microprocessor using an instruction field to define DSP instructions |
US6247036B1 (en) * | 1996-01-22 | 2001-06-12 | Infinite Technology Corp. | Processor with reconfigurable arithmetic data path |
US5901301A (en) * | 1996-02-07 | 1999-05-04 | Mitsubishi Denki Kabushiki Kaisha | Data processor and method of processing data |
US5946004A (en) * | 1996-02-19 | 1999-08-31 | Sega Enterprises, Ltd. | Enhanced function board for use in processing image data and image processing apparatus using the same |
US5940785A (en) * | 1996-04-29 | 1999-08-17 | International Business Machines Corporation | Performance-temperature optimization by cooperatively varying the voltage and frequency of a circuit |
US6138136A (en) * | 1996-06-26 | 2000-10-24 | U.S. Philips Corporation | Signal processor |
US5923871A (en) * | 1996-08-07 | 1999-07-13 | Elbrus International | Multifunctional execution unit having independently operable adder and multiplier |
US6058410A (en) * | 1996-12-02 | 2000-05-02 | Intel Corporation | Method and apparatus for selecting a rounding mode for a numeric operation |
US6154831A (en) * | 1996-12-02 | 2000-11-28 | Advanced Micro Devices, Inc. | Decoding operands for multimedia applications instruction coded with less number of bits than combination of register slots and selectable specific values |
US5880984A (en) * | 1997-01-13 | 1999-03-09 | International Business Machines Corporation | Method and apparatus for performing high-precision multiply-add calculations using independent multiply and add instruments |
US5909698A (en) * | 1997-03-17 | 1999-06-01 | International Business Machines Corporation | Cache block store instruction operations where cache coherency is achieved without writing all the way back to main memory |
US6029267A (en) * | 1997-11-25 | 2000-02-22 | Lucent Technologies Inc. | Single-cycle, soft decision, compare-select operation using dual-add processor |
US6425070B1 (en) * | 1998-03-18 | 2002-07-23 | Qualcomm, Inc. | Variable length instruction decoder |
US6360312B1 (en) * | 1998-03-30 | 2002-03-19 | Matsushita Electric Industrial Co., Ltd. | Processor for making more efficient use of idling components and program conversion apparatus for the same |
US6088785A (en) * | 1998-04-15 | 2000-07-11 | Diamond Multimedia Systems, Inc. | Method of configuring a functionally redefinable signal processing system |
US6282633B1 (en) * | 1998-11-13 | 2001-08-28 | Tensilica, Inc. | High data density RISC processor |
US6560694B1 (en) * | 2000-01-14 | 2003-05-06 | Advanced Micro Devices, Inc. | Double prefix overrides to provide 16-bit operand size in a 32/64 operating mode |
Also Published As
Publication number | Publication date |
---|---|
US6988184B2 (en) | 2006-01-17 |
US20030018881A1 (en) | 2003-01-23 |
US6643768B2 (en) | 2003-11-04 |
DE60140603D1 (en) | 2010-01-07 |
EP1257911A1 (en) | 2002-11-20 |
CN1246771C (en) | 2006-03-22 |
ATE450000T1 (en) | 2009-12-15 |
US20030023833A1 (en) | 2003-01-30 |
EP1257911B1 (en) | 2009-11-25 |
US20040093481A1 (en) | 2004-05-13 |
HK1051244A1 (en) | 2003-07-25 |
US6772319B2 (en) | 2004-08-03 |
WO2001055843A1 (en) | 2001-08-02 |
US6631461B2 (en) | 2003-10-07 |
US20030023832A1 (en) | 2003-01-30 |
EP1257911A4 (en) | 2005-01-26 |
AU2001231182A1 (en) | 2001-08-07 |
CN1404586A (en) | 2003-03-19 |
US20030018882A1 (en) | 2003-01-23 |
US6446195B1 (en) | 2002-09-03 |
US20060112259A1 (en) | 2006-05-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6772319B2 (en) | Dyadic instruction processing instruction set architecture with 20-bit and 40-bit DSP and control instructions | |
US6598155B1 (en) | Method and apparatus for loop buffering digital signal processing instructions | |
US6557096B1 (en) | Processors with data typer and aligner selectively coupling data bits of data buses to adder and multiplier functional blocks to execute instructions with flexible data types | |
US6832306B1 (en) | Method and apparatus for a unified RISC/DSP pipeline controller for both reduced instruction set computer (RISC) control instructions and digital signal processing (DSP) instructions | |
US6732203B2 (en) | Selectively multiplexing memory coupling global bus data bits to narrower functional unit coupling local bus | |
US6748516B2 (en) | Method and apparatus for instruction set architecture to perform primary and shadow digital signal processing sub-instructions simultaneously | |
WO2002019098A1 (en) | Method and apparatus for a unified risc/dsp pipeline controller for both reduced instruction set computer (risc) control instructions and digital signal processing (dsp) instructions |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |