A sequence state matrix has a plurality of time slots for storing a plurality of memory device signals. The memory device signals are loaded into the matrix by a sequencer load unit, which loads the memory device signals at locations in the matrix corresponding to the times that the signals will be coupled to a memory device. The sequencer load unit loads the signals into the matrix at a rate corresponding to a frequency of a system clock signal controlling the operation of the electronic system. A first in, first out (“FIFO”) buffer receives the memory device signals from the sequence state matrix at a rate corresponding to the frequency of the system clock signal. A command selector transfers the memory device signals from the FIFO buffer to the memory device at a rate corresponding to the frequency of a memory clock signal controlling the operation of the memory device.
|
13. A system for coupling memory device signals from an electronic system synchronized to a system clock signal to a memory device synchronized to a memory clock signal, the system comprising:
a sequence state matrix having a plurality of time slots for each of a plurality of the memory device signals, the sequence state matrix storing the memory device signals at respective locations corresponding to the times that the memory device signals will be coupled to the memory device;
a first in, first out (“FIFO”) buffer coupled to the sequence state matrix to receive the memory device signals from the matrix in the order that the memory device signals are stored in the sequence state matrix, the memory device signals being transferred from the sequence state matrix to the FIFO buffer responsive to a first clock signal;
a command selector coupled to the FIFO buffer to receive the memory device signals from the FIFO buffer and transfer the memory device signals to the memory device responsive to a second clock signal; and
a phasing unit coupled to the FIFO buffer and to the command selector, the phasing unit generating the first and second clock signals at respective frequencies in which the ratio between the frequency of the first clock signal and the frequency of the second clock signal corresponds to ratio between the frequency of the system clock signal and the frequency of the memory clock signal.
7. A system for coupling memory device signals, comprising:
a sequence state matrix having a plurality of time slots for each of a plurality of the memory device signals;
a sequencer load unit coupled to receive the memory device signals, the sequencer load unit coupled to the sequence state matrix to load the memory device signals into the sequence state matrix at locations in the matrix corresponding to the times that the memory device signals will be coupled to the memory device, the sequencer load unit loading the memory device signals into the sequence state matrix at a rate corresponding to a frequency of a system clock signal;
a first in, first out (“FIFO”) buffer coupled to the sequence state matrix to receive the memory device signals from the matrix at respective times corresponding to the locations into which the memory device signals were loaded, the FIFO buffer receiving the memory device signals from the matrix at a rate corresponding to the frequency of the system clock signal; and
a combinatorial unit coupled to the sequence state matrix and the sequencer load unit, the combinatorial unit determining the location of memory device signals stored in the sequence state matrix and coupling corresponding information to the sequencer load unit, the sequencer load unit determining the locations in the sequence state matrix in which to store the memory device signals based at least in part on the information received from the combinatorial unit.
1. A system for coupling memory device signals from an electronic system to a memory device, comprising:
a sequence state matrix having a plurality of time slots for each of a plurality of the memory device signals;
a sequencer load unit coupled to receive the memory device signals from the electronic system, the sequencer load unit coupled to the sequence state matrix to load the memory device signals into the sequence state matrix at locations in the matrix corresponding to the times that the memory device signals will be coupled to the memory device, the sequencer load unit loading the memory device signals into the sequence state matrix at a rate corresponding to a frequency of a system clock signal controlling the operation of the electronic system;
a first in, first out (“FIFO”) buffer coupled to the sequence state matrix to receive the memory device signals from the matrix at respective times corresponding to the locations into which the memory device signals were loaded, the FIFO buffer receiving the memory device signals from the matrix at a rate corresponding to the frequency of the system clock signal; and
a command selector coupled to the FIFO buffer to receive the memory device signals from the FIFO buffer and transfer the memory device signals to the memory device, the command selector transferring the memory device signals to the memory device at a rate corresponding to the frequency of a memory clock signal controlling the operation of the memory device.
31. A computer system, comprising:
a processing unit operable to perform computing functions;
a system controller coupled to the processing unit, the system controller operating in synchronism with a system clock signal;
at least one input device coupled to the processing unit through the system controller;
at least one output device coupled to the processing unit through the system controller;
at least one data storage devices coupled to the processing unit through the system controller;
a memory device operating in synchronism with a memory clock signal; and
a memory controller included in the system controller, the memory controller coupling memory device signals from the processing unit to the memory device, the memory controller comprising:
a sequence state matrix having a plurality of time slots for each of a plurality of the memory device signals received from the processing unit, the sequence state matrix storing the memory device signals at respective locations corresponding to the times that the memory device signals will be coupled to the memory device;
a first in, first out (“FIFO”) buffer coupled to the sequence state matrix to receive the memory device signals from the matrix in the order that the memory device signals are stored in the sequence state matrix, the memory device signals being transferred from the sequence state matrix to the FIFO buffer responsive to a first clock signal;
a command selector coupled to the FIFO buffer to receive the memory device signals from the FIFO buffer and transfer the memory device signals to the memory device responsive to a second clock signal; and
a phasing unit coupled to the FIFO buffer and to the command selector, the phasing unit generating the first and second clock signals at respective frequencies in which the ratio between the frequency of the first clock signal and the frequency of the second clock signal corresponds to ratio between the frequency of the system clock signal and the frequency of the memory clock signal.
17. A computer system, comprising:
a processing unit operable to perform computing functions;
a system controller coupled to the processing unit, the system controller operating in synchronism with a system clock signal;
at least one input device coupled to the processing unit through the system controller;
at least one output device coupled to the processing unit through the system controller;
at least one data storage devices coupled to the processing unit through the system controller;
a memory device operating in synchronism with a memory clock signal; and
a memory controller included in the system controller, the memory controller coupling memory device signals from the processing unit to the memory device, the memory controller comprising:
a sequence state matrix having a plurality of time slots for each of a plurality of the memory device signals;
a sequencer load unit coupled to receive the memory device signals from the processing unit, the sequencer load unit coupled to the sequence state matrix to load the memory device signals into the sequence state matrix at locations in the matrix corresponding to the times that the memory device signals will be coupled to the memory device; the sequencer load unit loading the memory device signals into the sequence state matrix at a rate corresponding to a frequency of the system clock signal;
a first in, first out (“FIFO”) buffer coupled to the sequence state matrix to receive the memory device signals from the matrix at respective times corresponding to the locations into which the memory device signals were loaded, the FIFO buffer receiving the memory device signals from the matrix at a rate corresponding to the frequency of the system clock signal; and
a command selector coupled to the FIFO buffer to receive the memory device signals from the FIFO buffer and transfer the memory device signals to the memory device, the command selector transferring the memory device signals to the memory device at a rate corresponding to the frequency of the memory clock signal.
24. A computer system, comprising:
a processing unit operable to perform computing functions;
a system controller coupled to the processing unit, the system controller operating in synchronism with a system clock signal;
at least one input device coupled to the processing unit through the system controller;
at least one output device coupled to the processing unit through the system controller;
at least one data storage devices coupled to the processing unit through the system controller;
a memory device operating in synchronism with a memory clock signal; and
a memory controller included in the system controller, the memory controller coupling memory device signals from the processing unit to the memory device, the memory controller comprising:
a sequence state matrix having a plurality of time slots for each of a plurality of the memory device signals;
a sequencer load unit coupled to receive the memory device signals from the processing unit, the sequencer load unit coupled to the sequence state matrix to load the memory device signals into the sequence state matrix at locations in the matrix corresponding to the times that the memory device signals will be coupled to the memory device, the sequencer load unit loading the memory device signals into the sequence state matrix at a rate corresponding to a frequency of the system clock signal;
a first in, first out (“FIFO”) buffer coupled to the sequence state matrix to receive the memory device signals from the matrix at respective times corresponding to the locations into which the memory device signals were loaded, the FIFO buffer receiving the memory device signals from the matrix at a rate corresponding to the frequency of the system clock signal, the memory device signals being transferred from the FWO buffer to the memory device at a rate corresponding to the frequency of the memory clock signal; and
a combinatorial unit coupled to the sequence state matrix and the sequencer load unit, the combinatorial unit determining the location of memory device signals stored in the sequence state matrix and coupling corresponding information to the sequencer load unit, the sequencer load unit determining the locations in the sequence state matrix in which to store the memory device signals based at least in part on the information received from the combinatorial unit.
5. The system of
6. The system of
11. The system of
12. The system of
18. The computer system of
20. The computer system of
21. The computer system of
22. The computer system of
23. The computer system of
25. The computer system of
27. The computer system of
28. The computer system of
29. The computer system of
30. The computer system of
32. The computer system of
34. The computer system of
35. The computer system of
|
This invention relates to memory devices, and more particularly to a system and method for interfacing a memory device to a system in which the system and memory device may operate at different clock speeds.
Memory devices, such as dynamic random access memories (“DRAMs”) may operate either asynchronously or synchronously. When operating synchronously, the operation of the memory device is controlled by a clock signal, and the speed at which the memory device operates is thus determined by the frequency of the clock signal. The memory device may be interfaced with an electronic device, such as a computer system, that is also operated synchronously at a frequency determined by its own clock signal, known as the system clock signal. Generally, the frequency of the system clock signal is the same as the frequency of the memory clock signal. However, it is often possible for a memory device to operate at a higher speed than the speed corresponding to the frequency of the system clock signal. In such case, the memory clock signal may have a higher frequency than the frequency of the system clock signal.
If a memory device synchronized to a relatively high speed memory clock signal could be interfaced with a system synchronized to a relatively slow speed system clock signal, it might be possible to increase the speed at which data could be written to or read from the memory device. However, it can be difficult to interface a memory device operating according to a memory clock signal having one frequency with an electronic system operating according to a system clock having a different, usually slower, frequency. This difficulty stems from the fact that the different clock frequencies inherently prevents the memory device from operating in synchronism with the electronic system.
There is therefore a need for a system and method for allowing a memory device operating in synchronism with a memory clock signal to interface with an electronic system operating in synchronism with a system clock signal having a frequency that may be different from the frequency of the memory clock signal.
A sequencer is used to transfer memory device signals, such as command, addresses and data signals, from an electronic system operating at a system clock speed to a memory device operating at a higher memory clock speed. The sequencer, includes a sequencer state matrix into which the memory device signals are loaded in the order in which they will be applied to the memory device. The memory device signals are loaded into the sequence state matrix at the slower system clock speed. The memory device signals are then transferred from the sequence state matrix to a first in, first out buffer at the system clock speed, and are then transferred from the first in, first out buffer to the memory device at the higher memory clock speed.
A computer system 100 according to one embodiment of the invention is shown in
The computer system 100 includes a system clock 126 that is coupled to the system controller 110 and may be coupled to other components in the computer system 100. The system clock 126 generates a system clock signal to which the operation of system controller 110 is synchronized.
The system controller 110 also includes a memory controller 130 for controlling access to a system memory 140, which may be a synchronous dynamic random access memory (“SDRAM”). The operation of the memory controller 130 is also synchronized to the system clock signal generated by the system clock 126. The memory controller 130 allows the processor 104 to write data to and read data from the system memory 140, and may also allow other devices (not shown) to write data to and read data from the system memory 140 in a direct memory operation, as is well known in the art. The memory controller 130 is coupled to the system memory 140 through a control bus 142, an address bus 144 and a data bus 146. The operation of the system memory 140 is synchronized to a memory clock signal generated by a memory clock 148. The frequency of the memory clock signal is preferably greater than the frequency of the system clock signal generated by the system clock 126 so that data can be written to and read from the system memory 140 at a faster rate. Significantly, the memory controller 130 includes a sequencer 150 that allows the system memory 140 operating at a speed controlled by the memory clock signal to interface with other components of the computer system 100 operating at a slower speed corresponding to the frequency of the system clock signal.
One embodiment of the sequencer 150 is shown in
The memory device signals coupled through the input registers 160 are applied to a command parser 170, which analyzes the memory device signals and determines individual commands corresponding to combinations of the memory device command signals. The command parser 170 applies signals indicative of the individual commands to a sequencer load logic unit 176, which has an output bus coupled to a sequencer state matrix 180. The sequencer state matrix is essentially a set of first in, first out buffers operating in synchronism with each other, with a separate buffer being provided for each memory device signal. The load logic unit 176 examines the individual commands to determine the time slot in which each of the commands can be applied to the system memory 140. The commands are then loaded into the sequencer state matrix 180 at locations corresponding to the respective time slots. The time slots selected for being loaded with the commands thus correspond to the times at which the commands can be applied to the system memory 140 at the frequency of the memory clock signal generated by the memory clock 148.
It is important that the time slots at which the commands are applied to the system memory 140 not conflict with each other. For this reason, a combinatorial unit 184 examines the commands that have been loaded into the sequencer state matrix 180. The combinatorial unit 184 then provides information signals to the sequencer load logic unit 176 via path 188 indicative of the nature and location of all commands that have already been loaded into the sequencer state matrix 180. Using this information, the sequencer load logic unit 176 can determine locations in the matrix 180 where additional command can be loaded into the matrix 180 without causing a conflict when the commands are subsequently applied to the system memory 140.
The command parser 170, the sequencer load logic unit 176, the sequencer state matrix 180 and the combinatorial unit 184 are preferably respective logic circuits, the design of which will be apparent to one skilled in the art. The operation of all of these units is synchronized to the system clock signal generated by the system clock system clock 126, although, as previously mentioned, the time slots in the matrix 180 into which the commands and addresses are loaded correspond to the times at which the commands can be applied to the system memory 140 at the frequency of the memory clock signal generated by the memory clock 148.
Once the commands and addresses have been loaded into the sequencer state matrix 180, they are transferred to a first in, first out (FIFO) buffer 190 at a rate corresponding to the frequency of the system clock signal. However, the system clock signal from the system clock 126 is not used to load the commands and addresses into the buffer 190. Instead, the commands and addressed are loaded into the FIFO buffer 190 responsive to a first clock signal from a phasing unit 194. A second clock signal is generated by the phasing unit 194, which is applied to a command selector 200. The command selector 200 transfers the commands and addresses from the FIFO buffer in the same order that the buffer 190 was loaded at a rate determined by the second clock signal. The second clock signal has a frequency that corresponds to the memory clock signal from the memory clock 148. Thus, the frequency ratio between the first and second clock signals from the phasing unit 194 corresponds to the frequency ratio between the system clock signal and the memory clock signal. The phasing unit 194 thus compensates for the difference between the frequency of the system clock signal and the frequency of the memory clock signal.
The commands and addresses coupled from the FIFO buffer 190 by the command selector 200 are coupled to the system memory 140 through a set of output buffers 204, and the data are coupled to and from the system memory 140 through a set of output buffers 204 and input buffers 206.
The manner in which the commands are loaded into the sequencer state matrix 180 will now be explained with reference to
In contrast to a memory read at a clock frequency of 200 MHz, the sequencer state matrix 180 may be loaded for a memory read at 100 MHz as shown in
In each of the cases shown in
From the foregoing it will be appreciated that, although specific embodiments of the invention have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the invention. Accordingly, the invention is not limited except as by the appended claims.
Patent | Priority | Assignee | Title |
10176861, | Apr 21 2005 | Innovations In Memory LLC | RAIDed memory system management |
10417159, | Apr 21 2005 | Innovations In Memory LLC | Interconnection system |
7636803, | Sep 28 2006 | ADVANCED SILICON TECHNOLOGIES, LLC | Device and method for transferring data between devices |
7681099, | May 17 2007 | Advanced Micro Devices, INC | Techniques for integrated circuit clock signal manipulation to facilitate functional and speed test |
7737752, | May 17 2007 | TAIWAN SEMICONDUCTOR MANUFACTURING CO , LTD | Techniques for integrated circuit clock management |
7921318, | May 17 2007 | GLOBALFOUNDRIES U S INC | Techniques for integrated circuit clock management using pulse skipping |
8014485, | May 17 2007 | Advanced Micro Devices, Inc.; Advanced Micro Devices, INC | Techniques for integrated circuit clock management using multiple clock generators |
8028186, | Oct 23 2006 | Innovations In Memory LLC | Skew management in an interconnection system |
8090973, | Oct 23 2006 | Innovations In Memory LLC | Skew management in an interconnection system |
8112655, | Apr 21 2005 | Innovations In Memory LLC | Mesosynchronous data bus apparatus and method of data transmission |
8195849, | Sep 28 2006 | ADVANCED SILICON TECHNOLOGIES, LLC | Device and method for transferring data between devices |
8452929, | Apr 21 2005 | Innovations In Memory LLC | Method and system for storage of data in non-volatile media |
8575972, | Mar 23 2009 | Advanced Micro Devices, Inc. | Digital frequency synthesizer device and method thereof |
8726064, | Apr 21 2005 | Innovations In Memory LLC | Interconnection system |
8806262, | Oct 23 2006 | VIOLIN SYSTEMS LLC | Skew management in an interconnection system |
9286198, | Apr 21 2005 | Innovations In Memory LLC | Method and system for storage of data in non-volatile media |
9384818, | Apr 21 2005 | Innovations In Memory LLC | Memory power management |
9582449, | Apr 21 2005 | Innovations In Memory LLC | Interconnection system |
9727263, | Apr 21 2005 | Innovations In Memory LLC | Method and system for storage of data in a non-volatile media |
Patent | Priority | Assignee | Title |
4245303, | Oct 25 1977 | Digital Equipment Corporation | Memory for data processing system with command and data buffering |
5155809, | May 17 1989 | International Business Machines Corp. | Uncoupling a central processing unit from its associated hardware for interaction with data handling apparatus alien to the operating system controlling said unit and hardware |
5448715, | Jul 29 1992 | Hewlett-Packard Company | Dual clock domain interface between CPU and memory bus |
5471587, | Sep 30 1992 | Intel Corporation | Fractional speed bus coupling |
5487092, | Dec 22 1994 | International Business Machines Corporation | System for high-speed synchronization across clock domains |
5600824, | Feb 04 1994 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Clock generating means for generating bus clock and chip clock synchronously having frequency ratio of N-1/N responsive to synchronization signal for inhibiting data transfer |
5915107, | Sep 26 1997 | AMD TECHNOLOGIES HOLDINGS, INC ; GLOBALFOUNDRIES Inc | Cross clock domain clocking for a system using two clock frequencies where one frequency is fractional multiple of the other |
5923193, | Dec 11 1996 | Intel Corporation | Method and apparatus for transferring signals between multiple clock timing domains |
5923858, | May 01 1997 | Cirrus Logic, Inc.; Cirrus Logic, INC | Method and apparatus to interface a peripheral device operating in an internal clock domain to a PCI bus operating in a PCI clock domain |
6000022, | Oct 10 1997 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Method and apparatus for coupling signals between two circuits operating in different clock domains |
6006340, | Mar 27 1998 | Synopsys, Inc | Communication interface between two finite state machines operating at different clock domains |
6016549, | Jun 14 1996 | LENOVO SINGAPORE PTE LTD | Peripheral unit having at least two sequencer circuits configured to control data transfers for power saving |
6112307, | Dec 30 1993 | Intel Corporation | Method and apparatus for translating signals between clock domains of different frequencies |
6128749, | Nov 03 1998 | Intel Corporation | Cross-clock domain data transfer method and apparatus |
6134638, | Aug 13 1997 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Memory controller supporting DRAM circuits with different operating speeds |
6202119, | Dec 19 1997 | Round Rock Research, LLC | Method and system for processing pipelined memory commands |
6279077, | May 22 1996 | Texas Instruments Incorporated | Bus interface buffer control in a microprocessor |
6279090, | Sep 03 1998 | Round Rock Research, LLC | Method and apparatus for resynchronizing a plurality of clock signals used in latching respective digital signals applied to a packetized memory device |
6363076, | Jan 27 1998 | International Business Machines Corporation; IBM Corporation | Phantom buffer for interfacing between buses of differing speeds |
6370600, | May 25 1999 | AMD TECHNOLOGIES HOLDINGS, INC ; GLOBALFOUNDRIES Inc | Staging buffer for translating clock domains when source clock frequency exceeds target clock frequency |
6389529, | Jun 25 1999 | International Business Machines Corporation | Method for alternate preferred time delivery of load data |
6414903, | Aug 21 2000 | Round Rock Research, LLC | Method and apparatus for crossing clock domain boundaries |
6434684, | Sep 03 1998 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Method and apparatus for coupling signals across different clock domains, and memory device and computer system using same |
6449703, | Jul 13 1998 | Round Rock Research, LLC | Pipelined memory controller |
6526469, | Nov 12 1999 | International Business Machines Corporation | Bus architecture employing varying width uni-directional command bus |
6542569, | Mar 05 1997 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Memory device command buffer apparatus and method and memory devices and computer systems using same |
6546451, | Sep 30 1999 | Hewlett Packard Enterprise Development LP | Method and apparatus for decoupling processor speed from memory subsystem speed in a node controller |
6590901, | Apr 01 1998 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Method and apparatus for providing a packet buffer random access memory |
6594713, | Sep 10 1999 | Texas Instruments Incorporated | Hub interface unit and application unit interfaces for expanded direct memory access processor |
6622228, | Jul 31 1998 | Round Rock Research, LLC | System and method of processing memory requests in a pipelined memory controller |
6718449, | Jul 09 2001 | Sony Corporation; Sony Electronics Inc. | System for data transfer between different clock domains, and for obtaining status of memory device during transfer |
6775755, | Sep 03 1998 | Micron Technology, Inc. | Method and apparatus for coupling signals across different clock domains, and memory device and computer system using same |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 10 2002 | JEDDELOH, JOSEPH M | Micron Technology, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 012949 | /0097 | |
May 24 2002 | Micron Technology, Inc. | (assignment on the face of the patent) | / | |||
Apr 26 2016 | Micron Technology, Inc | MORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 038954 | /0001 | |
Apr 26 2016 | Micron Technology, Inc | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | CORRECTIVE ASSIGNMENT TO CORRECT THE REPLACE ERRONEOUSLY FILED PATENT #7358718 WITH THE CORRECT PATENT #7358178 PREVIOUSLY RECORDED ON REEL 038669 FRAME 0001 ASSIGNOR S HEREBY CONFIRMS THE SECURITY INTEREST | 043079 | /0001 | |
Apr 26 2016 | Micron Technology, Inc | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 038669 | /0001 | |
Jun 29 2018 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Micron Technology, Inc | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 047243 | /0001 | |
Jul 03 2018 | MICRON SEMICONDUCTOR PRODUCTS, INC | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 047540 | /0001 | |
Jul 03 2018 | Micron Technology, Inc | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 047540 | /0001 | |
Jul 31 2019 | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | Micron Technology, Inc | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 051028 | /0001 | |
Jul 31 2019 | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | MICRON SEMICONDUCTOR PRODUCTS, INC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 051028 | /0001 | |
Jul 31 2019 | MORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENT | Micron Technology, Inc | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 050937 | /0001 |
Date | Maintenance Fee Events |
Oct 28 2005 | ASPN: Payor Number Assigned. |
Jun 03 2009 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Mar 11 2013 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jun 15 2017 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Jan 03 2009 | 4 years fee payment window open |
Jul 03 2009 | 6 months grace period start (w surcharge) |
Jan 03 2010 | patent expiry (for year 4) |
Jan 03 2012 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jan 03 2013 | 8 years fee payment window open |
Jul 03 2013 | 6 months grace period start (w surcharge) |
Jan 03 2014 | patent expiry (for year 8) |
Jan 03 2016 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jan 03 2017 | 12 years fee payment window open |
Jul 03 2017 | 6 months grace period start (w surcharge) |
Jan 03 2018 | patent expiry (for year 12) |
Jan 03 2020 | 2 years to revive unintentionally abandoned end. (for year 12) |