EP3657506B1 - Impedanzkompensation auf grundlage der detektion von sensordaten - Google Patents
Impedanzkompensation auf grundlage der detektion von sensordaten Download PDFInfo
- Publication number
- EP3657506B1 EP3657506B1 EP19211469.2A EP19211469A EP3657506B1 EP 3657506 B1 EP3657506 B1 EP 3657506B1 EP 19211469 A EP19211469 A EP 19211469A EP 3657506 B1 EP3657506 B1 EP 3657506B1
- Authority
- EP
- European Patent Office
- Prior art keywords
- memory
- memory device
- memory controller
- impedance
- impedance calibration
- 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.)
- Active
Links
- 230000015654 memory Effects 0.000 claims description 358
- 230000008859 change Effects 0.000 claims description 61
- 230000004044 response Effects 0.000 claims description 29
- 238000001514 detection method Methods 0.000 claims description 4
- 238000012544 monitoring process Methods 0.000 claims description 4
- 238000000034 method Methods 0.000 description 19
- 238000010586 diagram Methods 0.000 description 17
- 230000008569 process Effects 0.000 description 15
- 238000012545 processing Methods 0.000 description 15
- 238000004891 communication Methods 0.000 description 13
- 230000002093 peripheral effect Effects 0.000 description 12
- 230000006870 function Effects 0.000 description 10
- 230000007246 mechanism Effects 0.000 description 6
- 238000013459 approach Methods 0.000 description 5
- 230000001413 cellular effect Effects 0.000 description 5
- 238000005516 engineering process Methods 0.000 description 5
- 239000000872 buffer Substances 0.000 description 3
- 230000009977 dual effect Effects 0.000 description 3
- 238000004519 manufacturing process Methods 0.000 description 3
- 238000003032 molecular docking Methods 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 239000007787 solid Substances 0.000 description 3
- 230000002457 bidirectional effect Effects 0.000 description 2
- 238000012937 correction Methods 0.000 description 2
- 230000001419 dependent effect Effects 0.000 description 2
- 230000007613 environmental effect Effects 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 230000007774 longterm Effects 0.000 description 2
- 239000000758 substrate Substances 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 101100498818 Arabidopsis thaliana DDR4 gene Proteins 0.000 description 1
- 230000003044 adaptive effect Effects 0.000 description 1
- 239000000969 carrier Substances 0.000 description 1
- 230000005670 electromagnetic radiation Effects 0.000 description 1
- 238000001914 filtration Methods 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 238000010295 mobile communication Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 239000002070 nanowire Substances 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 230000000717 retained effect Effects 0.000 description 1
- 210000001525 retina Anatomy 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 230000001960 triggered effect Effects 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/3037—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a memory, e.g. virtual memory, cache
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3058—Monitoring arrangements for monitoring environmental properties or parameters of the computing system or of the computing system component, e.g. monitoring of power, currents, temperature, humidity, position, vibrations
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3089—Monitoring arrangements determined by the means or processing involved in sensing the monitored data, e.g. interfaces, connectors, sensors, probes, agents
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/42—Bus transfer protocol, e.g. handshake; Synchronisation
- G06F13/4204—Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus
- G06F13/4234—Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus being a memory bus
- G06F13/4243—Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus being a memory bus with synchronous protocol
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/02—Detection or location of defective auxiliary circuits, e.g. defective refresh counters
- G11C29/021—Detection or location of defective auxiliary circuits, e.g. defective refresh counters in voltage or current generators
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/02—Detection or location of defective auxiliary circuits, e.g. defective refresh counters
- G11C29/022—Detection or location of defective auxiliary circuits, e.g. defective refresh counters in I/O circuitry
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/02—Detection or location of defective auxiliary circuits, e.g. defective refresh counters
- G11C29/028—Detection or location of defective auxiliary circuits, e.g. defective refresh counters with adaption or trimming of parameters
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/04—Detection or location of defective memory elements, e.g. cell constructio details, timing of test signals
- G11C29/08—Functional testing, e.g. testing during refresh, power-on self testing [POST] or distributed testing
- G11C29/12—Built-in arrangements for testing, e.g. built-in self testing [BIST] or interconnection details
- G11C29/46—Test trigger logic
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/04—Detection or location of defective memory elements, e.g. cell constructio details, timing of test signals
- G11C29/50—Marginal testing, e.g. race, voltage or current testing
- G11C29/50008—Marginal testing, e.g. race, voltage or current testing of impedance
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/04—Arrangements for writing information into, or reading information out from, a digital store with means for avoiding disturbances due to temperature effects
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/10—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
- G11C7/1051—Data output circuits, e.g. read-out amplifiers, data output buffers, data output registers, data output level conversion circuits
- G11C7/1057—Data output buffers, e.g. comprising level conversion circuits, circuits for adapting load
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/10—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
- G11C7/1078—Data input circuits, e.g. write amplifiers, data input buffers, data input registers, data input level conversion circuits
- G11C7/1084—Data input buffers, e.g. comprising level conversion circuits, circuits for adapting load
Definitions
- Embodiments of the invention are generally related to inter-device I/O impedance compensation, and more particularly to managing impedance compensation based on detecting sensor data.
- Memory devices continue to scale to higher densities as the systems that use the memory increase in storage demands. Even as the amount of memory increases, there is an expectation that computing platforms such as servers, desktop or laptop computers, mobile devices, as well as consumer and business electronics will increase in performance. Increasing performance while also increasing memory size has resulted in increasing bandwidth scaling. The increased memory bandwidth scaling has required I/O (input/output) impedance compensation (ZQ comp) to be able to maintain adequate signal integrity. In previous generations of memory, different forms of resistance compensation or ZQ comp are primarily managed by the memory controller using modes in the memory devices (e.g., DRAM (dynamic random access memory)) to maintain a required tolerance. The modes refer to operating under different configuration settings.
- DRAM dynamic random access memory
- US 2006/158214 A1 describes an apparatus providing independent control of on-die termination (ODT) of output buffers.
- ODTs for the buffer circuits of an input/output (I/O) buffer can be enabled and disabled in response to an ODT control signal.
- US 2011/066798 A1 discusses an automatic calibration operation at a semiconductor device without issuing a calibration command from a controller. Because a calibration operation is performed in response to an auto refresh command having been issued for a predetermined number of times, a periodical calibration operation can be secured and a read operation or a write operation is not requested from a controller during a calibration operation.
- a memory subsystem utilizes sensor data from the memory device to manage memory I/O (input/output) impedance compensation.
- the memory controller and the memory device can monitor a need for impedance compensation instead of managing impedance compensation according to worst case scenarios.
- the memory controller can send a ZQ comp (impedance compensation) signal when the memory device is ready for an update instead of having the memory controller regularly send ZQ comp signals when changes are not needed.
- the ZQ comp signal can refer to all signals issued by the memory controller to cause an update to the impedance compensation by the memory device.
- the ZQ comp signal can include a ZQCal start signal (e.g., a signal to initiate impedance calibration) and/or a ZQCal latch signal (e.g., a signal to set the configuration for the impedance compensation).
- the memory device indicates when it is ready to perform an impedance compensation change.
- the memory controller can send a ZQ comp signal to the memory device in response to a compensation flag or other indication set by the memory device.
- the memory controller can send a ZQ comp signal in response to a determination that a sensor value recorded by the memory device has changed in excess of a threshold.
- the memory device can record sensor data that indicates when a change greater than a threshold has occurred in an operating condition.
- a flag indicating the change can trigger the memory controller to selectively send a ZQ comp signal in response to the flag.
- the memory controller can selectively issue ZQ comp signals to multiple memory devices to manage down time on the command/address (C/A) bus, and thus improve bandwidth utilization of the C/A bus.
- the memory controller issues only a ZQCal latch command in response to sensor data.
- the memory controller issues both a ZQCal start command and a ZQCal latch command in response to sensor data.
- the memory device generates a flag in response to detecting a change in temperature or thermal performance condition or operating condition, such as with a temperature sensor. In one embodiment, the memory device generates a flag in response to detecting a change in an operating voltage, such as with a voltage sensor. It will be understood that modern memory devices include multiple on-die sensors to detect changes in performance conditions. Traditionally such information is used to adjust operation of self-refresh or other operations. Thus, the memory device can monitor conditions that affect I/O impedance with sensors that are already present but traditionally used for other purposes.
- the memory device records sensor data in a Mode Register or other register on the memory device.
- a controller on the memory device itself determines when the sensor data has changed more than a threshold, and sets a flag in a Mode Register.
- the memory device provides the sensor data periodically to the memory controller, which can then determine whether a change exceeds a threshold, and indicates a need to perform impedance compensation.
- the memory controller periodically monitors or checks the Mode Register to determine if a flag has been set indicating the need for impedance compensation adjustment.
- a connector between the memory controller and memory device can be used as a flag for impedance compensation. The connector could be used for multiple condition flags, and determine what the flag indicates if set, by reading a register.
- the memory controller issues an impedance compensation signal to trigger a change in the memory device I/O settings.
- the impedance compensation signal can trigger the memory device to make an adjustment to driver impedance.
- the impedance compensation signal can trigger the memory device to make an adjustment to on-die termination settings.
- Memory devices generally refer to volatile memory technologies. Volatile memory is memory whose state (and therefore the data stored on it) is indeterminate if power is interrupted to the device. Nonvolatile memory refers to memory whose state is determinate even if power is interrupted to the device. Dynamic volatile memory requires refreshing the data stored in the device to maintain state.
- DRAM dynamic random access memory
- SDRAM synchronous DRAM
- a memory subsystem as described herein may be compatible with a number of memory technologies, such as DDR3 (dual data rate version 3, original release by JEDEC (Joint Electronic Device Engineering Council) on June 27, 2007, currently on release 21), DDR4 (DDR version 4, initial specification published in September 2012 by JEDEC), LPDDR3 (low power DDR version 3, JESD209-3B, Aug 2013 by JEDEC), LPDDR4 (LOW POWER DOUBLE DATA RATE (LPDDR) version 4, JESD209-4, originally published by JEDEC in August 2014), WIO2 (Wide I/O 2 (WideIO2), JESD229-2, originally published by JEDEC in August 2014), HBM (HIGH BANDWIDTH MEMORY DRAM, JESD235, originally published by JEDEC in October 2013), DDR5 (DDR version 5, currently in discussion by JEDEC), LPDDR5 (currently in discussion by JEDEC), WIO3 (Wide I/O 3, currently in discussion by JEDEC), HBM
- reference to memory devices can refer to a nonvolatile memory device whose state is determinate even if power is interrupted to the device.
- the nonvolatile memory device is a block addressable memory device, such as NAND or NOR technologies.
- a memory device can also include a future generation nonvolatile devices, such as a three dimensional crosspoint memory device, or other byte addressable nonvolatile memory devices.
- the memory device can be or include multi-threshold level NAND flash memory, NOR flash memory, single or multi-level Phase Change Memory (PCM), a resistive memory, nanowire memory, ferroelectric transistor random access memory (FeTRAM), magnetoresistive random access memory (MRAM) memory that incorporates memristor technology, or spin transfer torque (STT)-MRAM, or a combination of any of the above, or other memory.
- PCM Phase Change Memory
- FeTRAM ferroelectric transistor random access memory
- MRAM magnetoresistive random access memory
- STT spin transfer torque
- FIG. 1 is a block diagram of an embodiment of a system in which impedance compensation is based on memory device sensor data.
- System 100 represents components of a memory subsystem having a memory controller 110 that manages impedance compensation of memory devices 120 in accordance with any embodiment described herein.
- System 100 can be included in any type of computing device or electronic circuit that performs I/O impedance compensation, and is not necessarily limited to memory subsystems, although the memory subsystem is the example used throughout.
- System 100 receives memory access requests from a host or a processor, which is processing logic that executes operations based on data stored in memory 120 or generates data to store in memory 120.
- a processor can be or include host processor, central processing unit (CPU), microcontroller or microprocessor, graphics processor, peripheral processor, application specific processor, or other processor, whether single core or multicore processor.
- Memory controller 110 represents logic to interface with memory 120 and manage access to data stored in the memory.
- memory controller 110 is integrated into the hardware of the host processor.
- memory controller 110 is standalone hardware, separate from the host processor.
- Memory controller 110 can be a separate circuit on a substrate that includes the processor.
- Memory controller 110 can be a separate die or chip integrated on a common substrate with a processor die (e.g., as a system on a chip (SoC)).
- SoC system on a chip
- at least some of memory 120 can be included on a SoC with memory controller 110 and/or a host processor.
- memory 120 includes volatile memory resources.
- memory 120 includes DRAMs.
- the memory resources of memory 120 can be managed, for example, as different levels of memory with separate channels, DIMMs (dual inline memory modules), ranks, DRAMs, banks, pages, rows, cachelines, and/or other architecture. Each separate memory level and resource can be individually addressable.
- system 100 includes multiple memory 120[0] ... 120[N-1], where N is an integer (typically a binary integer, or in groups of 2 N +1).
- Memory 120 includes I/O 122, which includes hardware resources to interconnect with corresponding I/O 112 of memory controller 110.
- I/O 112, 122 can include drivers, ODT (on die termination), pins, connectors, traces, pads, wires, and/or other hardware.
- I/O 122 and 112 are typically organized in one or more buses of signal lines, such as a command/address (C/A) bus for memory controller 110 to send access commands and address information, and a data bus to allow memory controller 110 and memory 120 to exchange data. The data is read from the different memory resources with a Read command or written to the memory resources with a Write command.
- C/A command/address
- I/O 112 and I/O 122 can include data interfaces of different sizes, such as x4, x8, or x16 interfaces, where the 'x' represents the interface and the numeral after the 'x' represents the data bit width of the interface (e.g., x4 has a 4-bit wide interface, and so forth).
- each memory 120 includes at least one sensor 124.
- Sensor 124 can include a thermal sensor, a current sensor, a voltage sensor, or other device to monitor an operating condition of the memory. It will be understood that different I/O impedance is useful for different operating conditions.
- memory 120 reports a change in an operating condition detected by sensor 124 to memory controller 110.
- memory controller 110 can adjust one or more settings related to ZQ comp 128, which represents hardware mechanisms that configure the I/O impedance (whether input or output) of memory 120.
- memory 120 can set flag 126 if memory 120 determines from a reading of sensor 124 that an operating condition has changed by more than a threshold, memory 120 can set flag 126.
- each memory 120 can separately indicate its operating condition to memory controller 110.
- memory controller 110 separately manages the ZQ comp 128 of each individual memory 120.
- each memory 120 may include two separate channels on the same memory die. In such an implementation, ZQ comp 128 can be applied to both channels of a single die, assuming that the proximity of each channel on the same die would experience the same operating conditions.
- Memory controller 110 includes scheduler 130, which represents logic within memory controller 110 to manage the timing of access operations and commands with respect to memory 120.
- Scheduler 130 can generate and determine how to order commands to service requests for data generated by a host processor.
- scheduler 130 includes impedance compensation scheduler 132.
- scheduler 132 is part of the logic of scheduler 130. Scheduler 132 is illustrated specifically with reference to the ability of memory controller 110 to manage operations related to adjusting settings of ZQ comp 128 in the various memories 120.
- each memory 120 is a DRAM having sensor 124 which includes a thermal sensor, and flag 126 is a bit in a Mode Register of the DRAM.
- the DRAM utilizes its existing on-die thermal sensor to notify memory controller 110 when an adjustment to a ZQ comp setting is required.
- memory controller 110 monitors the Mode Register bit represented by 126 (e.g., reading the bit periodically to determine its state).
- Each DRAM 120 can set flag 126 based on a difference in the temperature from the last notification.
- the DRAM sets flag 126 it can store the value as a baseline for a subsequent flag to indicate a need to adjust ZQ comp 128.
- a change in the sensor reading can be either a positive or a negative change.
- sensor 124 internally controls the comparison, and sets flag 126 to trigger memory controller 110 to issue a ZQ calibration latch command (e.g., ZQCal latch).
- memory 120 can store the previous and current readings (values) of sensor 124 and trigger memory controller 110 to read and compare the values. With flag 126 or other indication from memory 120, the host or memory controller 110 would not need to manage timing associated with periodically issuing a ZQCal latch command. Thus, memory 120 can trigger memory controller 110 to issue the command when it needs the command issued, and memory controller 110 would not need to manage the timing or use up C/A bus bandwidth sending commands that will be ignored by memory 120 (ignored because no ZQ comp change or update is necessary).
- memory controller 110 is traditionally required to manage the timing of issuing a ZQ comp signal to all memories 120. Such a process traditionally takes time over a millisecond (ms) or more, even though the timing for each individual device is traditionally on the order of 1 microsecond (us). By allowing memory controller 110 to issue ZQ comp signals in response to sensor data on each memory device, memory controller 110 can save considerable bandwidth.
- ZQ comp scheduler 132 can include logic to determine preferred timing to issue ZQ comp signals. For example, in one embodiment, scheduler 132 waits until a threshold number of memories 120 (e.g., some number more than one) have set flag 126 prior to generating any ZQ comp signals. Thus, when scheduler 132 disables access traffic commands on the C/A bus to schedule ZQ comp signal(s), it can issue signals for multiple devices and spread the overhead over multiple devices. In one embodiment, scheduler 132 includes logic to wait until a threshold number of memories 120 trigger flag 126, unless a threshold period of time has passed since the first flag was detected, and then issue the ZQ comp signals anyway.
- a threshold number of memories 120 e.g., some number more than one
- scheduler 132 includes logic to wait until a threshold number of memories 120 trigger flag 126, unless a threshold period of time has passed since the first flag was detected, and then issue the ZQ comp signals anyway.
- memory controller sends a sequence of ZQ comp signals to multiple parallel memories 120 in response to one or more flags 126 being set.
- memory controller 110 sends a series of commands for impedance compensation to a subset or all memories 120 in response detecting a first flag 126 by one of the memories.
- memory controller 110 can avoid sending ZQ comp signals that are not needed. Instead of having memory controller 110 incur overhead in preemptively having both memory controller 110 and memories 120 performing ZQ comp operations when not required, system 100 can respond to the need for such operations. Such operation can provide multiple paths to improve system performance by allowing adjustments on how the impedance compensation can be managed.
- each memory 120 can know (e.g., be configured with values to indicate) when the thresholds can be set to optimize for them to meet a tolerance improving the speed of the system.
- Such configuration can result in better tolerances for I/O due to each memory vendor controlling the timing of impedance compensation to their specific process and/or memory implementation, rather than relying on generic system-wide worst case tolerances being used.
- memory controller 110 reads sensor data from each memory 120.
- reading the sensor data can be understood as reading flag 126 and/or reading the values of sensor 124.
- Scheduler 132 can determine that a performance condition has changed in excess of a threshold by either reading flag 126 or by reading the sensor data and comparing it against a previously stored reading.
- Memory controller 110 can store the previous reading and/or memory 120 can store the previous reading.
- Memory controller 110 generates an impedance compensation signal to trigger memory 120 to adjust at least one setting related to ZQ comp 128.
- FIG. 2 is a block diagram of an embodiment of a memory subsystem in which memory device sensor data can be used for impedance compensation in addition to refresh control settings.
- System 200 can be one example of a memory subsystem in accordance with system 100 of Figure 1 . System 200 more specifically illustrates certain features that can be implemented by one embodiment of system 100.
- Memory controller 210 manages access to memory 220. Memory 220 can be one of multiple memory devices in system 200. Memory controller 210 includes I/O 212 to interface with memory 220 via I/O 230 of memory 220.
- memory controller 210 includes refresh control 214.
- Refresh control 214 represents logic within memory controller 210 to manage the refresh of volatile memory 220.
- Refresh control 214 can include logic for managing self-refresh settings for memory 220 and/or for normal refresh where memory controller issues the refresh commands.
- refresh control 214 adjusts its operation based on information from sensors in memory 220.
- memory controller 210 includes ZQ compensation control 216.
- ZQ comp control 216 represents logic to manage impedance compensation for the I/O interface of memory 220 (I/O 230).
- ZQ comp control 216 can perform compensation control in accordance with any embodiment described herein.
- ZQ comp control 216 can be or include a scheduler to manage the timing of compensation control in system 200.
- ZQ comp control 216 determines when to send an impedance compensation signal to memory 220 and other memory devices based on sensor data indicating that the sensor has detected a change in an operating condition.
- memory 220 will flag the change, but memory controller 210 will still determine when to issue a signal to trigger the memory device to adjust its I/O compensation. It will be understood that even though memory controller 210 makes a determination of when to send a compensation signal, the memory controller generates the signal in response to detecting or determining the flag or indication by the memory.
- Memory 220 includes array 242, which represents the memory resources of memory 220.
- the memory resources can include multiple rows of data, addressable by row and column.
- Logic 244 represents decode logic within memory 220 to address a location within array 242 identified by a memory access command, such as a read or write.
- Controller 222 represents a controller of memory 220. It will be understood that memory controller 210 is a controller for system 200 and controls access to memory 220 for the host. Controller 222 represents processing resources within memory 220 to enable the memory to manage and schedule its own operations to service the memory access commands received from memory controller 210.
- memory 220 includes one or more sensors 226.
- Sensor 226 can include a voltage sensor, temperature sensor, current sensor, or other sensor that can detect a change in a performance condition that affects the impedance of I/O 230. It will be understood that many modern memories include sensors on-die. The sensors have traditionally been used to detect conditions related to overage conditions. Certain changes in the conditions detected by sensor 226 can also indicate a condition that affects the input and output impedance of I/O 230.
- controller 222 determines based on readings from sensor 226 that a condition has changed in excess of a threshold. It will be understood that the threshold will be set based on system architecture, memory type, I/O type, memory size, and other factors. The threshold determines when a performance condition changes sufficiently to have an undesired impact on the I/O impedance of I/O 230. A change in I/O impedance an affect margining and/or timing of transmit and receive.
- I/O 230 includes driver 232 to drive the I/O signal lines for memory 220 to send data to memory controller 210.
- I/O 230 includes ODT (on-die termination) 234 to control the input impedance for memory 220 to receive data from memory controller 210.
- Driver 232 and ODT 234 are configurable by settings with memory 220, and can collective be referred to as I/O settings. The settings of driver 232 and ODT 234 can affect timing, reflections, and other aspects of signal integrity on exchanges (either transmit or receive) between memory controller 210 and memory 220.
- register 224 represents a register that includes I/O settings for I/O 230.
- memory 220 includes two channels on a single memory die, and the I/O settings are shared across channels.
- the I/O settings apply to different I/O for memory 220.
- driver 232 can apply to bidirectional signal lines (such as a data bus), but will not apply to a unidirectional bus (such as a command/address bus).
- ODT 234 can apply to both unidirectional and bidirectional signal lines.
- ODT includes both pull up and pull down legs, and combinations of pull up and pull down can be configured, as is understood in the art.
- the I/O settings can determine how hard (e.g., how much current to use) driver 232 is to drive the signal lines, and how ODT is to be configured to terminate the signal lines.
- a ZQCal signal or other compensation signal from memory controller 210 can initiate the adjustment to I/O settings within memory 220.
- register 224 represents or includes a Mode Register for memory 220.
- a Mode Register is a register within memory 220 that controls various operating settings for memory 220. The different settings can correspond with different modes of operation.
- memory controller 210 simply sets a specific bit pattern to register elements of the Mode Register to place memory 220 in a specific mode. Depending on what mode memory 220 is in, controller 222 can apply certain settings to I/O 230 and/or other components of memory 220 and/or apply specific timing parameters to its operations.
- memory 220 sets a flag in register 224 (which can be a Mode Register or other register accessible by memory controller 210) in response to detecting a change in sensor 226.
- controller 222 can store (in a register or memory location used by controller 222 for its operation) one or more values of readings from sensor 226.
- Memory 220 can detect a change in a new sensor reading as compared to a previous or stored reading.
- register 224 represents storage where one or more sensor values can be stored.
- memory controller 210 periodically reads the value or flag set by memory 220 in register 224 to determine whether the memory is ready for an adjustment to its I/O impedance settings.
- System 200 could alternatively be configured with an interrupt-based mechanism. However, an interrupt mechanism may require a dedicated signal line or multiplexed/repurposed signal line to convey the interrupt from memory 220 to memory controller 210.
- FIG. 3 is an embodiment of a timing diagram of a command/address timing for adaptable impedance compensation.
- C/A signal 310 represents a traditional approach to impedance compensation, which is based on worst case system conditions. With a worst case approach, C/A 310 illustrates a repeated schedule wherein the memory controller initiates impedance compensation (referred to as ZQ comp for purposes of Figure 3 ) with a ZQCal start signal. The timing between initiating the ZQCal and issuing a ZQ comp latch signal (ZQCal latch) is tZQCal, which is scheduled to be 1 microsecond (us) minimum.
- the memory controller traditionally must initiate a ZQ calibration to trigger the memory to prepare for the ZQ comp, and then issue a latch signal to cause the memory to latch the ZQ comp.
- the time for the memory device to latch the ZQ comp is tZQLat, which is approximately 30 nanoseconds (ns).
- the memory controller will hold the C/A bus idle (stop the bus) during the adjustment, and thus, C/A 310 will experience the overhead of tZQCal + tZQLat for each calibration performed, for every memory device.
- the memory controller must traditionally repeat the schedule on C/A 310 for each memory device, regardless of whether the memory needs to adjust its ZQ comp settings.
- the idle time of the C/A bus, and consequently the loss in active bandwidth could extend into milliseconds of idle time per second.
- the memory controller can hide the tZQCal latency in the background by continuing to issue other commands. However, the timing must still be monitored and scheduled for each device over a regular schedule regardless of whether the memory device needs to be updated or not, which can unnecessarily tie up memory controller resources.
- C/A 320 illustrates a flag check mechanism to issuing ZQ comp in accordance with any embodiment described herein.
- the issuing of ZQ comp in accordance with C/A 320 can significantly reduce the overhead associated with ZQ comp. Instead of needing to periodically issue the ZQ comp commands and schedule ZQCal latch after the 1 us period, the memory controller only issues ZQ comp commands as needed.
- C/A 320 starts off illustrating a period of time where no change to the impedance settings are needed because there is no detected change to performance conditions, or because the changes to performance conditions do not exceed a threshold that indicates the need to adjust compensation.
- the memory controller checks a flag that the memory will set if the sensors indicate a change in a performance condition in excess of a threshold. Such a determination can be made in accordance with any embodiment described herein.
- the memory controller will continue operation without issuing a ZQ comp command. Assuming that the flag check in C/A 320 does indicate a need to perform ZQ comp (the condition shown in Figure 3 ), the memory controller issues a ZQCal latch signal. It will be understood that the time tZQChk (time between checking the flag and issuing a latch signal) is adaptable in at least two ways. tZQChk is adaptable because it is expected that the memory controller will not always issue a ZQCal latch signal directly after performing a check, because at least some of the time the flag will not be set.
- tZQChk is also adaptable in that, in one embodiment, even when the flag is set, the memory controller can control when to issue the ZQCal latch signal for at least a period of time. For example, the memory controller can wait until a certain number of memory devices set a flag before issuing ZQCal latch. It will be understood that after issuing ZQCal latch on C/A 320, the same period of time, tZQLat of approximately 30 ns occurs. The memory controller will repeat the checking and issuing of ZQCal latch only as needed in C/A 320.
- the time to check the flag and determine to issue ZQCal latch is comparable to the time tZQLat.
- the timing from the flag check to ZQCal latch can be on the order of tens of nanoseconds, which is significantly lower than the 1 us that the memory controller must traditionally manage.
- multiple devices can be ready for a ZQ comp adjustment, and can all be latched in sequence, which reduces significant overhead from not needing to initiate ZQ comp in multiple memory devices that do not need to update their impedance compensation.
- Such an approach can maximize the scheduling of ZQ comp signals on C/A 320.
- a memory device includes sensors that it monitors for purposes of setting the timing configuration of refresh state (e.g., timing of scheduling by the memory device itself for self-refresh and/or the timing of scheduling by the memory controller for auto refresh).
- the memory controller periodically checks the sensor data for purposes of configuring refresh timing.
- the memory controller can additionally perform impedance compensation checking based on the same sensor data checked for refresh. In such an implementation, a readout or checking of a ZQ comp flag can occur during a refresh readout or refresh monitoring operation. Therefore, checking the ZQ comp flag can be implemented with very minimal overhead.
- FIG. 4 is a flow diagram of an embodiment of a process for performing impedance compensation based on memory device sensor data.
- System 400 for performing impedance compensation can be performed by a system in accordance with any embodiment described herein, such as system 100 of Figure 1 and/or system 200 of Figure 2 .
- the impedance compensation operations include parallel operations at the memory controller and the memory device.
- the memory controller monitors a flag to be set by the memory, and determines if the flag indicates the memory is read for an impedance compensation adjustment, 402. If the flag does not indicate the need to change compensation, 404 NO branch, the memory controller continues to monitor the flag without issuing an impedance compensation command.
- the memory monitors one or more sensors to determine whether to set the flag, 412.
- the sensor(s) monitor one or more performance conditions that affect I/O impedance of the memory. Based on values read from the sensor(s), in one embodiment, the memory determines if a change in a performance condition exceeds a threshold, 414. In one embodiment, the memory controller reads the values and makes the determination. If the change in condition is not greater than some threshold X, 416 NO branch, the memory continues to monitor the sensor, 412. It will be understood that the change in performance condition could be positive or negative. Thus, X could represent either the positive or negative number, or the condition in 416 could be whether the absolute value of the change exceeds X.
- the memory updates a compensation flag or other indication, 418.
- the flag indicates that the memory is ready to perform impedance compensation.
- the memory stores the condition value for use to compare against subsequent readings from the sensor, 420.
- the memory controller will detect the flag when it next evaluates the flag. If the flag is set, 404 YES branch, in one embodiment, the memory controller determines whether to issue an impedance compensation command, 422. In one embodiment, the memory controller will wait until multiple memory devices are ready for compensation prior to issuing a command. In one embodiment, the memory controller will delay issuing a command until after issuing a time-sensitive memory access command.
- the memory controller determines not to update the impedance compensation of the memory, 424 NO branch, there might be any of a number of operations the memory controller may perform prior to issuing the command. Eventually the memory controller will update the impedance compensation. If the memory controller is to update the impedance compensation, 424 YES branch, the memory controller can reset the flag, 426. In one embodiment, the memory controller can directly write the value of the flag. In one embodiment, the memory controller issues a signal that causes the memory to reset the flag.
- the memory controller generates one or more impedance compensation signals or commands to issue to one or more memories, 428.
- the memory controller sends the signals or issues the commands to the memory, 430.
- the memory receives the ZQ comp signal and decodes the signal, 432.
- the memory determines what update to make, 434.
- the ZQ comp signal indicates what change to make.
- the memory determines what change to make in association with detecting the condition indicated by the sensor and setting the flag.
- the memory can update different aspects of the I/O impedance.
- the memory updates a setting related to ODT, 436 ODT branch.
- the memory can set a new setting for one or more aspects of ODT, such as read impedance and/or write impedance, 438.
- the memory updates a setting related to the output driver, 436 DRIVER branch.
- the memory can set a new setting for the output driver, 440.
- FIG. 5 is a flow diagram of an embodiment of a process for applying memory device sensor data for self-refresh control and impedance compensation.
- Process 500 illustrates an embodiment of how a memory can apply sensor data. Whereas process 400 of Figure 4 illustrates a process in which the memory device itself makes a determination to set a flag based on a reading of its sensor(s), process 500 illustrates a process in which the memory controller can compute the determination.
- the memory includes one or more sensors, which is monitors for a change, 502. In one embodiment, the memory periodically acquires and records the sensor reading. In one embodiment, the memory records the sensor data in a register accessible to the memory controller, 504.
- the memory controller determines if it is time to read the register for the sensor data, 506. If it is time for the memory controller to read the register, 508 YES branch, the memory provides the register data, 510. In one embodiment, the memory controller uses the register data with the sensor readings to determine what settings to apply to the memory for purposes of refresh and/or self-refresh. Thus, the memory controller can set one or more refresh settings based on the sensor data, 512. In one embodiment, the memory controller applies the sensor data also to determine whether to issue a ZQ compensation command to the memory. In one embodiment, such an operation may require the memory controller to manage the traditional 1 us timing of tZQCal, but will only need to manage such timing when a change in compensation is required.
- the memory controller can still preserve bandwidth on the C/A bus by such an approach to ZQ comp.
- the memory controller can determine if the sensor data indicates a need for impedance compensation in the memory, 514.
- the determination and issuance of the impedance compensation can be performed in accordance with process 400 starting at 424. The difference would be that the memory controller may need to issue both a ZQCal initiate (or start) command as well as a latch as the ZQ comp signal or command.
- FIG. 6 is a block diagram of an embodiment of a computing system in which impedance compensation based on memory device sensor data can be implemented.
- System 600 represents a computing device in accordance with any embodiment described herein, and can be a laptop computer, a desktop computer, a server, a gaming or entertainment control system, a scanner, copier, printer, routing or switching device, or other electronic device.
- System 600 includes processor 620, which provides processing, operation management, and execution of instructions for system 600.
- Processor 620 can include any type of microprocessor, central processing unit (CPU), processing core, or other processing hardware to provide processing for system 600.
- Processor 620 controls the overall operation of system 600, and can be or include, one or more programmable general-purpose or special-purpose microprocessors, digital signal processors (DSPs), programmable controllers, application specific integrated circuits (ASICs), programmable logic devices (PLDs), or the like, or a combination of such devices.
- DSPs digital signal processors
- ASICs application specific integrated circuits
- PLDs programmable logic devices
- Memory subsystem 630 represents the main memory of system 600, and provides temporary storage for code to be executed by processor 620, or data values to be used in executing a routine.
- Memory subsystem 630 can include one or more memory devices such as read-only memory (ROM), flash memory, one or more varieties of random access memory (RAM), or other memory devices, or a combination of such devices.
- Memory subsystem 630 stores and hosts, among other things, operating system (OS) 636 to provide a software platform for execution of instructions in system 600. Additionally, other instructions 638 are stored and executed from memory subsystem 630 to provide the logic and the processing of system 600. OS 636 and instructions 638 are executed by processor 620.
- Memory subsystem 630 includes memory device 632 where it stores data, instructions, programs, or other items.
- memory subsystem includes memory controller 634, which is a memory controller to generate and issue commands to memory device 632. It will be understood that memory controller 634 could be a physical part of processor 620.
- Bus 610 is an abstraction that represents any one or more separate physical buses, communication lines/interfaces, and/or point-to-point connections, connected by appropriate bridges, adapters, and/or controllers. Therefore, bus 610 can include, for example, one or more of a system bus, a Peripheral Component Interconnect (PCI) bus, a HyperTransport or industry standard architecture (ISA) bus, a small computer system interface (SCSI) bus, a universal serial bus (USB), or an Institute of Electrical and Electronics Engineers (IEEE) standard 1394 bus (commonly referred to as "Firewire").
- PCI Peripheral Component Interconnect
- ISA HyperTransport or industry standard architecture
- SCSI small computer system interface
- USB universal serial bus
- IEEE Institute of Electrical and Electronics Engineers
- the buses of bus 610 can also correspond to interfaces in network interface 650.
- System 600 also includes one or more input/output (I/O) interface (s) 640, network interface 650, one or more internal mass storage device (s) 660, and peripheral interface 670 coupled to bus 610.
- I/O interface 640 can include one or more interface components through which a user interacts with system 600 (e.g., video, audio, and/or alphanumeric interfacing).
- Network interface 650 provides system 600 the ability to communicate with remote devices (e.g., servers, other computing devices) over one or more networks.
- Network interface 650 can include an Ethernet adapter, wireless interconnection components, USB (universal serial bus), or other wired or wireless standards-based or proprietary interfaces.
- Storage 660 can be or include any conventional medium for storing large amounts of data in a nonvolatile manner, such as one or more magnetic, solid state, or optical based disks, or a combination.
- Storage 660 holds code or instructions and data 662 in a persistent state (i.e., the value is retained despite interruption of power to system 600).
- Storage 660 can be generically considered to be a "memory," although memory 630 is the executing or operating memory to provide instructions to processor 620. Whereas storage 660 is nonvolatile, memory 630 can include volatile memory (i.e., the value or state of the data is indeterminate if power is interrupted to system 600).
- Peripheral interface 670 can include any hardware interface not specifically mentioned above. Peripherals refer generally to devices that connect dependently to system 600. A dependent connection is one where system 600 provides the software and/or hardware platform on which operation executes, and with which a user interacts.
- system 600 is a server device.
- system 600 in one embodiment in a server device, system 600 can be one of multiple systems combined together in a server configuration.
- the server can be implemented as a blade server combined with other blade servers in a chassis system.
- memory subsystem 630 includes ZQ comp control 680, which represents logic within system 600 to implement I/O impedance control for memory 632 based on sensor data.
- ZQ comp control 680 is shown as a separate element in system 600, but represents logic in memory controller 634 and memory 632 to implement ZQ comp in accordance with any embodiment described herein.
- memory 632 determines when it needs ZQ comp and sets a flag to trigger memory controller 634 to issue a ZQ comp command.
- FIG. 7 is a block diagram of an embodiment of a mobile device in which impedance compensation based on memory device sensor data can be implemented.
- Device 700 represents a mobile computing device, such as a computing tablet, a mobile phone or smartphone, a wireless-enabled e-reader, wearable computing device, or other mobile device. It will be understood that certain of the components are shown generally, and not all components of such a device are shown in device 700.
- Device 700 includes processor 710, which performs the primary processing operations of device 700.
- Processor 710 can include one or more physical devices, such as microprocessors, application processors, microcontrollers, programmable logic devices, or other processing means.
- the processing operations performed by processor 710 include the execution of an operating platform or operating system on which applications and/or device functions are executed.
- the processing operations include operations related to I/O (input/output) with a human user or with other devices, operations related to power management, and/or operations related to connecting device 700 to another device.
- the processing operations can also include operations related to audio I/O and/or display I/O.
- device 700 includes audio subsystem 720, which represents hardware (e.g., audio hardware and audio circuits) and software (e.g., drivers, codecs) components associated with providing audio functions to the computing device. Audio functions can include speaker and/or headphone output, as well as microphone input. Devices for such functions can be integrated into device 700, or connected to device 700. In one embodiment, a user interacts with device 700 by providing audio commands that are received and processed by processor 710.
- audio subsystem 720 represents hardware (e.g., audio hardware and audio circuits) and software (e.g., drivers, codecs) components associated with providing audio functions to the computing device. Audio functions can include speaker and/or headphone output, as well as microphone input. Devices for such functions can be integrated into device 700, or connected to device 700. In one embodiment, a user interacts with device 700 by providing audio commands that are received and processed by processor 710.
- Display subsystem 730 represents hardware (e.g., display devices) and software (e.g., drivers) components that provide a visual and/or tactile display for a user to interact with the computing device.
- Display subsystem 730 includes display interface 732, which includes the particular screen or hardware device used to provide a display to a user.
- display interface 732 includes logic separate from processor 710 to perform at least some processing related to the display.
- display subsystem 730 includes a touchscreen device that provides both output and input to a user.
- display subsystem 730 includes a high definition (HD) display that provides an output to a user.
- High definition can refer to a display having a pixel density of approximately 100 PPI (pixels per inch) or greater, and can include formats such as full HD (e.g., 1080p), retina displays, 4K (ultra high definition or UHD), or others.
- I/O controller 740 represents hardware devices and software components related to interaction with a user. I/O controller 740 can operate to manage hardware that is part of audio subsystem 720 and/or display subsystem 730. Additionally, I/O controller 740 illustrates a connection point for additional devices that connect to device 700 through which a user might interact with the system. For example, devices that can be attached to device 700 might include microphone devices, speaker or stereo systems, video systems or other display device, keyboard or keypad devices, or other I/O devices for use with specific applications such as card readers or other devices.
- I/O controller 740 can interact with audio subsystem 720 and/or display subsystem 730.
- input through a microphone or other audio device can provide input or commands for one or more applications or functions of device 700.
- audio output can be provided instead of or in addition to display output.
- display subsystem includes a touchscreen
- the display device also acts as an input device, which can be at least partially managed by I/O controller 740.
- I/O controller 740 manages devices such as accelerometers, cameras, light sensors or other environmental sensors, gyroscopes, global positioning system (GPS), or other hardware that can be included in device 700.
- the input can be part of direct user interaction, as well as providing environmental input to the system to influence its operations (such as filtering for noise, adjusting displays for brightness detection, applying a flash for a camera, or other features).
- device 700 includes power management 750 that manages battery power usage, charging of the battery, and features related to power saving operation.
- Memory subsystem 760 includes memory device (s) 762 for storing information in device 700.
- Memory subsystem 760 can include nonvolatile (state does not change if power to the memory device is interrupted) and/or volatile (state is indeterminate if power to the memory device is interrupted) memory devices.
- Memory 760 can store application data, user data, music, photos, documents, or other data, as well as system data (whether long-term or temporary) related to the execution of the applications and functions of system 700.
- memory subsystem 760 includes memory controller 764 (which could also be considered part of the control of system 700, and could potentially be considered part of processor 710).
- Memory controller 764 includes a scheduler to generate and issue commands to memory device 762.
- Connectivity 770 includes hardware devices (e.g., wireless and/or wired connectors and communication hardware) and software components (e.g., drivers, protocol stacks) to enable device 700 to communicate with external devices.
- the external device could be separate devices, such as other computing devices, wireless access points or base stations, as well as peripherals such as headsets, printers, or other devices.
- Connectivity 770 can include multiple different types of connectivity.
- device 700 is illustrated with cellular connectivity 772 and wireless connectivity 774.
- Cellular connectivity 772 refers generally to cellular network connectivity provided by wireless carriers, such as provided via GSM (global system for mobile communications) or variations or derivatives, CDMA (code division multiple access) or variations or derivatives, TDM (time division multiplexing) or variations or derivatives, LTE (long term evolution - also referred to as "4G”), or other cellular service standards.
- Wireless connectivity 774 refers to wireless connectivity that is not cellular, and can include personal area networks (such as Bluetooth), local area networks (such as WiFi), and/or wide area networks (such as WiMax), or other wireless communication.
- Wireless communication refers to transfer of data through the use of modulated electromagnetic radiation through a non-solid medium. Wired communication occurs through a solid communication medium.
- Peripheral connections 780 include hardware interfaces and connectors, as well as software components (e.g., drivers, protocol stacks) to make peripheral connections. It will be understood that device 700 could both be a peripheral device ("to” 782) to other computing devices, as well as have peripheral devices ("from” 784) connected to it. Device 700 commonly has a "docking" connector to connect to other computing devices for purposes such as managing (e.g., downloading and/or uploading, changing, synchronizing) content on device 700. Additionally, a docking connector can allow device 700 to connect to certain peripherals that allow device 700 to control content output, for example, to audiovisual or other systems.
- software components e.g., drivers, protocol stacks
- device 700 can make peripheral connections 780 via common or standards-based connectors.
- Common types can include a Universal Serial Bus (USB) connector (which can include any of a number of different hardware interfaces), DisplayPort including MiniDisplayPort (MDP), High Definition Multimedia Interface (HDMI), Firewire, or other type.
- USB Universal Serial Bus
- MDP MiniDisplayPort
- HDMI High Definition Multimedia Interface
- Firewire or other type.
- memory subsystem 760 includes ECC 766.
- ECC 766 is shown as a separate element, but represents internal ECC in memory devices 762 and system level ECC in memory controller 764.
- the internal ECC generates internal check bits after performing error detection and correction in response to a read request.
- the external ECC of memory controller 764 can use the check bits as metadata to augment error correction at the system level.
- memory subsystem 760 includes ZQ comp control 766, which represents logic within system 700 to implement I/O impedance control for memory 762 based on sensor data.
- ZQ comp control 766 is shown as a separate element in system 700, but represents logic in memory controller 764 and memory 762 to implement ZQ comp in accordance with any embodiment described herein.
- memory 762 determines when it needs ZQ comp and sets a flag to trigger memory controller 764 to issue a ZQ comp command.
- a method for impedance compensation of an I/O (input/output) interface includes: detecting, via logic on a memory device, a change in a performance condition affecting I/O impedance for the memory device; triggering a compensation flag signal to an associated memory controller in response to detecting the change; and receiving at the memory device from the memory controller, in response to the compensation flag signal, an impedance compensation signal triggering a change in I/O impedance compensation in the memory device.
- detecting the change in performance condition comprises detecting a change in operating temperature that exceeds a threshold. In one embodiment, detecting the change in performance condition comprises detecting a change in operating voltage that exceeds a threshold. In one embodiment, detecting the change in performance condition comprises detecting the change with on-die sensors. In one embodiment, triggering the compensation flag signal comprises setting a value in a Mode Register of the memory device to be checked periodically by the memory controller. In one embodiment, the impedance compensation signal triggering the change in I/O impedance compensation comprises triggering an adjustment to a driver impedance. In one embodiment, the impedance compensation signal triggering the change in I/O impedance compensation comprises triggering an adjustment to an on-die termination value.
- the memory device is one of multiple memory devices coupled in parallel to the memory controller, and wherein receiving the impedance compensation signal in response to the compensation flag signal comprises receiving the impedance compensation signal from the memory controller only after the memory controller has received a compensation flag from a threshold number of the multiple memory devices.
- the memory device is one of multiple memory devices coupled in parallel to the memory controller, and wherein receiving the impedance compensation signal triggering the change in I/O impedance compensation further comprises receiving one of a continuous sequence of impedance compensation signals sent in sequence by the memory controller.
- the impedance compensation signal comprises a ZQCal latch signal that triggers the memory device to set an impedance compensation configuration.
- the impedance compensation signal comprises a ZQCal start signal that triggers the memory device to initiate an impedance compensation calibration routine, and a ZQCal latch signal that triggers the memory device to set an impedance compensation configuration.
- a memory controller that manages impedance compensation of a memory includes: I/O (input/output) hardware coupled to a memory device to read data from the memory device indicating a change in a sensor reading; and a scheduler to determine that a performance condition affecting I/O impedance for the memory device has changed in excess of a threshold based on reading the data from the memory device, and in response to determining that the performance condition has changed in excess of the threshold, to generate an impedance compensation signal to the memory device to trigger a change in I/O impedance compensation in the memory device.
- I/O input/output
- the I/O hardware is to a flag set by the memory device indicating that the performance condition has changed in excess of the threshold. In one embodiment, the I/O hardware is to read data from the sensor in response to a flag set by the memory device. In one embodiment, the I/O hardware is to read data from the sensor in response to a flag set by the memory device indicating that the performance condition has changed in excess of the threshold. In one embodiment, the scheduler is to determine that a change in operating temperature exceeds a threshold within the memory. In one embodiment, the scheduler is to determine that a change in operating voltage that exceeds a threshold within the memory. In one embodiment, the sensor comprises an on-die sensor of the memory device that monitors performance conditions to set a parameter for refresh for the memory device.
- the I/O hardware is to read one or more values from a Mode Register of the memory device. In one embodiment, the I/O hardware is to periodically check the one or more values of the Mode Register. In one embodiment, the scheduler is to generate an impedance compensation signal triggering an adjustment to a driver impedance of the memory device I/O. In one embodiment, the scheduler is to generate an impedance compensation signal triggering an adjustment to an on-die termination value of the memory device I/O. In one embodiment, the I/O couples to multiple parallel memory devices, and wherein the scheduler is to delay generating the impedance compensation signal for a memory device until at least a threshold number of memory devices are determined to have a performance conditions affecting I/O impedance that have changed in excess of a threshold.
- the I/O couples to multiple parallel memory devices, and wherein the scheduler is to schedule a continuous sequence of impedance compensation signals sent in sequence to at least a plurality of the multiple parallel memory devices. In one embodiment, the I/O couples to multiple parallel memory devices, and wherein the scheduler is to schedule a period of time to cease sending access commands on a command/address (C/A) bus for all memory devices, and to send a sequence of impedance compensation signals to at least two of the memory devices while no access command traffic is sent over the C/A bus. In one embodiment, the scheduler is to generate a ZQCal latch signal that triggers the memory device to set an impedance compensation configuration. In one embodiment, the scheduler is to generate a ZQCal start signal that triggers the memory device to initiate an impedance compensation calibration routine, and a ZQCal latch signal that triggers the memory device to set an impedance compensation configuration.
- C/A command/address
- an electronic device with a memory subsystem includes: an LPDDR (low power dual data rate) DRAM (dynamic random access memory) including an on-die sensor to detect changes to a performance condition that affects I/O impedance for the DRAM, and a register to record data about the performance condition; and a memory controller to control access to the LPDDR DRAM, the memory controller including I/O (input/output) hardware coupled to the DRAM to read data from the DRAM indicating a change in a sensor reading; and a scheduler to determine that a performance condition affecting I/O impedance for the DRAM has changed in excess of a threshold based on reading the data from the memory device, and in response to determining that the performance condition has changed in excess of the threshold, to generate an impedance compensation signal to the DRAM to trigger a change in I/O impedance compensation in the DRAM; and a touchscreen display coupled to generate a display based on data accessed from the DRAM.
- the electronic device can include a memory controller coupled to a DRAM
- an apparatus for impedance compensation of an I/O (input/output) interface includes: means for detecting, via logic on a memory device, a change in a performance condition affecting I/O impedance for the memory device; means for triggering a compensation flag signal to an associated memory controller in response to detecting the change; and means for receiving at the memory device from the memory controller, in response to the compensation flag signal, an impedance compensation signal triggering a change in I/O impedance compensation in the memory device.
- the apparatus can include means for performing any embodiment of the method described above.
- an article of manufacture comprising a computer readable storage medium having content stored thereon, which when accessed causes a machine to perform operations including: detecting, via logic on a memory device, a change in a performance condition affecting I/O impedance for the memory device; triggering a compensation flag signal to an associated memory controller in response to detecting the change; and receiving at the memory device from the memory controller, in response to the compensation flag signal, an impedance compensation signal triggering a change in I/O impedance compensation in the memory device.
- the article of manufacture can include content for performing operation in accordance with any embodiment of the method described above.
- Flow diagrams as illustrated herein provide examples of sequences of various process actions.
- the flow diagrams can indicate operations to be executed by a software or firmware routine, as well as physical operations.
- a flow diagram can illustrate the state of a finite state machine (FSM), which can be implemented in hardware and/or software.
- FSM finite state machine
- FIG. 1 Flow diagrams as illustrated herein provide examples of sequences of various process actions.
- the flow diagrams can indicate operations to be executed by a software or firmware routine, as well as physical operations.
- a flow diagram can illustrate the state of a finite state machine (FSM), which can be implemented in hardware and/or software.
- FSM finite state machine
- the content can be directly executable ("object” or “executable” form), source code, or difference code (“delta” or “patch” code).
- the software content of the embodiments described herein can be provided via an article of manufacture with the content stored thereon, or via a method of operating a communication interface to send data via the communication interface.
- a machine readable storage medium can cause a machine to perform the functions or operations described, and includes any mechanism that stores information in a form accessible by a machine (e.g., computing device, electronic system, etc.), such as recordable/non-recordable media (e.g., read only memory (ROM), random access memory (RAM), magnetic disk storage media, optical storage media, flash memory devices, etc.).
- a communication interface includes any mechanism that interfaces to any of a hardwired, wireless, optical, etc., medium to communicate to another device, such as a memory bus interface, a processor bus interface, an Internet connection, a disk controller, etc.
- the communication interface can be configured by providing configuration parameters and/or sending signals to prepare the communication interface to provide a data signal describing the software content.
- the communication interface can be accessed via one or more commands or signals sent to the communication interface.
- Each component described herein can be a means for performing the operations or functions described.
- Each component described herein includes software, hardware, or a combination of these.
- the components can be implemented as software modules, hardware modules, special-purpose hardware (e.g., application specific hardware, application specific integrated circuits (ASICs), digital signal processors (DSPs), etc.), embedded controllers, hardwired circuitry, etc.
- special-purpose hardware e.g., application specific hardware, application specific integrated circuits (ASICs), digital signal processors (DSPs), etc.
- embedded controllers e.g., hardwired circuitry, etc.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Quality & Reliability (AREA)
- Mathematical Physics (AREA)
- Dram (AREA)
- Memory System (AREA)
- Multimedia (AREA)
Claims (10)
- Speichervorrichtung, die Folgendes umfasst:ein Register (224), das durch die Speichervorrichtung (120; 220) mit einem Impedanzkalibrierungs-Aktualisierungsmerker (126) wahlweise beschreibbar ist, um einem Speicher-Controller (110; 210) anzuzeigen, dass die Speichervorrichtung (120; 220) bereit ist, eine I/O-Impedanzkalibrierungs-Aktualisierung durchzuführen; undI/O-Hardware, Ein-/Ausgabe-Hardware (122; 230), um Anweisungen, die ein Impedanzkalibrierungs-Verriegelungssignal (ZQCAL LATCH) enthalten, in Reaktion auf eine Detektion durch den Speicher-Controller (110; 210), dass der Impedanzkalibrierungs-Aktualisierungsmerker (126) gesetzt ist, vom Speicher-Controller (110; 210) zu empfangen, um eine neue Kalibriereinstellung in der Speichervorrichtung (120; 220) zu setzen, wobeidie Speichervorrichtung (120; 220) konfiguriert ist zumÜberwachen eines oder mehrerer Sensoren (124), um zu bestimmen, ob der Impedanzkalibrierungs-Aktualisierungsmerker (126) gesetzt werden soll, wobei der eine oder die mehreren Sensoren (124) einen oder mehrere Leistungsfähigkeitszustände überwachen, die sich auf eine I/O-Impedanz der Speichervorrichtung (120; 220) auswirken, undBestimmen auf der Grundlage von Werten, die von dem einen oder den mehreren Sensoren (124) gelesen wurden, ob eine Änderung eines Leistungsfähigkeitszustands einen Schwellenwert überschreitet, und Setzen des Impedanzkalibrierungs-Aktualisierungsmerkers (126) lediglich dann, wenn die Änderung des Leistungsfähigkeitszustands den Schwellenwert überschreitet.
- Speichervorrichtung nach Anspruch 1, wobei die I/O-Hardware (122; 230) ausgelegt ist, eine Abfrageanforderung, den Impedanzkalibrierungs-Aktualisierungsmerker (126) zu prüfen, vom Speicher-Controller (110; 210) regelmäßig zu empfangen, oder die I/O-Hardware ausgelegt ist, das Impedanzkalibrierungs-Verriegelungssignal mit vorhergehendem Eingang eines Impedanzkalibrierungs-Startsignals (ZQCAL START) zu empfangen.
- Speichervorrichtung nach Anspruch 1, wobei das Register (224) ein Modusregister umfasst und die I/O-Hardware (122; 230) ausgelegt ist, eine Anweisung, das Modusregister zu lesen, um den Impedanzkalibrierungs-Aktualisierungsmerker (126) zu prüfen, regelmäßig zu empfangen.
- Speichervorrichtung nach Anspruch 1, wobei die neue Kalibriereinstellung eine I/O-Treiberimpedanzeinstellung oder eine chipinterne Abschlusseinstellung, ODT-Einstellung, umfasst.
- Speichervorrichtung nach Anspruch 1, wobei der eine oder die mehreren Sensoren chipinterne Sensoren (226) sind.
- Speichervorrichtung nach Anspruch 1, wobei die Speichervorrichtung (120; 220) eine dynamische Schreib- /Lese-Speichervorrichtung, DRAM-Vorrichtung, umfasst, die mit einer Niedrigleistungs-Doppeldatenraten-Norm, LPDDR-Norm, kompatibel ist.
- System, das Folgendes umfasst:eine Speichervorrichtung (120; 220) nach einem der vorhergehenden Ansprüche undeinen Speicher-Controller (110; 210), der Folgendes umfasst:I/O-Hardware, Ein-/Ausgabe-Hardware (112; 212), um eine Kopplung an die Speichervorrichtung (120; 220) herzustellen, um einen Impedanzkalibrierungs-Aktualisierungsmerker (126) der Speichervorrichtung (120; 220) zu lesen, wobei der Impedanzkalibrierungs-Aktualisierungsmerker (126) ausgelegt ist, anzuzeigen, dass die Speichervorrichtung (129; 220) bereit ist, eine I/O-Impedanzkalibrierungs-Aktualisierung durchzuführen; undeine Planungsvorrichtung (132; 216), um ein Impedanzkalibrierungs-Verriegelungssignal (ZQCAL LATCH) in Reaktion auf eine Detektion, dass der Impedanzkalibrierungs-Aktualisierungsmerker (126) gesetzt ist, anstelle eines Impedanzkalibrierungssignals mit einer festen Zeitplanung zu planen; wobeidie I/O-Hardware (112; 212) ausgelegt ist, das Impedanzkalibrierungs-Verriegelungssignal zur Speichervorrichtung (120; 220) zu senden, um eine neue Kalibriereinstellung in der Speichervorrichtung (120; 220) zu setzen.
- System nach Anspruch 7, wobei die I/O-Hardware (112; 212) des Speicher-Controllers (110; 210) ausgelegt ist, eine Abfrageanforderung, um den Impedanzkalibrierungs-Aktualisierungsmerker (126) zu prüfen, zu der Speichervorrichtung (120; 220) regelmäßig zu senden.
- System nach Anspruch 7, wobei die I/O-Hardware (112; 212) des Speicher-Controllers (110; 210) ausgelegt ist, eine Anweisung, das Modusregister zu lesen, um den Impedanzkalibrierungs-Aktualisierungsmerker (126) zu prüfen, periodisch zu senden.
- System nach Anspruch 7, wobei die Speichervorrichtung (120; 220) eine von mehreren Speichervorrichtungen, die parallel an den Speicher-Controller (110; 210) gekoppelt sind, ist und der Speicher-Controller (110; 210) ausgelegt ist, verschiedene Impedanzkalibrierungs-Aktualisierungen auf der Grundlage verschiedener Impedanzkalibrierungs-Aktualisierungsmerker (126) von verschiedenen Speichervorrichtungen (120; 220) zu managen.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/670,411 US10025685B2 (en) | 2015-03-27 | 2015-03-27 | Impedance compensation based on detecting sensor data |
EP16773699.0A EP3274994B1 (de) | 2015-03-27 | 2016-03-07 | Impedanzkompensation auf grundlage der detektion von sensordaten |
PCT/US2016/021153 WO2016160276A1 (en) | 2015-03-27 | 2016-03-07 | Impedance compensation based on detecting sensor data |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP16773699.0A Division EP3274994B1 (de) | 2015-03-27 | 2016-03-07 | Impedanzkompensation auf grundlage der detektion von sensordaten |
Publications (2)
Publication Number | Publication Date |
---|---|
EP3657506A1 EP3657506A1 (de) | 2020-05-27 |
EP3657506B1 true EP3657506B1 (de) | 2022-01-12 |
Family
ID=56974261
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP19211469.2A Active EP3657506B1 (de) | 2015-03-27 | 2016-03-07 | Impedanzkompensation auf grundlage der detektion von sensordaten |
EP16773699.0A Active EP3274994B1 (de) | 2015-03-27 | 2016-03-07 | Impedanzkompensation auf grundlage der detektion von sensordaten |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP16773699.0A Active EP3274994B1 (de) | 2015-03-27 | 2016-03-07 | Impedanzkompensation auf grundlage der detektion von sensordaten |
Country Status (7)
Country | Link |
---|---|
US (2) | US10025685B2 (de) |
EP (2) | EP3657506B1 (de) |
JP (2) | JP6729940B2 (de) |
KR (2) | KR102581206B1 (de) |
CN (2) | CN110059048B (de) |
TW (1) | TWI643206B (de) |
WO (1) | WO2016160276A1 (de) |
Families Citing this family (29)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10325655B2 (en) * | 2015-04-10 | 2019-06-18 | Hewlett Packard Enterprise Development Lp | Temperature compensation circuits |
US10141935B2 (en) * | 2015-09-25 | 2018-11-27 | Intel Corporation | Programmable on-die termination timing in a multi-rank system |
US10284198B2 (en) * | 2015-10-02 | 2019-05-07 | Samsung Electronics Co., Ltd. | Memory systems with ZQ global management and methods of operating same |
US9653144B1 (en) | 2016-06-28 | 2017-05-16 | Intel Corporation | Apparatuses, methods, and systems for package on package memory refresh and self-refresh rate management |
JP6640677B2 (ja) | 2016-08-19 | 2020-02-05 | キオクシア株式会社 | 半導体記憶装置 |
JP2018045743A (ja) * | 2016-09-13 | 2018-03-22 | 東芝メモリ株式会社 | 半導体装置及びメモリシステム |
US9965222B1 (en) * | 2016-10-21 | 2018-05-08 | Advanced Micro Devices, Inc. | Software mode register access for platform margining and debug |
US10348270B2 (en) | 2016-12-09 | 2019-07-09 | Micron Technology, Inc. | Apparatuses and methods for calibrating adjustable impedances of a semiconductor device |
US10366765B2 (en) * | 2016-12-15 | 2019-07-30 | Taiwan Semiconductor Manufacturing Co., Ltd. | Adjustment circuit for partitioned memory block |
US10062453B1 (en) * | 2017-03-09 | 2018-08-28 | Toshiba Memory Corporation | Calibrating I/O impedances using estimation of memory die temperature |
US10193711B2 (en) | 2017-06-22 | 2019-01-29 | Micron Technology, Inc. | Timing based arbitration methods and apparatuses for calibrating impedances of a semiconductor device |
KR102396741B1 (ko) * | 2017-09-11 | 2022-05-12 | 에스케이하이닉스 주식회사 | 임피던스 캘리브레이션 회로를 포함하는 메모리 시스템 |
KR102391503B1 (ko) * | 2017-09-11 | 2022-04-28 | 에스케이하이닉스 주식회사 | 임피던스 캘리브레이션 회로를 포함하는 메모리 시스템 |
US10615798B2 (en) | 2017-10-30 | 2020-04-07 | Micron Technology, Inc. | Apparatuses and methods for identifying memory devices of a semiconductor device sharing an external resistance |
KR102649322B1 (ko) | 2018-05-25 | 2024-03-20 | 삼성전자주식회사 | 메모리 장치, 메모리 시스템, 및 메모리 장치의 동작 방법 |
US11163487B2 (en) * | 2018-06-04 | 2021-11-02 | Micron Technology, Inc. | Methods for generating notifications for updated information from mode registers of a memory device to a host and memory devices and systems employing the same |
US10692560B2 (en) * | 2018-06-06 | 2020-06-23 | Intel Corporation | Periodic calibrations during memory device self refresh |
US11570685B2 (en) | 2018-10-24 | 2023-01-31 | Carrier Corporation | Power savings for wireless sensors |
US11074976B2 (en) * | 2019-08-26 | 2021-07-27 | Sandisk Technologies Llc | Temperature dependent impedance mitigation in non-volatile memory |
KR20210047475A (ko) * | 2019-10-22 | 2021-04-30 | 삼성전자주식회사 | 센서를 구비한 멀티 디스플레이 장치 |
CN112817884A (zh) * | 2019-11-15 | 2021-05-18 | 安徽寒武纪信息科技有限公司 | 一种存储器以及包括该存储器的设备 |
US10747245B1 (en) | 2019-11-19 | 2020-08-18 | Micron Technology, Inc. | Apparatuses and methods for ZQ calibration |
US11579784B2 (en) | 2019-11-27 | 2023-02-14 | Micron Technology, Inc. | Refresh counters in a memory system |
US12009842B2 (en) * | 2019-12-20 | 2024-06-11 | Intel Corporation | Error correcting code circuitry compatible with multi-width interfaces |
JP6890701B1 (ja) * | 2020-05-19 | 2021-06-18 | 華邦電子股▲ふん▼有限公司Winbond Electronics Corp. | コードシフト算出回路およびコードシフト値の算出方法 |
US11621038B2 (en) * | 2021-07-21 | 2023-04-04 | Micron Technology, Inc. | Driver for non-binary signaling |
EP4390925A1 (de) * | 2021-11-04 | 2024-06-26 | Samsung Electronics Co., Ltd. | Elektronische vorrichtung zur steuerung des betriebs eines flüchtigen speichers und betriebsverfahren dafür |
KR20230112334A (ko) | 2022-01-20 | 2023-07-27 | 에스케이하이닉스 주식회사 | 반도체 장치, 반도체 시스템, 및 반도체 장치의 동작 방법 |
CN115695103B (zh) * | 2022-11-21 | 2024-05-17 | 深圳数马电子技术有限公司 | 阻抗自适应方法、装置、计算机设备和存储介质 |
Family Cites Families (46)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5517613A (en) * | 1991-12-12 | 1996-05-14 | Emc Corporation | Environment sensing/control circuit |
US6262625B1 (en) * | 1999-10-29 | 2001-07-17 | Hewlett-Packard Co | Operational amplifier with digital offset calibration |
FI106411B (fi) * | 1999-02-03 | 2001-01-31 | Nokia Mobile Phones Ltd | Menetelmä ja järjestely ilmaisimen ja ohjaussignaalin lämpöryöminnän kompensoimiseksi jaksoittaisessa säädössä |
US6292059B1 (en) * | 1999-10-29 | 2001-09-18 | Scientific-Atlanta, Inc. | Systems, methods, and circuits for providing thermal compensation in amplifiers |
US6476392B1 (en) * | 2001-05-11 | 2002-11-05 | Irvine Sensors Corporation | Method and apparatus for temperature compensation of an uncooled focal plane array |
US6785793B2 (en) * | 2001-09-27 | 2004-08-31 | Intel Corporation | Method and apparatus for memory access scheduling to reduce memory access latency |
US7114087B2 (en) * | 2003-05-27 | 2006-09-26 | Intel Corporation | Method to detect a temperature change by a thermal monitor and compensating for process, voltage, temperature effects caused by the temperature change |
JP2005010966A (ja) | 2003-06-18 | 2005-01-13 | Olympus Corp | Lsi装置 |
US7111143B2 (en) * | 2003-12-30 | 2006-09-19 | Infineon Technologies Ag | Burst mode implementation in a memory device |
KR100532972B1 (ko) | 2004-04-28 | 2005-12-01 | 주식회사 하이닉스반도체 | 온 다이 터미네이션 임피던스 조절 장치 |
US7227376B2 (en) | 2004-11-05 | 2007-06-05 | Ati Technologies Inc. | Dynamic impedance compensation circuit and method |
US7138823B2 (en) * | 2005-01-20 | 2006-11-21 | Micron Technology, Inc. | Apparatus and method for independent control of on-die termination for output buffers of a memory device |
US8169233B2 (en) | 2009-06-09 | 2012-05-01 | Google Inc. | Programming of DIMM termination resistance values |
US8060774B2 (en) | 2005-06-24 | 2011-11-15 | Google Inc. | Memory systems and memory modules |
US7432731B2 (en) | 2005-06-30 | 2008-10-07 | Intel Corporation | Method and apparatus to calibrate DRAM on resistance (Ron) and on-die termination (ODT) values over process, voltage and temperature (PVT) variations |
JP4916699B2 (ja) * | 2005-10-25 | 2012-04-18 | エルピーダメモリ株式会社 | Zqキャリブレーション回路及びこれを備えた半導体装置 |
US8118483B2 (en) | 2006-06-21 | 2012-02-21 | Intel Corporation | Thermal sensor having toggle control |
US7644250B2 (en) * | 2006-06-30 | 2010-01-05 | Intel Corporation | Defining pin functionality at device power on |
US7459930B2 (en) * | 2006-11-14 | 2008-12-02 | Micron Technology, Inc. | Digital calibration circuits, devices and systems including same, and methods of operation |
US20080198666A1 (en) | 2007-02-20 | 2008-08-21 | Aaron Nygren | Semiconductor device including adjustable driver output impedances |
JP2008271517A (ja) * | 2007-03-23 | 2008-11-06 | Matsushita Electric Ind Co Ltd | 高周波電力増幅器、半導体装置、および高周波電力増幅方法 |
KR100937951B1 (ko) | 2008-09-05 | 2010-01-21 | 주식회사 하이닉스반도체 | 캘리브래이션 회로, 온 다이 터미네이션 장치 및 반도체 메모리 장치 |
JP2010117987A (ja) * | 2008-11-14 | 2010-05-27 | Denso Corp | メモリ制御装置、およびメモリ制御プログラム |
US8482339B1 (en) * | 2009-06-12 | 2013-07-09 | National Acquisition Sub, Inc. | Method and apparatus for temperature compensation of filter circuits |
JP2011040983A (ja) | 2009-08-11 | 2011-02-24 | Renesas Electronics Corp | 半導体集積回路、半導体記憶装置、及びインピーダンス調整方法 |
JP5287599B2 (ja) * | 2009-08-24 | 2013-09-11 | 株式会社リコー | 電子機器 |
US8307270B2 (en) * | 2009-09-03 | 2012-11-06 | International Business Machines Corporation | Advanced memory device having improved performance, reduced power and increased reliability |
JP2011081893A (ja) * | 2009-09-11 | 2011-04-21 | Elpida Memory Inc | 半導体装置及びこれを備えるデータ処理システム |
US20110068765A1 (en) * | 2009-09-22 | 2011-03-24 | Qualcomm Incorporated | System and method for power calibrating a pulse generator |
JP2011101143A (ja) | 2009-11-05 | 2011-05-19 | Elpida Memory Inc | 半導体装置及びそのシステムとキャリブレーション方法 |
JP2011170943A (ja) * | 2010-02-22 | 2011-09-01 | Sony Corp | 記憶制御装置、記憶装置、記憶装置システム |
KR101206498B1 (ko) | 2010-07-08 | 2012-11-29 | 에스케이하이닉스 주식회사 | 임피던스 캘리브레이션 회로 및 그 동작 방법 |
US8738852B2 (en) * | 2011-08-31 | 2014-05-27 | Nvidia Corporation | Memory controller and a dynamic random access memory interface |
JP2013085078A (ja) * | 2011-10-07 | 2013-05-09 | Elpida Memory Inc | 半導体装置及びこれを備える半導体モジュール |
FR2987210B1 (fr) * | 2012-02-22 | 2014-02-21 | Ulis | Procede de correction de la derive d'un detecteur de rayonnement infrarouge comportant une matrice de bolometres resistifs d'imagerie et dispositif mettant en oeuvre un tel procede |
KR20140008745A (ko) | 2012-07-11 | 2014-01-22 | 삼성전자주식회사 | 자기 메모리 장치 |
KR20140100330A (ko) * | 2013-02-06 | 2014-08-14 | 삼성전자주식회사 | 메모리 시스템 및 그것의 동작 방법 |
KR20140107890A (ko) * | 2013-02-28 | 2014-09-05 | 에스케이하이닉스 주식회사 | 메모리, 이를 포함하는 메모리 시스템 및 메모리 콘트롤러의 동작 방법 |
TWI508087B (zh) * | 2013-07-01 | 2015-11-11 | Mstar Semiconductor Inc | 記憶體信號的動態相位追蹤方法及其相關控制電路 |
US9779039B2 (en) | 2013-08-29 | 2017-10-03 | Micron Technology, Inc. | Impedance adjustment in a memory device |
US9292076B2 (en) * | 2013-09-16 | 2016-03-22 | Intel Corporation | Fast recalibration circuitry for input/output (IO) compensation finite state machine power-down-exit |
US9704557B2 (en) * | 2013-09-25 | 2017-07-11 | Qualcomm Incorporated | Method and apparatus for storing retention time profile information based on retention time and temperature |
US9269404B1 (en) | 2014-08-07 | 2016-02-23 | Qualcomm Incorporated | Semiconductor package on package memory channels with arbitration for shared calibration resources |
US20160179113A1 (en) | 2014-12-17 | 2016-06-23 | Sandisk Technologies Inc. | Temperature Independent Reference Current Generation For Calibration |
US9621160B2 (en) | 2015-03-05 | 2017-04-11 | Micron Technology, Inc. | Circuits for impedance adjustment having multiple termination devices with switchable resistances and methods of adjusting impedance |
US20160378366A1 (en) * | 2015-06-24 | 2016-12-29 | Intel Corporation | Internal consecutive row access for long burst length |
-
2015
- 2015-03-27 US US14/670,411 patent/US10025685B2/en active Active
-
2016
- 2016-02-04 TW TW105103783A patent/TWI643206B/zh active
- 2016-03-07 JP JP2017541939A patent/JP6729940B2/ja active Active
- 2016-03-07 CN CN201910052999.7A patent/CN110059048B/zh active Active
- 2016-03-07 KR KR1020177023566A patent/KR102581206B1/ko active IP Right Grant
- 2016-03-07 EP EP19211469.2A patent/EP3657506B1/de active Active
- 2016-03-07 WO PCT/US2016/021153 patent/WO2016160276A1/en active Application Filing
- 2016-03-07 KR KR1020187037130A patent/KR102617628B1/ko active IP Right Grant
- 2016-03-07 EP EP16773699.0A patent/EP3274994B1/de active Active
- 2016-03-07 CN CN201680019113.3A patent/CN107408099B/zh active Active
-
2018
- 2018-05-30 US US15/993,245 patent/US10552285B2/en active Active
-
2020
- 2020-06-29 JP JP2020112055A patent/JP6965494B2/ja active Active
Also Published As
Publication number | Publication date |
---|---|
EP3274994B1 (de) | 2019-12-04 |
US10025685B2 (en) | 2018-07-17 |
KR20170131371A (ko) | 2017-11-29 |
KR20190000387A (ko) | 2019-01-02 |
US10552285B2 (en) | 2020-02-04 |
KR102581206B1 (ko) | 2023-09-21 |
CN110059048A (zh) | 2019-07-26 |
TWI643206B (zh) | 2018-12-01 |
EP3274994A4 (de) | 2018-11-21 |
US20160284386A1 (en) | 2016-09-29 |
JP6965494B2 (ja) | 2021-11-10 |
JP6729940B2 (ja) | 2020-07-29 |
US20190004919A1 (en) | 2019-01-03 |
CN107408099A (zh) | 2017-11-28 |
WO2016160276A1 (en) | 2016-10-06 |
EP3657506A1 (de) | 2020-05-27 |
KR102617628B1 (ko) | 2023-12-27 |
CN110059048B (zh) | 2024-02-02 |
EP3274994A1 (de) | 2018-01-31 |
CN107408099B (zh) | 2021-04-20 |
TW201642257A (zh) | 2016-12-01 |
JP2018511108A (ja) | 2018-04-19 |
JP2020170532A (ja) | 2020-10-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10552285B2 (en) | Impedance compensation based on detecting sensor data | |
US11789880B2 (en) | Load reduced nonvolatile memory interface | |
US10109340B2 (en) | Precharging and refreshing banks in memory device with bank group architecture | |
US10872647B2 (en) | Flexible DLL (delay locked loop) calibration | |
US20170110178A1 (en) | Hybrid refresh with hidden refreshes and external refreshes | |
US20170285992A1 (en) | Memory subsystem with narrow bandwidth repeater channel | |
US20160028395A1 (en) | On-die termination control without a dedicated pin in a multi-rank system | |
US9953694B2 (en) | Memory controller-controlled refresh abort | |
US20180121123A1 (en) | Efficiently training memory device chip select control | |
US9390785B2 (en) | Method, apparatus and system for determining a write recovery time of a memory based on temperature |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE APPLICATION HAS BEEN PUBLISHED |
|
AC | Divisional application: reference to earlier application |
Ref document number: 3274994 Country of ref document: EP Kind code of ref document: P |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: REQUEST FOR EXAMINATION WAS MADE |
|
17P | Request for examination filed |
Effective date: 20201120 |
|
RBV | Designated contracting states (corrected) |
Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: EXAMINATION IS IN PROGRESS |
|
17Q | First examination report despatched |
Effective date: 20210129 |
|
GRAP | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOSNIGR1 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: GRANT OF PATENT IS INTENDED |
|
INTG | Intention to grant announced |
Effective date: 20210802 |
|
GRAS | Grant fee paid |
Free format text: ORIGINAL CODE: EPIDOSNIGR3 |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE PATENT HAS BEEN GRANTED |
|
AC | Divisional application: reference to earlier application |
Ref document number: 3274994 Country of ref document: EP Kind code of ref document: P |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: EP |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R096 Ref document number: 602016068422 Country of ref document: DE |
|
REG | Reference to a national code |
Ref country code: IE Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: REF Ref document number: 1462908 Country of ref document: AT Kind code of ref document: T Effective date: 20220215 |
|
REG | Reference to a national code |
Ref country code: NL Ref legal event code: FP |
|
REG | Reference to a national code |
Ref country code: LT Ref legal event code: MG9D |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: MK05 Ref document number: 1462908 Country of ref document: AT Kind code of ref document: T Effective date: 20220112 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: RS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: PT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220512 Ref country code: NO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220412 Ref country code: LT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: HR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: ES Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: BG Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220412 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: PL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: LV Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: GR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220413 Ref country code: FI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: AT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220512 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R097 Ref document number: 602016068422 Country of ref document: DE |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SM Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: SK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: RO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: MC Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: EE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: DK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: CZ Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: PL |
|
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: AL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 |
|
REG | Reference to a national code |
Ref country code: BE Ref legal event code: MM Effective date: 20220331 |
|
26N | No opposition filed |
Effective date: 20221013 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LU Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220307 Ref country code: LI Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220331 Ref country code: IE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220307 Ref country code: CH Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220331 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: BE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220331 |
|
P01 | Opt-out of the competence of the unified patent court (upc) registered |
Effective date: 20230518 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: NL Payment date: 20231215 Year of fee payment: 9 Ref country code: FR Payment date: 20231212 Year of fee payment: 9 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 Ref country code: CY Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: DE Payment date: 20231128 Year of fee payment: 9 Ref country code: GB Payment date: 20240108 Year of fee payment: 9 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: HU Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT; INVALID AB INITIO Effective date: 20160307 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220112 |