This invention relates to the field of integrated circuits and, in particular, to improving power delivery.
Advances in semi-conductor processing and logic design have permitted an increase in the amount of logic that may be present on integrated circuit devices. As a result, the power demands of integrated circuits, such as microprocessors, have drastically increased. Typically there have been two approaches to handling this voltage supply degradation. In one post-design scenario, a large amount of decoupling capacitors are added to a processor package and/or motherboard to reduce voltage droops. Yet, adding capacitors is both monetarily expensive (extra money per capacitor) and physically expensive (the capacitors take up additional critical signal routing/placement space). In a second, pre-design scenario, processor designers take into account the voltage supply issues by adding a guard-band (a tolerance band that the processor still operates appropriately). However, an increase in guard-band both results in an additional power losses and performance degradation, since the designers are constrained by designing to worst case scenarios.
As one example of such a worst case scenario, input/output (I/O) patterns that cause resonant frequencies on I/O interfaces potentially cause noise in an associated power delivery network. In fact, as the I/O speeds of devices increases, power delivery noise targets shrink, accordingly. And as the power delivery noise targets decrease, the need for more on-die decoupling capacitors increase, which results in even more expense. Unfortunately, current scramblers only provide random pattern scrambling without consideration of a patterns affect on a power delivery network.
The present invention is illustrated by way of example and not intended to be limited by the figures of the accompanying drawings.
In the following description, numerous specific details are set forth, such as examples of specific types of specific processor configurations, specific mathematical function responses, specific hardware structures, specific logic states, specific step stimuli, etc. in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that these specific details need not be employed to practice the present invention. In other instances, well known components or methods, such as specific and alternative processor architecture, specific logic circuits/code for described algorithms, specific I/O interface, specific power delivery components, and other specific operational details of processors haven't been described in detail in order to avoid unnecessarily obscuring the present invention.
The method and apparatus described herein are for predictive noise reduction in power distribution networks. Specifically, predictive noise reduction is discussed primarily in reference to processor input/output (I/O) interfaces, such as external interconnect I/O interfaces for communicating with external devices or I/O interfaces for communication between parts/sections of a processor. Yet, the apparatus' and methods described herein are not so limited, as they may be implemented in conjunction with any power delivery network for an interface or device. For example, the predictive noise reduction may be utilized in a computer system's power delivery network or other device (a chipset, I/O device, graphics card, etc.) within a computer system. Or the predictive noise reduction may be utilized in embedded, small form-factor devices, such as PDAs and cell phones.
Referring to
In one embodiment, a processing element refers to a thread unit, a thread slot, a process unit, a context, a logical processor, a hardware thread, a core, and/or any other element, which is capable of holding a state for a processor, such as an execution state or architectural state. In other words, a processing element, in one embodiment, refers to any hardware capable of being independently associated with code, such as a software thread, operating system, application, or other code. A physical processor typically refers to an integrated circuit, which potentially includes any number of other processing elements, such as cores or hardware threads.
A core often refers to logic located on an integrated circuit capable of maintaining an independent architectural state wherein each independently maintained architectural state is associated with at least some dedicated execution resources. In contrast to cores, a hardware thread typically refers to any logic located on an integrated circuit capable of maintaining an independent architectural state wherein the independently maintained architectural states share access to execution resources. As can be seen, when certain resources are shared and others are dedicated to an architectural state, the line between the nomenclature of a hardware thread and core overlaps. Yet often, a core and a hardware thread are viewed by an operating system as individual logical processors, where the operating system is able to individually schedule operations on each logical processor.
Physical processor 100, as illustrated in
As depicted, core 101 includes two hardware threads 101a and 101b, which may also be referred to as hardware thread slots 101a and 101b. Therefore, software entities, such as an operating system, in one embodiment potentially view processor 100 as four separate processors, i.e. four logical processors or processing elements capable of executing four software threads concurrently. As eluded to above, a first thread is associated with architecture state registers 101a, a second thread is associated with architecture state registers 101b, a third thread may be associated with architecture state registers 102a, and a fourth thread may be associated with architecture state registers 102b. As illustrated, architecture state registers 101a are replicated in architecture state registers 101b, so individual architecture states/contexts are capable of being stored for logical processor 101a and logical processor 101b. In core 101, other smaller resources, such as instruction pointers and renaming logic in rename allocater logic 130 may also be replicated for threads 101a and 101b. Some resources, such as re-order buffers in reorder/retirement unit 135, ILTB 120, load/store buffers, and queues may be shared through partitioning. Other resources, such as general purpose internal registers, page-table base register, low-level data-cache and data-TLB 115, execution unit(s) 140, and portions of out-of-order unit 135 are potentially fully shared.
Processor 100 often includes other resources, which may be fully shared, shared through partitioning, or dedicated by/to processing elements. In
Core 101 further includes decode module 125 coupled to fetch unit 120 to decode fetched elements. Fetch logic, in one embodiment, includes individual sequencers associated with thread slots 101a, 101b, respectively. Usually core 101 is associated with a first Instruction Set Architecture (ISA), which defines/specifies instructions executable on processor 100. Here, often machine code instructions that are part of the first ISA include a portion of the instruction (referred to as an opcode), which references/specifies an instruction or operation to be performed. Decode logic 125 includes circuitry that recognizes these instructions from their opcodes and passes the decoded instructions on in the pipeline for processing as defined by the first ISA. For example, as discussed in more detail below decoders 125, in one embodiment, include logic designed or adapted to recognize specific, new instructions, such as a conditional commit instruction and/or a speculative checkpoint instruction. As a result or the recognition by decoders 125, the architecture or core 101 takes specific, predefined actions to perform tasks associated with the appropriate instruction.
In one example, allocator and renamer block 130 includes an allocator to reserve resources, such as register files to store instruction processing results. However, threads 101a and 101b are potentially capable of out-of-order execution, where allocator and renamer block 130 also reserves other resources, such as reorder buffers to track instruction results. Unit 130 may also include a register renamer to rename program/instruction reference registers to other registers internal to processor 100. Reorder/retirement unit 135 includes components, such as the reorder buffers mentioned above, load buffers, and store buffers, to support out-of-order execution and later in-order retirement of instructions executed out-of-order.
Scheduler and execution unit(s) block 140, in one embodiment, includes a scheduler unit to schedule instructions/operation on execution units. For example, a floating point instruction is scheduled on a port of an execution unit that has an available floating point execution unit. Register files associated with the execution units are also included to store information instruction processing results. Exemplary execution units include a floating point execution unit, an integer execution unit, a jump execution unit, a load execution unit, a store execution unit, and other known execution units.
Lower level data cache and data translation buffer (D-TLB) 150 are coupled to execution unit(s) 140. The data cache is to store recently used/operated on elements, such as data operands, which are potentially held in memory coherency states. The D-TLB is to store recent virtual/linear to physical address translations. As a specific example, a processor may include a page table structure to break physical memory into a plurality of virtual pages.
Here, cores 101 and 102 share access to higher-level or further-out cache 110, which is to cache recently fetched elements. Note that higher-level or further-out refers to cache levels increasing or getting further way from the execution unit(s). In one embodiment, higher-level cache 110 is a last-level data cache—last cache in the memory hierarchy on processor 100—such as a second or third level data cache. However, higher level cache 110 is not so limited, as it may be associated with or include an instruction cache. A trace cache—a type of instruction cache—instead may be coupled after decoder 125 to store recently decoded traces.
In the depicted configuration, processor 100 also includes bus interface module 105 to communicate with devices external to processor 100, such as system memory 175, a chipset, a northbridge, or other integrated circuit. Memory 175 may be dedicated to processor 100 or shared with other devices in a system. Common examples of types of memory 175 include dynamic random access memory (DRAM), static RAM (SRAM), non-volatile memory (NV memory), and other known storage devices.
In one embodiment, processor 100 includes predictive noise reduction logic 106 to reduce noise in a power delivery network for the interface, such as bus interface 105. As an example, noise reduction logic 106 is adapted to characterize a power delivery network associated with bus interface 105. And based on that characterization, one or more worst case patterns for noise on a power distribution network associated with bus interface 105 is identified/predicted. Moreover, upon subsequent detection of such worst case patterns, they may be avoided to reduce noise on the power delivery network.
In one embodiment, characterization of a power delivery network for bus interface 105 includes providing a step function characterization of bus interface 105. Specifically, a step function stimuli, such as pulling I/O cells of bus interface 105 to a specific voltage level (high or low voltage), is provided. And a step function response associated with bus interface 105, such as a recording of voltage of bus interface 105 vs. time, is determined. Here, note that the step function response may be quantified in a time or a frequency domain, such as determining a resonant frequency from the step function response. Then, based on the step function response, one or more patterns that generate noise in a power delivery network associated with bus interface 105 are identified/predicted as patterns to avoid. As a result, when one of the patterns to avoid is to be transmitted on bus interface 105, predictive noise reduction logic 106 detects and manipulates the pattern, such that the noise associated with the pattern is elided. Essentially, predictive noise reduction logic 106 avoids specific bus activity from bus interface 105 to controller hub 170 that hits a resonant frequency of the power delivery network for bus interface 105. And consequently, with the reduction of worst case noise scenarios for the power delivery network, both pre and post-design associated costs are reduced (less decoupling capacitors have to be added to processor 100 and a designed guard-band may be shrunk; this reduction potentially leads to more die space and reduced per unit cost).
Although the discussion of predictive noise reduction has been discussed in reference to an external interface (bus interface 105), predictive noise reduction may be used on any interface between logic, cores, units, etc. of processor 100. Therefore, use of the term input/output (I/O) interface may refer to an interface that communicates externally with another device or internally with another part of a device. For example, predictive noise reduction logic 106 is the included in core 101 for communication with other units, such as higher level cache 110 or core 102. Or, logic 106 may be included between units, such as execution units 140 and lower level data cache 150. In addition, noise reduction logic 106 may also be included in controller hub 170, as well as between other devices, such as on a graphics interconnect, a memory interconnect, an input/output interconnect, or other known interconnect. Essentially, the noise reduction methods and apparatus described herein may be utilized within any known power delivery network.
In addition, characterization of a power delivery network is not limited to description of the network through a mathematical function. Instead, different stimuli, such as different patterns, may be generated and the power distribution network may then be profiled based on the transmitted patterns. From the collected profile information, which may be statically obtained through simulation or dynamically obtained during runtime, specific worst-case noise patterns are identified and avoided.
Here, caching agents are utilized to manage a slice of a physically distributed cache. As an example, each cache component is to manage a slice of a cache for a collocated core—a core the cache agent is associated with for purpose of managing the distributed slice of the cache. Much like cache agents handle traffic on a ring interconnect and interface with cache slices, core agents/components are to handle traffic and interface with cores. Additionally, the ring interconnect may couple Memory Controller Interface Logic (MCIL) and/or other controllers to interface with other modules, such memory and/or a graphics processor. As a result, predictive power delivery noise reduction, as described herein, may be utilized between any of the agents, between the on-processor memory interface module and local processing elements, between the on-processor memory interface module and external devices, as well as between any of the agents and the caches and cores they communicate with.
Turning to
Often, power distribution network to 210 refers to any distribution logic to deliver voltage/current (power) to interface 205; because of this interconnection to each I/O cell within interface 205, the power demands by one or more cells has an effect on power distribution network 210. For example, transmitters often transmit logical binary values, where a high voltage (e.g. 1 volt) represents a logical one a and a low voltage (e.g. 0.4 volts) represents a logical zero. And as multiple transmitters in interface 205 transition between these voltage levels, the noise generated in network 210 potentially causes adverse power distribution effects (undershoot, droop, overshoot, ringing, etc.). Moreover, specific patterns, such as pattern 250 (a collection of logical values to be transmitted in parallel by multiple transmitters of interface 205), create more noise in network 210 as compared to other patterns; these adverse patterns are often referred to as worse case patterns.
In the illustrative example, pattern input 230 (the binary information from the internal logic to be transmitted through an interconnect) is provided to pattern generation logic 235. Pattern generation logic 235 takes input 230 and formulates a pattern according to a protocol for transmission by interface 225 to an associated interconnect. Previously, a purely random scrambler was sometimes provided to scramble the pattern input in hopes of reducing crosstalk and noise. Yet, these random scramblers only provide ‘random’ scrambling without any knowledge of the worst case patterns or prediction thereof. As a result, whether scrambled or unscrambled, worst case patterns previously could be unknowingly passed to interface 205. And during transmission such worst case patterns were potentially encountered, causing adverse noise scenarios for power distribution network 210.
In contrast, in one embodiment, predictive noise reduction logic 215 is provided to characterize a power distribution network 210 and predict worst case patterns to avoid based on such characterization. Power characterization logic 217 may include any known logic for characterizing or representing power distribution logic, such as network 210 for interface 205. As one embodiment, characterization logic 217 includes logic adapted to implement a mathematical function or logic to capture a mathematical function response.
As a specific illustrative example, characterization logic 217 includes step function logic adapted to determine the step function response of interface 205 including distribution network 210. Mathematically, a step function often refers to a function of real numbers, which can be written as a finite linear combination of indicator functions of intervals (i.e. a piecewise constant function). In this case, a step function stimuli is provided to interface 205 including distribution network 210. As an example, the step function stimuli includes pulling all I/O's of interface 205 to a specific voltage level (providing a current pulse that causes all I/O cells to pull to the voltage level). In one scenario, the I/O's of interface 205 are all driven high. Or alternatively, the I/O's of interface 205 are pulled low. In yet another example, the I/O cells are driven to any voltage level, such as a nominal or threshold voltage.
Referring temporarily to
The step function response associated with interface 205 and network 210 is determined by characterization logic 217 and/or prediction logic 219 based on their response to the step function stimuli. In one embodiment, prediction logic 219 is to predict one or more I/O pattern(s) to avoid based on the mathematical function response. In one case, a resonant frequency associated with interface 205 including network 210 is determined. Here, logic, such as frequency determination logic, is to determine the resonant frequency from characterization logic 217's step function response information regarding interface 205. Additionally, in one embodiment, prediction logic 219 also predicts one or more patterns to avoid transmitting through interface 205. In one case, prediction logic 219 predicts the patterns that generate the resonant frequency (the worst case noise scenarios) for interface 205 including network 210 as determined from the step response by characterization logic 217. Note that the discussion above has been primarily in reference to step function responses and resonant frequencies; however, predictive power noise reduction is not so limited. Other mathematical function responses or power network characterization techniques may be utilized.
Regardless of how patterns to avoid, such as pattern 225, are determined; in one embodiment, a scrambler scrambles (manipulates) incoming pattern 230 in response to detecting that incoming pattern 230 matches/includes a pattern to avoid, such as pattern 225. As mentioned above, previous scramblers didn't take into account specific, worst-case patterns to avoid for noise reduction. Yet, in this case, predicted, worst-case patterns are determined based on actual power distribution network characterization. And those worst-case patterns are provided to generation logic 235 to be avoided. As a result, when one of those patterns is to be generated and transmitted through interface 205, generation logic 235 including a structure, such as a scrambler, manipulates pattern 230. However, note that other apparatus and methods to manipulate or avoid a pattern may be used, where a scrambler is not included. As a result, worst-case patterns are not transmitted through interface 205. And by reducing worst-case noise in network 210, the extreme (corner) noise cases may be reduced/eliminated. Consequently, during design and manufacture, a reduced number of decoupling capacitors and a smaller guard band may be used, which increases die space availability and reduces cost per unit.
Although
Turning to
In addition, predictive noise reduction logic 415 is included to predict patterns that interface 405 is to avoid transmitting, which reduces the worst-case noise in power distribution network 410. Step function logic 416 is adapted to determining a step function response for interface 405 (i.e. a step function response for a power distribution/delivery network 410 for interface 405). In one scenario, step function logic 416, or other logic (stimuli logic that may artificially create a patter in generation logic 435 or directly affect I/O transmitters in interface 405), provide/create a step function stimuli, such as causing some or all of the transmitters in interface 405 to transition to a specific voltage (low, nominal, threshold or high voltages). In another embodiment, certain specific patterns with different logical levels are artificially generated. And the response of network 410 is characterized/profiled.
Based on the response of interface 405 including network 410, frequency logic 417 determines a resonant frequency for power distribution network 410. For example, assume the step function stimuli includes pulling all transmitters of interface 405 to a low logical level (a low voltage level). Step function logic 416, in one embodiment, determines an amount of time (cycles or other known temporal duration measurement) from the stimuli to the transmitters reaching the actual minimum voltage. Essentially, the voltage versus time—V(t)—of interface 405 is tracked/plotted. Based on that amount of time, frequency logic 417 is adapted to determine a resonant frequency of the power distribution network 410. To illustrate, a mathematical equation, such as (one) divided by (two multiplied by the amount of time), approximates the resonant frequency. In other words, a resonant frequency for network 410 is determined from the response of interface 405 to the step function stimuli.
Pattern prediction logic 418, in one embodiment, utilizes the determined resonant frequency to predict one or more patterns for interface 405 to avoid. Any known method of equating a pattern to frequency may be utilized, including a mathematically based prediction. Additionally, actual, post-silicon measurement may be utilized to characterize an impedance profile for the power distribution network, which a resonant frequency and subsequently worst-case patterns are determined from.
In the illustrated embodiment, prediction logic 418 predicts patterns, when transmitted by interface 405, cause the resonant frequency. And thereby potentially cause the worst-case noise in distribution network 410. Note that feedback may be provided from pattern generation logic 435 to pattern prediction/detection logic 418 to ensure there is no resonant frequency content in generated pattern 445 before it reaches I/O interface 405. As a result, in one embodiment, prediction logic 418 includes a feedback loop 470. Here, a first initial prediction may be made based on the step function response and determined resonant frequency. And during runtime, if a transmitted pattern causes a certain amount of measured noise in network 410 (i.e. caused the resonant frequency), that transmitted pattern is added to a list or grouping of patterns predicted by logic 418 to be avoided. Furthermore, the feedback loop 470 potentially includes feedback to any of the other illustrated blocks, such as the step function logic to dynamically adapt to any changes in the power delivery network.
Similar to the discussion of
Note that the discussion above focused on a step response quantified in a time domain (determining a resonant frequency from a voltage response versus time). However, the same noise reduction prediction (predicted I/O patterns to avoid) may be performed in the frequency domain. Additionally, actual, post-silicon measurement may be utilized to characterize an impedance profile for the power distribution network, which a resonant frequency and subsequently worst-case patterns are determined from. The post silicon measurement may be obtained by any known frequency domain impedance measurement technique. For example, one frequency domain technique includes modulating a core clock frequency over a desired frequency range to obtain power delivery network impedance for the frequency range, as well as resonant frequencies/worst-case patterns therefrom.
In reference to
In the illustrated embodiment, voltage comparison logic 516 is to compare the interface logic 505's I/O voltage 510 to a specified, threshold voltage. For example, assume a stimulus of pulling I/Os low is generated. The voltage comparison logic 516, in this example, is to determine if the I/O voltage 510 reaches the minimum voltage. And count logic 517 in conjunction with comparison logic 516 is to determine when (at what point) that minimum (or other specified voltage level) is reached. Here, count logic 517 and voltage comparison logic 516 is to determine an amount of time, such as a number of cycles, from a stimulus until maximum or minimum voltages are reached.
A specific illustrative example of finding a resonant frequency of a network from a step response voltage is described. Here, comparator logic 511 finds a Time ‘T’, as illustrated in the step response chart 315 of
f=½T Equation 1
To provide another perspective of the illustrative example, two storage elements (SE 517a and 517b), such as registers, are included in count logic 517. Here, SE 517a represent a point at which the end voltage levels, such as a minimum or maximum voltages, are reached. And SE 517b indicates a time/number of cycles that elapsed to that corresponding point. In this case, a first logical level (illustrated as a logical one) is shifted (written) into SE 517a until an end voltage (such as a minimum voltage) is reached; at which time a time t1, as above is determined. As depicted, this point at which the end voltages (such as a minimum voltage) are reached is referred to as transition point 518 (i.e. transition point ‘t1’). Similarly, values in SE 517b correspond to the entries of SE 517a and include an amount of elapsed time, such as a number of cycles (i.e. timestamps of associated measurements). For example, assume a counter is reset to zero and starts counting once per cycle from the initiation of the stimulus (pulling all I/Os low). As can be seen in the illustrative example of
Note that the included cycle numbers are purely illustrative. And any temporal measurement may be utilized to measure the period between a system reaching minimum and maximum voltages after a stimulus. The combination of voltage comparison logic 516 and count logic 517 may also be referred to as a specific type of analog to digital converter, such as a flash comparator. As a result, any equivalent structure may be utilized to characterize a power distribution network.
In one embodiment, pattern prediction logic 519 is to predict one or more patterns to avoid based on the output from the flash comparator (516, 517). As an example, a resonant frequency is determined from voltage in comparison to time (the time domain). Here, a resonant frequency is determined from the amount of time, as measured by count logic 517, between reaching end voltages, such as an amount of time between minimum and maximum voltages (an illustrative example shown in chart 315.
And based on that resonant frequency, I/O patterns that are determined to generate the resonant frequency are predicted to be avoided. As aforementioned, such predicted patterns, such as pattern 525, are avoided by interface 505 (e.g. a scrambler scrambles input pattern 530 into pattern 545 if incoming pattern 530 matches predicted pattern 525). However, a scrambler is not required, but is instead only an illustrative example of how to avoid a predicted pattern. Also note that generation logic may be included in interface 505, which was described above. Moreover, a resonant frequency may also be determined by alternative logic and methods, such as stepping clock frequency to determine an impedance profile interface 505 as aforementioned.
Referring next to
In flow 605, a pattern associated with a resonant frequency for a power delivery network associated with an input/output (I/O) interface it is determined. As described above, in one embodiment, is a step function stimuli is provided to an interface. The response of a power delivery network associated with the interface is determined. And from that response, a resonant frequency of the power delivery network is also determined. Based on the resonant frequency, one or more patterns are predicted to be avoided. However, any known method of characterizing a power delivery network or obtaining a resonant frequency of a power distribution network may be utilized. And then any known method of determining a pattern that causes such a resonant frequency may also be used.
Next, in flow 610, the pattern associated with the resonant frequency is detected to be transmitted by the interface. For example, an incoming pattern to be transmitted by the interface is compared against predicted patterns. When a match is found, the pattern associated with the resonant frequency is scrambled or manipulated to obtain a scrambled pattern. And in flow 620, the scrambled pattern is transmitted by the interface, instead of the pattern associated with the resonant frequency that would potentially cause a worst-case noise scenario within the power distribution network. Although not illustrated, receiving logic, in this embodiment, is adapted to understand and descramble the scramble pattern to obtain the appropriate information. Consequently, worst case noise scenarios are potentially avoided, which allows for designers and OEMs to place less capacitors per part; this optimization results in more processor die space a reduction in per unit cost. Note that feedback may be provided from pattern generation logic to pattern prediction/detection logic to ensure there is no resonant frequency content in generated pattern before it reaches an I/O interface. As a result, in one embodiment, feedback loop 417 is included.
In addition, since parts (processors) and platforms vary across products, each interface and power delivery network is unique in its characteristics. As a result, a simulation or other generic solution doesn't address the individuality of the characteristics of each platform, such as potential differing resonant frequencies across different parts of even the same product line. Yet, the apparatus' and methods described herein include actual characterization of each network in a platform to take into account such individual characteristics. As a result, the apparatus' and methods described herein may be implemented across each platform in the same manner, but they provide an adaptive, flexible approach to predicting and reducing noise in a power delivery network that address the problem across platforms in the correct, individualized manner.
A module as used herein refers to any hardware, software, firmware, or a combination thereof. Often module boundaries that are illustrated as separate commonly vary and potentially overlap. For example, a first and a second module may share hardware, software, firmware, or a combination thereof, while potentially retaining some independent hardware, software, or firmware. In one embodiment, use of the term logic includes hardware, such as transistors, registers, or other hardware, such as programmable logic devices. However, in another embodiment, logic also includes software or code integrated with hardware, such as firmware or micro-code.
A value, as used herein, includes any known representation of a number, a state, a logical state, or a binary logical state. Often, the use of logic levels, logic values, or logical values is also referred to as 1's and 0's, which simply represents binary logic states. For example, a 1 refers to a high logic level and 0 refers to a low logic level. In one embodiment, a storage cell, such as a transistor or flash cell, may be capable of holding a single logical value or multiple logical values. However, other representations of values in computer systems have been used. For example the decimal number ten may also be represented as a binary value of 1010 and a hexadecimal letter A. Therefore, a value includes any representation of information capable of being held in a computer system.
Moreover, states may be represented by values or portions of values. As an example, a first value, such as a logical one, may represent a default or initial state, while a second value, such as a logical zero, may represent a non-default state. In addition, the terms reset and set, in one embodiment, refer to a default and an updated value or state, respectively. For example, a default value potentially includes a high logical value, i.e. reset, while an updated value potentially includes a low logical value, i.e. set. Note that any combination of values may be utilized to represent any number of states.
The embodiments of methods, hardware, software, firmware or code set forth above may be implemented via instructions or code stored on a machine-accessible or machine readable medium which are executable by a processing element. A machine-accessible/readable medium includes any mechanism that provides (i.e., stores and/or transmits) information in a form readable by a machine, such as a computer or electronic system. For example, a machine-accessible medium includes random-access memory (RAM), such as static RAM (SRAM) or dynamic RAM (DRAM); ROM; magnetic or optical storage medium; flash memory devices; electrical storage devices; optical storage devices; acoustical storage devices; other form of storage devices for holding propagated signals (e.g., carrier waves, infrared signals, digital signals); etc.
Reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Thus, the appearances of the phrases “in one embodiment” or “in an embodiment” in various places throughout this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures, or characteristics may be combined in any suitable manner in one or more embodiments.
In the foregoing specification, a detailed description has been given with reference to specific exemplary embodiments. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense. Furthermore, the foregoing use of embodiment and other exemplarily language does not necessarily refer to the same embodiment or the same example, but may refer to different and distinct embodiments, as well as potentially the same embodiment.
Number | Name | Date | Kind |
---|---|---|---|
5856755 | Falconer | Jan 1999 | A |
6204583 | Falconer | Mar 2001 | B1 |
6249142 | Hall et al. | Jun 2001 | B1 |
6577179 | Falconer | Jun 2003 | B2 |
6587323 | Falconer | Jul 2003 | B1 |
6741165 | Langfahl et al. | May 2004 | B1 |
6774819 | Falconer | Aug 2004 | B1 |
6794895 | Falconer | Sep 2004 | B2 |
6834109 | Pare, Jr. et al. | Dec 2004 | B1 |
6870901 | Gudmundsson et al. | Mar 2005 | B1 |
6970415 | Galarza et al. | Nov 2005 | B1 |
6970560 | Hench et al. | Nov 2005 | B1 |
6978015 | Erickson et al. | Dec 2005 | B1 |
7076677 | Falconer | Jul 2006 | B2 |
7098670 | Cole | Aug 2006 | B2 |
7349480 | Tsatsanis | Mar 2008 | B2 |
7522515 | Tsatsanis | Apr 2009 | B2 |
7796544 | Hench | Sep 2010 | B2 |
7864692 | Hench et al. | Jan 2011 | B1 |
7945050 | Mozak | May 2011 | B2 |
8139658 | Tsatsanis et al. | Mar 2012 | B2 |
8503678 | Falconer | Aug 2013 | B2 |
20050194981 | Cole | Sep 2005 | A1 |
20060226854 | Cole | Oct 2006 | A1 |
20090017761 | Li et al. | Jan 2009 | A1 |
20100003938 | Hunter et al. | Jan 2010 | A1 |
20120076007 | Nelson | Mar 2012 | A1 |
20120159226 | Prathaban et al. | Jun 2012 | A1 |
Number | Date | Country | |
---|---|---|---|
20120159226 A1 | Jun 2012 | US |