US5983340A - Microprocessor system with flexible instruction controlled by prior instruction - Google Patents
Microprocessor system with flexible instruction controlled by prior instruction Download PDFInfo
- Publication number
- US5983340A US5983340A US08/568,714 US56871495A US5983340A US 5983340 A US5983340 A US 5983340A US 56871495 A US56871495 A US 56871495A US 5983340 A US5983340 A US 5983340A
- Authority
- US
- United States
- Prior art keywords
- instruction
- alu
- field
- destination
- processor
- 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.)
- Expired - Lifetime
Links
- 101100120298 Rattus norvegicus Flot1 gene Proteins 0.000 description 8
- 101100412403 Rattus norvegicus Reg3b gene Proteins 0.000 description 8
- 238000010586 diagram Methods 0.000 description 4
- 238000000034 method Methods 0.000 description 4
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000005236 sound signal Effects 0.000 description 2
- 102100023882 Endoribonuclease ZC3H12A Human genes 0.000 description 1
- 101710112715 Endoribonuclease ZC3H12A Proteins 0.000 description 1
- 230000003044 adaptive effect Effects 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000013144 data compression Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 230000008569 process Effects 0.000 description 1
- 230000003252 repetitive effect Effects 0.000 description 1
- 238000001228 spectrum 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/30181—Instruction operation extension or modification
-
- 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/3016—Decoding the operand specifier, e.g. specifier format
- G06F9/30163—Decoding the operand specifier, e.g. specifier format with implied specifier, e.g. top of stack
-
- 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/3016—Decoding the operand specifier, e.g. specifier format
- G06F9/30167—Decoding the operand specifier, e.g. specifier format of immediate specifier, e.g. constants
-
- 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/3824—Operand accessing
Definitions
- the present invention is directed to a pipelined processor. Specifically, the present invention is directed to a pipelined processor having sequential processing instructions wherein at least some of the processing instructions conditionally use an operand.
- a typical processor architecture may include a series of processing instructions where an instruction having an immediate data format can use one or more operands. Because immediate instructions can not specify all the operands they need, they use implied operands that are typically the result of the prior instruction.
- the typical implied operands are an "accumulator,” a register usually located in the arithmetic unit of a processor, or a "top of stack,” the last memory location used in a last in first out data memory mechanisms.
- accumulator a register usually located in the arithmetic unit of a processor
- top of stack the last memory location used in a last in first out data memory mechanisms.
- a pipeline architecture has several pipeline latches or bus states that may contain useful data that could also be used as an implied operand.
- Restricting an immediate instruction's second operand to be the outputs of the previous instruction or data supplied by a single pipeline latch limits the functionality of the immediate instruction in the processor. It is therefore an object of the present invention to provide a pipelined processor enhanced functionality through an expanded availability of operands that can be received by an immediate instruction.
- One object of an embodiment of the present invention is to provide a pipelined processor enhanced functionality by expanding the availability of second input operands that an immediate instruction can receive.
- an embodiment of the present invention is directed to a data processing apparatus having a pipelined computer architecture.
- the pipelined computer architecture performs a plurality of sequential processing instructions.
- Each processing instruction provides an output that is written to a destination in a register or a memory defined by a destination address.
- An immediate instruction uses the output generated by the prior instruction as a second operand.
- An immediate instruction may use based upon the destination operand selected by the previous instruction, either an input operand of that previous instruction or the output of the previous instruction as a second operand.
- FIG. 1 shows a block diagram of a system within which an embodiment of the present invention operates.
- FIG. 2 shows a block diagram describing the interaction between the controller and the coprocessor of a preferred embodiment.
- FIG. 3a shows a two-operand immediate instruction format in an embodiment having thirty two bit instructions.
- FIG. 3b shows a three-operand immediate instruction format in an embodiment having thirty two bit instructions.
- FIG. 4 shows a specific application of an embodiment for performing a clipping operation.
- FIG. 1 shows a block diagram of a system within which an embodiment of the present invention operates.
- a system may be within a hand held digital cordless phone or some other radio frequency device for receiving and transmitting signals having real-time processing requirements and requirements for low power, light weight and small volume.
- a controller 40, a coprocessor 50, and a baseband modem 80 are incorporated in a single application specific integrated circuit (ASIC) 30.
- the controller 40 may be a general purpose processor such as the 6502 processor.
- the coprocessor 50 is preferably a specialized processor for performing repetitive operations at high speed.
- the baseband modem 80 provides spread spectrum modulation.
- the microphone/speaker 10 provides audio signals to a codec 20.
- the codec 20 digitally samples the audio signals and provides digital data to the ASIC 30 for processing according to algorithms stored in the ASIC 30.
- the controller 40 commands the coprocessor 50 to process the sampled data provided by the codec 20 using digital signal processing operations. These signal processing operations may include speech data compression using adaptive differential pulse code modulation such as those set forth in the CCITT G721 standard.
- the resultant data is provided to the controller for supplying encoded data to the baseband modem 80, which provides a modulation signal to the R/F unit 60 to be converted into a signal in the 900 megahertz frequency band and then amplified and transmitted over the antenna 70.
- the R/F unit 60 In receiving, the R/F unit 60 amplifies and converts to the baseband frequency the signals received from the antenna 70 to provide to the baseband modem 80 a signal which it demodulates into digital data which is passed to the controller 40.
- the received data is provided to the coprocessor 50 where it is decoded.
- the decoded digital data is then passed to the codec 20 through the controller 40.
- the codec 20 converts the decoded digital data into an amplified analog signal that is provided to microphone/speaker 10.
- FIG. 2 shows a block diagram describing how the controller 140 controls the execution of the coprocessor 150.
- the start address from the start address register 160 is moved to the program counter 180 to indicate the location of the first instruction to be performed in a procedure commanded by the controller 140. After each instruction is performed, the program counter 180 increments.
- the stop address from the stop address register 170 is provided to halt logic 145 so that processing halts when the program counter 180 reaches stop address 170.
- the ROM 155 provides instructions and immediate data to the decoder 185 and the ALU 165 over the Immediate Data bus 195.
- This embodiment may implement a three stage pipelined processor. In such a three stage processor, at any particular cycle a first instruction is being executed in the ALU 165 using data from the Shared Data Memory 175 or the immediate data supplied by the ROM 155 over the Immediate Data bus 195, while a second instruction, which is expected to be executed immediately following the execution of the first instruction, is being decoded in the instruction decoder 185 and a third instruction, which is expected to be executed immediately following the execution of the second instruction, is being fetched from ROM 155 according to the program counter 180.
- the coprocessor may utilize thirty two bit instructions and can have at least two types of instruction formats, a two-operand immediate instruction format and a three-operand instruction format.
- FIG. 3a shows the immediate instruction format 200 which includes sixteen bits for an immediate data field 210, a six bit destination field for specifying the address of the destination of the output 220, a seven bit field for specifying an ALU function in ALU operation field 230 and three bits for specifying an opcode in opcode field 240.
- the opcode in opcode field 240 preferably identifies the type of instruction format, among other things.
- the three-operand instruction format 250 shown in FIG. 3b differs from the immediate instruction format 200 in that two input operands are specified in the fields 260 and 265.
- a shift field 255 preferably specifies the number of bits to shift the "A" input operand.
- the sixteen bits in the immediate data field 210 specify only one operand. Some immediate data format instructions require only one input operand. Other immediate data instructions may require a second input operand.
- the ALU uses an implied second operand based upon the nature of the instruction. For example, an immediate data instruction for addition requires an implied second operand.
- the opcode shown in field 240 of the immediate data instruction format 200 shown in FIG. 3a along with the specified instruction in the ALU operation field 230 are used by the ALU logic for determining whether an implied second operand is needed in performing the instruction.
- the implied second input operand in the immediate instruction format is either the result of performing a previous instruction or the data stored in a pipelined latch.
- the instruction sequencer 190 in performing an immediate instruction has the available for use of the state the ALU output bus immediately following the execution of the previous instruction such as that which may be stored in a destination latch (not shown).
- the instruction decoder means such as an instruction sequencer or decoder in performing the immediate instruction either loads the output bus state of the previous instruction into the ALU B-input pipeline latch or preserves the contents of the pipelined input latch.
- the instruction sequencer may use the data already stored in the pipeline latch as the second operand again in the current or a later instruction.
- destination field specifies that the ALU result is not to be written to any destination (e.g. "Noplace").
- the instruction sequencer preferably uses the state of the ALU output bus as the implied second operand for an immediate instruction.
- the ALU passes either the first operand or the second operand to the destination specified in the current instruction.
- the ALU passes to the destination of the current instruction either the immediate data or the implied second operand, the contents of the ALU B-input latch for example, based upon the output bus state following the execution of the previous instruction.
- the ALU may also select which value to load to the destination based upon ALU status bits set as a result of the execution of the previous instruction such as an ALU a sign out flag, a carry in flag, or an ALU zero out flag.
- FIG. 4 illustrates a specific application of an embodiment for performing a clipping operation. However, it is understood that this embodiment can implement other procedures employing level testing operations on the amplitudes of digitally sampled signals.
- FIG. 4 shows this particular clipping operation for an eight bit word. However, it is understood that this clipping operation may also be performed for words of other sizes.
- input values are clipped to be between 1111000b and 00001000b (-8 and 8 base ten). If the input value exceeds 00001000b, the ALU forces the output to be 00001000b. If the input value is between 11111000b and 00001000b, the ALU returns the input value as the output value. If the input value is less than 11111000b, the ALU forces the output value to be 11111000b.
- Steps 400 represent an instruction having 3-operand format 250 while steps 405, 410, 415 and 420 represent instructions having the immediate instruction format 200 as shown in FIG. 3b and 3a, respectively, for performing the clipping operation.
- the values shown in quotations in each of the steps represent the binary immediate data of the instruction corresponding to the step such as "00001000b" in step 405.
- Columns 450 and 460 show values of first and second general purpose registers, Registers 1 and 2, before and after each instruction performed by the ALU.
- Column 470 shows the state of an output bus, reflecting the output of the ALU after performing the previous instruction and before performing the next instruction. Alternatively, the output of the ALU can be loaded to a destination latch.
- Column 480 labeled "B-in Latch” shows the contents of the ALU B-input latch which is a pipeline latch.
- the values shown in the four boxes disposed between each step represent the contents of the respective registers, output bus state and contents of the ALU B-input latch, where "X" represents an indeterminate value.
- the shaded boxes 490, 492, 494 and 496 show the actual calculation being performed.
- the output bus state is not always loaded into the ALU the B-input latch. Whether the output bus state of a previous instruction is loaded into the ALU B-input latch depends on the destination specified in the destination field of the previous instruction and the SRC B field of the current instruction when it is a three-operand instruction.
- the instructions shown in FIG. 4 designate "Noplace,” “SAVEB,” “Reg1” (Register 1) and “Reg2” (Register 2) as destinations (memory locations) for the results from performing the instructions corresponding to the destination fields shown in FIGS. 3a and 3b.
- the destinations "SAVEB” and “Reg2” as used in instruction steps 405, 410, 415 and 420 correspond to the destination field 220 of the immediate instruction format shown in FIG. 3a. Where an instruction has the destination "SAVEB", the contents of the B-in latch are preserved to be used by the following instruction.
- Step 400 the contents of Register 1, which is the input value for this clipping operation "01000000b", is both loaded into B-in latch at 404 and becomes the output bus state at 403.
- Step 400 merely illustrates initialization.
- the ALU performs the instruction "SubR -- Imed ⁇ 00001000b ⁇ to SAVEB” to subtract the immediate data, "00001000b", from the output state "01000000b” shown at 403. Since the instruction at step 400 does not specify "SAVEB” as the destination, the output bus state resulting from the previous instruction at 403 ("01000000b") is also loaded to the B-in latch at 404. Performing the instruction at step 405 changes the state of the output bus to reflect the value shown at 408 to "00111000b". As “01000000b”, the input value, exceeds "00001000b", the positive limit of the clipping operation, a positive value results from performing this instruction.
- step 410 since the instruction at step 405 specifies "SAVEB" as the destination ("01000000b") the previous B-in latch value is preserved at 409.
- Step 410 the instruction "MovGT -- Imed ⁇ 00001000b ⁇ to Reg2” loads either the immediate data ("00001000b") to Reg2 or the value stored in the B-in latch, depending on the sign of the state of the output bus at 408. Since the sign of the state of the output bus at 408 is positive, the ALU when performing this instruction loads the immediate data (which is the maximum "clipped” output value) into Reg2 at 412 and changes the state of the output bus at 413 to be the immediate data.
- the ALU performs instruction "SubR -- Imed ⁇ 11111000b ⁇ to SAVEB” to subtract the immediate data, which is the negative limit of the clipping operation ("11111000b"). Since the instruction at step 410 does not specify "SAVEB” as the destination, the output bus state resulting from the previous instruction at 413 ("00001000b") is also loaded to the B-in latch at 414. The output bus state is changed to reflect the result of this instruction ("00010000b") as shown at 418.
- Step 420 since the instruction at step 455 specifies "SAVEB" as the destination, ("00001000b") the previous B-in latch value is preserved at 419.
- Step 420 the instruction "MovLT -- Imed ⁇ 11111000b ⁇ to Reg2" loads either the immediate data "11111000b” or the contents of the B-in latch depending on the sign of the output bus state at 418 resulting from the previous instruction.
- This instruction clips the output of the instruction at step 410 to the negative limit of the clipping operation if the input initialized at step 400 is less than the negative limit. Since the sign of the output bus state at 418 ("00010000b") is positive, this instruction does not change the state of the output bus according to the immediate data "11111000b". Hence, the output of the instruction at step 410 is not clipped to the negative limit as the input data at step 400 is greater than that lower clipping limit.
- the contents of Reg2 are preserved from 417 to 422 and the output bus state is changed to be the contents of Reg2.
- the pipelined processor includes an instruction sequencer that performs immediate data format instructions that may require a second operand.
- the instruction sequencer may select either the contents of the ALU B-input pipeline latch or the output bus state resulting from the previous instruction as the second operand of the current instruction depending on the destination specified in the destination field of the previous instruction. Additionally, in executing some of the immediate data format instructions having implied second operands, the ALU loads to the destination and the output bus either the immediate data of the current instruction or the contents of the pipelined latch depending on the ALU status of the previous instruction. Accordingly, the instruction sequencer is afforded greater flexibility in the selection of a second operand for an immediate data format instruction.
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Executing Machine-Instructions (AREA)
Abstract
Description
Claims (4)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/568,714 US5983340A (en) | 1995-12-07 | 1995-12-07 | Microprocessor system with flexible instruction controlled by prior instruction |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/568,714 US5983340A (en) | 1995-12-07 | 1995-12-07 | Microprocessor system with flexible instruction controlled by prior instruction |
Publications (1)
Publication Number | Publication Date |
---|---|
US5983340A true US5983340A (en) | 1999-11-09 |
Family
ID=24272425
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US08/568,714 Expired - Lifetime US5983340A (en) | 1995-12-07 | 1995-12-07 | Microprocessor system with flexible instruction controlled by prior instruction |
Country Status (1)
Country | Link |
---|---|
US (1) | US5983340A (en) |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2000033177A1 (en) * | 1998-12-03 | 2000-06-08 | Sun Microsystems, Inc. | Implicitly derived register specifiers in a processor |
US6766460B1 (en) | 2000-08-23 | 2004-07-20 | Koninklijke Philips Electronics N.V. | System and method for power management in a Java accelerator environment |
US6782407B1 (en) | 2000-09-26 | 2004-08-24 | Koninklijke Philips Electronics N.V. | System and method for low overhead boundary checking of java arrays |
US20050280302A1 (en) * | 2004-06-22 | 2005-12-22 | Dale Ropp | Vehicle seat suspension with omni directional isolator |
US7114056B2 (en) | 1998-12-03 | 2006-09-26 | Sun Microsystems, Inc. | Local and global register partitioning in a VLIW processor |
US9977754B2 (en) | 2013-09-09 | 2018-05-22 | Samsung Electronics Co., Ltd. | Electronic system with diagnostic interface mechanism and method of operation thereof |
US11016779B2 (en) * | 2013-05-24 | 2021-05-25 | Coherent Logix, Incorporated | Memory-network processor with programmable optimizations |
US11620132B2 (en) * | 2019-05-08 | 2023-04-04 | International Business Machines Corporation | Reusing an operand received from a first-in-first-out (FIFO) buffer according to an operand specifier value specified in a predefined field of an instruction |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4782441A (en) * | 1985-06-14 | 1988-11-01 | Hitachi, Ltd. | Vector processor capable of parallely executing instructions and reserving execution status order for restarting interrupted executions |
US5185872A (en) * | 1990-02-28 | 1993-02-09 | Intel Corporation | System for executing different cycle instructions by selectively bypassing scoreboard register and canceling the execution of conditionally issued instruction if needed resources are busy |
US5488728A (en) * | 1992-04-27 | 1996-01-30 | Intel Corporation | Microprocessor having a run/stop pin for accessing an idle mode |
US5504912A (en) * | 1987-04-17 | 1996-04-02 | Hitachi, Ltd. | Coprocessor executing pipeline control for executing protocols and instructions |
US5559977A (en) * | 1992-08-04 | 1996-09-24 | Intel Corporation | Method and apparatus for executing floating point (FP) instruction pairs in a pipelined processor by stalling the following FP instructions in an execution stage |
US5574927A (en) * | 1994-03-25 | 1996-11-12 | International Meta Systems, Inc. | RISC architecture computer configured for emulation of the instruction set of a target computer |
US5579527A (en) * | 1992-08-05 | 1996-11-26 | David Sarnoff Research Center | Apparatus for alternately activating a multiplier and a match unit |
US5598546A (en) * | 1994-08-31 | 1997-01-28 | Exponential Technology, Inc. | Dual-architecture super-scalar pipeline |
US5619668A (en) * | 1992-08-10 | 1997-04-08 | Intel Corporation | Apparatus for register bypassing in a microprocessor |
-
1995
- 1995-12-07 US US08/568,714 patent/US5983340A/en not_active Expired - Lifetime
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4782441A (en) * | 1985-06-14 | 1988-11-01 | Hitachi, Ltd. | Vector processor capable of parallely executing instructions and reserving execution status order for restarting interrupted executions |
US5504912A (en) * | 1987-04-17 | 1996-04-02 | Hitachi, Ltd. | Coprocessor executing pipeline control for executing protocols and instructions |
US5185872A (en) * | 1990-02-28 | 1993-02-09 | Intel Corporation | System for executing different cycle instructions by selectively bypassing scoreboard register and canceling the execution of conditionally issued instruction if needed resources are busy |
US5488728A (en) * | 1992-04-27 | 1996-01-30 | Intel Corporation | Microprocessor having a run/stop pin for accessing an idle mode |
US5559977A (en) * | 1992-08-04 | 1996-09-24 | Intel Corporation | Method and apparatus for executing floating point (FP) instruction pairs in a pipelined processor by stalling the following FP instructions in an execution stage |
US5579527A (en) * | 1992-08-05 | 1996-11-26 | David Sarnoff Research Center | Apparatus for alternately activating a multiplier and a match unit |
US5619668A (en) * | 1992-08-10 | 1997-04-08 | Intel Corporation | Apparatus for register bypassing in a microprocessor |
US5574927A (en) * | 1994-03-25 | 1996-11-12 | International Meta Systems, Inc. | RISC architecture computer configured for emulation of the instruction set of a target computer |
US5598546A (en) * | 1994-08-31 | 1997-01-28 | Exponential Technology, Inc. | Dual-architecture super-scalar pipeline |
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2000033177A1 (en) * | 1998-12-03 | 2000-06-08 | Sun Microsystems, Inc. | Implicitly derived register specifiers in a processor |
US20010052063A1 (en) * | 1998-12-03 | 2001-12-13 | Marc Tremblay | Implicitly derived register specifiers in a processor |
US7114056B2 (en) | 1998-12-03 | 2006-09-26 | Sun Microsystems, Inc. | Local and global register partitioning in a VLIW processor |
US7117342B2 (en) | 1998-12-03 | 2006-10-03 | Sun Microsystems, Inc. | Implicitly derived register specifiers in a processor |
US6766460B1 (en) | 2000-08-23 | 2004-07-20 | Koninklijke Philips Electronics N.V. | System and method for power management in a Java accelerator environment |
US6782407B1 (en) | 2000-09-26 | 2004-08-24 | Koninklijke Philips Electronics N.V. | System and method for low overhead boundary checking of java arrays |
US20050280302A1 (en) * | 2004-06-22 | 2005-12-22 | Dale Ropp | Vehicle seat suspension with omni directional isolator |
US11016779B2 (en) * | 2013-05-24 | 2021-05-25 | Coherent Logix, Incorporated | Memory-network processor with programmable optimizations |
US11544072B2 (en) | 2013-05-24 | 2023-01-03 | Coherent Logix, Inc. | Memory-network processor with programmable optimizations |
US11900124B2 (en) | 2013-05-24 | 2024-02-13 | Coherent Logix, Incorporated | Memory-network processor with programmable optimizations |
US9977754B2 (en) | 2013-09-09 | 2018-05-22 | Samsung Electronics Co., Ltd. | Electronic system with diagnostic interface mechanism and method of operation thereof |
US11620132B2 (en) * | 2019-05-08 | 2023-04-04 | International Business Machines Corporation | Reusing an operand received from a first-in-first-out (FIFO) buffer according to an operand specifier value specified in a predefined field of an instruction |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6467035B2 (en) | System and method for performing table look-ups using a multiple data fetch architecture | |
US6438676B1 (en) | Distance controlled concatenation of selected portions of elements of packed data | |
US4539635A (en) | Pipelined digital processor arranged for conditional operation | |
US4821225A (en) | Arithmetic and logic unit with prior state dependent logic operations | |
US6505288B1 (en) | Matrix operation apparatus and digital signal processor capable of performing matrix operations | |
US5983340A (en) | Microprocessor system with flexible instruction controlled by prior instruction | |
JP3173777B2 (en) | Data processing device | |
US6446193B1 (en) | Method and apparatus for single cycle processing of data associated with separate accumulators in a dual multiply-accumulate architecture | |
JPH0895804A (en) | Central processor | |
EP0287115B1 (en) | Coprocessor and method of controlling the same | |
US4954947A (en) | Instruction processor for processing branch instruction at high speed | |
US6530011B1 (en) | Method and apparatus for vector register with scalar values | |
US6185670B1 (en) | System for reducing number of opcodes required in a processor using an instruction format including operation class code and operation selector code fields | |
US6499099B1 (en) | Central processing unit method and apparatus for extending general instructions with extension data of an extension register | |
US4893267A (en) | Method and apparatus for a data processor to support multi-mode, multi-precision integer arithmetic | |
US5390306A (en) | Pipeline processing system and microprocessor using the system | |
EP0301708A2 (en) | Parallel arithmetic logic unit | |
US6209012B1 (en) | System and method using mode bits to support multiple coding standards | |
US20030046516A1 (en) | Method and apparatus for extending instructions with extension data of an extension register | |
US5956494A (en) | Method, apparatus, and computer instruction for enabling gain control in a digital signal processor | |
US6925548B2 (en) | Data processor assigning the same operation code to multiple operations | |
US5479620A (en) | Control unit modifying micro instructions for one cycle execution | |
EP0889394A2 (en) | Program control method | |
CA1253969A (en) | Variable position shift | |
US6996702B2 (en) | Processing unit with cross-coupled ALUs/accumulators and input data feedback structure including constant generator and bypass to reduce memory contention |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: ROCKWELL INTERNATIONAL CORPORATION, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GAREY, KENNETH E.;MILLER, MARK E.;REEL/FRAME:008009/0441 Effective date: 19951205 |
|
AS | Assignment |
Owner name: CREDIT SUISSE FIRST BOSTON, NEW YORK Free format text: SECURITY INTEREST;ASSIGNORS:CONEXANT SYSTEMS, INC.;BROOKTREE CORPORATION;BROOKTREE WORLDWIDE SALES CORPORATION;AND OTHERS;REEL/FRAME:009826/0056 Effective date: 19981221 |
|
AS | Assignment |
Owner name: ROCKWELL SCIENCE CENTER, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ROCKWELL INTERNATIONAL CORPORATION;REEL/FRAME:010012/0694 Effective date: 19961115 |
|
AS | Assignment |
Owner name: ROCKWELL SCIENCE CENTER, LLC, CALIFORNIA Free format text: MERGER;ASSIGNOR:ROCKWELL SCIENCE CENTER, INC.;REEL/FRAME:010054/0355 Effective date: 19970827 |
|
AS | Assignment |
Owner name: CONEXANT SYSTEMS, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ROCKWELL SCIENCE CENTER LLC;REEL/FRAME:010083/0724 Effective date: 19981210 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: CONEXANT SYSTEMS, INC., CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CREDIT SUISSE FIRST BOSTON;REEL/FRAME:012273/0217 Effective date: 20011018 Owner name: BROOKTREE WORLDWIDE SALES CORPORATION, CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CREDIT SUISSE FIRST BOSTON;REEL/FRAME:012273/0217 Effective date: 20011018 Owner name: BROOKTREE CORPORATION, CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CREDIT SUISSE FIRST BOSTON;REEL/FRAME:012273/0217 Effective date: 20011018 Owner name: CONEXANT SYSTEMS WORLDWIDE, INC., CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CREDIT SUISSE FIRST BOSTON;REEL/FRAME:012273/0217 Effective date: 20011018 |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: BANK OF NEW YORK TRUST COMPANY, N.A.,ILLINOIS Free format text: SECURITY AGREEMENT;ASSIGNOR:CONEXANT SYSTEMS, INC.;REEL/FRAME:018711/0818 Effective date: 20061113 Owner name: BANK OF NEW YORK TRUST COMPANY, N.A., ILLINOIS Free format text: SECURITY AGREEMENT;ASSIGNOR:CONEXANT SYSTEMS, INC.;REEL/FRAME:018711/0818 Effective date: 20061113 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
AS | Assignment |
Owner name: CONEXANT SYSTEMS, INC.,CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A. (FORMERLY, THE BANK OF NEW YORK TRUST COMPANY, N.A.);REEL/FRAME:023998/0838 Effective date: 20100128 Owner name: CONEXANT SYSTEMS, INC., CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A. (FORMERLY, THE BANK OF NEW YORK TRUST COMPANY, N.A.);REEL/FRAME:023998/0838 Effective date: 20100128 |
|
AS | Assignment |
Owner name: THE BANK OF NEW YORK, MELLON TRUST COMPANY, N.A.,I Free format text: SECURITY AGREEMENT;ASSIGNORS:CONEXANT SYSTEMS, INC.;CONEXANT SYSTEMS WORLDWIDE, INC.;CONEXANT, INC.;AND OTHERS;REEL/FRAME:024066/0075 Effective date: 20100310 Owner name: THE BANK OF NEW YORK, MELLON TRUST COMPANY, N.A., Free format text: SECURITY AGREEMENT;ASSIGNORS:CONEXANT SYSTEMS, INC.;CONEXANT SYSTEMS WORLDWIDE, INC.;CONEXANT, INC.;AND OTHERS;REEL/FRAME:024066/0075 Effective date: 20100310 |
|
AS | Assignment |
Owner name: BROOKTREE BROADBAND HOLDING, INC., CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A.;REEL/FRAME:025384/0253 Effective date: 20101108 Owner name: CONEXANT SYSTEMS, INC., CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A.;REEL/FRAME:025384/0253 Effective date: 20101108 Owner name: CONEXANT SYSTEMS WORLDWIDE, INC., CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A.;REEL/FRAME:025384/0253 Effective date: 20101108 Owner name: CONEXANT, INC., CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A.;REEL/FRAME:025384/0253 Effective date: 20101108 |
|
AS | Assignment |
Owner name: SKYWORKS SOLUTIONS, INC., MASSACHUSETTS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CONEXANT SYSTEMS, INC.;REEL/FRAME:026227/0755 Effective date: 20110428 |
|
REMI | Maintenance fee reminder mailed | ||
FPAY | Fee payment |
Year of fee payment: 12 |
|
SULP | Surcharge for late payment |
Year of fee payment: 11 |