A system memory includes a memory hub controller, a memory module accessible by the memory hub controller, and an expansion module having a processor circuit coupled to the memory module and also having access to the memory module. The memory hub controller is coupled to the memory hub through a first portion of a memory bus on which the memory requests from the memory hub controller and memory responses from the memory hub are coupled. A second portion of the memory bus couples the memory hub to the processor circuit and is used to couple memory requests from the processor circuit and memory responses provided by the memory hub to the processor circuit.
| 
 | 1.  A method of configuring a system memory, comprising:
 providing a memory module having a plurality of memory devices coupled to a memory hub, the memory hub adapted to receive memory command packets and access the memory devices according to the memory command packets and further adapted to provide memory responses in response thereto, the memory hub including a switch circuit having a plurality of switch nodes and adapted to couple any one switch node to another switch node, a plurality of link interface circuits, each link interface circuit having a first node coupled to a respective one of the plurality of switch nodes and further having a second node coupled to either the first or second portions of the memory bus, each link interface circuit coupling signals from its first node to its second node, a memory controller coupled to a switch node of the switch circuit to receive memory command packets and translate the same into memory device command signals, and a local memory bus coupled to the memory controller and the memory devices on which the memory device command signals are provided; coupling the memory hub of the memory module to a first portion of a memory bus coupled to a system controller, the system controller adapted to provide memory requests to access the memory devices on the first portion of the memory bus and receive memory responses from the memory hub on the first portion of the memory bus; and coupling an expansion module having a processor circuit located thereon to a second portion of the memory bus coupled to the memory hub, the processor circuit adapted to provide memory requests on the second portion of the memory bus to the memory hub to access the memory devices of the memory module and further adapted to process data included in the memory responses provided on the second portion of the memory bus from the memory hub. 2.  The method of  3.  The method of  4.  The method of  5.  The method of  | |||||||||||||||||||||||||||||
This application is a divisional of pending U.S. patent application Ser. No. 10/810,229, filed Mar. 25, 2004.
The present invention relates generally to a memory system for a processor-based computing system, and more particularly, to a hub-based memory system providing expansion capabilities for computer components.
Computer systems use memory devices, such as dynamic random access memory (“DRAM”) devices, to store data that are accessed by a processor. These memory devices are normally used as system memory in a computer system. In a typical computer system, the processor communicates with the system memory through a processor bus and a memory controller. The memory devices of the system memory, typically arranged in memory modules having multiple memory devices, are coupled through a memory bus to the memory controller. The processor issues a memory request, which includes a memory command, such as a read command, and an address designating the location from which data or instructions are to be read. The memory controller uses the command and address to generate appropriate command signals as well as row and column addresses, which are applied to the system memory through the memory bus. In response to the commands and addresses, data are transferred between the system memory and the processor. The memory controller is often part of a system controller, which also includes bus bridge circuitry for coupling the processor bus to an expansion bus, such as a PCI bus.
In memory systems, high data bandwidth is desirable. Generally, bandwidth limitations are not related to the memory controllers since the memory controllers sequence data to and from the system memory as fast as the memory devices allow. One approach that has been taken to increase bandwidth is to increase the speed of the memory data bus coupling the memory controller to the memory devices. Thus, the same amount of information can be moved over the memory data bus in less time. However, despite increasing memory data bus speeds, a corresponding increase in bandwidth does not result. One reason for the non-linear relationship between data bus speed and bandwidth is the hardware limitations within the memory devices themselves. That is, the memory controller has to schedule all memory commands to the memory devices such that the hardware limitations are honored. Although these hardware limitations can be reduced to some degree through the design of the memory device, a compromise must be made because reducing the hardware limitations typically adds cost, power, and/or size to the memory devices, all of which are undesirable alternatives. Thus, given these constraints, although it is easy for memory devices to move “well-behaved” traffic at ever increasing rates, for example, sequel traffic to the same page of a memory device, it is much more difficult for the memory devices to resolve “badly-behaved traffic,” such as bouncing between different pages or banks of the memory device. As a result, the increase in memory data bus bandwidth does not yield a corresponding increase in information bandwidth.
In addition to the limited bandwidth between processors and memory devices, the performance of computer systems is also limited by latency problems that increase the time required to read data from system memory devices. More specifically, when a memory device read command is coupled to a system memory device, such as a synchronous DRAM (“SDRAM”) device, the read data are output from the SDRAM device only after a delay of several clock periods. Therefore, although SDRAM devices can synchronously output burst data at a high data rate, the delay in initially providing the data can significantly slow the operating speed of a computer system using such SDRAM devices. Increasing the memory data bus speed can be used to help alleviate the latency issue. However, as with bandwidth, the increase in memory data bus speeds do not yield a linear reduction of latency, for essentially the same reasons previously discussed.
Although increasing memory data bus speed has, to some degree, been successful in increasing bandwidth and reducing latency, other issues are raised by this approach. For example, as the speed of the memory data bus increases, loading on the memory bus needs to be decreased in order to maintain signal integrity since traditionally, there has only been wire between the memory controller and the memory slots into which the memory modules are plugged. Several approaches have been taken to address the memory bus loading issue. For example, reducing the number of memory slots to limit the number of memory modules that contribute to the loading of the memory bus, adding buffer circuits on a memory module in order to provide sufficient fanout of control signals to the memory devices on the memory module, and providing multiple memory device interfaces on the memory module since there are too few memory module connectors on a single memory device interface. The effectiveness of these conventional approaches are, however, limited. A reason why these techniques were used in the past is that it was cost-effective to do so. However, when only one memory module can be plugged in per interface, it becomes too costly to add a separate memory interface for each memory slot. In other words, it pushes the system controllers package out of the commodity range and into the boutique range, thereby, greatly adding cost.
One recent approach that allows for increased memory data bus speed in a cost effective manner is the use of multiple memory devices coupled to the processor through a memory hub. A computer system 100 shown in 
The system controller 110 includes a memory hub controller 128 that is coupled to the processor 104. The system controller 110 is further coupled over a high speed bi-directional or unidirectional system controller/hub interface 134 to several memory modules 130a–n. As shown in 
The memory devices 148 on the memory modules 130a–n are typically capable of operating at high clock frequencies in order to facilitate the relatively high speed operation of the overall memory system. Consequently, computer systems employing this architecture can also use the high-speed system controller/hub interface 134 to complement the high clock speeds of the memory devices 148. Additionally, with a memory hub based system, signal integrity can be maintained on the system controller/hub interface 134 since the signals are typically transmitted through multiple memory hubs 140 to and from the memory hub controller 128. Moreover, this architecture also provides for easy expansion of the system memory without concern for degradation in signal quality as more memory modules are added, such as occurs in conventional memory bus architectures.
Although the memory hub architecture shown in 
As well known, arbitration schemes are implemented by the system controller 110 in order to prioritize memory requests it receives from the various components 112, 118, 120, 124, as well as memory requests received from the processor 104. The arbitration schemes that are implemented attempt to provide efficient memory access to the various components 112, 118, 120, 124, and processor 104 in order to maximize processing capabilities. Some memory requests are given priority over others regardless of the order in which the requests are received by the system controller 110, for example, the processor 104 is often given highest priority to access the memory modules 130a–n to avoid the situation where processing is halted while the processor 104 is waiting for a memory request to be serviced. As sophisticated as arbitration techniques have become, it is still unlikely that bottlenecks at the system controller 110 can be completely avoided. Even where a component is given direct memory access to the memory modules 130a–n, such as the graphics controller 112, it is nevertheless subject to the arbitration routine that is implemented by the system controller 110, and consequently, the component does not have unlimited access privileges to the memory modules 130a–n. It is by the nature of the architecture used in the computer system 100, namely, providing access to the memory modules 130a–n through the single point of the system controller 110, that makes bottlenecks at the system controller 110 inevitable. Therefore, there is a need for an alternative system and method for providing components of a processing system, such as a computer system, access to memory resources.
A system memory in one aspect of the invention includes a memory hub controller, a memory module accessible by the memory hub controller, and an expansion module coupled to the memory module having a processor circuit also having access to the memory module. The memory hub controller provides memory requests to access memory devices, and the memory module includes a plurality of memory devices coupled to a memory hub. The memory hub receives the memory requests, accesses the memory devices according to the memory requests, and provides memory responses in response to the memory requests. The processor circuit of the expansion module provides memory requests to the memory hub of the memory module to access the memory devices, and processes data returned in the memory responses from the memory hub. The memory hub controller is coupled to the memory hub through a first portion of a memory bus on which the memory requests and the memory responses are coupled. A second portion of the memory bus couples the memory hub to the processor circuit and is used to couple memory requests from the processor circuit and memory responses provided by the memory hub to the processor circuit.
As shown in 
In contrast to the computer system 100 of 
Although the component expansion module 230 is shown in 
The arrangement of the system 200 allows for access to the memory modules 130a–c by the component expansion module 230 without intervention by the system controller 110. As previously discussed, the memory hubs 240 can receive memory requests and provide memory responses in both the downstream and upstream directions. By adopting a consistent communication protocol with the memory hubs 240 of the memory modules 130a–c, communication with the memory hubs 240 of the memory modules 130a–c can be performed directly by the component expansion module 230, thereby eliminating the need for intervention by the system controller 110. As a result, access to the memory modules 130a–c is not limited to going through the system controller 110, but the component expansion module 230 can access the memory modules 130a–c directly. In contrast, the graphics controller 112 in the computer system 100 (
Many suitable communication protocols are known in the art, including the use of command packets that include appropriate information for making memory requests to particular memory modules 130a–c in the system 200 and providing memory responses in return. For example, command packets can include information such as identification data for uniquely identifying the particular memory request, address information for identifying a particular memory module 130a–c to which the memory request is directed, and memory device command information, including memory addresses, command type, and where a write operation is requested, data can be included as well. Other protocols can be used as well, and it will be appreciated by those ordinarily skilled in the art that the present invention is not limited by the particular protocol implemented.
Additionally, the arrangement of the system 200 reduces the memory request and response load on the system controller 110 since it is relieved from handling the memory requests from a requesting entity, namely the graphics controller 112 (
The cross bar switch 310 can also couple any of the link interfaces 302, 304, 306, 308 to either or both of the memory controllers 324a, 324b, each of which is coupled to a plurality of memory devices 148 (not shown in 
It will be appreciated by those ordinarily skilled in the art that 
The memory hub controller 428 is coupled over a high speed bi-directional or unidirectional system controller/hub interface 134 to several memory modules 130a–c. The controller/hub interface 134 includes a downstream bus 154 and an upstream bus 156 which are used to couple data, address, and/or control signals away from or toward, respectively, the memory hub controller 428. Each memory module 130a–c in the system 400 includes a memory hub 240 that is coupled to the system controller/hub interface 134, and which is further coupled a number of memory devices 148 through command, address and data buses, collectively shown as bus 150. The memory hub 240 efficiently routes memory requests and responses between the memory hub controller 128 and the memory devices 148. As with the memory hub 240 shown in 
Coupled in series with the memory modules 130a–c over the downstream and upstream buses 154, 156 are component expansion modules 230 and 430. The component expansion module 230, as previously described with reference to 
Unlike the systems 100 and 200, where the input and output devices 118, 120 are coupled to the system controller 110, input and output devices (not shown in 
It will be appreciated by those ordinarily skilled in the art that the embodiments 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 | 
| 7289347, | Aug 02 2002 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | System and method for optically interconnecting memory devices | 
| 7366864, | Mar 08 2004 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Memory hub architecture having programmable lane widths | 
| 7370134, | Mar 25 2004 | Round Rock Research, LLC | System and method for memory hub-based expansion bus | 
| 7382639, | Aug 02 2002 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | System and method for optically interconnecting memory devices | 
| 7539800, | Jul 30 2004 | International Business Machines Corporation | System, method and storage medium for providing segment level sparing | 
| 7581073, | Aug 09 2006 | International Business Machines Corporation | Systems and methods for providing distributed autonomous power management in a memory system | 
| 7584336, | Jun 08 2006 | International Business Machines Corporation | Systems and methods for providing data modification operations in memory subsystems | 
| 7587559, | Aug 10 2006 | International Business Machines Corporation | Systems and methods for memory module power management | 
| 7590797, | Apr 08 2004 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | System and method for optimizing interconnections of components in a multichip memory module | 
| 7590882, | Oct 29 2004 | International Business Machines Corporation | System, method and storage medium for bus calibration in a memory subsystem | 
| 7594055, | May 24 2006 | International Business Machines Corporation | Systems and methods for providing distributed technology independent memory controllers | 
| 7596675, | Mar 08 2004 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Memory hub architecture having programmable lane widths | 
| 7603526, | Jan 29 2007 | International Business Machines Corporation | Systems and methods for providing dynamic memory pre-fetch | 
| 7606988, | Jan 29 2007 | International Business Machines Corporation | Systems and methods for providing a dynamic memory bank page policy | 
| 7610423, | Oct 29 2004 | International Business Machines Corporation | Service interface to a memory system | 
| 7610430, | Mar 25 2004 | Round Rock Research, LLC | System and method for memory hub-based expansion bus | 
| 7636813, | May 22 2006 | International Business Machines Corporation | Systems and methods for providing remote pre-fetch buffers | 
| 7636833, | Aug 15 2006 | International Business Machines Corporation | Method for selecting memory busses according to physical memory organization information associated with virtual address translation tables | 
| 7640386, | May 24 2006 | International Business Machines Corporation | Systems and methods for providing memory modules with multiple hub devices | 
| 7669086, | Aug 02 2006 | International Business Machines Corporation | Systems and methods for providing collision detection in a memory system | 
| 7685392, | Nov 28 2005 | International Business Machines Corporation | Providing indeterminate read data latency in a memory system | 
| 7717752, | Jul 01 2008 | TWITTER, INC | 276-pin buffered memory module with enhanced memory system interconnect and features | 
| 7721140, | Jan 02 2007 | International Business Machines Corporation | Systems and methods for improving serviceability of a memory system | 
| 7765368, | Jul 30 2004 | International Business Machines Corporation | System, method and storage medium for providing a serialized memory interface with a bus repeater | 
| 7836252, | Aug 29 2002 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | System and method for optimizing interconnections of memory devices in a multichip module | 
| 7844771, | Oct 29 2004 | International Business Machines Corporation | System, method and storage medium for a memory subsystem command interface | 
| 7870459, | Oct 23 2006 | International Business Machines Corporation | High density high reliability memory module with power gating and a fault tolerant address and command bus | 
| 7899969, | Mar 25 2004 | Round Rock Research, LLC | System and method for memory hub-based expansion bus | 
| 7934115, | Oct 31 2005 | International Business Machines Corporation | Deriving clocks in a memory system | 
| 8015384, | Mar 08 2004 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Memory hub architecture having programmable lane widths | 
| 8117371, | Mar 25 2004 | Round Rock Research, LLC | System and method for memory hub-based expansion bus | 
| 8140942, | Oct 29 2004 | International Business Machines Corporation | System, method and storage medium for providing fault detection and correction in a memory subsystem | 
| 8145868, | Nov 28 2005 | International Business Machines Corporation | Method and system for providing frame start indication in a memory system having indeterminate read data latency | 
| 8151042, | Nov 28 2005 | International Business Machines Corporation | Method and system for providing identification tags in a memory system having indeterminate data response times | 
| 8296541, | Oct 29 2004 | International Business Machines Corporation | Memory subsystem with positional read data latency | 
| 8327105, | Nov 28 2005 | International Business Machines Corporation | Providing frame start indication in a memory system having indeterminate read data latency | 
| 8381064, | Oct 23 2006 | International Business Machines Corporation | High density high reliability memory module with power gating and a fault tolerant address and command bus | 
| 8438329, | Apr 08 2004 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | System and method for optimizing interconnections of components in a multichip memory module | 
| 8495328, | Nov 28 2005 | International Business Machines Corporation | Providing frame start indication in a memory system having indeterminate read data latency | 
| 8589643, | Oct 20 2003 | Round Rock Research, LLC | Arbitration system and method for memory responses in a hub-based memory system | 
| 8589769, | Oct 29 2004 | International Business Machines Corporation | System, method and storage medium for providing fault detection and correction in a memory subsystem | 
| 8775764, | Mar 08 2004 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Memory hub architecture having programmable lane widths | 
| 9274991, | Nov 01 2004 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Memory hub architecture having programmable lane widths | 
| 9357649, | May 08 2012 | Inernational Business Machines Corporation | 276-pin buffered memory card with enhanced memory system interconnect | 
| 9519315, | Mar 12 2013 | International Business Machines Corporation | 276-pin buffered memory card with enhanced memory system interconnect | 
| Patent | Priority | Assignee | Title | 
| 4045781, | Feb 13 1976 | Digital Equipment Corporation | Memory module with selectable byte addressing for digital data processing system | 
| 4240143, | Dec 22 1978 | Unisys Corporation | Hierarchical multi-processor network for memory sharing | 
| 4245306, | Dec 21 1978 | Unisys Corporation | Selection of addressed processor in a multi-processor network | 
| 4253144, | Dec 21 1978 | Unisys Corporation | Multi-processor communication network | 
| 4253146, | Dec 21 1978 | Unisys Corporation | Module for coupling computer-processors | 
| 4443845, | Jun 26 1980 | Texas Instruments Incorporated | Memory system having a common interface | 
| 4608702, | Dec 21 1984 | ADVANCED MICRO DEVICES, INC , 901 THOMPSON PLACE, P O BOX 3453, SUNNYVALE, CA 94088 A CORP OF DE | Method for digital clock recovery from Manchester-encoded signals | 
| 4707823, | Jul 21 1986 | Chrysler Motors Corporation | Fiber optic multiplexed data acquisition system | 
| 4724520, | Jul 01 1985 | United Technologies Corporation | Modular multiport data hub | 
| 4813772, | Sep 08 1987 | The Regents of the University of California | Electro-optical interface | 
| 4891808, | Dec 24 1987 | Tellabs Operations, Inc | Self-synchronizing multiplexer | 
| 4930128, | Jun 26 1987 | Hitachi, Ltd. | Method for restart of online computer system and apparatus for carrying out the same | 
| 4953930, | Mar 15 1989 | Ramtech, Inc.; RAMTECH, INC , A CORP OF DE | CPU socket supporting socket-to-socket optical communications | 
| 5241506, | Nov 15 1989 | Kabushiki Kaisha Toshiba | Semiconductor memory circuit apparatus | 
| 5243703, | Apr 18 1990 | Rambus, Inc. | Apparatus for synchronously generating clock signals in a data processing system | 
| 5251303, | Jan 13 1989 | International Business Machines Corporation | System for DMA block data transfer based on linked control blocks | 
| 5269022, | Mar 28 1990 | Kabushiki Kaisha Toshiba | Method and apparatus for booting a computer system by restoring the main memory from a backup memory | 
| 5307381, | Dec 27 1991 | Intel Corporation | Skew-free clock signal distribution network in a microprocessor | 
| 5317752, | Dec 22 1989 | Tandem Computers Incorporated | Fault-tolerant computer system with auto-restart after power-fall | 
| 5319755, | Apr 18 1990 | Rambus, Inc. | Integrated circuit I/O using high performance bus interface | 
| 5327553, | Dec 22 1989 | Tandem Computers Incorporated | Fault-tolerant computer system with /CONFIG filesystem | 
| 5355391, | Mar 06 1992 | RAMBUS INC A CORP OF CALIFORNIA | High speed bus system | 
| 5379382, | Apr 22 1991 | Freescale Semiconductor, Inc | Uni and bi-directional signal transfer modes in peripheral controller and method of operating same | 
| 5432823, | Mar 06 1992 | Rambus, Inc. | Method and circuitry for minimizing clock-data skew in a bus system | 
| 5432907, | May 12 1992 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Network hub with integrated bridge | 
| 5442770, | Jan 24 1989 | RENESAS ELECTRONICS AMERICA, INC | Triple port cache memory | 
| 5461627, | Dec 24 1991 | Proxim Wireless Corporation | Access protocol for a common channel wireless network | 
| 5465229, | May 19 1992 | Sun Microsystems, Inc. | Single in-line memory module | 
| 5479370, | Feb 20 1992 | Kabushiki Kaisha Toshiba | Semiconductor memory with bypass circuit | 
| 5497476, | Sep 21 1992 | International Business Machines Corporation | Scatter-gather in data processing system | 
| 5502621, | Mar 31 1994 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Mirrored pin assignment for two sided multi-chip layout | 
| 5544319, | Mar 25 1992 | Sun Microsystems, Inc | Fiber optic memory coupling system with converter transmitting and receiving bus data in parallel fashion and diagnostic data in serial fashion | 
| 5566325, | Jun 30 1994 | SAMSUNG ELECTRONICS CO , LTD | Method and apparatus for adaptive memory access | 
| 5577220, | Jul 23 1993 | LENOVO SINGAPORE PTE LTD | Method for saving and restoring the state of a CPU executing code in protected mode including estimating the value of the page table base register | 
| 5581767, | Jun 16 1993 | Nippon Sheet Glass Co., Ltd. | Bus structure for multiprocessor system having separated processor section and control/memory section | 
| 5606717, | Apr 18 1990 | Rambus, Inc. | Memory circuitry having bus interface for receiving information in packets and access time registers | 
| 5608264, | Jun 05 1995 | INTERSIL AMERICAS LLC | Surface mountable integrated circuit with conductive vias | 
| 5623534, | Apr 07 1995 | THE CHASE MANHATTAN BANK, AS COLLATERAL AGENT | Method and apparatus for exchanging administrative information between local area networks | 
| 5638334, | Apr 18 1990 | Rambus Inc. | Integrated circuit I/O using a high performance bus interface | 
| 5659798, | Feb 02 1996 | TRUSTEES OF PRINCETON UNIVERSITY, THE | Method and system for initiating and loading DMA controller registers by using user-level programs | 
| 5706224, | Oct 10 1996 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | Content addressable memory and random access memory partition circuit | 
| 5715456, | Feb 13 1995 | Lenovo PC International | Method and apparatus for booting a computer system without pre-installing an operating system | 
| 5729709, | Nov 12 1993 | Intel Corporation | Memory controller with burst addressing circuit | 
| 5748616, | Sep 19 1994 | LBF ENTERPRISES | Data link module for time division multiplexing control systems | 
| 5787475, | Jul 21 1992 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Controlled prefetching of data requested by a peripheral | 
| 5818844, | Jun 06 1996 | GLOBALFOUNDRIES Inc | Address generation and data path arbitration to and from SRAM to accommodate multiple transmitted packets | 
| 5819304, | Jan 29 1996 | AONIX, S A | Random access memory assembly | 
| 5822255, | Aug 13 1996 | SOCIONEXT INC | Semiconductor integrated circuit for supplying a control signal to a plurality of object circuits | 
| 5831467, | Nov 05 1991 | MOSYS, INC | Termination circuit with power-down mode for use in circuit module architecture | 
| 5832250, | Jan 26 1996 | Unisys Corporation | Multi set cache structure having parity RAMs holding parity bits for tag data and for status data utilizing prediction circuitry that predicts and generates the needed parity bits | 
| 5875352, | Nov 03 1995 | Oracle America, Inc | Method and apparatus for multiple channel direct memory access control | 
| 5875454, | Jul 24 1996 | International Business Machiness Corporation | Compressed data cache storage system | 
| 5928343, | Apr 18 1990 | Rambus Inc. | Memory module having memory devices containing internal device ID registers and method of initializing same | 
| 5966724, | Jan 11 1996 | Micron Technology, Inc | Synchronous memory device with dual page and burst mode operations | 
| 5973935, | Apr 07 1997 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Interdigitated leads-over-chip lead frame for supporting an integrated circuit die | 
| 5973951, | May 19 1992 | Sun Microsystems, Inc. | Single in-line memory module | 
| 5978567, | Jul 27 1994 | CSC Holdings, LLC | System for distribution of interactive multimedia and linear programs by enabling program webs which include control scripts to define presentation by client transceiver | 
| 5987196, | Nov 06 1997 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Semiconductor structure having an optical signal path in a substrate and method for forming the same | 
| 6023726, | Jan 20 1998 | Meta Platforms, Inc | User configurable prefetch control system for enabling client to prefetch documents from a network server | 
| 6026226, | Oct 28 1996 | Altera Corporation | Local compilation in context within a design hierarchy | 
| 6029250, | Sep 09 1998 | Round Rock Research, LLC | Method and apparatus for adaptively adjusting the timing offset between a clock signal and digital signals transmitted coincident with that clock signal, and memory device and system using same | 
| 6031241, | Mar 11 1997 | EUV, L L C | Capillary discharge extreme ultraviolet lamp source for EUV microlithography and other related applications | 
| 6033951, | Aug 16 1996 | United Microelectronics Corp. | Process for fabricating a storage capacitor for semiconductor memory devices | 
| 6061263, | Dec 29 1998 | Round Rock Research, LLC | Small outline rambus in-line memory module | 
| 6061296, | Aug 17 1998 | TAIWAN SEMICONDUCTOR MANUFACTURING CO , LTD | Multiple data clock activation with programmable delay for use in multiple CAS latency memory devices | 
| 6067262, | Dec 11 1998 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Redundancy analysis for embedded memories with built-in self test and built-in self repair | 
| 6073190, | Jul 18 1997 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | System for dynamic buffer allocation comprising control logic for controlling a first address buffer and a first data buffer as a matched pair | 
| 6076139, | Dec 31 1996 | Hewlett Packard Enterprise Development LP | Multimedia computer architecture with multi-channel concurrent memory access | 
| 6078451, | Sep 17 1996 | International Business Machines Corporation | Method and apparatus for adjusting data window phase when retrieving data stored on a recording medium | 
| 6079008, | Apr 04 1997 | HANGER SOLUTIONS, LLC | Multiple thread multiple data predictive coded parallel processing system and method | 
| 6098158, | Dec 18 1997 | Lenovo PC International | Software-enabled fast boot | 
| 6101151, | Jun 12 1998 | Mitsubishi Denki Kabushiki Kaisha | Synchronous semiconductor memory device employing temporary data output stop scheme | 
| 6105075, | Aug 05 1997 | PMC-SIERRA, INC | Scatter gather memory system for a hardware accelerated command interpreter engine | 
| 6111757, | Jan 16 1998 | International Business Machines Corp.; International Business Machines Corporation | SIMM/DIMM memory module | 
| 6125431, | Aug 02 1996 | OKI SEMICONDUCTOR CO , LTD | Single-chip microcomputer using adjustable timing to fetch data from an external memory | 
| 6131149, | Jun 04 1997 | SUNPLUS TECHNOLOGY CO , LTD | Apparatus and method for reading data from synchronous memory with skewed clock pulses | 
| 6134624, | Jun 08 1998 | Oracle America, Inc | High bandwidth cache system | 
| 6137709, | Dec 29 1998 | Round Rock Research, LLC | Small outline memory module | 
| 6144587, | Jun 23 1998 | Longitude Licensing Limited | Semiconductor memory device | 
| 6167465, | May 20 1998 | Creative Technology, Ltd | System for managing multiple DMA connections between a peripheral device and a memory and performing real-time operations on data carried by a selected DMA connection | 
| 6167486, | Nov 18 1996 | RENESAS ELECTRONICS AMERICA, INC | Parallel access virtual channel memory system with cacheable channels | 
| 6175571, | Jul 22 1994 | Network Peripherals, Inc. | Distributed memory switching hub | 
| 6185352, | Feb 24 2000 | Corning Optical Communications LLC | Optical fiber ribbon fan-out cables | 
| 6186400, | Mar 20 1998 | Symbol Technologies, LLC | Bar code reader with an integrated scanning component module mountable on printed circuit board | 
| 6191663, | Dec 22 1998 | Intel Corporation | Echo reduction on bit-serial, multi-drop bus | 
| 6201724, | Nov 12 1998 | Longitude Licensing Limited | Semiconductor memory having improved register array access speed | 
| 6208180, | Dec 29 1995 | Intel Corporation | Core clock correction in a 2/N mode clocking scheme | 
| 6219725, | Aug 28 1998 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Method and apparatus for performing direct memory access transfers involving non-sequentially-addressable memory locations | 
| 6226729, | Nov 03 1998 | Intel Corporation | Method and apparatus for configuring and initializing a memory device and a memory channel | 
| 6229727, | Sep 28 1998 | Cisco Technology, Inc | Method and apparatus for support of multiple memory devices in a single memory socket architecture | 
| 6233376, | May 18 1999 | The United States of America as represented by the Secretary of the Navy | Embedded fiber optic circuit boards and integrated circuits | 
| 6243769, | Jul 18 1997 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Dynamic buffer allocation for a computer system | 
| 6243831, | Oct 31 1998 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Computer system with power loss protection mechanism | 
| 6246618, | Jun 30 2000 | Mitsubishi Denki Kabushiki Kaisha | Semiconductor integrated circuit capable of testing and substituting defective memories and method thereof | 
| 6247107, | Apr 06 1998 | Advanced Micro Devices, Inc. | Chipset configured to perform data-directed prefetching | 
| 6249802, | Sep 19 1997 | Hewlett Packard Enterprise Development LP | Method, system, and computer program product for allocating physical memory in a distributed shared memory network | 
| 6256692, | Oct 13 1997 | Fujitsu Limited | CardBus interface circuit, and a CardBus PC having the same | 
| 6266730, | Sep 26 1997 | Rambus Inc. | High-frequency bus system | 
| 6272609, | Jul 31 1998 | Round Rock Research, LLC | Pipelined memory controller | 
| 6285349, | Feb 26 1999 | Intel Corporation | Correcting non-uniformity in displays | 
| 6286083, | Jul 08 1998 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Computer system with adaptive memory arbitration scheme | 
| 6294937, | May 25 1999 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Method and apparatus for self correcting parallel I/O circuitry | 
| 6301637, | Jun 08 1998 | Storage Technology Corporation | High performance data paths | 
| 6327642, | Nov 18 1996 | RENESAS ELECTRONICS AMERICA, INC | Parallel access virtual channel memory system | 
| 6330205, | Dec 22 1999 | Longitude Licensing Limited | Virtual channel synchronous dynamic random access memory | 
| 6347055, | Jun 24 1999 | NEC Corporation | Line buffer type semiconductor memory device capable of direct prefetch and restore operations | 
| 6349363, | Dec 08 1998 | Intel Corporation | Multi-section cache with different attributes for each section | 
| 6356573, | Jan 31 1998 | Mellanox Technologies Ltd | Vertical cavity surface emitting laser | 
| 6367074, | Dec 28 1998 | Intel Corporation | Operation of a system | 
| 6370068, | Jan 05 2000 | SAMSUNG ELECTRONICS CO , LTD | Semiconductor memory devices and methods for sampling data therefrom based on a relative position of a memory cell array section containing the data | 
| 6373777, | Jul 14 1998 | NEC Corporation | Semiconductor memory | 
| 6381190, | May 13 1999 | Longitude Licensing Limited | Semiconductor memory device in which use of cache can be selected | 
| 6392653, | Jun 25 1998 | Inria Institut National de Recherche en Informatique et en Automatique | Device for processing acquisition data, in particular image data | 
| 6401213, | Jul 09 1999 | Round Rock Research, LLC | Timing circuit for high speed memory | 
| 6405280, | Jun 05 1998 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Packet-oriented synchronous DRAM interface supporting a plurality of orderings for data block transfers within a burst sequence | 
| 6421744, | Oct 25 1999 | SHENZHEN XINGUODU TECHNOLOGY CO , LTD | Direct memory access controller and method therefor | 
| 6434639, | Nov 13 1998 | Intel Corporation | System for combining requests associated with one or more memory locations that are collectively associated with a single cache line to furnish a single memory operation | 
| 6434654, | Mar 26 1999 | NXP B V | System bus with a variable width selectivity configurable at initialization | 
| 6434696, | May 11 1998 | ANPA INC | Method for quickly booting a computer system | 
| 6434736, | Jul 08 1999 | Intel Corporation | Location based timing scheme in memory design | 
| 6438622, | Nov 17 1998 | Intel Corporation | Multiprocessor system including a docking system | 
| 6438668, | Sep 30 1999 | Apple Inc | Method and apparatus for reducing power consumption in a digital processing system | 
| 6449308, | May 25 1999 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | High-speed digital distribution system | 
| 6453393, | Sep 18 2000 | Intel Corporation | Method and apparatus for interfacing to a computer memory | 
| 6457116, | Oct 31 1997 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | Method and apparatus for controlling contexts of multiple context processing elements in a network of multiple context processing elements | 
| 6462978, | Aug 21 1997 | Renesas Electronics Corporation | Method of designing semiconductor integrated circuit device and semiconductor integrated circuit device | 
| 6463059, | Dec 04 1998 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Direct memory access execution engine with indirect addressing of circular queues in addition to direct memory addressing | 
| 6470422, | Dec 08 1998 | Intel Corporation | Buffer memory management in a system having multiple execution entities | 
| 6473828, | Jul 03 1998 | Renesas Electronics Corporation | Virtual channel synchronous dynamic random access memory | 
| 6477592, | Aug 06 1999 | Integrated Memory Logic, Inc | System for I/O interfacing for semiconductor chip utilizing addition of reference element to each data element in first data stream and interpret to recover data elements of second data stream | 
| 6477614, | Sep 30 1998 | Intel Corporation | Method for implementing multiple memory buses on a memory module | 
| 6477621, | Nov 18 1996 | RENESAS ELECTRONICS AMERICA, INC | Parallel access virtual channel memory system | 
| 6479322, | Jun 01 1998 | Renesas Electronics Corporation | Semiconductor device with two stacked chips in one resin body and method of producing | 
| 6490188, | Sep 02 1999 | Round Rock Research, LLC | Semiconductor devices having mirrored terminal arrangements, devices including same, and methods of testing such semiconductor devices | 
| 6493803, | Aug 23 1999 | GLOBALFOUNDRIES Inc | Direct memory access controller with channel width configurability support | 
| 6496909, | Apr 06 1999 | Hewlett Packard Enterprise Development LP | Method for managing concurrent access to virtual memory data structures | 
| 6501471, | Dec 13 1999 | Intel Corporation | Volume rendering | 
| 6502161, | Jan 05 2000 | Rambus Inc. | Memory system including a point-to-point linked memory subsystem | 
| 6505287, | Dec 20 1999 | HTC Corporation | Virtual channel memory access controlling circuit | 
| 6523092, | Sep 29 2000 | Intel Corporation | Cache line replacement policy enhancement to avoid memory page thrashing | 
| 6523093, | Sep 29 2000 | Intel Corporation | Prefetch buffer allocation and filtering system | 
| 6526498, | Oct 31 1997 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | Method and apparatus for retiming in a network of multiple context processing elements | 
| 6539490, | Aug 30 1999 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Clock distribution without clock delay or skew | 
| 6552564, | Aug 30 1999 | Micron Technology, Inc. | Technique to reduce reflections and ringing on CMOS interconnections | 
| 6553479, | Oct 31 1997 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | Local control of multiple context processing elements with major contexts and minor contexts | 
| 6564329, | Mar 16 1999 | HANGER SOLUTIONS, LLC | System and method for dynamic clock generation | 
| 6570429, | Oct 20 2000 | CRAY, INC | Method and apparatus for providing a clock signal to a semiconductor chip | 
| 6584543, | Jul 22 1999 | Round Rock Research, LLC | Reconfigurable memory with selectable error correction storage | 
| 6587912, | Sep 30 1998 | Intel Corporation | Method and apparatus for implementing multiple memory buses on a memory module | 
| 6590816, | Mar 05 2001 | Polaris Innovations Limited | Integrated memory and method for testing and repairing the integrated memory | 
| 6594713, | Sep 10 1999 | Texas Instruments Incorporated | Hub interface unit and application unit interfaces for expanded direct memory access processor | 
| 6594722, | Jun 29 2000 | Intel Corporation | Mechanism for managing multiple out-of-order packet streams in a PCI host bridge | 
| 6598154, | Dec 29 1998 | Intel Corporation | Precoding branch instructions to reduce branch-penalty in pipelined processors | 
| 6615325, | Jan 11 1996 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Method for switching between modes of operation | 
| 6622227, | Dec 27 2000 | Intel Corporation | Method and apparatus for utilizing write buffers in memory control/interface | 
| 6628294, | Dec 31 1999 | Intel Corporation | Prefetching of virtual-to-physical address translation for display data | 
| 6629220, | Aug 20 1999 | Intel Corporation | Method and apparatus for dynamic arbitration between a first queue and a second queue based on a high priority transaction type | 
| 6631440, | Nov 30 2000 | Hewlett Packard Enterprise Development LP | Method and apparatus for scheduling memory calibrations based on transactions | 
| 6636110, | May 01 1998 | Mitsubishi Denki Kabushiki Kaisha | Internal clock generating circuit for clock synchronous semiconductor memory device | 
| 6636957, | Nov 03 1998 | Intel Corporation | Method and apparatus for configuring and initializing a memory device and a memory channel | 
| 6646929, | Dec 05 2001 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Methods and structure for read data synchronization with minimal latency | 
| 6651139, | Mar 15 1999 | Fuji Xerox Co., Ltd. | Multiprocessor system | 
| 6658509, | Oct 03 2000 | Intel Corporation | Multi-tier point-to-point ring memory interface | 
| 6662304, | Dec 11 1998 | Round Rock Research, LLC | Method and apparatus for bit-to-bit timing correction of a high speed memory bus | 
| 6665202, | Sep 25 2001 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | Content addressable memory (CAM) devices that can identify highest priority matches in non-sectored CAM arrays and methods of operating same | 
| 6667895, | Dec 06 2001 | Samsung Electronics Co., Ltd. | Integrated circuit device and module with integrated circuits | 
| 6681292, | Aug 27 2001 | Intel Corporation | Distributed read and write caching implementation for optimized input/output applications | 
| 6697926, | Jun 06 2001 | Round Rock Research, LLC | Method and apparatus for determining actual write latency and accurately aligning the start of data capture with the arrival of data at a memory device | 
| 6715018, | Jun 16 1998 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Computer including installable and removable cards, optical interconnection between cards, and method of assembling a computer | 
| 6718440, | Sep 28 2001 | BEIJING XIAOMI MOBILE SOFTWARE CO , LTD | Memory access latency hiding with hint buffer | 
| 6721187, | Mar 16 2001 | GOOGLE LLC | Multi-layered high density connections | 
| 6721195, | Jul 12 2001 | Micron Technology, Inc. | Reversed memory module socket and motherboard incorporating same | 
| 6724685, | Oct 31 2001 | Polaris Innovations Limited | Configuration for data transmission in a semiconductor memory system, and relevant data transmission method | 
| 6728800, | Jun 28 2000 | Intel Corporation | Efficient performance based scheduling mechanism for handling multiple TLB operations | 
| 6735679, | Jul 08 1998 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Apparatus and method for optimizing access to memory | 
| 6735682, | Mar 28 2002 | Intel Corporation | Apparatus and method for address calculation | 
| 6745275, | Jan 25 2000 | VIA Technologies, Inc. | Feedback system for accomodating different memory module loading | 
| 6751113, | Mar 07 2002 | NETLIST, INC | Arrangement of integrated circuits in a memory module | 
| 6751703, | Dec 27 2000 | EMC IP HOLDING COMPANY LLC | Data storage systems and methods which utilize an on-board cache | 
| 6751722, | Oct 31 1997 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Local control of multiple context processing elements with configuration contexts | 
| 6754117, | Aug 16 2002 | Round Rock Research, LLC | System and method for self-testing and repair of memory modules | 
| 6754812, | Jul 06 2000 | Intel Corporation | Hardware predication for conditional instruction path branching | 
| 6756661, | Mar 24 2000 | PS4 LUXCO S A R L | Semiconductor device, a semiconductor module loaded with said semiconductor device and a method of manufacturing said semiconductor device | 
| 6760833, | Aug 01 1997 | Round Rock Research, LLC | Split embedded DRAM processor | 
| 6771538, | Feb 01 1999 | TESSERA ADVANCED TECHNOLOGIES, INC | Semiconductor integrated circuit and nonvolatile memory element | 
| 6772261, | Apr 27 2000 | International Business Machines Corporation | Interface that allows testing and using memory modules in computer systems not designed for the modules | 
| 6775747, | Jan 03 2002 | Intel Corporation | System and method for performing page table walks on speculative software prefetch operations | 
| 6789173, | Jun 03 1999 | Hitachi, LTD | Node controller for performing cache coherence control and memory-shared multiprocessor system | 
| 6792059, | Nov 30 2000 | Northrop Grumman Systems Corporation | Early/on-time/late gate bit synchronizer | 
| 6792496, | Aug 02 2001 | Intel Corporation | Prefetching data for peripheral component interconnect devices | 
| 6793408, | Dec 31 2002 | Intel Corporation | Module interface with optical and electrical interconnects | 
| 6795899, | Mar 22 2002 | TAHOE RESEARCH, LTD | Memory system with burst length shorter than prefetch length | 
| 6799246, | Jun 24 1993 | TALON RESEARCH, LLC | Memory interface for reading/writing data from/to a memory | 
| 6799268, | Jun 30 2000 | INTEL CORPORATION, A CORPORATION OF DELAWARE | Branch ordering buffer | 
| 6804760, | Dec 23 1994 | Round Rock Research, LLC | Method for determining a type of memory present in a system | 
| 6804764, | Jan 22 2002 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Write clock and data window tuning based on rank select | 
| 6807630, | Dec 15 2000 | International Business Machines Corporation | Method for fast reinitialization wherein a saved system image of an operating system is transferred into a primary memory from a secondary memory | 
| 6811320, | Nov 13 2002 | System for connecting a fiber optic cable to an electronic device | |
| 6816931, | Apr 10 2002 | Avision Inc. | Upstream peripheral device serving as a USB host | 
| 6816947, | Jul 20 2000 | Hewlett Packard Enterprise Development LP | System and method for memory arbitration | 
| 6820181, | Aug 29 2002 | Round Rock Research, LLC | Method and system for controlling memory accesses to memory modules having a memory hub architecture | 
| 6821029, | Sep 10 2002 | XILINX, Inc. | High speed serial I/O technology using an optical link | 
| 6823023, | Jan 31 2000 | Intel Corporation | Serial bus communication system | 
| 6845409, | Jul 25 2000 | Oracle America, Inc | Data exchange methods for a switch which selectively forms a communication channel between a processing unit and multiple devices | 
| 6889304, | Feb 28 2001 | Rambus Inc. | Memory device supporting a dynamically configurable core organization | 
| 6910109, | Sep 30 1998 | Intel Corporation | Tracking memory page state | 
| 6950956, | Oct 19 1999 | Rambus Inc. | Integrated circuit with timing adjustment mechanism and method | 
| 6956996, | Apr 24 2002 | BROADCOM INTERNATIONAL PTE LTD | Tri-state optical systems and methods | 
| 7000062, | Jan 05 2000 | Rambus Inc. | System and method featuring a controller device and a memory module that includes an integrated circuit buffer device and a plurality of integrated circuit memory devices | 
| 7016213, | May 13 2003 | AMD TECHNOLOGIES HOLDINGS, INC ; GLOBALFOUNDRIES Inc | Method for initializing a system including a host and plurality of memory modules connected via a serial memory interconnect | 
| 7016606, | Feb 28 2000 | University of Maryland Baltimore County | Error mitigation system using line coding for optical WDM communications | 
| 7024547, | Dec 10 2001 | Intel Corporation | Method and system for initializing a hardware device | 
| 7035212, | Jan 25 2001 | RPX Corporation | Method and apparatus for end to end forwarding architecture | 
| 7047351, | Aug 16 2002 | Round Rock Research, LLC | Memory hub bypass circuit and method | 
| 7062595, | Apr 24 2001 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Integrated gigabit ethernet PCI-X controller | 
| 20010023474, | |||
| 20010034839, | |||
| 20010039612, | |||
| 20020038412, | |||
| 20020112119, | |||
| 20020116588, | |||
| 20020144064, | |||
| 20030005223, | |||
| 20030043158, | |||
| 20030043426, | |||
| 20030093630, | |||
| 20030149809, | |||
| 20030163649, | |||
| 20030177320, | |||
| 20030193927, | |||
| 20030217223, | |||
| 20030227798, | |||
| 20030229734, | |||
| 20030229770, | |||
| 20040022094, | |||
| 20040024959, | |||
| 20040028412, | |||
| 20040044833, | |||
| 20040047169, | |||
| 20040123088, | |||
| 20040126115, | |||
| 20040128421, | |||
| 20040144994, | |||
| 20040148482, | |||
| 20040230718, | |||
| 20040236885, | |||
| 20040251929, | |||
| 20040257890, | |||
| 20050044327, | |||
| 20050071542, | |||
| 20050091464, | |||
| 20050162882, | |||
| 20050177690, | |||
| 20050210216, | |||
| 20050228939, | |||
| 20050257021, | |||
| EP849685, | |||
| JP2001265539, | |||
| WO227499, | |||
| WO9319422, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Apr 07 2006 | Micron Technology, Inc. | (assignment on the face of the patent) | / | |||
| Dec 23 2009 | Micron Technology, Inc | Round Rock Research, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 023786/ | 0416 | 
| Date | Maintenance Fee Events | 
| Mar 14 2007 | ASPN: Payor Number Assigned. | 
| Sep 16 2010 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. | 
| Oct 02 2014 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. | 
| Dec 03 2018 | REM: Maintenance Fee Reminder Mailed. | 
| May 20 2019 | EXP: Patent Expired for Failure to Pay Maintenance Fees. | 
| Date | Maintenance Schedule | 
| Apr 17 2010 | 4 years fee payment window open | 
| Oct 17 2010 | 6 months grace period start (w surcharge) | 
| Apr 17 2011 | patent expiry (for year 4) | 
| Apr 17 2013 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Apr 17 2014 | 8 years fee payment window open | 
| Oct 17 2014 | 6 months grace period start (w surcharge) | 
| Apr 17 2015 | patent expiry (for year 8) | 
| Apr 17 2017 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Apr 17 2018 | 12 years fee payment window open | 
| Oct 17 2018 | 6 months grace period start (w surcharge) | 
| Apr 17 2019 | patent expiry (for year 12) | 
| Apr 17 2021 | 2 years to revive unintentionally abandoned end. (for year 12) |