A pipelined run-to-completion processor includes no instruction counter and only fetches instructions either: as a result of being prompted from the outside by an input data value and/or an initial fetch information value, or as a result of execution of a fetch instruction. Initially the processor is not clocking. An incoming value kick-starts the processor to start clocking and to fetch a block of instructions from a section of code in a table. The input data value and/or the initial fetch information value determines the section and table from which the block is fetched. A LUT converts a table number in the initial fetch information value into a base address where the table is found. Fetch instructions at the ends of sections of code cause program execution to jump from section to section. A finished instruction causes an output data value to be output and stops clocking of the processor.
|
1. A method comprising:
(a) receiving an input value onto a processor, wherein the processor includes no instruction counter;
(b) converting the input value into a base address value and an offset value, wherein the base address value is the base address of a table of code in an external memory, and wherein the offset value indicates an offset from the base address to a section of code within the table;
(c) in response to the receiving of the input value of (a) fetching a first block of information of the section of code without use by the processor of any instruction counter, wherein the first block of information includes a plurality of instructions, wherein at least one of the instructions of the first block of information is a fetch instruction, wherein the fetch instruction includes an opcode indicating that the fetch instruction is a fetch instruction, wherein execution by the processor of a fetch instruction involves decoding of the opcode of the fetch instruction, and wherein the processor only begins clocking in response to receiving an input value; and
(d) executing the instructions of the first block of information including executing the fetch instruction.
22. A method comprising:
(a) receiving an initial fetch information value onto a processor, wherein the processor does not include any instruction counter, and wherein the initial fetch information value is a multi-bit value that is received in (a) onto a port of the processor;
(b) using the initial fetch information value to determine a base address value and an offset value, wherein the base address value is a base address of a table of code in an external memory, and wherein the offset value indicates an offset from the base address to a section of code within the table;
(c) in response to the receiving of the initial fetch information value of (a) fetching a first block of information of the section of code without use by the processor of any instruction counter, wherein the first block of information includes a plurality of instructions, wherein at least one of the instructions of the first block is a fetch instruction, wherein the fetch instruction includes an opcode indicating that the fetch instruction is a fetch instruction, wherein execution by the processor of a fetch instruction involves decoding of the opcode of the fetch instruction, and wherein the processor only fetches instructions in response to receiving an initial fetch information value from an external source onto the port or as a result of executing a fetch instruction; and
(d) executing the instructions of the first block of information including executing the fetch instruction, and wherein (a), (b), (c) and (d) are performed by the processor.
28. A method comprising:
(a) generating a set of flags from a network packet, wherein the set of flags characterizes the network packet;
(b) receiving prompting information onto a processor, wherein the set of flags is a part of the prompting information, wherein the processor does not include any instruction counter, and wherein the processor is not clocking when the prompting information is received in (b);
(c) using the set of flags to determine an address of a block of information in a memory external to the processor, wherein the block of information includes a plurality of instructions executable by the processor, wherein at least one of the instructions is a fetch instruction, wherein the fetch instruction includes an opcode indicating that the fetch instruction is a fetch instruction, wherein execution by the processor of a fetch instruction involves decoding of the opcode of the fetch instruction, and wherein the processor only fetches instructions in response to receiving prompting information onto the processor or as a result of executing a fetch instruction;
(d) in response to the receiving of the prompting information in (b) causing the processor to start clocking;
(e) in response to the receiving of the prompting information in (b) fetching the block of information from the memory without use by the processor of any instruction counter; and
(f) executing the instructions of the block of information including executing the fetch instruction, and wherein (b), (c), (d), (e) and (f) are performed by the processor.
13. A processor comprising:
means for fetching blocks of information from a memory system external to the processor without the use of an instruction counter, wherein the means only fetches blocks of information from the memory system in response to either a receiving of a fetch information value onto the processor from an external source or to a receiving of a fetch information value from a stage within the processor, wherein the processor includes no instruction counter and the means fetches a block of information without use of any instruction counter, wherein a fetch information value received onto the processor from the external source includes a table number value, wherein the means determines a base address value from the table number value, and wherein the base address value is supplied as part of a memory request that is supplied from the means to the memory system, and wherein the base address value is a base address of a table that contains the block of information;
a decode stage coupled to the means, wherein the decode stage can decode a fetch instruction, wherein the fetch instruction includes an opcode indicating that the fetch instruction is a fetch instruction, wherein execution by the processor of a fetch instruction involves decoding of the opcode of the fetch instruction;
a register file read stage coupled to the decode stage; and
an execute stage coupled to the register file read stage, wherein the execute stage executes the fetch instruction by outputting fetch information to the means thereby prompting the means to fetch a block of information.
19. A system comprising:
a processor comprising:
means for fetching blocks of information without the use of an instruction counter, wherein the means only fetches blocks of information in response to either a receiving of a fetch information value onto the processor from an external source or to a receiving of a fetch information value from a stage within the processor, wherein the processor includes no instruction counter and the means fetches blocks of information without use of any instruction counter, wherein a fetch information value received onto the processor from the external source includes a table number value;
a decode stage coupled to the means, wherein the decode stage can decode a fetch instruction, wherein the fetch instruction includes an opcode indicating that the fetch instruction is a fetch instruction, wherein execution by the processor of a fetch instruction involves decoding of the opcode of the fetch instruction;
a register file read stage coupled to the decode stage; and
an execute stage coupled to the register file read stage, wherein the execute stage executes the fetch instruction by outputting fetch information to the means thereby prompting the means to fetch a block of information; and
a memory system external to the processor, wherein the memory system receives a memory request from the processor, wherein the memory request includes the table number value, wherein the memory system determines a base address value from the table number value, and wherein the base address value is a base address of a table of code stored in the memory system that contains the block of information.
2. The method of
3. The method of
(e) executing a finished instruction, wherein execution of the finished instruction causes a clocking of the pipeline to stop.
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
10. The method of
11. The method of
12. The method of
(e) as a result of the executing of the fetch instruction of the first block of information in (d) fetching a second block of information, wherein the second block of information is located in the same section of code as the first block of information, and wherein the fetching of the second block of information is performed by the processor.
14. The processor of
15. The processor of
17. The processor of
20. The system of
21. The processor of
23. The method of
24. The method of
25. The method of
26. The method of
(e) as a result of the executing of the fetch instruction of the first block of information in (d) fetching a second block of information, wherein the second block of information is located in the same section of code as the first block of information, and wherein the fetching of the second block of information is performed by the processor.
27. The method of
(e) generating a set of flags from a part of a network packet, wherein the set of flags characterizes the network packet, and wherein the set of flags is a part of the initial fetch information value that is received onto the port of the processor in (a), and
(f) supplying the part of the network packet to the processor, wherein (e) and (f) occur prior to the fetching of the first block of information in (c).
|
The described embodiments relate generally to pipelined run-to-completion processors.
In a first novel aspect, a pipelined run-to-completion processor includes no instruction counter and only fetches instructions either: as a result of being prompted from the outside by an incoming input data value and/or an incoming initial fetch information value, or as a result of execution of a fetch instruction. Due to the lack of an instruction counter and the associated control circuitry which can be substantial, the pipelined run-to-completion processor can be realized in a small amount of integrated circuit area. In one example, the pipelined run-to-completion processor is implemented in about ten thousand equivalent gates.
Initially the pipelined run-to-completion processor is stopped and is not clocking. An initial fetch information value and/or input data value is supplied to the processor. The initial fetch information value and/or input data value kick-starts the processor into clocking and causes the processor to do an initial fetch of a block of instructions, where the block of instructions is one block of many in a section of code. There are typically many sections of code in a table of code. There are many such tables of code stored in an external memory.
In a second novel aspect, which particular block of instructions it is (of which particular section, or which particular table) that is fetched is determined by the input data value and/or the initial fetch information value. In one specific embodiment, a lookup table circuit in the processor converts a table number value in the initial fetch information value into a base address value, where the base address value is the address in the memory where the table starts. The offset from the base address of the table to the beginning of the section of code may be specified by a part of the initial fetch information value and/or by a part of the input data value, or the offset can be derived from such parts of the initial fetch information value and/or input data value. Fetch instructions at the ends of sections of code cause program execution to jump from section to section and/or from table to table. At the end of a program is a special “finished” instruction. Execution of this finished instruction causes an output data value to be output from the processor and causes clocking of the processor to stop.
In a third novel aspect, the incoming input data value and/or initial fetch information value causes the run-to-completion processor to start clocking, and execution of a finished instruction causes the run-to-completion processor to stop clocking.
In a fourth novel aspect, the pipelined run-to-completion processor executes a novel pop stack absolute instruction. The pop stack absolute instruction includes an opcode, an absolute pointer value, a “flag don't touch” bit, and predicate bits. A register file of the processor is used as a stack. A data value is stored in the register file, with a data value portion (a portion of the larger data value) being stored in a particular register of the register file. If a condition indicated by the predicate bits is not true, then an operation of the instruction is not performed. If the condition is true, then the stack of the processor is popped thereby generating an operand A. The absolute pointer value identifies the particular register of the stack. The identification of the register is not relative to a stack pointer or to the top of the stack, but rather the identification is “absolute” in that the absolute pointer value points to a specific register independent of the value of a stack pointer or which register is the top of the stack. The data value portion stored in this identified particular register is then used as an operand B. The arithmetic logic operation specified by the opcode of the instruction is performed using operand A and operand B thereby generating a result, and the data value portion in the particular register of the stack is replaced with the result. If the “flag don't touch bit” is set to a particular value, then the flag bits (carry flag and zero flag) are not affected by execution of the instruction.
Further details and embodiments and techniques are described in the detailed description below. This summary does not purport to define the invention. The invention is defined by the claims.
The accompanying drawings, where like numerals indicate like components, illustrate embodiments of the invention.
Reference will now be made in detail to background examples and some embodiments of the invention, examples of which are illustrated in the accompanying drawings.
Initially, the state machine 6 is in the idle state 16. The pipeline is clocked by the clock signal CLK 17. In the idle state, the state machine disables the clock signal CLK. The pipeline 7 is therefore not being clocked, and power consumption of the processor 4 is reduced. In the idle state, the state machine 6 also outputs the idle signal 18 via conductor 19. An external circuit external to the processor then supplies an input data value 20 onto the input data port 13 of the processor and asserts the start signal 21 (also referred to as the “PE select signal”). The input data port 13 in this case is a set of conductors that extends from outside the processor and to the register file read stage 11. The asserting of the start signal 21 informs the processor that the input data value 20 on the input data port 13 is available to be read. In response to the assertion of the start signal 21, the state machine transitions to the enable clock signal state 22. The transition of the state machine to the enable clock signal state 22 enables the pipeline 7 by supplying the clock signal CLK 17 to the pipeline 7. At the same time that the input data value is being supplied to the processor via conductors 23 and the input data port 13, an initial fetch information value 24 is supplied to the processor 4 via conductors 25 and initial fetch information port 14. In the present example, the initial fetch information determination circuit 5 includes a characterizer circuit and a Ternary Content Addressable Memory (TCAM). The characterizer is an amount of combinatorial logic that receives the input data value, characterizes various parts of the input data value, and generates therefrom a set of flag values. The value of a particular flag as output by the characterizer indicates whether the input data value has a corresponding particular characteristic. If, for example, the input data value 20 is an IPv4 network packet, then this characteristic is detected by the characterizer and the characterizer assert an IPv4 flag (the IPv4 flag is set), otherwise the characterizer does not assert the IPv4 flag (the IPv4 flag is cleared). There are many flags output by the characterizer, with each different flag indicating whether the input data value has a corresponding different characteristic. The flags as output by the characterizer are supplied to inputs of the TCAM. Depending on the values of the flags determined from the input data value 20, the TCAM outputs a multi-bit value (referred to as the “input fetch information value”) onto the initial fetch information port 14 of the processor circuit 2.
The fetch request stage 8 generates memory requests that are supplied to the external memory system 3. The fetch request stage 8 can only output a memory request in response to either: 1) an incoming input data value and/or an incoming initial fetch information value, or 2) a fetch information value supplied to the fetch request stage as a result of execution by the pipeline of a fetch instruction. In the present example, both an incoming input data value is being supplied to the pipeline as well as an associated initial fetch information value. The incoming input data value 20 and/or initial fetch information value 24 prompts the pipeline 7 to issue a memory request 26. The memory request 26 is communicated to the external memory system 3. As explained in further detail below, the memory request 26 is a request to read one 128-bit word 57 from the memory, where the address of the 128-bit word 57 is given by a base address value 28 and an offset value 29. The 128-bit word 47 is located at the beginning of a section 27 of code. A 128-bit word is also referred to here as a “block of information”. The memory of the memory system 3 is organized as a set of uniquely addressable 128-bit words. The base address value identifies the beginning of a table, TABLE #1 in this case, of code. The offset value identifies an offset from the base address 28 at the beginning of the table to the beginning of the section 27 of code. The external memory system 3 stores many such tables of code. The tables in
In one specific example, the particular section 27 of code that the processor is prompted to fetch within table TABLE #1 depends on the initial fetch information value 24. The particular table as well is determined by the initial fetch information value 24. The initial fetch information value 24 includes a table number value. The fetch request stage 8 includes a table number to base address lookup circuit 30. The table number value is supplied to the lookup table circuit 30, and the lookup table circuit 30 outputs the base address value for the table. The base address value is then incorporated into the actual memory request 26.
The memory system 3 responds by returning to the processor circuit 2 a memory response 31. The memory response 31 includes one 128-bit block of information at the beginning of the identified section 27 of code. The 128-bit block of information 57 contains sixteen octets. The 128-bit block of information 47 includes a plurality of instructions, where an instruction can involve one, two or three octets, depending on the type of instruction. The number of instructions in a 128-bit block is therefore variable. The 128-bit block of information 57 is received by the fetch shift selector stage 9. The fetch shift selector stage 9 stores the 128-bit block of information 57, and then outputs three octets, where the particular octets output are for the next instruction to be consumed by the pipeline. Immediately after the fetch of the 128-bit block 57, it is the first, second and third octets of the 128-bit block that are output from the fetch shift selector stage 9.
The decode stage 10 receives the selected octets 32, and decodes the instruction. Based on the instruction, the decode stage 10 loads an A register pointer AP 33, a B register pointer BP 34, carry flag bit C 67, zero flag bit Z 68, a stack pointer SP 35, and a packet pointer PP 36. The A register pointer AP 33 identifies one register (8-bit portion) of a register file 37 in the register file read stage 11. This identified 8-bit portion contains the value of the A register for the instruction to be executed. The B register pointer BP 34 identifies another register (8-bit portion) of the register file 37 that contains the value of a B register for the instruction to be executed. The stack pointer SP 35 identifies one register (8-bit portion) of the register file 37 that is the top of the stack. The 8-bit portions of the register file are usable as a stack, and there are instructions in the instruction set of the processor that use the stack. The packet pointer PP 36 identifies one bit in the input data register 38 in the register file read stage 11, where the bit is the first bit of a multi-bit value to be used in the instruction to be executed. In addition to determining the pointer values, the decode stage 10 sends a “number of octets consumed signal” 39 back to the fetch shift selector stage 9. The number of octets consumed depends on the instruction just consumed. If the instruction just consumed involves only one octet, then the decode stage 10 informs the fetch shift selector stage 9 to shift the bits the fetch shift selector stage outputs by one octet. If the instruction just consumed involves two octets, then the decode stage 10 informs the fetch shift selector stage 9 to shift the bits the fetch shift selector stage outputs by two octets. If the instruction just consumed involves three octets, then the decode stage 10 informs the fetch shift selector stage 9 to shift the bits the fetch shift selector stage outputs by three octets. Which octets of the block of information 57 that are output by the fetch shift selector stage 9 are therefore determined by the decode stage 10 using the number of octets consumed signal 39.
The register file read stage 11 stores the input date value 20 into an input data register 38, and sends a signal 56 back to the state machine 6, thereby causing the state machine 6 to transition from the enable clock signal state 22 to the operating state 50. The state machine 6 signals the external circuit that the processor circuit 2 has received the input data value 20 by outputting an operating signal 55. The external circuit can then stop driving input data value 20 onto the input data port 13.
The register file read stage 11 uses the pointer values 33 and 34 from the decode stage to identify the portions of the register file 37 that store the A register value RA 40, and store the B register value RB 41. The register file read stage 11 uses the packet pointer value 36 from the decode stage to identify the portion of the input data register 38 that stores the PCK data value 42 to be used by the instruction. The contents of the register file 37 are output from the register file read stage 11 to the output buffers 59, but the output buffers 59 are disabled. The contents of the register file 37 are therefore not driven onto the output data port 15.
The execute stage 12 receives the RA value 40 (the contents of the A register), the RB value 41 (the contents of the B register) and the PCK data value 42 from the register file read stage 11. The operation to be performed on these values is determined by control signals (not shown) received from the decode stage 10, where the operation is determined by the opcode of the instruction. The instruction set of the processor includes several different types of instructions including: ALU (Arithmetic Logic Unit) instructions, memory access instructions for data, instruction fetch instructions, and processor control instructions. Some of the instructions use the packet pointer 36 and the input data register 38 so that the instruction can obtain and use a part or parts of the input data value 20. Although not illustrated in
If the execute stage is executing a fetch instruction, then the execute stage supplies fetch information 44 back to the fetch request stage 8 via conductors 45. The execute stage also supplies associated data 46 via conductors 47. In the same way that an externally prompted fetch is prompted by fetch information received on initial fetch information port 14 and input data value received on input data port 13, so too is an internally prompted fetch from the execute stage 12 prompted by fetch information 44 on conductors 45 and data 46 on conductors 47.
As stated above, once the pipeline is operating it does not and cannot fetch instructions unless either: 1) it is prompted to by the receipt of another input data value (and associated initial fetch information value) or, 2) it is prompted to by execution of a fetch instruction. If the processor executes the last instruction of the fetched block of information and there is not a next instruction that has already been fetched, then the processor would hang. Accordingly, in the present example, the last instruction of the fetched block of information 57 is another fetch instruction. This last fetch instruction causes the processor to fetch the next 128-bit block of information from the same section 27 of code. The processor then continues on executing instructions from this second 128-bit block of information. The section 27 of code has a particular function. At the end of the code for performing this function is another fetch instruction, but this fetch instruction is an instruction to fetch the next 128-bit block of code from another table. In this way, the code executed by the processor is modular, with the code of one table causing a fetch into the code of another table, and so forth, from table to table. When fetching into the next table, the offset into the table is typically determined by a characteristic of the input data value 20, as recorded by flags generated by the characterizer. In some embodiments, the flags as determined by the characterizer are incorporated into the input data value 20 as stored in the input data register 38. When execution jumps from one table to the next, the particular section of code that is specifically tailored to data having a characteristic is vectored to (as opposed to vectoring to another section of the table whose code is not for data having the characteristic) due to the fetch instruction having access to the flags.
After the functions of the code have been carried out and execution of the code has traversed from table to table, a final “finished instruction” is executed. Execution of the finished instruction causes the execute stage 12 to assert a finished signal 48 on conductor 49. Asserting of the finished signal 48 causes the state machine 6 to transition from the operating state 50 to the finished state 51. In the finished state 51, the state machine asserts a finished signal 52 that is output from the processor circuit 2. The finished signal 52 as output from the processor circuit 2 is also referred to as the “PE has data to be read” signal. Assertion of the finished signal 52 indicates to an external circuit that the processor circuit 2 has data to supply to the external circuit. In response to the assertion of the “PE has data to be read” signal 52, the external circuit enables the outputting of the data output value 53 onto output data port 15 by asserting a “PE select signal” 58. Assertion of the PE select signal 58 causes the output buffers 59 to be enabled. The buffers 59 then drive the contents of the register file 37 onto the output data port 15 and to the external circuit. Execution of the finished instruction also causes the state machine to stop the clock signal CLK from being supplied to the pipeline. The pipeline therefore stops clocking, and power consumption is reduced.
While the PE select signal 58 is asserted and the output data value 53 is being driven onto the output data port 15, the external circuit reads the output data value 53 from the output data port 15. The external circuit then deasserts the PE select signal 58 thereby disabling driver 59, and asserts an “output data was read” signal 54. Assertion of the “output data was read signal” 54 causes the state machine 6 to transition to the idle state 16. In the idle state 16, the state machine asserts the idle signal 18. At this point, the pipeline is not being clocked, but it is ready to receive another input data value and another associated initial fetch information value.
Each section of code is typically an amount of code that is specialized to do a particular discrete task on input data having a particular characteristic or characteristics. In one simplified illustrative example, a first section of code does VLAN and MAC address processing, a second section of code does IP header analysis processor, a third section of code does tunnel decapsulation processing, and a fourth section of code does inner header processing. Execution of a fetch instruction at the end of the first section references an IP header version flag (a flag in the initial fetch information value 24 that indicates whether packet data is IPv4 or IPv6), and as a result of this flag fetches code at the beginning of the second section. Execution of a fetch instruction at the end of the second section references a header value in the input data value 20 (the header value indicates whether the packet is a tunnel packet, and if so what kind of tunnel), and as a result of this header value fetches code at the beginning of the third section. Execution of a fetch instruction at the end of the third section references a set of data values stored in memory system 3 (the set of data values indicates whether the packet data is an ethernet frame or an IP packet), and as a result of this set of data values fetches code at the beginning of the fourth section. Another processor (not shown) preloads the set of data values into the memory system 3 so that the set of data values is later usable by processor circuit 2 executing a fetch instruction to determine which section of code to execute next. Memory system 3, in addition to storing blocks of information of code, stores many such sets of data values.
In one example, the processor circuit 2 is one of many such processor circuits (also referred to picoengines) in a pool (also referred to as a picoengine pool). The output data values from the processor circuits are read out of the pool one by one, and are stored in an external FIFO. An external output data reader circuit supplies a PE select signal to each of the processor circuits 2, but it only asserts one PE select signal going to one processor circuit at a time. The currently selected processor circuit is made to output its output data value onto a common output bus, and the output data value is communicated via this bus to the FIFO. After the output data value is stored in the FIFO, the output data reader circuit deasserts the PE select signal and asserts another PE select signal, so that another of the processor circuits will then output its output data value onto the common output bus. In this way the output data values from processor circuits are read, one by one. Each output value includes a buffer pool number value that indicates a particular processor (an ME microengine processor) that will perform further processing on the input data value. A first particular type of input data values will typically be further processed by a first ME processor, whereas a second particular type of input data values will typically be further processed by a second ME processor, and so forth. For additional information on a picoengine pool and an output data reader, see: U.S. patent application Ser. No. 14/251,592, entitled “Picoengine Multi-Processor With Task Management”, filed Apr. 12, 2014, by Gavin J. Stark (the entire subject matter of which is incorporated herein by reference).
Although in the specific embodiment of
In one example, to realize an integrated circuit embodiment of the pipelined run-to-completion processor 4 of
Although certain specific embodiments are described above for instructional purposes, the teachings of this patent document have general applicability and are not limited to the specific embodiments described above. The particular interface signaling and interface logic of
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
5390311, | Feb 08 1989 | Intel Corporation | Method and apparatus for accessing microcoded instructions in a computer system |
5754806, | Nov 03 1995 | HOLTEK SEMICONDUCTOR INC | Memory table look-up device and method |
5935253, | Oct 17 1991 | Intel Corporation | Method and apparatus for powering down an integrated circuit having a core that operates at a speed greater than the bus frequency |
20020095609, | |||
20070028050, | |||
20100161949, | |||
20120117327, | |||
20140372731, | |||
20150046563, | |||
20150339125, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 01 2014 | Netronome Systems, Inc. | (assignment on the face of the patent) | / | |||
May 01 2014 | STARK, GAVIN J | NETRONOME SYSTEMS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032802 | /0037 | |
Jun 05 2018 | NETRONOME SYSTEMS, INC | KREOS CAPITAL V UK LIMITED | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 046319 | /0743 | |
Dec 17 2020 | KREOS CAPITAL V UK LIMITED | NETRONOME SYSTEMS, INC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 054883 | /0293 |
Date | Maintenance Fee Events |
Jan 18 2019 | BIG: Entity status set to Undiscounted (note the period is included in the code). |
Jul 22 2024 | REM: Maintenance Fee Reminder Mailed. |
Nov 27 2024 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Nov 27 2024 | M1554: Surcharge for Late Payment, Large Entity. |
Date | Maintenance Schedule |
Dec 01 2023 | 4 years fee payment window open |
Jun 01 2024 | 6 months grace period start (w surcharge) |
Dec 01 2024 | patent expiry (for year 4) |
Dec 01 2026 | 2 years to revive unintentionally abandoned end. (for year 4) |
Dec 01 2027 | 8 years fee payment window open |
Jun 01 2028 | 6 months grace period start (w surcharge) |
Dec 01 2028 | patent expiry (for year 8) |
Dec 01 2030 | 2 years to revive unintentionally abandoned end. (for year 8) |
Dec 01 2031 | 12 years fee payment window open |
Jun 01 2032 | 6 months grace period start (w surcharge) |
Dec 01 2032 | patent expiry (for year 12) |
Dec 01 2034 | 2 years to revive unintentionally abandoned end. (for year 12) |