US6092146A - Dynamically configurable memory adapter using electronic presence detects - Google Patents

Dynamically configurable memory adapter using electronic presence detects Download PDF

Info

Publication number
US6092146A
US6092146A US08/904,187 US90418797A US6092146A US 6092146 A US6092146 A US 6092146A US 90418797 A US90418797 A US 90418797A US 6092146 A US6092146 A US 6092146A
Authority
US
United States
Prior art keywords
simm
memory
adapter
simms
computer system
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
US08/904,187
Inventor
Timothy Jay Dell
Kent Alan Dramstad
Marc Raymond Faucher
Bruce Gerard Hazelzet
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Priority to US08/904,187 priority Critical patent/US6092146A/en
Assigned to INTERNATIONAL BUSINESS MACHINES CORPORATION reassignment INTERNATIONAL BUSINESS MACHINES CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DELL, TIMOTHY J., DRAMSTAD, KENT A., FAUCHER, MARC R., HAZELZET, BRUCE G.
Application granted granted Critical
Publication of US6092146A publication Critical patent/US6092146A/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • G06F13/1668Details of memory controller
    • G06F13/1694Configuration of memory controller to different memory types

Definitions

  • the invention relates generally to memory adapters for computer systems, and more particularly, to a dynamically configurable memory adapter for adapting SIMMs to the computer systems that employ DIMMs.
  • RAM makes up the bulk of the computer system's memory, excluding the computer system's hard-drive, if one exists.
  • RAM typically comes in the form of dynamic RAM (hereinafter DRAM) which requires frequent recharging or refreshing to preserve its contents.
  • DRAM dynamic RAM
  • RAM data is typically arranged in bytes of 8 data bits.
  • An optional 9th bit, a parity bit, acts as a check on the correctness of the values of the other eight bits.
  • SIMM Single Inline Memory Module
  • a SIMM is a printed circuit board having, among other things, memory chips and connection points or pins. SIMMs are inserted into special sockets on the computer system's motherboard or memory carrier card.
  • a central characteristic of SIMMs is that although there are connection pins on both sides of the SIMM's printed circuit board, these connections are not singular. That is, pin 1 on the front side of the printed circuit board is connected to pin 1 on the backside of the printed circuit board. Therefore, although most SIMMs have a total of 144 pins, only 72 are available for electrical connection.
  • a DIMM (Dual Inline Memory Module) is also a printed circuit board having, among other things, memory chips and connection points or pins. DIMMs are also inserted into special sockets on the computer system's motherboard or memory carrier card. However, the DIMM includes a dual row of contacts, one on each side of the printed circuit board, which are available for electrical contact. Most general DIMMs include a total of 168 pins, with 84 pins on the front side and 84 pins on the back side of the printed circuit board. Each pin is available for electrical contact.
  • SIMMs and DIMMs are available in a variety of organizations (e.g., capacity), voltages, speeds, memory types/cycles, physical dimensions, and buffering. Almost all SIMMs and DIMMs have printed circuit boards which are "keyed” and/or “notched” to prevent them from being inserted backwards or into computer systems with different operating voltages from the SIMM or DIMM being inserted. Given the considerable differences between SIMMs and DIMMs, it is apparent these memory modules are not so easily interchanged. While the fundamental architecture of SIMMs and DIMMs is similar, the self-contained descriptive information (e.g., presence detects or PDs) and the physical form factors (e.g., notches, pins, etc.) are dissimilar. As a consequence of these dissimilarities, computer systems which employ DIMMs cannot readily accept SIMMs. Accordingly, it desired to provide a device which overcomes these considerable differences and allows for the use of SIMMs in computer systems that require DIMMs.
  • organizations e.g., capacity
  • a dynamically configurable memory adapter for adapting a plurality of SIMMs to a computer system configured to employ DIMMs.
  • the adapter includes a plurality of SIMM sockets for accepting the insertion of a plurality of SIMMs; an EEPROM for storing a plurality of serial presence detect data; and a logic device.
  • the logic device includes a plurality of presence detect inputs from each SIMM socket; an Error Correction Code detect input from each SIMM socket; a data width input for indicating the data width of an inserted SIMM; a memory type input for indicating the memory type of an inserted SIMM; a power-on-reset input; a plurality of SIMM characteristic tables; logic for determining the plurality of serial presence detect data from a plurality of SIMM characteristic tables; and logic for programming the EEPROM with the plurality of serial presence detect data.
  • SPD serial presence detect
  • FIGS. 1 and 2 are elevational and perspective views of the dynamic memory adapter of the present invention
  • FIG. 3 is a block diagram of the dynamic memory adapter of the present invention and a computer system incorporating the adapter;
  • FIG. 4 is diagram illustrating the inputs and outputs of a programmable logic device of the present invention.
  • FIG. 5 is a flowchart illustrating the interrogation and dynamic configuration logic of the present invention.
  • the memory adapter 100 allows two 72-pin SIMMs (Single Inline Memory Modules) to be used in a Joint Electronics Design Engineering Council (JEDEC) standard 168-pin unbuffered DRAM socket.
  • the memory adapter 100 includes a circuit board 118 onto which a plurality of devices are attached.
  • the devices attached to circuit board 118 are two 72-pin sockets 102 and 104, a logic device 114, I 2 C bus controller 112, DIP switches 108 and 110, an EEPROM (Electrically Erasable Programmable Read-Only Memory) 106, and a plurality of pin connectors at 116.
  • the circuit board 118 of the memory adapter 100 further includes a first notch 119 and a second notch 120.
  • SIMM pin socket 102 is preferably a zero degree 72-pin socket and SIMM pin socket 104 is preferably a 22.5 degree 72-pin socket.
  • the logic device 114 is preferably a CYPRESS CY7C343B PLD (Programmable Logic Device).
  • the I 2 C bus controller 114 is preferably a PHILIPS PCF8584 I 2 C bus controller.
  • the I 2 C bus is an industry standard serial bus.
  • the EEPROM 106 is preferably a NATIONAL NM24C02L EEPROM.
  • the pin connectors 116 are preferably gold and total 168 pins, with 84 pins on each side of the printed circuit board 118.
  • the first notch 119 is for indicating that the DIMM is unbuffered.
  • the second notch 120 is for indicating that the DIMM is a 5 volt DIMM.
  • the DIP switches 108 and 110 are each 2-position (ON, OFF) switches. While the elements have described with their preferred embodiments, it should be noted that suitable substitutes may exist which can also be employed.
  • the logic device 114 may be a TOSHIBA ASIC TC160G (Application Specific Integrated Circuit).
  • FIG. 2 a perspective view of the memory adapter 100 of the present invention is shown with a SIMM (202 and 204) inserted into sockets 102 and 104.
  • FIG. 2 illustrates the inserted SIMM positions with the zero degree socket 102 and the 22.5 degree socket 104.
  • Such a socket configuration provides two advantages. First, it allows for certain components to be mounted on the printed circuit board 118 in between sockets 102 and 104. Second, because DIMM sockets are very closely spaced on a computer motherboard, it provides the memory adapter with the dimensional compatibility of ordinary DIMMs thereby facilitating simple insertion of the memory adapter into a DIMM socket without occupying space reserved for other DIMMs and their sockets.
  • FIG. 3 Illustrated in FIG. 3 is an overall block diagram of the present invention in a computer system 300.
  • the computer system 300 is preferably a PC compatible computer system such as the IBM APTIVA®, PS/1®, PS/2® or equivalent.
  • the computer system 300 includes, among other things, a CPU and a memory controller 302 which provides the address and data paths and bus controls for memory operations. When installed, the computer system 300 also includes the memory adapter 100.
  • SIMMs 202 and 204 are in electrical communication with the logic device 114 via SIMM sockets 102 and 104.
  • the logic device 114 is also in electrical communication with DIP switches 108 and 110, the I 2 C bus controller 112, and the system memory controller 302.
  • the I 2 C bus controller 112 is further in electrical communication with EEPROM 106 and the system memory controller 302.
  • the I 2 C bus controller 112 serves as an interface between the computer system 300 high-speed memory bus and the memory adapter 100.
  • the logic device 114 includes dynamic configuration logic 304 and interrogation logic 306. As will be described in more detail, the dynamic configuration logic 304 and interrogation logic 306 are responsible for determining the SIMMs' characteristics and proper configuring of the EEPROM.
  • the logic device 114 includes a plurality of presence detect (PD) inputs from each SIMM (or SIMM socket). In particular, from each SIMM, the ECC, PD1, PD2, PD3, and PD4 signals are input into the logic device 114. A second set of inputs includes the DIP switch signals representing the WIDTH and MEMORY TYPE of the SIMMs are also provided to the logic device 114. A third set of inputs representing the computer system RAS 0 and CAS 0 control lines are further provided to the logic device 114.
  • the logic device 114 further includes a plurality of data outputs indicated by a DATA bus which are in circuit communication with the I 2 C bus controller 112.
  • the DATA bus is preferably an 8-bit bus.
  • a Power-ON-Reset (POR)input and an EEPROM power output are also provided.
  • a plurality of control lines also communicate the logic device 114 to the I 2 C bus controller 112.
  • the control lines include INT SCL OUT, IACK SDA IN, CLK, RD, W/R, AO, CS, and RESET.
  • the INT SCL OUT signal is the serial clock output from the I 2 C bus controller 112.
  • the IACK SDA IN signal is the serial data signal
  • the CLK is the clock signal
  • the RD is the read control signal
  • the W/R is the write control signal
  • the AO is the register select signal
  • the CS is the chip select signal
  • RESET is the reset signal which forces the I 2 C bus controller 112 into a predefined reset state. More information relating to the I 2 C bus controller 112 of the present invention may be found in the PCF8584 I 2 C-bus controller, Product Specification, Mar. 19, 1997, Philips Semiconductors.
  • a POR typically occurs when the computer system is switched from the off state to the on state (i.e., the computer is turned on).
  • POR Power-On-Reset
  • two SIMMs must be inserted into the SIMM sockets of the memory adapter of the present invention.
  • the two SIMMs should be matched pairs (e.g., 2 SIMMs, 8 MB, 2M ⁇ 32, 70 ns, EDO).
  • the memory adapter will also work with unmatched pairs.
  • the DIP switches are set according to Tables 2.1 and 2.2.
  • Tables 2.1 and 2.2 the values of SPD bytes 6, 11, and 2 are shown for the various SIMM configurations based on Parity/Width and Memory Type.
  • Table 2.1 in particular, the DIP switch positions for the SIMM organization of Parity/Width (i.e., "x64" and "x72"), along with the values for SPD bytes 6 and 11, are shown.
  • the "x64" and "x72" designations describe width, or the number of bits that can be accessed at the same time (i.e., 64 or 72 bits) on the SIMM.
  • FPM refers to a memory configuration known as Fast Page Mode.
  • Fast Page Mode allows the system's memory controller to access a plurality of data bits in terms of a page.
  • the DRAMS which make up the SIMM memory are typically composed of a matrix of rows and columns. The data bits are accessed by addressing a row and a column.
  • Extended Data Out In Extended Data Out, which is similar to Fast Page Mode in that once a memory row (i.e., a page) is addressed, it need not be re-addressed in order to access every data bit in the row (i.e., only the columns need be addressed.) However, in Extended Data Out mode, a new column access may be performed sooner because the memory controller may begin to access a new column while it is reading data from the current column.
  • the memory adapter of the present invention is inserted into a computer system which requires unbuffered 168-pin DRAM DIMMs.
  • the logic 500 reads the SIMM presence detects (PDs) and the DIP switch positions in step 502.
  • the logic advances to step 504 where it tests to determine if two non-ECC (Error Correction Code) SIMMs are present.
  • ECC generally involves the generation of a special series of bits which code a data byte.
  • the computer system's motherboard or memory adapter must have additional circuitry for producing and comparing the ECC bits for each data transfer.
  • step 506 EEPROM 106 is turned off.
  • EEPROM 106 is programmed via tables 2.1, 2.2, 3.1, 3.2, 4.1, 4.2, and 4.3 by logic device 114 and the I 2 C bus controller 112 in step 508.
  • the programming of EEPROMs is conventional and will not be described hereinafter.
  • step 508 the logic ends and the EEPROM, if programmed, may now be read by the computer system in the standard way that the Serial Presence Detects (SPDs) are read for DIMMs and the computer system may finish booting normally.
  • SPDs Serial Presence Detects
  • the logic device 114 serves to program the EEPROM 106 with the required SPDs so as to allow the computer system to properly access the SIMMs.
  • the pin layouts of DIMM and SIMM sockets are conventional and connections there between known.
  • the adapter 100 of the present invention includes hardwire connections between the pin configurations of the DIMM socket and the SIMMs.
  • SPD Serial Presence Detect
  • Table 1 the Serial Presence Detect (SPD) data which is programmed into the logic device 114 and subsequently into EEPROM 106 is shown.
  • SPD Serial Presence Detect
  • the values of certain output bytes is factory set and others are determined by the SIMM and DIP switch inputs to logic device 114 shown in FIG. 4.
  • bytes 0 and 1 are factory set to ⁇ 80 ⁇ x (which denotes hexadecimal notation).
  • SPD Byte 2 Memory Type is determined by Table 2.2 and has been discussed previously. SPD bytes 3, 4, and 5, for # Rows, # Columns, and # Banks, respectively are determined from Table 3.1.
  • the inputs PD1 and PD2 of each SIMM are used to determine the capacity of the SIMMs.
  • the PD1 and PD2 pins of the SIMM are known generally known as capacity pins and indicate the SIMM capacity (See Table 3.2).
  • a "0" indicates ground and a "1" indicates a NO CONNECT (i.e., floating) that is pulled up to V CC via a conventional pull-up resistor.
  • NO CONNECT i.e., floating
  • SPD byte 6 is set by Table 2.1. Table 2.1 has been discussed above and will not be discussed hereinafter. SPD bytes 7 and 8, Continuation and Interface level are factory set to ⁇ 00 ⁇ x. SPD bytes 9 and 10 which describe T RAC and T CAC (e.g., row and column access times) are determined by Table 4.2.
  • T RAC SPD byte 9
  • T CAC SPD byte 10
  • SPD byte 11 Configuration Types is determined from Table 2.1. As already mentioned, Table 2.1 has been discussed above and will not be presently discussed.
  • SPD byte 12 Refresh Type is factory set to ⁇ 00 ⁇ x. Refresh refers to the frequency at which the DRAM is refreshed or recharged. JEDEC approved refresh rates include 4K refresh in 64 ms and 2K refresh in 32 ms. The preferred factory setting indicates a 2K refresh in 32 ms.
  • SPD byte 13 DRAM data width is factory set to ⁇ 04 ⁇ x which indicates that the primary DRAM width is 4 bits wide, that is, the DRAM is organized such that it has 4 data input/output (DQs) pins. This is the case for almost all SIMMs.
  • SPD byte 14 Error Checking DRAM Width is factory set to ⁇ 00 ⁇ x which indicates that the DIMM does not use or support ECC (error correction code) checkbit DRAMs. SPD bytes 15-255 are not used and are factory set ⁇ 00 ⁇ x.
  • the adapter may include circuitry for switching between +5 volt SIMMs and +3.3 volt SIMMs. 5 volt and 3.3 volt SIMMs typically include different "keying" arrangements in an attempt to insure that SIMMs are inserted into SIMM sockets having the proper operating voltages. In such a case, the logic device of the present invention would include a set of operating voltage input from the SIMM sockets to indicate SIMM operating voltage. The power supply switching circuitry may then be properly controlled.
  • the EEPROM may be programmed, as appropriate, with the SPD data bytes shown in Table 1.
  • the computer system will thus read the SPD data from the EEPROM and complete boot-up.
  • the memory adapter 100 provides direct wiring between the SIMM sockets and the DIMM interface (i.e., system memory controller) on the motherboard.
  • the memory adapter may have more than two SIMM sockets and therefore SIMMs which would be dynamically configured. Therefore, the invention, in its broader aspects, is not limited to the specific details, the representative apparatus, and illustrative examples shown and described. Accordingly, departures may be made from such details without departing from the spirit or scope of the applicant's general inventive concept.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)

Abstract

A dynamically configurable memory adapter is provided for configuring SIMMs in a computer system which employs DIMMs. The adapter includes a plurality of SIMM sockets, a programmable logic device, an EEPROM, a bus controller, and DIP switches. The programmable logic device includes logic for interrogating and configuring serial presence detect data based on a plurality of SIMM characteristics included therein. The serial presence detect data is read by the computer system memory controller during the boot-up process. The dynamically configurable memory adapter also includes direct wiring between the DIMM interface and the SIMMs to thereby allow the SIMMs to directly talk to the memory controller.

Description

FIELD OF THE INVENTION
The invention relates generally to memory adapters for computer systems, and more particularly, to a dynamically configurable memory adapter for adapting SIMMs to the computer systems that employ DIMMs.
BACKGROUND OF THE INVENTION
Computer memory comes in two basic forms: Random Access Memory (hereinafter RAM) and Read-Only Memory (hereinafter ROM). RAM is generally used by a processor for reading and writing data. ROM is generally used for storing data which will never change, such as the Board Input/Output System (hereinafter BIOS).
Generally, RAM makes up the bulk of the computer system's memory, excluding the computer system's hard-drive, if one exists. RAM typically comes in the form of dynamic RAM (hereinafter DRAM) which requires frequent recharging or refreshing to preserve its contents. Organizationally, RAM data is typically arranged in bytes of 8 data bits. An optional 9th bit, a parity bit, acts as a check on the correctness of the values of the other eight bits.
A SIMM (Single Inline Memory Module) is a printed circuit board having, among other things, memory chips and connection points or pins. SIMMs are inserted into special sockets on the computer system's motherboard or memory carrier card. A central characteristic of SIMMs is that although there are connection pins on both sides of the SIMM's printed circuit board, these connections are not singular. That is, pin 1 on the front side of the printed circuit board is connected to pin 1 on the backside of the printed circuit board. Therefore, although most SIMMs have a total of 144 pins, only 72 are available for electrical connection.
A DIMM (Dual Inline Memory Module) is also a printed circuit board having, among other things, memory chips and connection points or pins. DIMMs are also inserted into special sockets on the computer system's motherboard or memory carrier card. However, the DIMM includes a dual row of contacts, one on each side of the printed circuit board, which are available for electrical contact. Most general DIMMs include a total of 168 pins, with 84 pins on the front side and 84 pins on the back side of the printed circuit board. Each pin is available for electrical contact.
SIMMs and DIMMs are available in a variety of organizations (e.g., capacity), voltages, speeds, memory types/cycles, physical dimensions, and buffering. Almost all SIMMs and DIMMs have printed circuit boards which are "keyed" and/or "notched" to prevent them from being inserted backwards or into computer systems with different operating voltages from the SIMM or DIMM being inserted. Given the considerable differences between SIMMs and DIMMs, it is apparent these memory modules are not so easily interchanged. While the fundamental architecture of SIMMs and DIMMs is similar, the self-contained descriptive information (e.g., presence detects or PDs) and the physical form factors (e.g., notches, pins, etc.) are dissimilar. As a consequence of these dissimilarities, computer systems which employ DIMMs cannot readily accept SIMMs. Accordingly, it desired to provide a device which overcomes these considerable differences and allows for the use of SIMMs in computer systems that require DIMMs.
SUMMARY OF THE INVENTION
According to one aspect of the present invention, a dynamically configurable memory adapter for adapting a plurality of SIMMs to a computer system configured to employ DIMMs is provided. The adapter includes a plurality of SIMM sockets for accepting the insertion of a plurality of SIMMs; an EEPROM for storing a plurality of serial presence detect data; and a logic device. The logic device includes a plurality of presence detect inputs from each SIMM socket; an Error Correction Code detect input from each SIMM socket; a data width input for indicating the data width of an inserted SIMM; a memory type input for indicating the memory type of an inserted SIMM; a power-on-reset input; a plurality of SIMM characteristic tables; logic for determining the plurality of serial presence detect data from a plurality of SIMM characteristic tables; and logic for programming the EEPROM with the plurality of serial presence detect data. Once the SIMM characteristic data is determined, it is given to the computer system during boot-up in the form of serial presence detect (SPD) data. Thereafter, the computer system may employ the SIMMs even though the computer system is designed to employ DIMMs.
It is therefore an advantage of the present invention to provide a memory adapter that allows the use of SIMMs in computer systems which require DIMMs.
It is a further advantage of this invention to provide a memory adapter that allows for detailed SIMM characteristic data to be provided to a computer system in for the form of serial presence detect data.
BRIEF DESCRIPTION OF THE DRAWINGS
In the accompanying drawings which are incorporated in and constitute a part of the specification, embodiments of the invention are illustrated, which, together with a general description of the invention given above, and the detailed description given below, serve to example the principles of this invention.
FIGS. 1 and 2 are elevational and perspective views of the dynamic memory adapter of the present invention;
FIG. 3 is a block diagram of the dynamic memory adapter of the present invention and a computer system incorporating the adapter;
FIG. 4 is diagram illustrating the inputs and outputs of a programmable logic device of the present invention; and
FIG. 5 is a flowchart illustrating the interrogation and dynamic configuration logic of the present invention.
DETAILED DESCRIPTION OF ILLUSTRATED EMBODIMENT
Referring now to FIG. 1, an elevational view of a memory adapter 100 of the present invention is shown. The memory adapter of the present invention allows two 72-pin SIMMs (Single Inline Memory Modules) to be used in a Joint Electronics Design Engineering Council (JEDEC) standard 168-pin unbuffered DRAM socket. The memory adapter 100 includes a circuit board 118 onto which a plurality of devices are attached. The devices attached to circuit board 118 are two 72- pin sockets 102 and 104, a logic device 114, I2 C bus controller 112, DIP switches 108 and 110, an EEPROM (Electrically Erasable Programmable Read-Only Memory) 106, and a plurality of pin connectors at 116. The circuit board 118 of the memory adapter 100 further includes a first notch 119 and a second notch 120.
SIMM pin socket 102 is preferably a zero degree 72-pin socket and SIMM pin socket 104 is preferably a 22.5 degree 72-pin socket. The logic device 114 is preferably a CYPRESS CY7C343B PLD (Programmable Logic Device). The I2 C bus controller 114 is preferably a PHILIPS PCF8584 I2 C bus controller. The I2 C bus is an industry standard serial bus. The EEPROM 106 is preferably a NATIONAL NM24C02L EEPROM. The pin connectors 116 are preferably gold and total 168 pins, with 84 pins on each side of the printed circuit board 118. The first notch 119 is for indicating that the DIMM is unbuffered. The second notch 120 is for indicating that the DIMM is a 5 volt DIMM. The DIP switches 108 and 110 are each 2-position (ON, OFF) switches. While the elements have described with their preferred embodiments, it should be noted that suitable substitutes may exist which can also be employed. For example, the logic device 114 may be a TOSHIBA ASIC TC160G (Application Specific Integrated Circuit).
Referring now to FIG. 2, a perspective view of the memory adapter 100 of the present invention is shown with a SIMM (202 and 204) inserted into sockets 102 and 104. FIG. 2 illustrates the inserted SIMM positions with the zero degree socket 102 and the 22.5 degree socket 104. Such a socket configuration provides two advantages. First, it allows for certain components to be mounted on the printed circuit board 118 in between sockets 102 and 104. Second, because DIMM sockets are very closely spaced on a computer motherboard, it provides the memory adapter with the dimensional compatibility of ordinary DIMMs thereby facilitating simple insertion of the memory adapter into a DIMM socket without occupying space reserved for other DIMMs and their sockets.
Illustrated in FIG. 3 is an overall block diagram of the present invention in a computer system 300. The computer system 300 is preferably a PC compatible computer system such as the IBM APTIVA®, PS/1®, PS/2® or equivalent. The computer system 300 includes, among other things, a CPU and a memory controller 302 which provides the address and data paths and bus controls for memory operations. When installed, the computer system 300 also includes the memory adapter 100. SIMMs 202 and 204 are in electrical communication with the logic device 114 via SIMM sockets 102 and 104. The logic device 114 is also in electrical communication with DIP switches 108 and 110, the I2 C bus controller 112, and the system memory controller 302. The I2 C bus controller 112 is further in electrical communication with EEPROM 106 and the system memory controller 302. The I2 C bus controller 112 serves as an interface between the computer system 300 high-speed memory bus and the memory adapter 100. The logic device 114 includes dynamic configuration logic 304 and interrogation logic 306. As will be described in more detail, the dynamic configuration logic 304 and interrogation logic 306 are responsible for determining the SIMMs' characteristics and proper configuring of the EEPROM.
Illustrated in FIG. 4 is an input/output diagram of the logic device 114. The logic device 114 includes a plurality of presence detect (PD) inputs from each SIMM (or SIMM socket). In particular, from each SIMM, the ECC, PD1, PD2, PD3, and PD4 signals are input into the logic device 114. A second set of inputs includes the DIP switch signals representing the WIDTH and MEMORY TYPE of the SIMMs are also provided to the logic device 114. A third set of inputs representing the computer system RAS 0 and CAS 0 control lines are further provided to the logic device 114. The logic device 114 further includes a plurality of data outputs indicated by a DATA bus which are in circuit communication with the I2 C bus controller 112. The DATA bus is preferably an 8-bit bus. A Power-ON-Reset (POR)input and an EEPROM power output are also provided.
A plurality of control lines also communicate the logic device 114 to the I2 C bus controller 112. The control lines include INT SCL OUT, IACK SDA IN, CLK, RD, W/R, AO, CS, and RESET. The INT SCL OUT signal is the serial clock output from the I2 C bus controller 112. The IACK SDA IN signal is the serial data signal, the CLK is the clock signal, the RD is the read control signal, the W/R is the write control signal, the AO is the register select signal, the CS is the chip select signal, and RESET is the reset signal which forces the I2 C bus controller 112 into a predefined reset state. More information relating to the I2 C bus controller 112 of the present invention may be found in the PCF8584 I2 C-bus controller, Product Specification, Mar. 19, 1997, Philips Semiconductors.
Referring now to FIG. 5, a flowchart of the dynamic configuration logic and interrogation logic is shown. The logic executes upon a Power-On-Reset (POR). A POR typically occurs when the computer system is switched from the off state to the on state (i.e., the computer is turned on). However, previous to the POR, two SIMMs must be inserted into the SIMM sockets of the memory adapter of the present invention. Preferably, the two SIMMs should be matched pairs (e.g., 2 SIMMs, 8 MB, 2M×32, 70 ns, EDO). However, the memory adapter will also work with unmatched pairs.
Once the SIMMs have been selected, the DIP switches are set according to Tables 2.1 and 2.2. Referring now to Tables 2.1 and 2.2, the values of SPD bytes 6, 11, and 2 are shown for the various SIMM configurations based on Parity/Width and Memory Type. Referring now to Table 2.1 in particular, the DIP switch positions for the SIMM organization of Parity/Width (i.e., "x64" and "x72"), along with the values for SPD bytes 6 and 11, are shown. The "x64" and "x72" designations describe width, or the number of bits that can be accessed at the same time (i.e., 64 or 72 bits) on the SIMM.
Referring now specifically to Table 2.2, the DIP switch positions for the SIMM organization of Memory Type (i.e., "FPM" and "EDO"), along with the values for SPD byte 2 is shown. "FPM" refers to a memory configuration known as Fast Page Mode. Fast Page Mode allows the system's memory controller to access a plurality of data bits in terms of a page. The DRAMS which make up the SIMM memory are typically composed of a matrix of rows and columns. The data bits are accessed by addressing a row and a column. In Fast Page Mode, once a memory row (i.e., a page) is addressed, it need not be re-addressed in order to access every data bit in the row (i.e., only the columns need be addressed.) "EDO" refers to a memory type known as Extended Data Out. In Extended Data Out, which is similar to Fast Page Mode in that once a memory row (i.e., a page) is addressed, it need not be re-addressed in order to access every data bit in the row (i.e., only the columns need be addressed.) However, in Extended Data Out mode, a new column access may be performed sooner because the memory controller may begin to access a new column while it is reading data from the current column.
Referring, once again, to FIG. 5, once the SIMMs are inserted and the DIP switches are set, the memory adapter of the present invention is inserted into a computer system which requires unbuffered 168-pin DRAM DIMMs. When the computer system is turned on and a Power-On-Reset POR occurs, the logic 500 reads the SIMM presence detects (PDs) and the DIP switch positions in step 502. After step 502, the logic advances to step 504 where it tests to determine if two non-ECC (Error Correction Code) SIMMs are present. ECC generally involves the generation of a special series of bits which code a data byte. The computer system's motherboard or memory adapter must have additional circuitry for producing and comparing the ECC bits for each data transfer. Accordingly, if two non-ECC SIMMs are NOT present, the logic advances to step 506 where EEPROM 106 is turned off. However, if two non-ECC SIMMs are present, EEPROM 106 is programmed via tables 2.1, 2.2, 3.1, 3.2, 4.1, 4.2, and 4.3 by logic device 114 and the I2 C bus controller 112 in step 508. The programming of EEPROMs is conventional and will not be described hereinafter. After step 508, the logic ends and the EEPROM, if programmed, may now be read by the computer system in the standard way that the Serial Presence Detects (SPDs) are read for DIMMs and the computer system may finish booting normally. In this manner, the logic device 114 serves to program the EEPROM 106 with the required SPDs so as to allow the computer system to properly access the SIMMs. The pin layouts of DIMM and SIMM sockets are conventional and connections there between known. The adapter 100 of the present invention includes hardwire connections between the pin configurations of the DIMM socket and the SIMMs.
Referring now to Table 1, the Serial Presence Detect (SPD) data which is programmed into the logic device 114 and subsequently into EEPROM 106 is shown. It should be noted that the values of certain output bytes is factory set and others are determined by the SIMM and DIP switch inputs to logic device 114 shown in FIG. 4. In particular, bytes 0 and 1 are factory set to `80`x (which denotes hexadecimal notation). SPD Byte 2 Memory Type is determined by Table 2.2 and has been discussed previously. SPD bytes 3, 4, and 5, for # Rows, # Columns, and # Banks, respectively are determined from Table 3.1.
Referring now to Table 3.1, the inputs PD1 and PD2 of each SIMM are used to determine the capacity of the SIMMs. The PD1 and PD2 pins of the SIMM are known generally known as capacity pins and indicate the SIMM capacity (See Table 3.2). For the PD1 and PD2 inputs, a "0" indicates ground and a "1" indicates a NO CONNECT (i.e., floating) that is pulled up to VCC via a conventional pull-up resistor. For each possible combination of PD1 and PD2 inputs for both SIMMs, the Row Address (SPD byte 3), Column Address (SPD byte 4), and # Banks (SPD byte 5) are assigned.
Referring again to Table 1, SPD byte 6 is set by Table 2.1. Table 2.1 has been discussed above and will not be discussed hereinafter. SPD bytes 7 and 8, Continuation and Interface level are factory set to `00`x. SPD bytes 9 and 10 which describe TRAC and TCAC (e.g., row and column access times) are determined by Table 4.2.
Referring now to Table 4.2, data for determining the SIMM DRAM speed is shown. This function is facilitated by the use of speed presence detect pins PD3 and PD4 of each SIMM (see Table 4.3). The values for TRAC (SPD byte 9) and TCAC (SPD byte 10) are determined by the slowest SIMM having the slowest TRAC. This will ensure that both SIMMs will operate properly since a SIMM can operate at a lower than rated speed but not a faster than rated speed.
Referring once again to Table 1, SPD byte 11 Configuration Types is determined from Table 2.1. As already mentioned, Table 2.1 has been discussed above and will not be presently discussed. SPD byte 12 Refresh Type is factory set to `00`x. Refresh refers to the frequency at which the DRAM is refreshed or recharged. JEDEC approved refresh rates include 4K refresh in 64 ms and 2K refresh in 32 ms. The preferred factory setting indicates a 2K refresh in 32 ms. SPD byte 13 DRAM data width is factory set to `04`x which indicates that the primary DRAM width is 4 bits wide, that is, the DRAM is organized such that it has 4 data input/output (DQs) pins. This is the case for almost all SIMMs. SPD byte 14 Error Checking DRAM Width is factory set to `00`x which indicates that the DIMM does not use or support ECC (error correction code) checkbit DRAMs. SPD bytes 15-255 are not used and are factory set `00`x. Additionally, the adapter may include circuitry for switching between +5 volt SIMMs and +3.3 volt SIMMs. 5 volt and 3.3 volt SIMMs typically include different "keying" arrangements in an attempt to insure that SIMMs are inserted into SIMM sockets having the proper operating voltages. In such a case, the logic device of the present invention would include a set of operating voltage input from the SIMM sockets to indicate SIMM operating voltage. The power supply switching circuitry may then be properly controlled.
Accordingly, once the logic device 114 has read all of its inputs (see FIG. 4), the EEPROM may be programmed, as appropriate, with the SPD data bytes shown in Table 1. The computer system will thus read the SPD data from the EEPROM and complete boot-up. Thereafter, the memory adapter 100 provides direct wiring between the SIMM sockets and the DIMM interface (i.e., system memory controller) on the motherboard.
              TABLE 1                                                     
______________________________________                                    
Serial Presence Detect (SPD) Data                                         
  Byte       Function         Value                                       
______________________________________                                    
0        # bytes written  Factory set to `80`x                            
  1 Total # SPD bytes Factory set to `08`x                                
  2 Memory Type See Table 2.2                                             
  3 # Rows See Table 3.1                                                  
  4 # Columns See Table 3.1                                               
  5 # Banks See Table 3.1                                                 
  6 Data Width See Table 2.1                                              
  7 Continuation Factory set to `00`x                                     
  8 Interface Level Factory set to `00`x                                  
  9 T.sub.RAC See Table 4.2                                               
  10  T.sub.CAC See Table 4.2                                             
  11  Configuration Type See Table 2.1                                    
  12  Refresh Type Factory set to `00`x                                   
  13  DRAM data width Factory set to `04`x                                
  14  Error Checking DRAM width Factory set to `00`x                      
  15-255 Not Currently Used Factory set to `00`x                          
______________________________________                                    
              TABLE 2.1                                                   
______________________________________                                    
DIP SWITCH PROGRAMMING (SPD BYTES 6, and 11)                              
    Parity/Width                                                          
              Result     SPD byte 6                                       
                                 SPD byte 11                              
______________________________________                                    
0 = Off   x64        `40`x     `00`x                                      
  1 = On x72 `48`x `01`x                                                  
______________________________________                                    
              TABLE 2.2                                                   
______________________________________                                    
DIP SWITCH PROGRAMMING (SPD BYTE 2)                                       
  Memory Type EDO    Result  SPD byte 2                                   
______________________________________                                    
0 = Off          FPM     `01`x                                            
  1 = On EDO `02`x                                                        
______________________________________                                    
              TABLE 3.1                                                   
______________________________________                                    
SPD PROGRAMMING CAPACITY (SPD BYTES 3, 4, and 5)                          
                                        SPD                               
  SIMM 1 SIMM 2 SPD BYTE 3 SPD BYTE 4 BYTE 5                              
PD 1 PD 2   PD 1   PD 2 Row Addr Col Addr # Banks                         
______________________________________                                    
0    0      0      0    10 (`0A`x)                                        
                                 10 (`0A`x)                               
                                          1 (`01`x)                       
  0 0 0 1 10 (`0A`x) 10 (`0A`x) 1 (`01`x)                                 
  0 0 1 0 10 (`0A`x) 10 (`0A`x) 1 (`01`x)                                 
  0 0 1 1 10 (`0A`x) 10 (`0A`x) 1 (`01`x)                                 
  0 1 0 0 10 (`0A`x) 10 (`0A`x) 1 (`01`x)                                 
  0 1 0 1 11 (`0B`x) 11 (`0B`x) 1 (`01`x)                                 
  0 1 1 0 11 (`0B`x) 11 (`0B`x) 1 ( `01`x)                                
  0 1 1 1 10 (`0A`x) 10 (`0A`x) 1 (`01`x)                                 
  1 0 0 0 10 (`0A`x) 10 (`0A`x) 1 (`01`x)                                 
  1 0 0 1 11 (`0B`x) 11 (`0B`x) 1 (`01`x)                                 
  1 0 1 0 11 (`0B`x) 11 (`0B`x) 2 (`02`x)                                 
  1 0 1 1 10 (`0A`x) 10 (`0A`x) 2 (`02`x)                                 
  1 1 0 0 10 (`0A`x) 10 (`0A`x) 1 (`01`x)                                 
  1 1 0 1 10 (`0A`x) 10 (`0A`x) 1 (`01`x)                                 
  1 1 1 0 10 (`0A`x) 10 (`0A`x) 2 (`02`x)                                 
  1 1 1 1 10 (`0A`x) 10 (`0A`x) 2 (`02`x)                                 
______________________________________                                    
              TABLE 3.2                                                   
______________________________________                                    
SIMM PRESENCE DETECTS (Capacity)                                          
  PD 1             PD 2   Capacity                                        
______________________________________                                    
0              0       4 MB                                               
  0 1 16 MB                                                               
  1 0 32 MB                                                               
  1 1  8 MB                                                               
______________________________________                                    
              TABLE 4.1                                                   
______________________________________                                    
SPD PROGRAMMING ECC                                                       
  SIMM 1 ECC      SIMM 2 ECC   RESULT                                     
______________________________________                                    
0             0            Block EEPROM                                   
  0 1 Block EEPROM                                                        
  1 0 Block EEPROM                                                        
  1 1 Enable EEPROM                                                       
______________________________________                                    
              TABLE 4.2                                                   
______________________________________                                    
SPD PROGRAMMING SPEED (SPD BYTES 9 AND 10)                                
  SIMM 1 SPEED SIMM 2 SP    SPD Byte 9                                    
                                     SPD Byte 10                          
PD 3   PD 4    PD 3     PD 4  T.sub.rac (ns)                              
                                       T.sub.cac (ns)                     
______________________________________                                    
0      0       0        0     `64` × (100)                          
                                       `1E` × (30)                  
  0 0 0 1 `64` × (100) `1E` × (30)                            
  0 0 1 0 `64` × (100) `1E` × (30)                            
  0 0 1 1 `64` × (100) `1E` × (30)                            
  0 1 0 0 `64` × (100) `1E` × (30)                            
  0 1 0 1 `46` × (70)  `14` × (20)                            
  0 1 1 0 `50` × (80)  `19` × (25)                            
  0 1 1 1 `46` × (70)  `14` × (20)                            
  1 0 0 0 `64` × (100) `1E` × (30)                            
  1 0 0 1 `50` × (80)  `19` × (25)                            
  1 0 1 0 `50` × (80)  `19` × (25)                            
  1 0 1 1 `50` × (80)  `19` × (25)                            
  1 1 0 0 `64` × (100) `1E` × (30)                            
  1 1 0 1 `46` × (70)  `14` × (20)                            
  1 1 1 0 `50` × (80)  `19` × (25)                            
  1 1 1 1 `3C` × (60)  `0F` × (15)                            
______________________________________                                    
              TABLE 4.3                                                   
______________________________________                                    
PRESENCE DETECT SPEED                                                     
  PD 3             PD 4   Speed (ns)                                      
______________________________________                                    
0              0      100                                                 
  0 1 70                                                                  
  1 0 80                                                                  
  1 1 60                                                                  
______________________________________                                    
While the present invention has been illustrated by the description of embodiments thereof, and while the embodiments have been described in considerable detail, it is not the intention of the applicants to restrict or in any way limit the scope of the appended claims to such detail. Additional advantages and modifications will readily appear to those skilled in the art. For example, the memory adapter may have more than two SIMM sockets and therefore SIMMs which would be dynamically configured. Therefore, the invention, in its broader aspects, is not limited to the specific details, the representative apparatus, and illustrative examples shown and described. Accordingly, departures may be made from such details without departing from the spirit or scope of the applicant's general inventive concept.

Claims (25)

We claim:
1. A dynamically configurable memory adapter for adapting a plurality of SIMM memory modules to a computer system configured to accept DIMM memory modules, the memory adapter comprising:
(a) a circuit board having connection pins for insertion into a DIMM socket on a computer system:
(b) a plurality of sockets on the circuit board for reception of SIMM module connection pins;
(c) logic on the circuit board electronically connected to said SIMM sockets for determining the characteristics of the plurality of SIMM memory modules including presence detect data;
(d) EEPROM on the circuit board electronically connected to said logic for storing the characteristics of the plurality of memory modules;
(e) a bus controller on the circuit board electronically connected to said EEPROM and said circuit board DIMM connection pins to dynamically configure the EEPROM for communicating the memory adapter to the computer system; and
(f) logic circuitry to prevent presence detect data if at least one SIMM memory module has ECC.
2. The adapter of claim 1 further comprising a logic device having a plurality of memory module characteristic tables.
3. The adapter of claim 2 wherein the logic device further comprises a plurality of inputs and outputs, wherein the inputs comprise a plurality of presence detect signals from the plurality of memory module characteristic data into the EEPROM.
4. The adapter of claim 2 wherein the logic device further comprises logic for programming serial presence detect data from the plurality of memory module characteristic tables.
5. The adapter of claim 3 wherein the logic device further comprises logic for associating the plurality of presence detect signals to the memory module characteristic tables.
6. The adapter of claim 1 further comprising a plurality of DIP switches for indicating the plurality of memory modules characteristic data width and DRAM memory type.
7. A dynamically configurable memory adapter for adapting a plurality of SIMMs to a computer system configured to employ DIMMs, the adapter comprising:
(a) a circuit board having DIMM connection pins for insertion into a DIMM socket on a computer system;
(b) a plurality of SIMM sockets on the circuit board for accepting the insertion of a plurality of SIMMs;
(c) an EEPROM on the circuit board for storing a plurality of serial presence detect data;
(d) a bus controller on the circuit board for interfacing the EEPROM to a logic device on the circuit board;
(e) the logic device comprising:
(1) a plurality of presence detect inputs from each SIMM socket;
(2) an Error Correction Code detect input from each SIMM socket;
(3) a data width input for indicating the data width of an inserted SIMM;
(4) a memory type input for indicating the memory type of an inserted SIMM;
(5) a power-on-reset input;
(6) a plurality of SIMM characteristic tables;
(7) logic for determining the plurality of serial presence detect data from a plurality of SIMM characteristic tables;
(8) logic for programming the EEPROM with the plurality of serial presence detect data; and
(9) logic to prevent presence detect data when an ECC-type SIMM memory module is detected.
8. The adapter of claim 7 wherein the plurality of SIMM characteristic tables includes a memory type table.
9. The adapter of claim 7 wherein the plurality of SIMM characteristic tables includes a data width table.
10. The adapter of claim 7 wherein the plurality of SIMM characteristic tables includes a column and row access time table.
11. The adapter of claim 7 wherein the plurality of SIMM characteristic tables includes a row and column address table.
12. The adapter of claim 7 wherein the plurality of SIMM sockets includes a zero degree SIMM socket and an at least 22.5 degree SIMM socket.
13. A method for dynamically configuring a plurality of SIMMs to a computer system configured to employ DIMMs, the method of comprising the steps of:
(a) providing a plurality of SIMMs;
(b) determining the speed of the plurality of SIMMs;
(c) determining the capacity of the plurality of SIMMs;
(d) determining the architecture of the plurality of SIMMs;
(e) generating a plurality of serial presence detect data from the speed, capacity and architecture of the SIMMs;
(f) storing the plurality of serial presence detect data in a storage device accessible by a memory controller of the computer system through a DIMM receiver; and
(g) rendering the storage device inaccessible to the computer system memory controller if at least one of the SIMMs includes Error Correction Code architecture.
14. The method of claim 13 wherein the step of determining the architecture of plurality of SIMMs comprises the steps of accessing a plurality of SIMM characteristic tables stored in a programmable logic device.
15. The method of claim 13 wherein the step of determining the architecture of plurality of SIMMs comprises the steps:
(a) determining the data width of the plurality of SIMMs;
(b) determining the memory type of the plurality of SIMMs;
(c) determining whether the plurality of SIMMs include Error Correction Code; and
(d) determining the row and column access time of the plurality of SIMMs.
16. The method of claim 15 wherein the step of determining the row and column access time of the plurality of SIMMs includes the step of determining the slowest row access time of the plurality of SIMMs.
17. The method of claim 13 wherein the storage device is EEPROM and the step of rendering the storage device inaccessible to the computer system memory controller comprises turning off the EEPROM.
18. The method of claim 13 wherein the step of storing the plurality of serial presence detect data in a storage device accessible by a memory controller of the computer system comprises the step of writing the serial presence detect data to an EEPROM accessible by the memory controller of the computer system.
19. The method of claim 13 further comprising the step of sending the plurality of serial presence detect data to the computer system memory controller.
20. A computer for accepting a plurality of types of memory modules comprising:
(a) a CPU;
(b) a system memory controller in circuit communication with the CPU; and
(c) a dynamically configurable memory adapter for adapting the plurality of SIMM memory modules to the computer system configured to accept DIMM memory modules, the adapter comprising:
(1) logic for determining the characteristics of the plurality of SIMM memory modules;
(2) EEPROM for storing the characteristics of the plurality of the plurality of types of memory modules;
(3) a bus controller to dynamically configure the EEPROM for communicating the memory adapter to the computer system; and
(4) logic to prevent presence detect data from being communicated to the computer system when an ECC-type SIMM memory module is detected.
21. The adapter of claim 20 further comprising a logic device having a plurality of memory module characteristic tables.
22. The adapter of claim 21 wherein the logic device further comprises a plurality of inputs and outputs, wherein the inputs comprise a plurality of presence detect signals from the plurality of types of memory module characteristic data into the EEPROM.
23. The adapter of claim 22 wherein the logic device further comprises logic for associating the plurality of presence detect signals to the memory module characteristic tables.
24. The adapter of claim 20 further comprising a plurality of DIP switches for indicating the plurality of types of memory modules characteristic data width and DRAM memory type.
25. The adapter of claim 20 wherein the plurality of memory modules include SIMMs.
US08/904,187 1997-07-31 1997-07-31 Dynamically configurable memory adapter using electronic presence detects Expired - Fee Related US6092146A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US08/904,187 US6092146A (en) 1997-07-31 1997-07-31 Dynamically configurable memory adapter using electronic presence detects

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US08/904,187 US6092146A (en) 1997-07-31 1997-07-31 Dynamically configurable memory adapter using electronic presence detects

Publications (1)

Publication Number Publication Date
US6092146A true US6092146A (en) 2000-07-18

Family

ID=25418731

Family Applications (1)

Application Number Title Priority Date Filing Date
US08/904,187 Expired - Fee Related US6092146A (en) 1997-07-31 1997-07-31 Dynamically configurable memory adapter using electronic presence detects

Country Status (1)

Country Link
US (1) US6092146A (en)

Cited By (40)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6178526B1 (en) * 1998-04-08 2001-01-23 Kingston Technology Company Testing memory modules with a PC motherboard attached to a memory-module handler by a solder-side adaptor board
US6289411B1 (en) * 1998-07-30 2001-09-11 Fujitsu Limited Circuit for generating a chip-enable signal for a multiple chip configuration
US6351827B1 (en) * 1998-04-08 2002-02-26 Kingston Technology Co. Voltage and clock margin testing of memory-modules using an adapter board mounted to a PC motherboard
US6357023B1 (en) * 1998-04-08 2002-03-12 Kingston Technology Co. Connector assembly for testing memory modules from the solder-side of a PC motherboard with forced hot air
US6457155B1 (en) * 1998-02-27 2002-09-24 International Business Machines Method for making a memory card adapter insertable into a motherboard memory card socket comprising a memory card receiving socket having the same configuration as the motherboard memory card socket
DE10208737A1 (en) * 2002-02-28 2003-09-18 Infineon Technologies Ag Adapter device for memory modules
US6625692B1 (en) * 1999-04-14 2003-09-23 Micron Technology, Inc. Integrated semiconductor memory chip with presence detect data capability
US20040024941A1 (en) * 2002-07-31 2004-02-05 Compaq Information Technologies Group, L.P. Method and apparatus for supporting hot-plug cache memory
US6715013B1 (en) * 1999-08-16 2004-03-30 Hewlett-Packard Development Company, L.P. Bus system having improved control process
US6742077B1 (en) * 1999-10-07 2004-05-25 Nec Corporation System for accessing a memory comprising interleaved memory modules having different capacities
US20040122984A1 (en) * 2001-05-14 2004-06-24 Hidemi Oyama Data processor and data table update method
US6772261B1 (en) * 2000-04-27 2004-08-03 International Business Machines Corporation Interface that allows testing and using memory modules in computer systems not designed for the modules
US20040151038A1 (en) * 2002-11-29 2004-08-05 Hermann Ruckerbauer Memory module and method for operating a memory module in a data memory system
US20040158701A1 (en) * 2003-02-12 2004-08-12 Dell Products L.P. Method of decreasing boot up time in a computer system
US6782451B2 (en) * 2000-08-03 2004-08-24 Asustek Computer Inc. Control circuit to allow the use of an unbuffered DIMM in a system with a registered-DIMM-only chipset
US20040174763A1 (en) * 2003-03-04 2004-09-09 Schnepper Randy L. Memory subsystem voltage control and method
US20040216011A1 (en) * 2003-04-28 2004-10-28 Kingston Technology Co. Extender Card with Intercepting EEPROM for Testing and Programming Un-Programmed Memory Modules on a PC Motherboard
US20040250056A1 (en) * 2003-06-03 2004-12-09 Christopher Chang System boot method
US20050033910A1 (en) * 2003-06-30 2005-02-10 Michael Sommer Method for data transfer
US20050044302A1 (en) * 2003-08-06 2005-02-24 Pauley Robert S. Non-standard dual in-line memory modules with more than two ranks of memory per module and multiple serial-presence-detect devices to simulate multiple modules
US20050060487A1 (en) * 1998-03-10 2005-03-17 Barth Richard M. Memory device having a power down exit register
US20050071580A1 (en) * 2003-09-30 2005-03-31 Intel Corporation Distributed memory initialization and test methods and apparatus
US20050188281A1 (en) * 2004-02-04 2005-08-25 Vincent Nguyen Memory module with testing logic
US20060053273A1 (en) * 2004-09-08 2006-03-09 Via Technologies Inc. Methods for memory initialization
US20080052462A1 (en) * 2006-08-24 2008-02-28 Blakely Robert J Buffered memory architecture
US20080195835A1 (en) * 2004-05-18 2008-08-14 Infineon Technologies Ag Configurable embedded processor
US20080301345A1 (en) * 2007-05-29 2008-12-04 Blinick Stephen L Multi-character adapter card
US20090037641A1 (en) * 2007-07-31 2009-02-05 Bresniker Kirk M Memory controller with multi-protocol interface
US20090234998A1 (en) * 2008-03-12 2009-09-17 Hon Hai Precision Industry Co., Ltd. Connection system
US20100064099A1 (en) * 2008-09-08 2010-03-11 Satyanarayana Nishtala Input-output module, processing platform and method for extending a memory interface for input-output operations
US20100091542A1 (en) * 2008-10-15 2010-04-15 Shaw Mark E Memory Module Having a Memory Device Configurable to Different Data Pin Configurations
US7788421B1 (en) * 2008-01-24 2010-08-31 Google Inc. Detectable null memory for airflow baffling
US20110289250A1 (en) * 2010-05-21 2011-11-24 Hon Hai Precision Industry Co., Ltd. Card adapter
US20150269024A1 (en) * 2014-03-21 2015-09-24 AMD Products (China) Co., Ltd. Independent ecc chip device, a motherboard, and a computer system
US9250954B2 (en) 2013-01-17 2016-02-02 Xockets, Inc. Offload processor modules for connection to system memory, and corresponding methods and systems
US9258276B2 (en) 2012-05-22 2016-02-09 Xockets, Inc. Efficient packet handling, redirection, and inspection using offload processors
US9286472B2 (en) 2012-05-22 2016-03-15 Xockets, Inc. Efficient packet handling, redirection, and inspection using offload processors
US9378161B1 (en) 2013-01-17 2016-06-28 Xockets, Inc. Full bandwidth packet handling with server systems including offload processors
WO2016122461A1 (en) * 2015-01-27 2016-08-04 Hewlett Packard Enterprise Development Lp In-line memory module carrier for an m.2 form factor module
US20220317889A1 (en) * 2019-12-26 2022-10-06 Huawei Technologies Co., Ltd. Memory Setting Method and Apparatus

Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5038320A (en) * 1987-03-13 1991-08-06 International Business Machines Corp. Computer system with automatic initialization of pluggable option cards
EP0440445A2 (en) * 1990-01-31 1991-08-07 Hewlett-Packard Company System memory initialization with presence detect encoding
US5253357A (en) * 1991-06-13 1993-10-12 Hewlett-Packard Company System for determining pluggable memory characteristics employing a status register to provide information in response to a preset field of an address
WO1994011802A1 (en) * 1992-11-12 1994-05-26 New Media Corporation Reconfigureable interface between a computer and peripheral devices
US5375084A (en) * 1993-11-08 1994-12-20 International Business Machines Corporation Selectable interface between memory controller and memory simms
US5446869A (en) * 1993-12-30 1995-08-29 International Business Machines Corporation Configuration and RAM/ROM control of PCI extension card residing on MCA adapter card
US5446860A (en) * 1993-01-11 1995-08-29 Hewlett-Packard Company Apparatus for determining a computer memory configuration of memory modules using presence detect bits shifted serially into a configuration register
US5509138A (en) * 1993-03-22 1996-04-16 Compaq Computer Corporation Method for determining speeds of memory modules
US5513135A (en) * 1994-12-02 1996-04-30 International Business Machines Corporation Synchronous memory packaged in single/dual in-line memory module and method of fabrication
US5524232A (en) * 1993-09-13 1996-06-04 Hajeer; Jahad K. Device for receiving and adapting a set of computer memory modules to a single computer memory module receiving socket
US5541941A (en) * 1994-01-28 1996-07-30 International Business Machines Corporation Method and structure for providing automatic parity sensing

Patent Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5038320A (en) * 1987-03-13 1991-08-06 International Business Machines Corp. Computer system with automatic initialization of pluggable option cards
US5491804A (en) * 1987-03-13 1996-02-13 International Business Machines Corp. Method and apparatus for automatic initialization of pluggable option cards
EP0440445A2 (en) * 1990-01-31 1991-08-07 Hewlett-Packard Company System memory initialization with presence detect encoding
US5253357A (en) * 1991-06-13 1993-10-12 Hewlett-Packard Company System for determining pluggable memory characteristics employing a status register to provide information in response to a preset field of an address
WO1994011802A1 (en) * 1992-11-12 1994-05-26 New Media Corporation Reconfigureable interface between a computer and peripheral devices
US5446860A (en) * 1993-01-11 1995-08-29 Hewlett-Packard Company Apparatus for determining a computer memory configuration of memory modules using presence detect bits shifted serially into a configuration register
US5509138A (en) * 1993-03-22 1996-04-16 Compaq Computer Corporation Method for determining speeds of memory modules
US5524232A (en) * 1993-09-13 1996-06-04 Hajeer; Jahad K. Device for receiving and adapting a set of computer memory modules to a single computer memory module receiving socket
US5375084A (en) * 1993-11-08 1994-12-20 International Business Machines Corporation Selectable interface between memory controller and memory simms
US5446869A (en) * 1993-12-30 1995-08-29 International Business Machines Corporation Configuration and RAM/ROM control of PCI extension card residing on MCA adapter card
US5541941A (en) * 1994-01-28 1996-07-30 International Business Machines Corporation Method and structure for providing automatic parity sensing
US5513135A (en) * 1994-12-02 1996-04-30 International Business Machines Corporation Synchronous memory packaged in single/dual in-line memory module and method of fabrication

Non-Patent Citations (6)

* Cited by examiner, † Cited by third party
Title
Cypress bulletin CY7C343/CY7C343B (Jan. 1990 Revised Mar. 1997). *
Cypress bulletin--CY7C343/CY7C343B (Jan. 1990--Revised Mar. 1997).
IBM Technical Disclosure Bulletin Dynamic Self Configuration for Memory Cards Arrangements vol. 31, No. 12, May 1989. *
IBM Technical Disclosure Bulletin--Dynamic Self-Configuration for Memory Cards Arrangements vol. 31, No. 12, May 1989.
Philips Semiconductor Data Sheet PCF8584 1 2 C bus controller; Product specification dated 1197 Mar. 19 Supersedes date of Aug. 29, 1995. *
Philips Semiconductor Data Sheet PCF8584 12 C-bus controller; Product specification dated 1197 Mar. 19 Supersedes date of Aug. 29, 1995.

Cited By (90)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6457155B1 (en) * 1998-02-27 2002-09-24 International Business Machines Method for making a memory card adapter insertable into a motherboard memory card socket comprising a memory card receiving socket having the same configuration as the motherboard memory card socket
US20050193183A1 (en) * 1998-03-10 2005-09-01 Barth Richard M. Method and apparatus for initializing dynamic random access memory (DRAM) devices
US7574616B2 (en) 1998-03-10 2009-08-11 Rambus Inc. Memory device having a power down exit register
US20050235130A1 (en) * 1998-03-10 2005-10-20 Barth Richard M System for a memory device having a power down mode and method
US20050216654A1 (en) * 1998-03-10 2005-09-29 Barth Richard M System and module including a memory device having a power down mode
US7571330B2 (en) * 1998-03-10 2009-08-04 Rambus Inc. System and module including a memory device having a power down mode
US8756395B2 (en) 1998-03-10 2014-06-17 Rambus Inc. Controlling DRAM at time DRAM ready to receive command when exiting power down
US7581121B2 (en) 1998-03-10 2009-08-25 Rambus Inc. System for a memory device having a power down mode and method
US20050154817A1 (en) * 1998-03-10 2005-07-14 Barth Richard M. Method of operation and controlling a memory device
US20050154853A1 (en) * 1998-03-10 2005-07-14 Barth Richard M. Memory device and method of operation of a memory device
US20050120161A1 (en) * 1998-03-10 2005-06-02 Barth Richard M. Methods of operation of a memory device and system
US8127152B2 (en) * 1998-03-10 2012-02-28 Rambus Inc. Method of operation of a memory device and system including initialization at a first frequency and operation at a second frequency and a power down exit mode
US20050060487A1 (en) * 1998-03-10 2005-03-17 Barth Richard M. Memory device having a power down exit register
US6178526B1 (en) * 1998-04-08 2001-01-23 Kingston Technology Company Testing memory modules with a PC motherboard attached to a memory-module handler by a solder-side adaptor board
US6357023B1 (en) * 1998-04-08 2002-03-12 Kingston Technology Co. Connector assembly for testing memory modules from the solder-side of a PC motherboard with forced hot air
US6357022B1 (en) * 1998-04-08 2002-03-12 Kingston Technology Co. Testing memory modules on a solder-side adaptor board attached to a PC motherboard
US6351827B1 (en) * 1998-04-08 2002-02-26 Kingston Technology Co. Voltage and clock margin testing of memory-modules using an adapter board mounted to a PC motherboard
US6289411B1 (en) * 1998-07-30 2001-09-11 Fujitsu Limited Circuit for generating a chip-enable signal for a multiple chip configuration
US20050099863A1 (en) * 1999-04-14 2005-05-12 Stubbs Eric T. Integrated semiconductor memory chip with presence detect data capability
US20040017723A1 (en) * 1999-04-14 2004-01-29 Stubbs Eric T. Integrated semiconductor memory chip with presence detect data capability
US7152143B2 (en) 1999-04-14 2006-12-19 Micron Technology, Inc. Integrated semiconductor memory chip with presence detect data capability
US6947341B2 (en) 1999-04-14 2005-09-20 Micron Technology, Inc. Integrated semiconductor memory chip with presence detect data capability
US6625692B1 (en) * 1999-04-14 2003-09-23 Micron Technology, Inc. Integrated semiconductor memory chip with presence detect data capability
US20040230732A1 (en) * 1999-08-16 2004-11-18 Hewlett-Packard Company Bus system having improved control process
US6715013B1 (en) * 1999-08-16 2004-03-30 Hewlett-Packard Development Company, L.P. Bus system having improved control process
US6957289B2 (en) * 1999-08-16 2005-10-18 Hewlett-Packard Development Company, L.P. Bus system having improved control process
US6742077B1 (en) * 1999-10-07 2004-05-25 Nec Corporation System for accessing a memory comprising interleaved memory modules having different capacities
US6772261B1 (en) * 2000-04-27 2004-08-03 International Business Machines Corporation Interface that allows testing and using memory modules in computer systems not designed for the modules
US6782451B2 (en) * 2000-08-03 2004-08-24 Asustek Computer Inc. Control circuit to allow the use of an unbuffered DIMM in a system with a registered-DIMM-only chipset
US20040122984A1 (en) * 2001-05-14 2004-06-24 Hidemi Oyama Data processor and data table update method
DE10208737B4 (en) * 2002-02-28 2008-08-14 Qimonda Ag Adapter device for memory modules
DE10208737A1 (en) * 2002-02-28 2003-09-18 Infineon Technologies Ag Adapter device for memory modules
US6788548B2 (en) 2002-02-28 2004-09-07 Infineon Technologies Ag Adapter apparatus for memory modules
US20040024941A1 (en) * 2002-07-31 2004-02-05 Compaq Information Technologies Group, L.P. Method and apparatus for supporting hot-plug cache memory
US20040151038A1 (en) * 2002-11-29 2004-08-05 Hermann Ruckerbauer Memory module and method for operating a memory module in a data memory system
US7275189B2 (en) * 2002-11-29 2007-09-25 Infineon Technologies Ag Memory module and method for operating a memory module in a data memory system
US20040158701A1 (en) * 2003-02-12 2004-08-12 Dell Products L.P. Method of decreasing boot up time in a computer system
US7529951B2 (en) 2003-03-04 2009-05-05 Micron Technology, Inc. Memory subsystem voltage control and method that reprograms a preferred operating voltage
US20040174763A1 (en) * 2003-03-04 2004-09-09 Schnepper Randy L. Memory subsystem voltage control and method
US20060129853A1 (en) * 2003-03-04 2006-06-15 Schnepper Randy L Memory subsystem voltage control and method
US20060129854A1 (en) * 2003-03-04 2006-06-15 Schnepper Randy L Memory subsystem voltage control and method
US7278038B2 (en) 2003-03-04 2007-10-02 Micron Technology, Inc. Operational voltage control circuit and method
US7127622B2 (en) 2003-03-04 2006-10-24 Micron Technology, Inc. Memory subsystem voltage control and method
US20040216011A1 (en) * 2003-04-28 2004-10-28 Kingston Technology Co. Extender Card with Intercepting EEPROM for Testing and Programming Un-Programmed Memory Modules on a PC Motherboard
US7117405B2 (en) 2003-04-28 2006-10-03 Kingston Technology Corp. Extender card with intercepting EEPROM for testing and programming un-programmed memory modules on a PC motherboard
US7206928B2 (en) * 2003-06-03 2007-04-17 Digi International Inc. System boot method
US20040250056A1 (en) * 2003-06-03 2004-12-09 Christopher Chang System boot method
US20050033910A1 (en) * 2003-06-30 2005-02-10 Michael Sommer Method for data transfer
US20050044302A1 (en) * 2003-08-06 2005-02-24 Pauley Robert S. Non-standard dual in-line memory modules with more than two ranks of memory per module and multiple serial-presence-detect devices to simulate multiple modules
US20050071580A1 (en) * 2003-09-30 2005-03-31 Intel Corporation Distributed memory initialization and test methods and apparatus
US7539909B2 (en) 2003-09-30 2009-05-26 Intel Corporation Distributed memory initialization and test methods and apparatus
US7234081B2 (en) * 2004-02-04 2007-06-19 Hewlett-Packard Development Company, L.P. Memory module with testing logic
US20050188281A1 (en) * 2004-02-04 2005-08-25 Vincent Nguyen Memory module with testing logic
US20080195835A1 (en) * 2004-05-18 2008-08-14 Infineon Technologies Ag Configurable embedded processor
US8270231B2 (en) * 2004-05-18 2012-09-18 Infineon Technologies Ag Configurable embedded processor
US7821849B2 (en) * 2004-05-18 2010-10-26 Infineon Technologies Ag Configurable embedded processor
US7392372B2 (en) * 2004-09-08 2008-06-24 Via Technologies, Inc. Method for memory initialization involves detecting primary quantity of memories and setting optimum parameters based on hardware information of memories
US20060053273A1 (en) * 2004-09-08 2006-03-09 Via Technologies Inc. Methods for memory initialization
US20080052462A1 (en) * 2006-08-24 2008-02-28 Blakely Robert J Buffered memory architecture
US7793043B2 (en) 2006-08-24 2010-09-07 Hewlett-Packard Development Company, L.P. Buffered memory architecture
US7596651B2 (en) * 2007-05-29 2009-09-29 International Business Machines Corporation Multi-character adapter card
US20080301345A1 (en) * 2007-05-29 2008-12-04 Blinick Stephen L Multi-character adapter card
US8347005B2 (en) * 2007-07-31 2013-01-01 Hewlett-Packard Development Company, L.P. Memory controller with multi-protocol interface
US20090037641A1 (en) * 2007-07-31 2009-02-05 Bresniker Kirk M Memory controller with multi-protocol interface
US7788421B1 (en) * 2008-01-24 2010-08-31 Google Inc. Detectable null memory for airflow baffling
US20090234998A1 (en) * 2008-03-12 2009-09-17 Hon Hai Precision Industry Co., Ltd. Connection system
US8117369B2 (en) * 2008-09-08 2012-02-14 Cisco Technology, Inc. Input-output module for operation in memory module socket and method for extending a memory interface for input-output operations
US20110099317A1 (en) * 2008-09-08 2011-04-28 Cisco Technology, Inc. Input-output module for operation in memory module socket and method for extending a memory interface for input-output operations
US7886103B2 (en) * 2008-09-08 2011-02-08 Cisco Technology, Inc. Input-output module, processing platform and method for extending a memory interface for input-output operations
US20100064099A1 (en) * 2008-09-08 2010-03-11 Satyanarayana Nishtala Input-output module, processing platform and method for extending a memory interface for input-output operations
US8116144B2 (en) 2008-10-15 2012-02-14 Hewlett-Packard Development Company, L.P. Memory module having a memory device configurable to different data pin configurations
US20100091542A1 (en) * 2008-10-15 2010-04-15 Shaw Mark E Memory Module Having a Memory Device Configurable to Different Data Pin Configurations
US20110289250A1 (en) * 2010-05-21 2011-11-24 Hon Hai Precision Industry Co., Ltd. Card adapter
US9286472B2 (en) 2012-05-22 2016-03-15 Xockets, Inc. Efficient packet handling, redirection, and inspection using offload processors
US9495308B2 (en) 2012-05-22 2016-11-15 Xockets, Inc. Offloading of computation for rack level servers and corresponding methods and systems
US9258276B2 (en) 2012-05-22 2016-02-09 Xockets, Inc. Efficient packet handling, redirection, and inspection using offload processors
US9665503B2 (en) 2012-05-22 2017-05-30 Xockets, Inc. Efficient packet handling, redirection, and inspection using offload processors
US9619406B2 (en) 2012-05-22 2017-04-11 Xockets, Inc. Offloading of computation for rack level servers and corresponding methods and systems
US9558351B2 (en) 2012-05-22 2017-01-31 Xockets, Inc. Processing structured and unstructured data using offload processors
US9348638B2 (en) 2013-01-17 2016-05-24 Xockets, Inc. Offload processor modules for connection to system memory, and corresponding methods and systems
US9436640B1 (en) 2013-01-17 2016-09-06 Xockets, Inc. Full bandwidth packet handling with server systems including offload processors
US9436639B1 (en) 2013-01-17 2016-09-06 Xockets, Inc. Full bandwidth packet handling with server systems including offload processors
US9436638B1 (en) 2013-01-17 2016-09-06 Xockets, Inc. Full bandwidth packet handling with server systems including offload processors
US9460031B1 (en) 2013-01-17 2016-10-04 Xockets, Inc. Full bandwidth packet handling with server systems including offload processors
US9378161B1 (en) 2013-01-17 2016-06-28 Xockets, Inc. Full bandwidth packet handling with server systems including offload processors
US9250954B2 (en) 2013-01-17 2016-02-02 Xockets, Inc. Offload processor modules for connection to system memory, and corresponding methods and systems
US9288101B1 (en) 2013-01-17 2016-03-15 Xockets, Inc. Full bandwidth packet handling with server systems including offload processors
US20150269024A1 (en) * 2014-03-21 2015-09-24 AMD Products (China) Co., Ltd. Independent ecc chip device, a motherboard, and a computer system
WO2016122461A1 (en) * 2015-01-27 2016-08-04 Hewlett Packard Enterprise Development Lp In-line memory module carrier for an m.2 form factor module
US20220317889A1 (en) * 2019-12-26 2022-10-06 Huawei Technologies Co., Ltd. Memory Setting Method and Apparatus

Similar Documents

Publication Publication Date Title
US6092146A (en) Dynamically configurable memory adapter using electronic presence detects
EP1194856B1 (en) A memory expansion module including multiple memory banks and a bank control circuit
KR100626223B1 (en) A memory expansion module with stacked memory packages
US5995405A (en) Memory module with flexible serial presence detect configuration
US6961281B2 (en) Single rank memory module for use in a two-rank memory module system
US6111775A (en) Method for accessing a memory array
US6457155B1 (en) Method for making a memory card adapter insertable into a motherboard memory card socket comprising a memory card receiving socket having the same configuration as the motherboard memory card socket
US6209074B1 (en) Address re-mapping for memory module using presence detect data
US5870325A (en) Memory system with multiple addressing and control busses
US7263019B2 (en) Serial presence detect functionality on memory component
KR920010974B1 (en) Self configuring memory system
US20050071600A1 (en) Memory module and memory support module
US6298426B1 (en) Controller configurable for use with multiple memory organizations
US6446184B2 (en) Address re-mapping for memory module using presence detect data
US20050044302A1 (en) Non-standard dual in-line memory modules with more than two ranks of memory per module and multiple serial-presence-detect devices to simulate multiple modules
US5504700A (en) Method and apparatus for high density sixteen and thirty-two megabyte single in-line memory module
KR960026780A (en) Synchronous Memory and Manufacturing Methods Packaged in Single / Dual In-Line Memory Modules
US7487413B2 (en) Memory module testing apparatus and method of testing memory modules
KR100245062B1 (en) High density simm or dimm with ras address re-mapping
US7545651B2 (en) Memory module with a predetermined arrangement of pins
US7167967B2 (en) Memory module and memory-assist module
KR20010038930A (en) Printed circuit board of a memory module
KR20050050343A (en) Memory module and memory-assist module
JP2004094785A (en) Memory module and auxiliary module for memory
JPH04278283A (en) Ram module and controller for the same module

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DELL, TIMOTHY J.;DRAMSTAD, KENT A.;FAUCHER, MARC R.;AND OTHERS;REEL/FRAME:008737/0210

Effective date: 19970725

FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

CC Certificate of correction
FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

FPAY Fee payment

Year of fee payment: 4

REMI Maintenance fee reminder mailed
LAPS Lapse for failure to pay maintenance fees
STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20080718