Data processor with trie traversal instruction set extension
First Claim
1. A processor comprising:
- a first input receiving a first input data, a second input receiving a second input data, a third input receiving a third input data and a fourth input receiving a partial subtraction and conditional move instruction;
a logic unit coupled to the first input, the second input, the third input and the fourth input, the logic unit including activatible partial subtraction and conditional move circuitry which is activated upon receipt of the partial subtraction and conditional instruction and which performs a comparison between the first input data and the third input data, if the comparison results in the first input data being equal to the third input data then a down traversal state is set, if the comparison results in the first input data being greater than the third input data then the second input data is copied into a predefined location and no state is set, if the comparison results in the first input data being less than the third input data then an insertion state is set and the first input data is inserted into a trie data structure;
an output coupled to the logic unit, the output outputting the third input data in a predefined location, storing the first input data into the trie data structure and maintaining the down traversal state and the insertion state information; and
wherein the processor can be programmed to process one of many different instructions.
0 Assignments
0 Petitions
Accused Products
Abstract
A programmable data communications device is provided to process multiple streams of data according to multiple protocols. The device is equipped with a co-processor including multiple, programmable processors allowing data to be operated on by multiple protocols. The programmable processors within the co-processor include extended instruction sets including instructions providing the operations of zero stuffing, CRC computation, partial compare, conditional move, and trie traversal. These instructions allow the processor(s) of the co-processor to more efficiently execute programs implementing data communications protocols. Since each processor is programmable, protocols standards which change may be accommodated. A network device equipped with the co-processor can handle multiple simultaneous streams of data and can implement multiple protocols on each data stream. The protocols can execute within the co-processor either independently of each other, or in conjunction with each other.
-
Citations
6 Claims
-
1. A processor comprising:
-
a first input receiving a first input data, a second input receiving a second input data, a third input receiving a third input data and a fourth input receiving a partial subtraction and conditional move instruction;
a logic unit coupled to the first input, the second input, the third input and the fourth input, the logic unit including activatible partial subtraction and conditional move circuitry which is activated upon receipt of the partial subtraction and conditional instruction and which performs a comparison between the first input data and the third input data, if the comparison results in the first input data being equal to the third input data then a down traversal state is set, if the comparison results in the first input data being greater than the third input data then the second input data is copied into a predefined location and no state is set, if the comparison results in the first input data being less than the third input data then an insertion state is set and the first input data is inserted into a trie data structure;
an output coupled to the logic unit, the output outputting the third input data in a predefined location, storing the first input data into the trie data structure and maintaining the down traversal state and the insertion state information; and
wherein the processor can be programmed to process one of many different instructions. - View Dependent Claims (2, 3, 4, 5)
-
-
6. A computer program product embodied on a computer readable medium and comprising partial subtraction and conditional move code that, when executed, causes a logic unit to perform the following:
-
receiving a first input data;
receiving a second input data;
receiving a third input data;
receiving a partial subtraction and conditional move instruction;
comparing the first input data and the third input data, if the comparison results in the first input data being equal to the third input data then a down traversal state is set, if the comparison results in the first input data being greater than the third input data then the second input data is copied into a predefined location and no state is set, if the comparison results in the first input data being less than the third input data then an insertion state is set and the first input data is inserted into a trie data structure;
outputting the third input data to a predefined location;
storing the first input data into the trie data structure;
maintaining the down traversal state and the insertion state information; and
wherein the logic unit can be programmed to process one of many different instructions.
-
Specification