CN111052068A - Memory array accessibility - Google Patents
Memory array accessibility Download PDFInfo
- Publication number
- CN111052068A CN111052068A CN201880056010.3A CN201880056010A CN111052068A CN 111052068 A CN111052068 A CN 111052068A CN 201880056010 A CN201880056010 A CN 201880056010A CN 111052068 A CN111052068 A CN 111052068A
- Authority
- CN
- China
- Prior art keywords
- data
- array
- row
- controller
- registers
- 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.)
- Granted
Links
- 238000000034 method Methods 0.000 claims abstract description 25
- 230000004044 response Effects 0.000 claims description 14
- 230000008685 targeting Effects 0.000 claims 1
- 230000000295 complement effect Effects 0.000 description 36
- 238000012545 processing Methods 0.000 description 24
- 238000010586 diagram Methods 0.000 description 21
- 239000013598 vector Substances 0.000 description 9
- 238000003491 array Methods 0.000 description 8
- 238000002955 isolation Methods 0.000 description 8
- 238000012546 transfer Methods 0.000 description 8
- 239000003990 capacitor Substances 0.000 description 7
- 238000013459 approach Methods 0.000 description 5
- 230000006870 function Effects 0.000 description 5
- 230000008569 process Effects 0.000 description 5
- 230000008859 change Effects 0.000 description 4
- 230000004048 modification Effects 0.000 description 4
- 238000012986 modification Methods 0.000 description 4
- 238000011067 equilibration Methods 0.000 description 3
- 230000011664 signaling Effects 0.000 description 3
- 230000003068 static effect Effects 0.000 description 3
- 230000003213 activating effect Effects 0.000 description 2
- 238000001514 detection method Methods 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 230000000153 supplemental effect Effects 0.000 description 2
- 230000004913 activation Effects 0.000 description 1
- 230000006978 adaptation Effects 0.000 description 1
- 230000002411 adverse Effects 0.000 description 1
- 230000000903 blocking effect Effects 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 230000001066 destructive effect Effects 0.000 description 1
- 238000010304 firing Methods 0.000 description 1
- 238000007667 floating Methods 0.000 description 1
- 230000000737 periodic effect Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 239000013589 supplement Substances 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/062—Securing storage systems
- G06F3/0622—Securing storage systems in relation to access
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/0644—Management of space entities, e.g. partitions, extents, pools
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0659—Command handling arrangements, e.g. command buffers, queues, command scheduling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/06—Sense amplifiers; Associated circuits, e.g. timing or triggering circuits
- G11C7/065—Differential amplifiers of latching type
-
- 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/1006—Data managing, e.g. manipulating data before writing or reading out, data bus switches or control circuits therefor
Abstract
Apparatus and methods for memory array accessibility may include an apparatus having an array of memory cells. The array may include a first portion accessible by a controller of the array and inaccessible to a device external to the apparatus. The array may include a second portion accessible to the device external to the apparatus. The array may include a number of registers that store row addresses that indicate which portion of the array is the first portion. The apparatus may include the controller configured to access the number of registers to allow the device external to the apparatus to access the second portion based on the stored row address.
Description
Technical Field
The present disclosure relates generally to semiconductor memory devices and methods, and more particularly to devices and methods related to memory array accessibility.
Background
Memory devices are typically provided as internal semiconductor integrated circuits in computers or other electronic systems. There are many different types of memory, including volatile and non-volatile memory. Volatile memory may require power to maintain its data (e.g., host data, error data, etc.) and includes Random Access Memory (RAM), Dynamic Random Access Memory (DRAM), Static Random Access Memory (SRAM), Synchronous Dynamic Random Access Memory (SDRAM), and Thyristor Random Access Memory (TRAM), among others. Non-volatile memory may provide persistent data by retaining stored data when not powered, and may include NAND flash memory, NOR flash memory, and resistance variable memory, such as Phase Change Random Access Memory (PCRAM), Resistive Random Access Memory (RRAM), and Magnetoresistive Random Access Memory (MRAM), such as spin torque transfer random access memory (sttram), among others.
Electronic systems typically include a number of processing resources (e.g., one or more processors) that can retrieve and execute instructions and store the results of the executed instructions in an appropriate location. A processor may include a number of functional units (e.g., referred to herein as functional unit circuits), such as Arithmetic Logic Unit (ALU) circuits, Floating Point Unit (FPU) circuits, AND/OR combinational logic blocks, that may execute instructions to perform logical operations (e.g., AND, OR, NOT, NAND, NOR, AND XOR logical operations) on data (e.g., one OR more operands).
Several components in an electronic system may be involved in providing instructions to functional unit circuitry for execution. The instructions may be generated, for example, by a processing resource such as a controller and/or a host processor. Data (e.g., operands on which an instruction is to be executed to perform a logical operation) can be stored in a memory array, which can be accessed by the functional unit circuitry. Instructions and/or data may be retrieved from the memory array and sorted and/or buffered before the functional unit circuitry begins executing instructions on the data. Furthermore, since different types of operations may be performed in one or more clock cycles via the functional unit circuitry, intermediate results and/or data of the operations may also be ordered and/or buffered.
In many cases, the processing resources (e.g., the processor and/or associated functional unit circuitry) may be external to the memory array and data may be accessed (e.g., via a bus between the processing resources and the memory array) to execute instructions. Data may be transferred from the memory array to an external processing resource via a bus. Data being transferred between the memory array and the external processing resource may be detected en route (e.g., by "snooping" pins of the bus). Some methods of providing security for data transfer may include encrypting/decrypting data; however, the encryption/decryption process may adversely affect system performance and/or increase circuit complexity, among other drawbacks.
Drawings
Fig. 1 is a block diagram of an apparatus in the form of a computing system including a memory device, according to several embodiments of the present disclosure.
FIG. 2 illustrates a schematic diagram of a portion of a memory array, according to several embodiments of the present disclosure.
FIG. 3 illustrates a schematic diagram of a portion of a memory array, according to several embodiments of the present disclosure.
FIG. 4 illustrates a schematic diagram of a portion of a memory array, according to several embodiments of the present disclosure.
FIG. 5 illustrates a schematic diagram of an example method of memory array accessibility, in accordance with several embodiments of the present disclosure. FIG. 6 is a schematic diagram illustrating a sensing circuit according to several embodiments of the present disclosure.
FIG. 7 is a schematic diagram illustrating a sensing circuit having selectable logical operation selection logic in accordance with several embodiments of the present disclosure.
FIG. 8 is a logic table illustrating results of selectable logic operations implemented by a sensing circuit in accordance with several embodiments of the present disclosure.
FIG. 9 illustrates a timing diagram associated with performing logic operations and shift operations using sensing circuitry in accordance with several embodiments of the present disclosure.
FIG. 10 illustrates a timing diagram associated with performing logic operations and shift operations using sensing circuitry in accordance with several embodiments of the present disclosure.
Detailed Description
An example apparatus includes an array of memory cells. The array may include a first portion that is accessible to a controller of the array and inaccessible to a device external to the apparatus. The array may include a second portion accessible to a device external to the apparatus. The array may include a number of registers that store a row address indicating which portion of the array is the first portion. The apparatus may include a controller configured to access the number of registers to allow a device external to the apparatus to access a second portion based on a stored row address.
According to various embodiments of the present disclosure, data stored in a memory array may be protected by preventing access to a particular portion of the memory array and allowing access to another portion of the memory array. For example, a device external to a memory built-in Processor (PIM) device, such as an external processor, may be prevented from accessing a particular portion (e.g., a non-accessible portion), and an external device may be allowed to access another portion (e.g., an accessible portion) of the memory array. The rows of registers may include addresses that indicate boundaries of inaccessible (e.g., protected) portions of the memory array, and data corresponding to addresses outside of the boundaries may be accessed by an external device. In at least one embodiment, the number of line registers may be written only by ISA instructions. As used herein, a PIM device refers to a memory device capable of performing bit vector operations on bit vectors stored in an array without transferring data to a processing resource external to the PIM device, such as a host processor.
A first row of registers may store an address indicating the beginning of the inaccessible portion and a second row of registers may store an address indicating the end of the inaccessible portion. The address stored in the row register can be modified in order to dynamically modify the inaccessible portion in response to more or less data being protected in the memory array. Since the protected data from the inaccessible portion is not transferred via the bus and/or pins across the PIM device, the protected data is not accessible by an external device that attempts to read the data while the data is being transferred, in order to determine how to access the protected data, change passwords or access to the protected data, alter instructions in the memory array, etc.
As used herein, "bit vector operations" are intended to refer to operations performed on bit vectors associated with virtual address spaces and/or physical address spaces used by PIM devices. Examples of bit vector operations may include logical operations (e.g., boolean operations) and/or mathematical operations (e.g., addition, subtraction, multiplication, division, etc.), among others. Fig. 6-11, described below, describe the operation of the PIM device and additionally describe how the operation is performed without transferring data external to the PIM device. Maintaining data in the memory device allows data in the first portion of the memory array to be protected when data and/or instructions in the memory array can be executed or operated on without transferring data along the bus and/or across pins that can be detected by an external device (e.g., a hacker, a detection device, etc.).
In some embodiments, the bit vector may be a physically contiguous number of bits that are physically contiguous stored in a row and/or in sensing circuitry of the PIM device. For example, a row of virtual address space in a PIM device may have a bit length of 16K bits (e.g., corresponding to 16K complementary pairs of memory cells in a DRAM configuration). As described herein, sensing circuitry 150 for such 16K bit rows can include corresponding 16K processing elements (e.g., compute components as described herein) that are formed at a pitch with sense lines that can be selectively coupled to corresponding memory cells in the 16 bit rows. As described additionally in conjunction with fig. 6 and elsewhere herein, the computing components and corresponding sense amplifiers in the PIM device may operate as a one-bit processing element.
Several embodiments of the present disclosure may provide improved parallelism and/or reduced power consumption in performing logic operations as compared to previous systems having external processors (e.g., processing resources located outside of a memory array, such as on a separate integrated circuit chip). For example, several embodiments may enable performing operations such as integer addition, subtraction, multiplication, division, and Content Addressable Memory (CAM) operations without transferring data out of the memory array and sensing circuitry via, for example, buses (e.g., data bus, address bus, control bus). However, embodiments are not limited to these examples. For example, the PIM device may perform several non-boolean logic operations, such as sense amplifier set, sense amplifier clear, copy, compare, destroy, and the like.
In previous approaches, data may be transferred from the array and sensing circuitry (e.g., via a bus comprising input/output (I/O) lines) to processing resources such as processors, microprocessors, and/or compute engines, which may include ALU circuitry and/or other functional unit circuitry configured to perform appropriate logical operations. However, transferring data from the memory array and sensing circuitry to such processing resources may involve significant power consumption. Even if the processing resources are located on the same chip as the memory array, significant power can be consumed in the following process: moving data out of the array to computational circuitry, which may involve performing a sense line (which may be referred to herein as a digit line or a data line) address access (e.g., activating a column decode signal) in order to transfer data from the sense line onto an I/O line (e.g., a local I/O line), moving the data to the array periphery, and providing the data to circuitry to perform computational functions. The ability of the PIM device to perform operations within the memory (e.g., in conjunction with executing instructions) allows data to be moved through the array to be processed without being transferred across the bus and/or across pins. In this way, a "monolithic" architecture for internally protecting data in a memory array may be achieved.
Furthermore, in some previous approaches, the circuitry of the processing resource (e.g., compute engine) may not comply with the pitch rules associated with the memory array. For example, a cell of a memory array may have a 4F2Or 6F2Cell size, where "F" is the feature size corresponding to a cell. Thus, devices (e.g., logic gates) associated with the ALU circuitry of previous PIM systems may not be able to be formed at the same spacing as the sense lines of the array, whichFor example, chip size and/or memory density may be affected.
For example, the sensing circuitry 150 described herein can be formed at the same pitch with a pair of complementary sense lines. For example, a pair of complementary memory cells may have a bit line with 6F2A unit size of pitch (e.g., 3F × 2F). If the spacing of a pair of complementary sense lines for a complementary memory cell is 3F, then the sensing circuitry being spaced indicates that the sensing circuitry (e.g., sense amplifiers and corresponding compute components of each respective pair of complementary sense lines) is formed to fit within the 3F spacing of the complementary sense lines.
In the following detailed description of the present disclosure, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration ways in which one or more embodiments of the disclosure may be practiced. These embodiments are described in sufficient detail to enable those of ordinary skill in the art to practice the embodiments of this disclosure, and it is to be understood that other embodiments may be utilized and that process, electrical, and structural changes may be made without departing from the scope of the present disclosure. As used herein, the designation "N" specifically with respect to a reference numeral in the drawings indicates that a number of the specific features so designated may be included. As used herein, "a number of a particular thing can refer to one or more of such things (e.g., a number of memory arrays can refer to one or more memory arrays).
The figures herein follow a numbering convention in which the first one or more digits correspond to the drawing figure number and the remaining digits identify an element or component in the drawing. Similar elements or components between different figures may be identified by the use of similar digits. For example, 206 may represent element "06" in fig. 2, and a similar element may be represented as 606 in fig. 6. As will be appreciated, elements shown in the various embodiments herein can be added, exchanged, and/or removed to provide several additional embodiments of the present disclosure. Additionally, as will be appreciated, the proportion and the relative scale of the elements provided in the figures are intended to illustrate certain embodiments of the present invention, and should not be taken in a limiting sense.
Fig. 1 is a block diagram of an apparatus in the form of a computing system 100 including a memory device 120, according to several embodiments of the present disclosure. As used herein, memory device 120, memory array 130, controller 140, and/or sensing circuitry 150 may also be considered "apparatus" individually.
The system 100 includes a host 110 coupled (e.g., connected) to a memory device 120 that includes a memory array 130. The memory device 120 may be a PIM device. Host 110 may be a host system such as a personal handheld computer, desktop computer, digital camera, smart phone, or memory card reader, among various other types of hosts. The host 110 may include a system motherboard and/or backplane, and may include a number of processing resources (e.g., one or more processors, microprocessors, or some other type of control circuitry). The system 100 may include separate integrated circuits, or both the host 110 and the memory device 120 may be on the same integrated circuit. For example, system 100 may be a server system and/or a High Performance Computing (HPC) system and/or a portion thereof. Although the example shown in fig. 1 illustrates a system having a Von Neumann architecture, embodiments of the present disclosure may be implemented in a non-Von Neumann architecture (e.g., a Turing (Turing) machine) that may not include one or more components (e.g., CPUs, ALUs, etc.) typically associated with Von Neumann architectures.
For clarity, the system 100 has been simplified to focus on features particularly relevant to the present disclosure. The memory array 130 may be, for example, a DRAM array, an SRAM array, an STT RAM array, a PCRAM array, a TRAM array, a RRAM array, a NAND flash array, and/or a NOR flash array. Array 130 may include memory cells arranged in rows coupled by access lines (which may be referred to herein as word lines or select lines) and arranged in columns coupled by sense lines. Although a single array 130 is shown in fig. 1, embodiments are not limited thereto. For example, the memory device 120 may include several arrays 130 (e.g., arrays of DRAM cells). An example DRAM array is described in connection with fig. 6.
The controller 140 decodes signals provided from the host 110 via the control bus 154. These signals may include chip enable signals, write enable signals, and address latch signals to control operations performed on the memory array 130, including data read, data write, and data erase operations. In various embodiments, the controller 140 is responsible for executing instructions from the host 110. The controller 140 may be a state machine, a sequencer, or some other type of control circuitry. The controller 140 may be implemented in hardware, firmware, and/or software. The controller 140 may also control a shift circuit, which may be implemented, for example, in the sensing circuit 150 according to various embodiments.
Examples of the sensing circuit 150 are described further below. For example, in several embodiments, the sensing circuitry 150 may include several sense amplifiers (e.g., the sense amplifier shown as 606 in FIG. 6 and 706 in FIG. 7) and several compute components (e.g., the compute component shown as 631 in FIG. 6 and/or 731 in FIG. 7) that may be used to perform bit vector operations on data stored in the array 130. The sense amplifier may include, for example, a static latch, which may be referred to herein as a master latch. The compute component 631 may include, for example, dynamic and/or static latches, which may be referred to herein as secondary latches, and may act and be referred to as accumulators.
In a number of embodiments, sensing circuitry (e.g., 150) can be used to perform operations using data stored in the array 130 as inputs and store the results of the logical operations back to the array 130 without transferring the data via sense line address access (e.g., without asserting a column decode signal). Thus, various logic functions may be performed using the sensing circuitry 150 and within the sensing circuitry 150, rather than being performed by (or in conjunction with) processing resources external to the sensing circuitry, such as by a processor associated with the host 110 and other processing circuitry, such as ALU circuitry located on the device 120 (e.g., on the controller 140 or elsewhere).
In various previous approaches, for example, data associated with operands would be read from memory via sense circuitry and provided to external ALU circuitry via I/O lines (e.g., via local I/O lines and global I/O lines). The external ALU circuitry may include a number of registers and will perform logical operations using the operands and transfer the results back to the array (e.g., 130) via the I/O lines. In contrast, in several embodiments of the present disclosure, sensing circuitry (e.g., 150) is configured to perform bit vector operations (e.g., logic operations) on data stored in memory (e.g., array 130) and store the results back to memory without enabling I/O lines (e.g., local I/O lines) coupled to the sensing circuitry, which may be formed on pitch with the memory cells of the array. Enabling the I/O line may include enabling (e.g., turning on) a transistor having a gate coupled to a decode signal (e.g., a column decode signal) and a source/drain coupled to the I/O line. The embodiments are not limited thereto. For example, in a number of embodiments, sensing circuitry (e.g., 150) can be used to perform logical operations without enabling column decode lines of the array; however, the local I/O lines may be enabled in order to transfer the results to the appropriate location rather than back to the array (e.g., to an external register).
Thus, in several embodiments, the array 130 and various circuitry external to the sensing circuitry 150 (e.g., external registers associated with the ALUs) need not perform logic functions, as the sensing circuitry 150 may perform appropriate logic operations to perform such logic functions without using external processing resources. In this manner, instructions in the array 130 may be executed on data stored in the array 130 internally to the array 130 without transferring the data out of the array and without exposing the data to possible detection, interception, hacking, and the like. Data and instructions in portions of the array that are not accessible by external devices may be protected, and additional portions of the array 130 storing unprotected data may be accessible.
Further, the sensing circuit 150 can be used to supplement and/or replace, at least to some extent, such external processing resources (or at least the bandwidth of such external processing resources). However, in several embodiments, in addition to performing logical operations by an external processing resource (e.g., host 110), the sensing circuit 150 may be used to perform logical operations (e.g., execute instructions). For example, the host 110 and/or the sensing circuitry 150 may be limited to performing only certain logical operations and/or a particular number of logical operations.
Fig. 2 illustrates a schematic diagram of a portion of a memory array 230, according to several embodiments of the present disclosure. The memory array 230 may be, for example, a DRAM array, an SRAM array, an STT RAM array, a PCRAM array, a TRAM array, a RRAM array, a NAND flash memory array, and/or a NOR flash memory array. Array 230 can include memory cells arranged in rows coupled by access lines (which can be referred to herein as word lines or select lines) and arranged in columns coupled by sense lines. Although a single array 230 is shown in fig. 2, embodiments are not limited thereto. For example, a memory device (such as memory device 120 in FIG. 1) may include several arrays 130 (e.g., arrays of DRAM cells). An example DRAM array is described in connection with fig. 7.
The memory array 230 may include a first portion 232 and a second portion 236. First portion 232 may include a number of rows of memory cells, illustrated as row X233 through row Y235, that are inaccessible (e.g., protected) by devices external to the memory device, such as memory device 120. As an example, a device external to the memory device cannot access data stored in the first portion 232, cannot execute instructions stored in the first portion 232, and cannot read data from and/or write data into the first portion 232. The first portion 232 may be accessible within a memory device (e.g., memory device 120), such as by a controller (e.g., controller 140). The first portion 232 may store data and/or instructions that may be executed by the controller. Data and/or instructions originating from first portion 232 may be prevented from being read while in the processor so that they are protected even when read by the processor inside the memory device.
The instructions may refer to Instruction Set Architecture (ISA) instructions, which may be binary-coded instructions that are accepted by the PIM device to perform various bit vector operations. ISA refers to the interface or boundary between software and hardware. Generally, programs executable on a PIM device can include a set of ISA instructions and data (e.g., operands). The ISA may allow for multiple implementations that may vary in terms of performance, physical size, and cost. An instruction stored in the first portion 232 may execute the instruction using data stored in the first portion 232 and the second portion 236 (e.g., using the data as operands). Instructions stored in the first portion 232 may be prevented from being executed at additional locations outside of the second portion 236 or the memory device. Instructions originating outside of the first portion 232 (e.g., DRAM Activate (ACT) instructions) may be prevented from being executed in the first portion 232. Instructions internal to the PIM device (e.g., PIM DRAM Activate (ACT) instructions) may be prevented from being executed outside of the first portion 323. In at least one embodiment, the instructions are executable to store the data result in the second portion 236. Data stored into the second portion 236 by a device external to the PIM device may only be stored in the first portion 232 by execution of the instructions in the first portion 232.
The second portion 236 may include several rows, namely row Y +1 through row Y + N. The second portion 236 may store data that is accessible to a memory device (e.g., the memory device 120) and a device external to the memory device. To transfer data stored in the first portion 232 to an external device, the data may be transferred to the second portion 236 and from the second portion 236 to the external device. To use the data set from the external device, the data set from the external device may be transferred to the second portion 236 and the instructions stored in the first portion 232 may be executed using the data set.
In at least some embodiments, the second portion 236 may be prevented from storing instructions in the second portion 236. In this manner, instructions may be restricted to being executed from the first portion 232 and not being executed from the second portion 236. The data stored in the second portion 236 may be recognized only as data (e.g., operands) and not as instructions. If an external device has added incorrect or erroneous data to the second portion 236, executing instructions from the first portion 232 may cause an error or incorrect result but not allow the instructions in the first portion 232 to be accessed or modified. Since the data in the second portion 236 is accessible, storing only the data and not the instructions in the second portion 236 prevents the instructions from being stored in the second portion 236 and executed from within the second portion 236 by an external device.
In at least one embodiment, the second portion 236 can store instructions for execution by the controller without reading data resulting from the execution or writing into the first portion 232. In this manner, data and/or instructions stored in the first portion 232 are protected from modification by instructions stored and executed in the second portion 236.
In response to a reset (e.g., a soft reset or a hard reset) of the memory device, the first portion 232 may be cleared (e.g., reset). In this manner, data within first portion 232 is also cleared in response to row registers 238, 239 reset that define the boundaries of first portion 232. Otherwise, when the row registers 238, 239 are reset, the boundary of the first portion 232 protecting the data may be cleared, and the data in the first portion 232 will be accessible to external devices and therefore not protected. By resetting the data of the first portion 232, the data previously stored in the first portion 232 is protected upon the memory device reset.
A memory device (e.g., memory device 120 in fig. 1) including memory array 230 may include fuses that disable row registers 238, 239 by default and that define first portion 232 without using the row registers 238, 239. Once the fuses are deactivated, the row registers 238, 239 may be activated to define the first portion 232.
FIG. 3 illustrates a schematic diagram of a portion of a memory array 330, according to several embodiments of the present disclosure. The memory array 330 may include a first portion 332 and a second portion 336. First portion 332 can include a number of rows of memory cells, illustrated as row X (333) through row Y (335), that are inaccessible (e.g., protected) by devices external to the memory device, such as memory device 120. The first portion 332 may be accessible within a memory device (e.g., memory device 120), such as by a controller (e.g., controller 140). The first portion 232 may store data and/or instructions that may be executed by the controller. The second portion 236 may include several rows, namely row Y +1 through row N. The second portion 236 may store data that is accessible to a memory device (e.g., the memory device 120) and a device external to the memory device.
The memory array 330 may include registers 338, 339 that store addresses associated with the first portion 332 and provide access control to the first portion 332. The registers 338, 339 may be stored in the periphery of the array 330 of memory cells (e.g., no operand data is stored in the cells). The first register 338 stores a row address of an initial row of cells that store data in the first portion 332. The second register 339 stores the row address of the last row of cells storing data in the first portion 332. In this manner, the row addresses stored in the first and second registers 338, 336 define the boundaries of the first portion 332 that are inaccessible to external devices.
The row addresses stored in the first and second registers 338, 339 may be modified in order to modify which cells of the array 330 are in the first portion 232 of cells and thereby modify which cells are not accessible to external devices. For example, the address stored in the second row register 338 may be modified from being associated with row Y (235) in FIG. 2 to being associated with row 337-1 to add an additional row of cells into the first portion 332. The additional modifications may include modifying the address stored in the second row register 338 to be associated with row 337-2 to add an additional row of cells, and the additional modifications may include modifying the address to be associated with row 337-3.
In this way, the amount of cell rows may be reduced to a size between row X333 and row 337-1, increased to an amount of rows between row X and row 337-2, and additionally increased to an amount of rows between row X and row 337-3. The modification may be based on the amount of data protected in the first portion 332. The row registers 338, 339 may be writable by ISA instructions. The row registers 338, 339 may be writable by ISA instructions executed from the first portion 332. By modifying the size of the first portion 332, the memory array 330 may dynamically protect the amount of data based on the size of the data and without being limited by the size of the first portion 332.
FIG. 4 illustrates a schematic diagram of a portion of a memory system 404 in accordance with several embodiments of the present disclosure. The memory system 404 may include a memory device (e.g., PIM device) 420 and encrypted user data 449 stored on a hard disk drive. The memory device 420 may include a memory array 430, a decryption key 441, and a hardware decryption engine 443.
The memory array 430 may include a first portion (e.g., a non-accessible portion) 432, a second portion (accessible portion 436 and row registers 438, 439. decryption key 441 may be used to trigger fuses in the memory device 420 to indicate that the rows of the first portion 432 are defined using the row registers 438, 439. the row registers 438, 439 may initially indicate that the first portion 432 is allowed to be accessed when data is initially loaded into the first portion.
FIG. 5 illustrates a schematic diagram of an example method 505 of memory array accessibility in accordance with several embodiments of the present disclosure. Method 505 may include clearing the memory array (e.g., memory arrays 230, 330, 430 in fig. 2-4, respectively) and the register (e.g., registers 238, 239, 338, 339, 438, 439 in fig. 2-4, respectively) at 551. In at least one embodiment, the first portion (e.g., first portion 232, 332, 432) and the second portion (e.g., second portion 236, 336, 436) can be eliminated. In at least one embodiment, the first portion can be removed and the second portion not.
The method 505 may include, at 555, decrypting the write into the first portion. The writing may be allowed by reversing the normal process of initially blocking writing or reading into the first portion, at which point the data to be protected will be written to the first portion at some point or where no data previously written thereto needs to be protected. The write may be data from an external device and/or a controller of a memory device, such as memory device 120 in fig. 1. The data written may be data indicating protection by the memory array. Where a first portion of a memory array has limited access (e.g., an external device does not access the first portion), data is written into the first portion.
The method 505 may include, at 559, performing a normal protected operation. The protected operation may include executing an instruction stored in the first portion on data (e.g., an operand) stored in either of the first portion and the second portion. The protected operation may include preventing an external device from accessing the first portion upon execution of the execution instruction in the first portion. The protected operation may include preventing instructions stored outside the first portion from being executed in the first portion. The protected operation may include preventing instructions from the first portion from executing outside the first portion. In this way, data stored in the first portion is prevented from being snooped or detected by hackers. Instructions and/or data stored in the first portion may be prevented from being read and no instructions and/or data may be written to the first portion. To access the data in the first portion, the data may be first written to and then read from the second portion.
FIG. 6 is a schematic diagram illustrating a sensing circuit according to several embodiments of the present disclosure. A memory cell includes a storage element (e.g., a capacitor) and an access device (e.g., a transistor). For example, transistor 602-1 and capacitor 603-1 comprise memory cells, and transistor 602-2 and capacitor 603-2 comprise memory cells, and so on. In this example, memory array 630 is a DRAM array of one transistor one capacitor (1T1C) memory cells. In a number of embodiments, the memory cells can be destructive read memory cells (e.g., reading data stored in a cell destroys data such that data originally stored in the cell is refreshed after being read).
The cells of the memory array 630 may be arranged in rows coupled by word lines 604-X (row X), 604-Y (row Y), etc., and columns coupled by pairs of complementary sense lines (e.g., data lines DIGIT (n)/DIGIT (n)) _. The individual sense lines corresponding to each pair of complementary sense lines may also be referred to as data lines 605-1(D) and 605-2(D _), respectively. Although only a pair of complementary data lines (e.g., one column) is shown in fig. 6, embodiments of the disclosure are not so limited, and the memory cell array may include additional columns of memory cells and/or data lines (e.g., 4096, 8192, 16384, etc.).
The memory cells may be coupled to different data lines and/or word lines. For example, a first source/drain region of the transistor 602-1 may be coupled to the data line 605-1(D), a second source/drain region of the transistor 602-1 may be coupled to the capacitor 603-1, and a gate of the transistor 602-1 may be coupled to the word line 604-Y. A first source/drain region of the transistor 602-2 may be coupled to the data line 605-2(D _), a second source/drain region of the transistor 602-2 may be coupled to the capacitor 603-2, and a gate of the transistor 602-2 may be coupled to the word line 604-X. A cell plate as shown in fig. 6 may be coupled to each of capacitors 603-1 and 603-2. The cell plates may be common nodes to which a reference voltage (e.g., ground) may be applied in various memory array configurations.
The memory array 630 is coupled to sensing circuitry 650, according to several embodiments of the present disclosure. In this example, the sense circuitry 650 includes sense amplifiers 606 and compute components 631 corresponding to respective columns of memory cells (e.g., coupled to respective pairs of complementary data lines). For example, the sensing circuit 650 may correspond to the sensing circuit 150 shown in fig. 1. Sense amplifier 606 can be coupled to the pair of complementary sense lines 605-1 and 605-2. The compute component 631 may be coupled to the sense amplifier 606 via pass gates 607-1 and 607-2. The gates of pass gates 607-1 and 607-2 may be coupled to logic operation selection logic 613.
The logic operation selection logic 613 may be configured to include pass gate logic for controlling pass gates coupled to the pair of complementary sense lines 605-1 and 605-2 that are not transposed between the sense amplifier 606 and the compute component 631 (as shown in FIG. 6), and/or swap gate logic for controlling swap gates coupled to the pair of complementary sense lines that are transposed between the sense amplifier 606 and the compute component 631 (such as discussed later with respect to FIG. 7). The logical operation selection logic 613 may also be coupled to the pair of complementary sense lines 605-1 and 605-2. The logical operation selection logic 613 may be configured to control the pass gates 607-1 and 607-2 (e.g., to control whether the pass gates 607-1 and 607-2 are in a conductive state or a non-conductive state) based on the selected logical operation, as described in detail below for various configurations of the logical operation selection logic 613.
The sense amplifier 606 may be operated to determine a data value (e.g., a logic state) stored in a selected memory cell. Sense amplifier 606 may include cross-coupled latches, which may be referred to herein as master latches. In the example illustrated in FIG. 6, the circuit corresponding to the sense amplifier 606 includes a latch 615 that includes four transistors coupled to the pair of complementary data lines 605-1 and 605-2. However, embodiments are not limited to this example. The latch 615 may be a cross-coupled latch (e.g., the gates of a pair of transistors, such as n-channel transistors (e.g., NMOS transistors) 627-1 and 627-2) cross-coupled with the gates of another pair of transistors, such as p-channel transistors (e.g., PMOS transistors) 629-1 and 629-2).
In operation, when a memory cell is being sensed (e.g., read), the voltage on one of the data lines 605-1(D) or 605-2(D _) will be slightly greater than the voltage on the other of the data lines 605-1(D) or 605-2(D _). The ACT signal may be driven high and the RNL signal may be driven low to enable (e.g., fire) the sense amplifier 606. The data line 605-1(D) or 605-2 (D) having the lower voltage will turn on the other of the PMOS transistors 629-1 or 629-2 (D) to a greater extent than one of the PMOS transistors 629-1 or 629-2 (D), thereby driving the data line 605-1(D) or 605-2 (D) having the higher voltage high to a greater extent than the other data line 605-1(D) or 605-2 (D) is driven high.
Similarly, the data line 605-1(D) or 605-2 (D) having a higher voltage will turn on the other one of the NMOS transistors 627-1 or 627-2 to a greater extent than one of the NMOS transistors 627-1 or 627-2, thereby driving the other data line 605-1(D) or 605-2 (D) to a greater extent than the other data line 605-1(D) or 627-2 (D) to lowData line 605-1(D) or 605-2(D _) is driven low. Thus, after a short delay, the data line 605-1(D) or 605-2(D _) having a slightly larger voltage is driven to the supply voltage VDDE.g., through a source transistor (not shown)), and the other data line 605-1(D) or 605-2(D _) is driven to the voltage of the reference voltage (e.g., to Ground (GND) through a sink transistor (not shown)). Thus, the cross-coupled NMOS transistors 627-1 and 627-2 and PMOS transistors 629-1 and 629-2 act as a pair of sense amplifiers that amplify the differential voltage on data lines 605-1(D) and 605-2(D _) and are used to latch the data value sensed from the selected memory cell.
Embodiments are not limited to the sense amplifier 606 configuration illustrated in FIG. 6. As an example, sense amplifier 606 may be a current mode sense amplifier and/or a single ended sense amplifier (e.g., a sense amplifier coupled to one digit line). Also, embodiments of the present disclosure are not limited to the folded data line architecture, such as shown in fig. 6.
The sense amplifier 606 may operate in conjunction with a compute component 631 to perform various logical operations using data from the array as inputs. In several embodiments, the results of the logical operations may be stored back to the array without transferring data via data line address access (e.g., without asserting a column decode signal so that data is transferred via local I/O lines to circuitry external to the array and sensing circuitry). Thus, several embodiments of the present disclosure may enable the use of less power to perform the logical operations associated therewith, as compared to various previous approaches. In addition, because several embodiments may eliminate the need to transfer data across I/O lines in order to perform logical functions (e.g., between memory and a discrete processor), several embodiments may achieve increased parallel processing capabilities over previous approaches.
Although fig. 6 shows the sense amplifier 606 to include the balancing circuit 614, embodiments are not so limited, and the balancing circuit 614 may be implemented separately from the sense amplifier 606, in a different configuration than that shown in fig. 6, or not implemented at all.
As described further below, in several embodiments, the sensing circuitry (e.g., the sense amplifiers 606 and compute components 631) is operable to perform selected logical operations and initially store the results in one of the sense amplifiers 606 or compute components 631 without transferring data from the sensing circuitry via the I/O lines (e.g., without performing data line address access via activation of, for example, a column decode signal).
As shown in fig. 6, the compute component 631 may also include a latch 664, which may be referred to herein as a secondary latch. The secondary latch 664 may be configured and operated in a manner similar to that described above with respect to the primary latch 615, except that the pair of cross-coupled p-channel transistors (e.g., PMOS transistors) comprising the secondary latch may have their respective sources coupled to a supply voltage (e.g., V |)DD) And the pair of cross-coupled n-channel transistors (e.g., NMOS transistors) of the secondary latch may have their respective sources selectively coupled to a reference voltage (e.g., ground) in order to successively enable the secondary latch. The configuration of the computing components is not limited to the configuration shown at 631 in fig. 6, and various other embodiments are described further below.
FIG. 7 is a schematic diagram illustrating a sensing circuit having selectable logical operation selection logic in accordance with several embodiments of the present disclosure. FIG. 7 shows a number of sense amplifiers 706 coupled to respective pairs of complementary sense lines 705-1 and 705-2, and a corresponding number of compute components 731 coupled to the sense amplifiers 706 via pass gates 707-1 and 707-2. The gates of PASS gates 707-1 and 707-2 may be controlled by a logic operation selection logic signal PASS. For example, the output of logical operation selection logic 713-6 may be coupled to the gates of pass gates 707-1 and 707-2.
According to the embodiment illustrated in FIG. 7, compute component 731 may comprise respective stages of loadable shift registers (e.g., shift cells) configured to shift data values left and right. According to some embodiments, the compute component 731 may have bi-directional shifting capability. The compute components 731 can comprise loadable shift registers configured to shift in multiple directions (e.g., to the left and right), in accordance with various embodiments of the present disclosure (e.g., with each compute component 731 acting as a respective shift stage). According to various embodiments of the present disclosure, compute component 731 may comprise respective stages of loadable shift registers (e.g., shift cells) configured to shift in one direction. A loadable shift register may be coupled to the pair of complementary sense lines 705-1 and 705-2, with node ST2 of each stage coupled to the sense line conveying a true data value (e.g., DIGIT (n)) and with node SF2 of each stage coupled to the sense line conveying a complementary (e.g., false) data value (e.g., DIGIT (n)) _).
According to some embodiments and as illustrated in fig. 7, each compute component 731 (e.g., stage) of the shift register includes a pair of right shift transistors 781 and 786, a pair of left shift transistors 789 and 790, and a pair of inverters 787 and 788. Signals PHASE1R, PHASE 2R, PHASE1L and PHASE2L may be applied to respective control lines 782, 783, 791 and 792 to enable/disable feedback on latches of corresponding compute component 731 in association with performing logical operations and/or shifting data according to embodiments described herein. Examples of shifting data (e.g., from a particular compute component 731 to an adjacent compute component 731) are described further below with respect to fig. 9 and 10.
The compute components 731 (e.g., stages) of the loadable shift register can include a first right shift transistor 781 having a gate coupled to a first right shift control line 780 (e.g., "PHASE 1R"), and a second right shift transistor 786 having a gate coupled to a second right shift control line 782 (e.g., "PHASE 2R"). The node ST2 of each stage of the loadable shift register is coupled to the input of the first inverter 787. The output of the first inverter 787 (e.g., node SF1) is coupled to one source/drain of the second right shift transistor 786, and the other source/drain of the second right shift transistor 786 is coupled to the input of the second inverter 788 (e.g., node SF 2). The output of the second inverter 788 (e.g., node ST1) is coupled to one source/drain of the first right shift transistor 781, and the other source/drain of the first right shift transistor 781 is coupled to the input of the second inverter (e.g., node SF2) for the neighboring compute component 731. The LATCH transistor 785 has a gate coupled to a LATCH control signal 784. One source/drain of the latch transistor 785 is coupled to the node ST2, and the other source/drain of the latch transistor 785 is coupled to the node ST 1.
The sense amplifier 706 can be coupled to a respective pair of complementary sense lines 705-1 and 705-2, and a corresponding compute component 731 is coupled to the sense amplifier 706 via respective pass gates 707-1 and 707-2. The gates of pass gates 707-1 and 707-2 may be controlled by respective logic operation selection logic signals "Passd" and "Passdb" that may be output from logic operation selection logic (not shown for clarity).
The first left shift transistor 789 is coupled between node SF2 of one loadable shift register to node SF1 of the loadable shift register corresponding to the adjacent compute component 731. The channel of the second left shift transistor 790 is coupled from node ST2 to node ST 1. The gate of the first left shift transistor 789 is coupled to a first left shift control line 791 (e.g., "PHASE 1L"), and the gate of the second left shift transistor 790 is coupled to a second left shift control line 792 (e.g., "PHASE 2L").
Logic operation selection logic 713-6 includes swap gate 742, as well as logic to control pass gates 707-1 and 707-2 and swap gate 742. Logic operation selection logic 713-6 includes four logic selection transistors: a logic select transistor 762 coupled between the gate of swap transistor 742 and the TF signal control line, a logic select transistor 752 coupled between the gates of pass gates 707-1 and 707-2 and the TT signal control line, a logic select transistor 754 coupled between the gates of pass gates 707-1 and 707-2 and the FT signal control line, and a logic select transistor 764 coupled between the gate of swap transistor 742 and the FF signal control line. The gates of logic select transistors 762 and 752 are coupled to a true sense line through isolation transistor 750-1 (having a gate coupled to an ISO signal control line). The gates of logic select transistors 764 and 754 are coupled to a complementary sense line through isolation transistor 750-2 (also having a gate coupled to an ISO signal control line). Fig. 10 and 11 illustrate timing diagrams associated with performing logic operations and shift operations using the sensing circuit shown in fig. 7.
The data values on the respective complementary sense lines 705-1 and 705-2 can be loaded into the respective compute component 731 (e.g., loadable shift register) by causing pass gates 707-1 and 707-2 to conduct, e.g., causing the pass control signal to go high. A gate controlled to have continuity (e.g., electrical continuity across a channel) is conductive and may be referred to herein as OPEN (OPEN). Gates that are controlled to have no continuity (e.g., electrical continuity across a channel) are said to be non-conductive and may be referred to herein as CLOSED (CLOSED). For example, continuity refers to a low resistance condition in which the gate is on. Data values may be loaded into respective compute components 731 by over-powering the corresponding compute components 731 with sense amplifiers 706 (e.g., to overwrite existing data values in the compute components 731) and/or by turning off the PHASE1R and PHASE 2R control signals 780 and 782 and the LATCH control signal 784. A first latch (e.g., a sense amplifier) may be configured to over-power a second latch (e.g., a compute component) when current provided by and presented to the first latch is sufficient to flip the second latch.
The sense amplifier 706 can be configured to over-power the compute component 731 by driving the voltage on the pair of complementary sense lines 705-1 and 705-2 to a maximum supply voltage corresponding to a data value (e.g., driving the pair of complementary sense lines 705-1 and 705-2 to a rail), which can change the voltage stored in the compute component 731A data value. According to various embodiments, the compute component 731 can be configured to transfer a data value to the pair of complementary sense lines 705-1 and 705-2 without driving the voltage of the pair of complementary sense lines 705-1 and 705-2 to a rail (e.g., to V)DDOr GND). As such, the compute component 731 can be configured to not over-power the sense amplifier 706 (e.g., the data value from the compute component 731 on the pair of complementary sense lines 705-1 and 705-2 will not change the data value stored in the sense amplifier 706 before the sense amplifier is enabled).
Once the data value is loaded into the compute component 731 of the loadable shift register, the true data value is spaced from the supplemental data value by the first inverter 787. The data value may be shifted to the right (e.g., to adjacent compute component 731) by alternating operation of first right shift transistor 781 and second right shift transistor 786, which may be achieved when first right shift control line 780 and second right shift control line 782 have periodic signals that go high out of phase with one another (e.g., alternating square waves are made 180 degrees out of phase with one another without overlapping). The LATCH control signal 784 can be activated to cause the LATCH transistor 785 to turn on, thereby latching a data value into the corresponding compute component 731 of the loadable shift register (e.g., while the signal PHASE1R remains low and PHASE 2R remains high to maintain the data value latched in the compute component 731).
Fig. 8 is a logic table illustrating results of selectable logic operations implemented by a sensing circuit (e.g., the sensing circuits shown in fig. 6 and 7) in accordance with several embodiments of the present disclosure. Four logic select control signals (e.g., TF, TT, FT, and FF) in combination with particular data values present on the complementary sense lines can be implemented to select one of a plurality of logic operations involving a starting data value stored in the sense amplifier 606 and the compute component 631. The four control signals (e.g., TF, TT, FT, and FF), in combination with particular data values present on the complementary sense lines (e.g., on nodes S and S), control the pass gates 707-1 and 707-2 and swap transistors 742, which in turn affect the data values in the compute component 731 and/or sense amplifier 706 before/after firing. The ability to selectively control the swap transistor 742 facilitates, among other things, implementing logical operations involving inverting data values (e.g., inverting operands and/or inverting results).
The logic table 8-1 illustrated in FIG. 8 shows the starting data value stored in compute component 631 shown in column A at 844, and the starting data value stored in sense amplifier 606 shown in column B at 845. The other 3 columns of headers in the logic table 8-1 refer to the states of the pass gates 607-1 and 607-2 and the swap transistor 742, which pass gates 607-1 and 607-2 and swap transistor 742 may be controlled to be open or closed depending on the states of the four logic select control signals (e.g., TF, TT, FT, and FF), respectively, and in conjunction with the particular data values present on the pair of complementary sense lines 605-1 and 605-2, when the ISO control signal is asserted. A "not open" column corresponds to both pass gates 607-1 and 607-2 and swap transistor 742 being in a non-conducting condition, a "positively open" column corresponds to pass gates 607-1 and 607-2 being in a conducting condition, and an "inversely open" column corresponds to swap transistor 742 being in a conducting condition. The configuration corresponding to pass gates 607-1 and 607-2 and swap transistor 742 both being in a conducting condition is not reflected in logic table 8-1, as this would cause the sense lines to be shorted together.
Via selective control of pass gates 707-1 and 707-2 and swap transistor 742, each of the three columns of the upper portion of logic table 8-1 may be combined with each of the three columns of the lower portion of logic table 8-1 to provide nine (e.g., 3 x 3) different resulting combinations, corresponding to nine different logic operations, as indicated by the respective connection paths shown at 875. The nine different selectable logic operations that may be implemented by the sensing circuit 650 are summarized in logic table 8-2.
The column of logic table 8-2 shows a header 880 that includes the state of the logic select control signals (e.g., FF, FT, TF, TT). For example, the state of a first logic select control signal (e.g., FF) is provided in row 876, the state of a second logic select control signal (e.g., FT) is provided in row 877, the state of a third logic select control signal (e.g., TF) is provided in row 878, and the state of a fourth logic select control signal (e.g., TT) is provided in row 879. The particular logical operations corresponding to the results are summarized in row 847.
Fig. 9 illustrates a timing diagram associated with performing a logical AND operation AND a shift operation using sensing circuitry in accordance with several embodiments of the present disclosure. Fig. 9 contains waveforms corresponding to signals EQ, ROW X, ROW Y, SENSE AMP, TF, TT, FT, FF, PHASE1R, PHASE 2R, PHASE1L, PHASE2L, ISO, Pass, DIGIT, and DIGIT _ respectively. The EQ signal corresponds to a balanced signal associated with the sense amplifier (e.g., EQ 626 shown in fig. 6). The ROW X and ROW Y signals correspond to signals applied to respective access lines (e.g., access lines 604-X and 604-Y shown in fig. 6) to access a selected cell (or ROW of cells). The SENSE AMP signal corresponds to a signal to enable/disable a SENSE amplifier (e.g., SENSE amplifier 706). The TF, TT, FT, and FF signals correspond to logic select control signals (e.g., signals coupled to logic select transistors 762, 752, 754, and 764), such as shown in fig. 7. The PHASE1R, PHASE 2R, PHASE1L and PHASE2L signals correspond to control signals (e.g., clock signals) provided to respective control lines 782, 783, 791 and 792 shown in fig. 7. The ISO signal corresponds to the signal coupled to the gates of isolation transistors 750-1 and 750-2 shown in fig. 7. The PASS signal corresponds to the signal coupled to the gates of PASS transistors 707-1 and 707-2 shown in fig. 7, and the PASS signal corresponds to the signal coupled to the gate of swap transistor 742. The DIGIT and DIGIT _ signals correspond to signals present on respective sense lines 705-1 (e.g., DIGIT (n)) and 705-2 (e.g., DIGIT (n)) _.
The timing diagram shown in FIG. 9 is associated with performing a logical AND operation on a data value stored in a first memory cell AND a data value stored in a second memory cell of the array. The memory cells can correspond to particular columns of the array (e.g., columns including complementary pairs of sense lines) and can be coupled to respective access lines (e.g., row X and row Y). In describing the logical AND operation shown in FIG. 9, reference is made to the sensing circuit described in FIG. 7. For example, the logical operations described in FIG. 9 may include storing a data value of a row X memory cell (e.g., a "row X data value") in a latch of a corresponding compute component 731 (e.g., an "A" data value), storing a data value of a row Y memory cell (e.g., a "row Y data value") in a latch of a corresponding sense amplifier 706 (e.g., a "B" data value), AND performing a selected logical operation on the row X data value AND the row Y data value (e.g., a logical AND operation in this example), the compute component 731 may be referred to as an accumulator 731, where the result of the selected logical operation is stored in the latch of the compute component 731.
As shown in fig. 9, at time T1The sensing amplifier 706 is disabled from balancing (e.g., EQ goes low). At time T2ROWX goes high to access (e.g., select) row X memory cells. At time T3SENSE amplifier 706 is enabled (e.g., SENSE AMP goes high), which drives complementary SENSE lines 705-1 and 705-2 to the appropriate track voltage (e.g., V) responsive to the row X data value (e.g., as shown by the DIGIT and DIGIT _ signals)DDAnd GND) and latches the row X data value in the sense amplifier 706. At time T4The PHASE 2R and PHASE2L signals go low, which disables feedback on the latch of compute component 731 (e.g., by turning off transistors 786 and 790, respectively) so that the values stored in the compute component can be overwritten during logic operations. And, at time T4ISO goes low, which disables isolation transistors 750-1 and 750-2. At time T5TT and FT are enabled (e.g., high), which causes PASS to go high (e.g., since either transistor 752 or 754 will depend on when at time T4Which of node ST2 (corresponding to node "S" in fig. 6) or node SF2 (corresponding to node "S" in fig. 6) is high to turn on when ISO is disabled) (recall that the voltages of nodes ST2 and SF2 dynamically reside on the gates of respective enable transistors 752 and 754 when ISO is disabled). PASS high enables PASS transistors 707-1 and 707-2 so that the DIGIT and DIGIT _ signals corresponding to the row X data values are provided to the respective compute component nodes ST2 and SF 2. At time T6TT and FT are disabled, which causes PASS to go low, disabling PASS transistors 707-1 and 707-2. Note that PASS is at time T5And T6Remains low since the TF and FF signals remain low. At time T7ROW X is disabled and PHASE 2R, PHASE2L and ISO are enabled. At time T7Enabling PHASE 2R and PHASE2L will startFeedback on the latch of the compute component 731 is used to cause the row X data value to be latched in the latch. At time T7Enabling ISO again couples nodes ST2 and SF2 to the gates of enable transistors 752, 754, 762, and 764. At time T8Balance is enabled (e.g., EQ goes high so that DIGIT and DIGIT _ are driven to a balance voltage, e.g., V)DD/2) and SENSE amplifier 706 is disabled (e.g., SENSE AMP goes low).
With the row X data value latched in compute component 731, balancing is disabled (e.g., at time T)9EQ goes low). At time T10ROW Y goes high to access (e.g., select) ROW Y memory cells. At time T11SENSE amplifier 706 is enabled (e.g., SENSE AMP goes high), which drives the complementary SENSE lines 705-1 and 705-2 to the appropriate track voltage (e.g., V) in response to the row Y data value (e.g., as shown by the DIGIT and DIGIT _ signals)DDAnd GND) and the row Y data value is latched in sense amplifier 706. At time T12The PHASE 2R and PHASE2L signals go low, which disables feedback on the latch of compute component 731 (e.g., by turning off transistors 786 and 790, respectively) so that the values stored in the compute component can be overwritten during logic operations. And, at time T12ISO goes low, which disables isolation transistors 750-1 and 750-2. Since the desired logical operation is an AND operation in this example, at time T13TT is enabled while TF, FT, AND FF remain disabled (as shown in table 8-2, FF-0, FT-0, TF-0, AND TT-1 correspond to a logical AND operation). Enabling TT causes PASS to go high or not depends on when at time T12The value stored in the calculation component 731 when ISO is disabled. For example, enable transistor 752 would turn on if node ST2 was high when ISO was disabled, and the enable transistor would be on when at time T12When the ISO is deactivated, the node ST2 is low and does not conduct.
In this example, if at time T13PASS goes high, PASS transistors 707-1 and 707-2 are enabled, and the DIGIT and DIGIT _ signals corresponding to the row Y data values are provided to respective compute component nodes ST2 and SF 2. Thus, the value stored in the compute component 731 (e.g., row X data value) canToggles depending on the values of DIGIT and DIGIT _ e.g., row Y data values. In this example, if PASS is at time T13Held low, pass transistors 707-1 and 707-2 are not enabled so that the DIGIT and DIGIT _ signals corresponding to the row Y data values remain isolated from nodes ST2 and SF2 of compute component 731. Thus, the data values in the compute component (e.g., row X data values) will remain the same.
At time T14TT is disabled, which causes PASS to go low (or remain low), causing PASS transistors 707-1 and 707-2 to be disabled. Note that PASS is at time T13And T14Remains low since the TF and FF signals remain low. At time T15ROW Y is disabled and PHASE 2R, PHASE2L and ISO are enabled. At time T15Enabling PHASE 2R AND PHASE2L enables feedback on the latch of compute component 731 so that the result of the AND operation (e.g., "a" AND "B") is latched in the latch. At time T15Enable ISO again couples nodes ST2 and SF2 to the gates of enable transistors 752, 754, 762, and 764. At time T16The sensing amplifier 706 is disabled (e.g., SENSE AMP goes low) and equilibration is enabled (e.g., EQ goes high so that DIGIT and DIGIT _ are driven to an equilibrium voltage).
The results of the AND operation, which are initially stored in compute component 731 in this example, can be transferred back to the memory array (e.g., via complementary sense lines back to memory cells coupled to row X, row Y, AND/or a different row) AND/or to an external location (e.g., an external processing component) via I/O lines.
Fig. 9 also includes (e.g., at 801) signaling associated with shifting data (e.g., from a compute component 731 to a neighboring compute component 731). The example shown in FIG. 9 illustrates two shifts to the left, such that data values stored in compute components corresponding to column "N" are shifted to the left to compute components corresponding to column "N-2". E.g. at time T16As shown, PHASE 2R and PHASE2L are disabled, which disables feedback on the compute component latches, as described above. To perform the first left shift, PHASE1L is at time T17Is enabled and at time T18And (4) stopping the use. Enabling PHASE 1L-inducedTurning on transistor 789 causes the data value at node SF1 to move to the left to node SF2 of the left adjacent compute component 731. PHASE2L then at time T19Is enabled and at time T20And (4) stopping the use. Enabling PHASE2L causes transistor 790 to turn on, which causes the data value from node ST1 to move to the left to node ST2, completing the shift to the left.
The above sequence (e.g., enable/disable PHASE1L and then enable/disable PHASE 2L) may be repeated to achieve the desired number of left shifts. For example, in this example, by at time T21Enable PHASE1L and at time T22PHASE1L is disabled to perform the second left shift. PHASE2L then at time T23Enabled to complete the second left shift. After the second left shift, PHASE2L remains enabled and PHASE 2R is enabled (e.g., at time T)24) Such that feedback is enabled to latch the data value in the compute component latch.
FIG. 10 illustrates a timing diagram associated with performing a logical XOR operation and a shift operation using sensing circuitry in accordance with several embodiments of the present disclosure. Fig. 10 includes the same waveforms described above in fig. 9. However, the timing diagram shown in fig. 10 is associated with performing a logical XOR operation on the row X AND row Y data values (e.g., as compared to a logical AND operation). Reference is again made to the sensing circuit described in fig. 7.
FIG. 10 at time T0To T9The indicated signaling is the same as in fig. 9 and is not repeated here. Thus, at time T9, the EQ is disabled and the row X data value is latched in the compute component 731. At time T10ROW Y goes high to access (e.g., select) ROW Y memory cells. At time T11SENSE amplifier 706 is enabled (e.g., SENSE AMP goes high), which drives the complementary SENSE lines 705-1 and 705-2 to the appropriate track voltage (e.g., V) in response to the row Y data value (e.g., as shown by the DIGIT and DIGIT _ signals)DDAnd GND) and the row Y data value is latched in sense amplifier 706. At time T12The PHASE 2R and PHASE2L signals go low, which disables feedback on the latch of compute component 731 (e.g., by turning off transistors 786 and 790, respectively) so that logic operation may be performedDuring which the value stored in the calculation component 731 is overwritten. And, at time T12ISO goes low, which disables isolation transistors 750-1 and 750-2. Since the desired logical operation is an XOR operation in this example, at time T13TF and FT are enabled while TT and FF remain disabled (FF-0, FT-1, TF-1, and TT-0 correspond to logical XOR (e.g., "AXB") operations, as shown in table 10-2). Whether enabling TF and FT causes PASS or PASS to go high depends on when at time T12The value stored in the calculation component 731 when ISO is disabled. For example, enable transistor 762 would be turned on if node ST2 was high when ISO is disabled, and enable transistor 762 would be turned on when at time T12When the ISO is deactivated, the node ST2 is low and does not conduct. Similarly, enable transistor 754 will conduct if node SF2 is high when ISO is disabled, and enable transistor 754 will not conduct if node SF2 is low when ISO is disabled.
In this example, if PASS is at time T13High, pass transistors 707-1 and 707-2 are enabled such that the DIGIT and DIGIT _ signals corresponding to the row Y data values are provided to the respective compute component nodes ST2 and SF 2. Thus, the value stored in compute component 731 (e.g., row X data value) can be flipped depending on the values of DIGIT and DIGIT _ such as row Y data value. In this example, if PASS is at time T13Held low, pass transistors 707-1 and 707-2 are not enabled so that the DIGIT and DIGIT _ signals corresponding to the row Y data values remain isolated from nodes ST2 and SF2 of compute component 731. Thus, the data values in the compute component (e.g., row X data values) will remain the same. In this example, if PASS at time T13High, then swap transistor 742 is enabled so that the DIGIT and DIGIT _ signals corresponding to the row Y data values will be provided to node SF2 in a transposed manner (e.g., "true" data values on DIGIT (n) and "supplemental" data values on DIGIT (n) _ will be provided to nodes ST2) to the respective compute component nodes ST2 and SF 2. Thus, the value stored in compute component 731 (e.g., row X data value) can be flipped depending on the values of DIGIT and DIGIT _ such as row Y data value. In this example, if PASS at time T13Is kept low, thatThe swap transistor 742 is not enabled so that the DIGIT and DIGIT _ signals corresponding to the row Y data values remain isolated from nodes ST2 and SF2 of the compute component 731. Thus, the data values in the compute component (e.g., row X data values) will remain the same.
At time T14TF and FT are disabled, which causes PASS and PASS to go low (or remain low), causing PASS transistors 707-1 and 707-2 and swap transistor 742 to be disabled. At time T15ROW Y is disabled and PHASE 2R, PHASE2L and ISO are enabled. At time T15Enabling PHASE 2R and PHASE2L enables feedback on the latch of the compute component 731 so that the result of the XOR operation (e.g., "a" XOR "B") is latched in the latch. At time T15Enable ISO again couples nodes ST2 and SF2 to the gates of enable transistors 752, 754, 762, and 764. At time T16The sensing amplifier 706 is disabled (e.g., SENSE AMP goes low) and equilibration is enabled (e.g., EQ goes high so that DIGIT and DIGIT _ are driven to an equilibrium voltage).
The result of the XOR operation, which is initially stored in compute component 731 in this example, may be transferred back to the memory array (e.g., via complementary sense lines back to memory cells coupled to row X, row Y, and/or a different row) and/or transferred to an external location (e.g., an external processing component) via I/O lines.
Fig. 10 also includes (e.g., at 1001) signaling associated with shifting data (e.g., from a compute component 731 to a neighboring compute component 731). The example shown in FIG. 10 illustrates two shifts to the right, such that data values stored in compute components corresponding to column "N" are shifted to the right to compute components corresponding to column "N + 2". E.g. at time T16As shown, PHASE 2R and PHASE2L are disabled, which disables feedback on the compute component latches, as described above. To perform the first shift right, PHASE1R is at time T17Is enabled and at time T18And (4) stopping the use. Enabling PHASE1R causes transistor 781 to conduct, which causes the data value at node ST1 to move to the right to node ST2 of the right neighboring compute component 731. PHASE 2R then at time T19Is enabled and at time T20And (4) stopping the use. Enabling the PHASE 2R cause transistor786 is on, which causes the data value from node SF1 to move to the right to node SF2, completing the shift to the right.
The above sequence (e.g., enable/disable PHASE1R and then enable/disable PHASE 2R) may be repeated to achieve the desired number of right shifts. For example, in this example, by at time T21Enable PHASE1R and at time T22The PHASE1R is disabled to perform the second right shift. PHASE 2R then at time T23Enabled to complete the second right shift. After the second right shift, PHASE1R remains disabled, PHASE 2R remains enabled, and PHASE2L is enabled (e.g., at time T)24) Such that feedback is enabled to latch the data value in the compute component latch.
Although the examples described in fig. 9 and 10 include the logical operation results being stored in a compute component (e.g., 371), the sense circuitry according to embodiments described herein is operable to perform the logical operation if the results are initially stored in the sense amplifier (e.g., as illustrated in fig. 9). Moreover, embodiments are not limited to the "AND" AND "XOR" logical operation examples described in FIGS. 9 AND 10, respectively. For example, sensing circuitry (e.g., 750 shown in fig. 7) according to embodiments of the disclosure may be controlled to perform various other logical operations, such as those shown in table 10-2.
Although example embodiments including various combinations and configurations of sense circuits, sense amplifiers, compute components, dynamic latches, isolation devices, and/or shift circuits have been illustrated and described herein, embodiments of the present disclosure are not limited to those combinations explicitly recited herein. Other combinations and configurations of the sensing circuits, sense amplifiers, compute components, dynamic latches, isolation devices, and/or shift circuits disclosed herein are expressly included within the scope of this disclosure.
Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that an arrangement calculated to achieve the same results can be substituted for the specific embodiments shown. This disclosure is intended to cover adaptations or variations of one or more embodiments of the present disclosure. It is to be understood that the above description is intended to be illustrative, and not restrictive. Combinations of the above embodiments, and other embodiments not specifically described herein, will be apparent to those of skill in the art upon reviewing the above description. The scope of one or more embodiments of the present disclosure includes other applications in which the above structures and methods are used. The scope of one or more embodiments of the disclosure should, therefore, be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled.
In the foregoing detailed description, certain features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the disclosed embodiments of the disclosure have to use more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus, the following claims are hereby incorporated into the detailed description, with each claim standing on its own as a separate embodiment.
Claims (30)
1. An apparatus, comprising:
an array of memory cells, wherein the array comprises:
a first portion accessible by a controller of the array and inaccessible by a device external to the apparatus;
a second portion accessible to the device external to the apparatus; and
a number of registers configured to store row addresses indicating which portion of the array is the first portion; and is
The controller is configured to access the number of registers to allow the device external to the apparatus to access the second portion based on the stored row address.
2. The apparatus of claim 1, wherein the number of registers comprises an access control register.
3. The apparatus of claim 2, wherein the access control register comprises a row access control register.
4. The apparatus of claim 1, wherein the controller is configured to:
allowing instructions stored in the first portion to be executed to write to or read from the second portion; and
instructions are not allowed to be executed from the second portion.
5. The apparatus of claim 1, wherein the number of registers are writable only by instructions executed from the first portion.
6. The apparatus of claim 1, wherein the controller is configured to allow data to be copied into the first portion only by executing the instructions executed from the first portion.
7. The apparatus of claim 1, wherein the controller is configured to prevent an external DRAMACT command from executing inside the first portion in response to the register being loaded.
8. The apparatus of claim 1, wherein the controller is configured to prevent internal PIM instruction commands from executing outside the first portion in response to the register being loaded.
9. The apparatus of claim 1, wherein the controller is configured to allow instructions to execute from the second portion only in response to the instructions not targeting in the first portion.
10. The apparatus of claim 1, wherein the controller is configured to prevent data from being copied from the first portion to the second portion in response to execution of an instruction not stored in the first portion.
11. The apparatus of claim 1, wherein the controller is configured to prevent data from being copied from the second portion to the first portion in response to execution of an instruction not stored in the first portion.
12. The apparatus of any one of claims 1-11, wherein the apparatus is a processor-built-in-memory PIM device comprising:
the array of the memory cells; and
the controller;
wherein the array and the controller are on the same die.
13. The apparatus of claim 12, wherein a host computer is coupled to the PIM device and is one of the devices external to the apparatus.
14. The apparatus of any one of claims 1-11, wherein the number of registers are configured to each store an address associated with a row of the array.
15. The apparatus of claim 14, wherein the portion of the array between the addresses stored in each of the number of registers is the first portion.
16. The apparatus of claim 14, wherein the first portion of the array is modified in response to the address associated with each of the number of registers being modified.
17. An apparatus, comprising:
an array of memory cells, comprising:
a first portion of a memory unit that is inaccessible to a device external to the apparatus and configured to store a first set of data and a set of instructions;
a second portion of memory cells accessible by the device external to the apparatus and configured to store a second set of data; and
a set of address registers, wherein the set of address registers indicates which portion of the array is the inaccessible first portion; and
a controller configured to execute the first set of instructions in the inaccessible first portion.
18. The apparatus of claim 17, wherein the accessible second portion comprises another set of instructions executed by the controller without reading or writing data into the first inaccessible portion of memory cells.
19. The apparatus of claim 17, wherein the controller is configured to communicate data from the inaccessible first portion to the accessible second portion.
20. The apparatus of any one of claims 17-19, wherein the controller is configured to recognize data written to the accessible second portion as an operand and not recognize the data as an instruction.
21. The apparatus of any one of claims 17-19, wherein the controller is configured to recognize data written to the inaccessible first portion as one of an operand and the set of instructions.
22. The apparatus of claim 21, wherein the controller is configured to execute the set of instructions in the inaccessible first portion.
23. The apparatus of claim 20, wherein the accessible second portion of memory cells is configured to store a second set of instructions, wherein the second set of instructions is executed without reading or writing data into the first inaccessible portion of memory cells.
24. A method, comprising:
reading addresses in a plurality of registers;
identifying a first portion of the memory cell array indicated by the read address;
executing instructions stored in the first portion within memory cells of the first portion;
preventing access to the first portion; and
access to a second portion of the array is allowed.
25. The method of claim 24, comprising modifying the addresses in the number of registers, which modifies which memory cells of the array make up the first portion.
26. The method of any one of claims 24-25, wherein a first address of a first one of the number of registers indicates a first row of cells of the first portion.
27. The method of claim 26, wherein a second address of a second register of the number of registers indicates a last cell row of the first portion.
28. The method of claim 26, comprising:
decrypting data as the data is initially read and written into the first portion; and
leaving the data unencrypted in the first portion.
29. The method of any one of claims 24 to 25, comprising clearing data from the first portion in response to performing a system reset.
30. The method of claim 29, comprising clearing the number of registers in response to performing the system reset.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/691,484 | 2017-08-30 | ||
US15/691,484 US10534553B2 (en) | 2017-08-30 | 2017-08-30 | Memory array accessibility |
PCT/US2018/047862 WO2019046111A1 (en) | 2017-08-30 | 2018-08-24 | Memory array accessibility |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111052068A true CN111052068A (en) | 2020-04-21 |
CN111052068B CN111052068B (en) | 2023-11-28 |
Family
ID=65435143
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201880056010.3A Active CN111052068B (en) | 2017-08-30 | 2018-08-24 | memory array accessibility |
Country Status (4)
Country | Link |
---|---|
US (3) | US10534553B2 (en) |
CN (1) | CN111052068B (en) |
DE (1) | DE112018004896T5 (en) |
WO (1) | WO2019046111A1 (en) |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10534553B2 (en) * | 2017-08-30 | 2020-01-14 | Micron Technology, Inc. | Memory array accessibility |
US10431291B1 (en) * | 2018-08-08 | 2019-10-01 | Micron Technology, Inc. | Systems and methods for dynamic random access memory (DRAM) cell voltage boosting |
US11153173B1 (en) * | 2019-09-10 | 2021-10-19 | Juniper Networks, Inc. | Dynamically updating compute node location information in a distributed computing environment |
US11422826B2 (en) | 2020-05-19 | 2022-08-23 | Micron Technology, Inc. | Operational code storage for an on-die microprocessor |
US11966328B2 (en) | 2020-12-18 | 2024-04-23 | Advanced Micro Devices, Inc. | Near-memory determination of registers |
KR20220127601A (en) * | 2021-03-11 | 2022-09-20 | 삼성전자주식회사 | Memory system, memory device of performing internal processing operations with interface, operation method of the memory device having the same |
US20230061037A1 (en) * | 2021-09-01 | 2023-03-02 | Micron Technology, Inc. | Apparatus with power-based data protection mechanism and methods for operating the same |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060036816A1 (en) * | 2004-07-29 | 2006-02-16 | Mcmahan Larry N | Communication among partitioned devices |
CN101095196A (en) * | 2004-11-29 | 2007-12-26 | 拉姆伯斯公司 | Multi-mode memory |
Family Cites Families (320)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4380046A (en) | 1979-05-21 | 1983-04-12 | Nasa | Massively parallel processor computer |
JPS6032911B2 (en) | 1979-07-26 | 1985-07-31 | 株式会社東芝 | semiconductor storage device |
US4435792A (en) | 1982-06-30 | 1984-03-06 | Sun Microsystems, Inc. | Raster memory manipulation apparatus |
US4727474A (en) | 1983-02-18 | 1988-02-23 | Loral Corporation | Staging memory for massively parallel processor |
EP0214718A3 (en) | 1985-07-22 | 1990-04-04 | Alliant Computer Systems Corporation | Digital computer |
US5201039A (en) | 1987-09-30 | 1993-04-06 | Mitsubishi Denki Kabushiki Kaisha | Multiple address-space data processor with addressable register and context switching |
US4843264A (en) | 1987-11-25 | 1989-06-27 | Visic, Inc. | Dynamic sense amplifier for CMOS static RAM |
US5276643A (en) | 1988-08-11 | 1994-01-04 | Siemens Aktiengesellschaft | Integrated semiconductor circuit |
JPH0713858B2 (en) | 1988-08-30 | 1995-02-15 | 三菱電機株式会社 | Semiconductor memory device |
US5023838A (en) | 1988-12-02 | 1991-06-11 | Ncr Corporation | Random access memory device with integral logic capability |
US4958378A (en) | 1989-04-26 | 1990-09-18 | Sun Microsystems, Inc. | Method and apparatus for detecting changes in raster data |
US5253308A (en) | 1989-06-21 | 1993-10-12 | Amber Engineering, Inc. | Massively parallel digital image data processor using pixel-mapped input/output and relative indexed addressing |
DE69132495T2 (en) | 1990-03-16 | 2001-06-13 | Texas Instruments Inc | Distributed processing memory |
US5034636A (en) | 1990-06-04 | 1991-07-23 | Motorola, Inc. | Sense amplifier with an integral logic function |
US5210850A (en) | 1990-06-15 | 1993-05-11 | Compaq Computer Corporation | Memory address space determination using programmable limit registers with single-ended comparators |
JP3361825B2 (en) | 1990-08-22 | 2003-01-07 | テキサス インスツルメンツ インコーポレイテツド | Memory array architecture |
JPH06103599B2 (en) | 1990-11-16 | 1994-12-14 | 三菱電機株式会社 | Semiconductor integrated circuit device |
US5325519A (en) | 1991-10-18 | 1994-06-28 | Texas Microsystems, Inc. | Fault tolerant computer with archival rollback capabilities |
FR2685973B1 (en) | 1992-01-03 | 1994-02-25 | France Telecom | MEMORY POINT FOR ASSOCIATIVE MEMORY. |
KR950005095Y1 (en) | 1992-03-18 | 1995-06-22 | 문정환 | A dram with bilateral global bit line |
JPH06215160A (en) | 1992-08-25 | 1994-08-05 | Texas Instr Inc <Ti> | Method and apparatus for data processing |
KR950004854B1 (en) | 1992-10-08 | 1995-05-15 | 삼성전자 주식회사 | Semiconductor memory device |
US5485373A (en) | 1993-03-25 | 1996-01-16 | Taligent, Inc. | Language-sensitive text searching system with modified Boyer-Moore process |
US5440482A (en) | 1993-03-25 | 1995-08-08 | Taligent, Inc. | Forward and reverse Boyer-Moore string searching of multilingual text having a defined collation order |
US5369622A (en) | 1993-04-20 | 1994-11-29 | Micron Semiconductor, Inc. | Memory with isolated digit lines |
US5754478A (en) | 1993-04-20 | 1998-05-19 | Micron Technology, Inc. | Fast, low power, write scheme for memory circuits using pulsed off isolation device |
JP2663838B2 (en) | 1993-07-27 | 1997-10-15 | 日本電気株式会社 | Semiconductor integrated circuit device |
JP3252306B2 (en) | 1993-08-10 | 2002-02-04 | 株式会社日立製作所 | Semiconductor nonvolatile storage device |
JP3904244B2 (en) | 1993-09-17 | 2007-04-11 | 株式会社ルネサステクノロジ | Single chip data processor |
JP3251421B2 (en) | 1994-04-11 | 2002-01-28 | 株式会社日立製作所 | Semiconductor integrated circuit |
US5655113A (en) | 1994-07-05 | 1997-08-05 | Monolithic System Technology, Inc. | Resynchronization circuit for a memory system and method of operating same |
JPH0831168A (en) | 1994-07-13 | 1996-02-02 | Hitachi Ltd | Semiconductor storage device |
US5481500A (en) | 1994-07-22 | 1996-01-02 | International Business Machines Corporation | Precharged bit decoder and sense amplifier with integrated latch usable in pipelined memories |
US5615404A (en) | 1994-10-31 | 1997-03-25 | Intel Corporation | System having independently addressable bus interfaces coupled to serially connected multi-ported signal distributors generating and maintaining frame based polling schedule favoring isochronous peripherals |
US5638128A (en) | 1994-11-08 | 1997-06-10 | General Instrument Corporation Of Delaware | Pixel interpolation filters for video decompression processor |
US5724366A (en) | 1995-05-16 | 1998-03-03 | Mitsubishi Denki Kabushiki Kaisha | Semiconductor memory device |
KR0146530B1 (en) | 1995-05-25 | 1998-09-15 | 김광호 | Semiconductor memory device |
US7301541B2 (en) | 1995-08-16 | 2007-11-27 | Microunity Systems Engineering, Inc. | Programmable processor and method with wide operations |
JP2812262B2 (en) | 1995-08-31 | 1998-10-22 | 日本電気株式会社 | Associative memory |
US6385634B1 (en) | 1995-08-31 | 2002-05-07 | Intel Corporation | Method for performing multiply-add operations on packed data |
JP2817836B2 (en) | 1995-11-30 | 1998-10-30 | 日本電気株式会社 | Semiconductor memory device |
JP3356612B2 (en) | 1996-02-29 | 2002-12-16 | インターナショナル・ビジネス・マシーンズ・コーポレーション | High-speed contour smoothing method and apparatus |
US6092186A (en) | 1996-05-07 | 2000-07-18 | Lucent Technologies Inc. | Apparatus and method for aborting un-needed instruction fetches in a digital microprocessor device |
US5915084A (en) | 1996-09-30 | 1999-06-22 | Advanced Micro Devices, Inc. | Scannable sense amplifier circuit |
US5991209A (en) | 1997-04-11 | 1999-11-23 | Raytheon Company | Split sense amplifier and staging buffer for wide memory architecture |
JP3592887B2 (en) | 1997-04-30 | 2004-11-24 | 株式会社東芝 | Nonvolatile semiconductor memory device |
US6510098B1 (en) | 1997-05-28 | 2003-01-21 | Cirrus Logic, Inc. | Method and apparatus for transferring data in a dual port memory |
JPH1115773A (en) | 1997-06-24 | 1999-01-22 | Matsushita Electron Corp | Semiconductor integrated circuit, computer system, data processor and data processing method |
US5935263A (en) | 1997-07-01 | 1999-08-10 | Micron Technology, Inc. | Method and apparatus for memory array compressed data testing |
US6195734B1 (en) | 1997-07-02 | 2001-02-27 | Micron Technology, Inc. | System for implementing a graphic address remapping table as a virtual register file in system memory |
US6181698B1 (en) | 1997-07-09 | 2001-01-30 | Yoichi Hariguchi | Network routing table using content addressable memory |
US6025221A (en) | 1997-08-22 | 2000-02-15 | Micron Technology, Inc. | Processing methods of forming integrated circuitry memory devices, methods of forming DRAM arrays, and related semiconductor masks |
US5991785A (en) | 1997-11-13 | 1999-11-23 | Lucent Technologies Inc. | Determining an extremum value and its index in an array using a dual-accumulation processor |
US5867429A (en) | 1997-11-19 | 1999-02-02 | Sandisk Corporation | High density non-volatile flash memory without adverse effects of electric field coupling between adjacent floating gates |
US6163862A (en) | 1997-12-01 | 2000-12-19 | International Business Machines Corporation | On-chip test circuit for evaluating an on-chip signal using an external test signal |
JP3488612B2 (en) | 1997-12-11 | 2004-01-19 | 株式会社東芝 | Sense amplifier circuit |
US5986942A (en) | 1998-01-20 | 1999-11-16 | Nec Corporation | Semiconductor memory device |
JPH11260057A (en) | 1998-03-13 | 1999-09-24 | Nec Corp | Semiconductor memory device |
JPH11265995A (en) | 1998-03-17 | 1999-09-28 | Mitsubishi Electric Corp | Semiconductor storage device |
JPH11306751A (en) | 1998-04-22 | 1999-11-05 | Toshiba Corp | Semiconductor storage |
US6005799A (en) | 1998-08-06 | 1999-12-21 | Silicon Aquarius | Methods and circuits for single-memory dynamic cell multivalue data storage |
US6141286A (en) | 1998-08-21 | 2000-10-31 | Micron Technology, Inc. | Embedded DRAM architecture with local data drivers and programmable number of data read and data write lines |
US7409694B2 (en) | 1998-09-09 | 2008-08-05 | Microsoft Corporation | Highly componentized system architecture with loadable virtual memory manager |
JP2000173269A (en) | 1998-12-08 | 2000-06-23 | Mitsubishi Electric Corp | Semiconductor storage device |
KR100381968B1 (en) | 1998-12-30 | 2004-03-24 | 주식회사 하이닉스반도체 | High speed action DRAM |
US6389507B1 (en) | 1999-01-15 | 2002-05-14 | Gigabus, Inc. | Memory device search system and method |
US5999435A (en) | 1999-01-15 | 1999-12-07 | Fast-Chip, Inc. | Content addressable memory device |
US6134164A (en) | 1999-04-22 | 2000-10-17 | International Business Machines Corp. | Sensing circuit for a memory cell array |
US6741104B2 (en) | 1999-05-26 | 2004-05-25 | Micron Technology, Inc. | DRAM sense amplifier for low voltages |
US6157578A (en) | 1999-07-15 | 2000-12-05 | Stmicroelectronics, Inc. | Method and apparatus for accessing a memory device |
US6208544B1 (en) | 1999-09-09 | 2001-03-27 | Harris Corporation | Content addressable memory cell providing simultaneous read and compare capability |
US6578058B1 (en) | 1999-10-06 | 2003-06-10 | Agilent Technologies, Inc. | System and method for comparing values from target systems |
US7124221B1 (en) | 1999-10-19 | 2006-10-17 | Rambus Inc. | Low latency multi-level communication interface |
US6418498B1 (en) | 1999-12-30 | 2002-07-09 | Intel Corporation | Integrated system management memory for system management interrupt handler independent of BIOS and operating system |
JP4627103B2 (en) | 2000-01-18 | 2011-02-09 | 富士通セミコンダクター株式会社 | Semiconductor memory device and control method thereof |
US6687175B1 (en) | 2000-02-04 | 2004-02-03 | Renesas Technology Corporation | Semiconductor device |
US20010042069A1 (en) | 2000-02-29 | 2001-11-15 | Petrov Peter D. | Method and apparatus for building a memory image |
US7028170B2 (en) | 2000-03-08 | 2006-04-11 | Sun Microsystems, Inc. | Processing architecture having a compare capability |
JP3983969B2 (en) | 2000-03-08 | 2007-09-26 | 株式会社東芝 | Nonvolatile semiconductor memory device |
US6678678B2 (en) | 2000-03-09 | 2004-01-13 | Braodcom Corporation | Method and apparatus for high speed table search |
JP3822412B2 (en) | 2000-03-28 | 2006-09-20 | 株式会社東芝 | Semiconductor memory device |
US6965648B1 (en) | 2000-05-04 | 2005-11-15 | Sun Microsystems, Inc. | Source synchronous link integrity validation |
AU2001270400A1 (en) | 2000-07-07 | 2002-01-21 | Mosaid Technologies Incorporated | A high speed dram architecture with uniform access latency |
US6466499B1 (en) | 2000-07-11 | 2002-10-15 | Micron Technology, Inc. | DRAM sense amplifier having pre-charged transistor body nodes |
AU2001285161A1 (en) | 2000-08-21 | 2002-03-04 | United States Postal Services | Delivery point validation system |
US6301164B1 (en) | 2000-08-25 | 2001-10-09 | Micron Technology, Inc. | Antifuse method to repair columns in a prefetched output memory architecture |
US6704828B1 (en) | 2000-08-31 | 2004-03-09 | Micron Technology, Inc. | System and method for implementing data pre-fetch having reduced data lines and/or higher data rates |
US6948056B1 (en) | 2000-09-28 | 2005-09-20 | Intel Corporation | Maintaining even and odd array pointers to extreme values by searching and comparing multiple elements concurrently where a pointer is adjusted after processing to account for a number of pipeline stages |
US6304477B1 (en) | 2001-01-31 | 2001-10-16 | Motorola, Inc. | Content addressable magnetic random access memory |
US6563754B1 (en) | 2001-02-08 | 2003-05-13 | Integrated Device Technology, Inc. | DRAM circuit with separate refresh memory |
US6650158B2 (en) | 2001-02-21 | 2003-11-18 | Ramtron International Corporation | Ferroelectric non-volatile logic elements |
US7546438B2 (en) | 2001-07-19 | 2009-06-09 | Chung Shine C | Algorithm mapping, specialized instructions and architecture features for smart memory computing |
US6807614B2 (en) | 2001-07-19 | 2004-10-19 | Shine C. Chung | Method and apparatus for using smart memories in computing |
ITRM20010531A1 (en) | 2001-08-31 | 2003-02-28 | Micron Technology Inc | LOW POWER AND HIGH VOLTAGE DETECTOR DEVICE FOR DITIPO FLASH MEMORIES. |
US7260672B2 (en) | 2001-09-07 | 2007-08-21 | Intel Corporation | Using data stored in a destructive-read memory |
US7062689B2 (en) | 2001-12-20 | 2006-06-13 | Arm Limited | Method and apparatus for memory self testing |
US20040073773A1 (en) | 2002-02-06 | 2004-04-15 | Victor Demjanenko | Vector processor architecture and methods performed therein |
US6707729B2 (en) | 2002-02-15 | 2004-03-16 | Micron Technology, Inc. | Physically alternating sense amplifier activation |
WO2003088033A1 (en) | 2002-04-09 | 2003-10-23 | University Of Rochester | Multiplier-based processor-in-memory architectures for image and graphics processing |
US7139890B2 (en) | 2002-04-30 | 2006-11-21 | Intel Corporation | Methods and arrangements to interface memory |
JP2003331598A (en) | 2002-05-13 | 2003-11-21 | Mitsubishi Electric Corp | Semiconductor memory device |
US7406494B2 (en) | 2002-05-14 | 2008-07-29 | Texas Instruments Incorporated | Method of generating a cycle-efficient bit-reverse index array for a wireless communication system |
JP2003346484A (en) | 2002-05-23 | 2003-12-05 | Mitsubishi Electric Corp | Nonvolatile semiconductor storage device |
US6789099B2 (en) | 2002-06-10 | 2004-09-07 | International Business Machines Corporation | Sense-amp based adder with source follower evaluation tree |
US7054178B1 (en) | 2002-09-06 | 2006-05-30 | Etron Technology, Inc. | Datapath architecture for high area efficiency |
US6987693B2 (en) | 2002-09-24 | 2006-01-17 | Sandisk Corporation | Non-volatile memory and method with reduced neighboring field errors |
US7079407B1 (en) | 2002-10-18 | 2006-07-18 | Netlogic Microsystems, Inc. | Content addressable memory (CAM) device including match line sensing |
US6765834B2 (en) | 2002-11-19 | 2004-07-20 | Hewlett-Packard Development Company, L.P. | System and method for sensing memory cells of an array of memory cells |
US6731542B1 (en) | 2002-12-05 | 2004-05-04 | Advanced Micro Devices, Inc. | Circuit for accurate memory read operations |
KR100546307B1 (en) | 2002-12-05 | 2006-01-26 | 삼성전자주식회사 | Semiconductor device comprising precharge circuit for precharging and/or equalizing global input and output line and layout of precharging and/or equalizing transistor |
US6888372B1 (en) | 2002-12-20 | 2005-05-03 | Altera Corporation | Programmable logic device with soft multiplier |
AU2002353406A1 (en) | 2002-12-27 | 2004-07-22 | Solid State System Co., Ltd. | Nonvolatile memory unit with specific cache |
US7346903B2 (en) | 2003-02-04 | 2008-03-18 | Sun Microsystems, Inc. | Compiling and linking modules of a cycle-based logic design |
US6768679B1 (en) | 2003-02-10 | 2004-07-27 | Advanced Micro Devices, Inc. | Selection circuit for accurate memory read operations |
US6819612B1 (en) | 2003-03-13 | 2004-11-16 | Advanced Micro Devices, Inc. | Apparatus and method for a sense amplifier circuit that samples and holds a reference voltage |
US6865122B2 (en) | 2003-04-11 | 2005-03-08 | Intel Corporation | Reclaiming blocks in a block-alterable memory |
US7574466B2 (en) | 2003-04-23 | 2009-08-11 | Micron Technology, Inc. | Method for finding global extrema of a set of shorts distributed across an array of parallel processing elements |
US7447720B2 (en) | 2003-04-23 | 2008-11-04 | Micron Technology, Inc. | Method for finding global extrema of a set of bytes distributed across an array of parallel processing elements |
US7454451B2 (en) | 2003-04-23 | 2008-11-18 | Micron Technology, Inc. | Method for finding local extrema of a set of values for a parallel processing element |
US9015390B2 (en) | 2003-04-25 | 2015-04-21 | Micron Technology, Inc. | Active memory data compression system and method |
DE10319271A1 (en) | 2003-04-29 | 2004-11-25 | Infineon Technologies Ag | Memory circuitry and manufacturing method |
JP3898152B2 (en) | 2003-05-27 | 2007-03-28 | ローム株式会社 | Storage device with operation function and operation storage method |
DE10335643B4 (en) * | 2003-08-04 | 2007-10-31 | Infineon Technologies Ag | Apparatus and method for controlling the access of a plurality of data processing devices to a memory |
WO2005024843A1 (en) | 2003-09-04 | 2005-03-17 | Koninklijke Philips Electronics N.V. | Integrated circuit and a method of cache remapping |
US6956770B2 (en) | 2003-09-17 | 2005-10-18 | Sandisk Corporation | Non-volatile memory and method with bit line compensation dependent on neighboring operating modes |
US7177183B2 (en) | 2003-09-30 | 2007-02-13 | Sandisk 3D Llc | Multiple twin cell non-volatile memory array and logic block structure and method therefor |
US7913125B2 (en) | 2003-11-04 | 2011-03-22 | Lsi Corporation | BISR mode to test the redundant elements and regular functional memory to avoid test escapes |
US6956786B2 (en) * | 2003-12-04 | 2005-10-18 | Infineon Technologies North America Corp. | Random access memory with optional inaccessible memory cells |
US6950771B1 (en) | 2003-12-09 | 2005-09-27 | Xilinx, Inc. | Correlation of electrical test data with physical defect data |
US7401281B2 (en) | 2004-01-29 | 2008-07-15 | International Business Machines Corporation | Remote BIST high speed test and redundancy calculation |
US7631236B2 (en) | 2004-01-29 | 2009-12-08 | International Business Machines Corporation | Hybrid built-in self test (BIST) architecture for embedded memory arrays and an associated method |
JP4819316B2 (en) | 2004-02-23 | 2011-11-24 | ルネサスエレクトロニクス株式会社 | Semiconductor device |
US7088606B2 (en) | 2004-03-10 | 2006-08-08 | Altera Corporation | Dynamic RAM storage techniques |
US7020017B2 (en) | 2004-04-06 | 2006-03-28 | Sandisk Corporation | Variable programming of non-volatile memory |
US7120063B1 (en) | 2004-05-07 | 2006-10-10 | Spansion Llc | Flash memory cell and methods for programming and erasing |
US8522205B2 (en) | 2004-05-18 | 2013-08-27 | Oracle International Corporation | Packaging multiple groups of read-only files of an application's components into multiple shared libraries |
JP2006127460A (en) | 2004-06-09 | 2006-05-18 | Renesas Technology Corp | Semiconductor device, semiconductor signal processing apparatus and crossbar switch |
US7061817B2 (en) | 2004-06-30 | 2006-06-13 | Micron Technology, Inc. | Data path having grounded precharge operation and test compression capability |
US7116602B2 (en) | 2004-07-15 | 2006-10-03 | Micron Technology, Inc. | Method and system for controlling refresh to avoid memory cell data losses |
US7434024B2 (en) | 2004-08-30 | 2008-10-07 | Ati Technologies, Inc. | SIMD processor with register addressing, buffer stall and methods |
US7685365B2 (en) | 2004-09-30 | 2010-03-23 | Intel Corporation | Transactional memory execution utilizing virtual memory |
US20060069849A1 (en) | 2004-09-30 | 2006-03-30 | Rudelic John C | Methods and apparatus to update information in a memory |
US20060149804A1 (en) | 2004-11-30 | 2006-07-06 | International Business Machines Corporation | Multiply-sum dot product instruction with mask and splat |
US7230851B2 (en) | 2004-12-23 | 2007-06-12 | Sandisk Corporation | Reducing floating gate to floating gate coupling effect |
KR100673901B1 (en) | 2005-01-28 | 2007-01-25 | 주식회사 하이닉스반도체 | Semiconductor device for low voltage |
US7543119B2 (en) | 2005-02-10 | 2009-06-02 | Richard Edward Hessel | Vector processor |
US7624313B2 (en) | 2005-03-28 | 2009-11-24 | Hewlett-Packard Development Company, L.P. | TCAM BIST with redundancy |
US7196928B2 (en) | 2005-04-05 | 2007-03-27 | Sandisk Corporation | Compensating for coupling during read operations of non-volatile memory |
US7187585B2 (en) | 2005-04-05 | 2007-03-06 | Sandisk Corporation | Read operation for non-volatile storage that includes compensation for coupling |
US7193898B2 (en) | 2005-06-20 | 2007-03-20 | Sandisk Corporation | Compensation currents in non-volatile memory read operations |
KR100720644B1 (en) | 2005-11-17 | 2007-05-21 | 삼성전자주식회사 | Memory device and method of operating the same |
JP4804479B2 (en) | 2005-12-13 | 2011-11-02 | スパンション エルエルシー | Semiconductor device and control method thereof |
JP5129450B2 (en) | 2006-01-16 | 2013-01-30 | ルネサスエレクトロニクス株式会社 | Information processing device |
US8077533B2 (en) | 2006-01-23 | 2011-12-13 | Freescale Semiconductor, Inc. | Memory and method for sensing data in a memory using complementary sensing scheme |
JP4989900B2 (en) | 2006-01-31 | 2012-08-01 | ルネサスエレクトロニクス株式会社 | Parallel processing unit |
US7400532B2 (en) | 2006-02-16 | 2008-07-15 | Micron Technology, Inc. | Programming method to reduce gate coupling interference for non-volatile memory |
DE602006008270D1 (en) | 2006-03-29 | 2009-09-17 | St Microelectronics Srl | A method and apparatus for detecting possible corruption of sector protection information of a non-volatile memory stored in an on-board volatile memory array at power up |
KR100755370B1 (en) | 2006-04-17 | 2007-09-04 | 삼성전자주식회사 | Semiconductor memory device |
TW200828333A (en) | 2006-04-28 | 2008-07-01 | Samsung Electronics Co Ltd | Sense amplifier circuit and sense amplifier-based flip-flop having the same |
US7752417B2 (en) | 2006-06-05 | 2010-07-06 | Oracle America, Inc. | Dynamic selection of memory virtualization techniques |
US7372715B2 (en) | 2006-06-14 | 2008-05-13 | Micron Technology, Inc. | Architecture and method for NAND flash memory |
US8069377B2 (en) | 2006-06-26 | 2011-11-29 | Micron Technology, Inc. | Integrated circuit having memory array including ECC and column redundancy and method of operating the same |
US7724559B2 (en) | 2006-07-14 | 2010-05-25 | International Business Machines Corporation | Self-referenced match-line sense amplifier for content addressable memories |
US7885119B2 (en) | 2006-07-20 | 2011-02-08 | Sandisk Corporation | Compensating for coupling during programming |
US7443729B2 (en) | 2006-07-20 | 2008-10-28 | Sandisk Corporation | System that compensates for coupling based on sensing a neighbor using coupling |
US7692466B2 (en) | 2006-08-18 | 2010-04-06 | Ati Technologies Ulc | Sense amplifier based flip-flop |
US7805587B1 (en) | 2006-11-01 | 2010-09-28 | Nvidia Corporation | Memory addressing controlled by PTE fields |
US8151082B2 (en) | 2007-12-06 | 2012-04-03 | Fusion-Io, Inc. | Apparatus, system, and method for converting a storage request into an append data storage command |
US7471536B2 (en) | 2006-12-08 | 2008-12-30 | Texas Instruments Incorporated | Match mismatch emulation scheme for an addressed location in a CAM |
US7460387B2 (en) | 2007-01-05 | 2008-12-02 | International Business Machines Corporation | eDRAM hierarchical differential sense amp |
US7743303B2 (en) | 2007-01-22 | 2010-06-22 | Micron Technology, Inc. | Defective memory block remapping method and system, and memory device and processor-based system using same |
US7937535B2 (en) | 2007-02-22 | 2011-05-03 | Arm Limited | Managing cache coherency in a data processing apparatus |
US7804718B2 (en) | 2007-03-07 | 2010-09-28 | Mosaid Technologies Incorporated | Partial block erase architecture for flash memory |
US7492640B2 (en) | 2007-06-07 | 2009-02-17 | Sandisk Corporation | Sensing with bit-line lockout control in non-volatile memory |
JP2009009665A (en) | 2007-06-29 | 2009-01-15 | Elpida Memory Inc | Semiconductor storage device |
US7996749B2 (en) | 2007-07-03 | 2011-08-09 | Altera Corporation | Signal loss detector for high-speed serial interface of a programmable logic device |
US7489543B1 (en) | 2007-07-25 | 2009-02-10 | Micron Technology, Inc. | Programming multilevel cell memory arrays |
US7694195B2 (en) | 2007-08-14 | 2010-04-06 | Dell Products L.P. | System and method for using a memory mapping function to map memory defects |
US7869273B2 (en) | 2007-09-04 | 2011-01-11 | Sandisk Corporation | Reducing the impact of interference during programming |
US7787319B2 (en) | 2007-09-06 | 2010-08-31 | Innovative Silicon Isi Sa | Sense amplifier circuitry for integrated circuit having memory cell array, and method of operating same |
US8042082B2 (en) | 2007-09-12 | 2011-10-18 | Neal Solomon | Three dimensional memory in a system on a chip |
US7965564B2 (en) | 2007-09-18 | 2011-06-21 | Zikbit Ltd. | Processor arrays made of standard memory cells |
US7663928B2 (en) | 2007-10-09 | 2010-02-16 | Ememory Technology Inc. | Sense amplifier circuit having current mirror architecture |
US8156299B2 (en) | 2007-10-19 | 2012-04-10 | Virident Systems Inc. | Managing memory systems containing components with asymmetric characteristics |
US7924628B2 (en) | 2007-11-14 | 2011-04-12 | Spansion Israel Ltd | Operation of a non-volatile memory array |
US7979667B2 (en) | 2007-12-10 | 2011-07-12 | Spansion Llc | Memory array search engine |
US7755960B2 (en) | 2007-12-17 | 2010-07-13 | Stmicroelectronics Sa | Memory including a performance test circuit |
US8495438B2 (en) | 2007-12-28 | 2013-07-23 | Texas Instruments Incorporated | Technique for memory imprint reliability improvement |
US7808854B2 (en) | 2008-02-19 | 2010-10-05 | Kabushiki Kaisha Toshiba | Systems and methods for data transfers between memory cells |
JP5194302B2 (en) | 2008-02-20 | 2013-05-08 | ルネサスエレクトロニクス株式会社 | Semiconductor signal processing equipment |
US20090254694A1 (en) | 2008-04-02 | 2009-10-08 | Zikbit Ltd. | Memory device with integrated parallel processing |
US8332580B2 (en) | 2008-04-02 | 2012-12-11 | Zikbit Ltd. | System, method and apparatus for memory with embedded associative section for computations |
US7957206B2 (en) | 2008-04-04 | 2011-06-07 | Micron Technology, Inc. | Read circuitry for an integrated circuit having memory cells and/or a memory cell array, and method of operating same |
US8339824B2 (en) | 2008-07-02 | 2012-12-25 | Cooke Laurence H | Nearest neighbor serial content addressable memory |
US8555037B2 (en) | 2008-08-15 | 2013-10-08 | Apple Inc. | Processing vectors using wrapping minima and maxima instructions in the macroscalar architecture |
US8417921B2 (en) | 2008-08-15 | 2013-04-09 | Apple Inc. | Running-min and running-max instructions for processing vectors using a base value from a key element of an input vector |
US8259509B2 (en) | 2008-08-18 | 2012-09-04 | Elpida Memory, Inc. | Semiconductor memory device and method with auxiliary I/O line assist circuit and functionality |
ITRM20080543A1 (en) | 2008-10-09 | 2010-04-10 | Micron Technology Inc | ARCHITECTURE AND METHOD FOR MEMORY PROGRAMMING. |
KR101596283B1 (en) | 2008-12-19 | 2016-02-23 | 삼성전자 주식회사 | Semiconductor memory device having improved precharge scheme for local I/O lines |
KR101622922B1 (en) | 2009-03-06 | 2016-05-20 | 삼성전자 주식회사 | Semiconductor memory device having improved precharge scheme for local I/O lines |
US8484276B2 (en) | 2009-03-18 | 2013-07-09 | International Business Machines Corporation | Processing array data on SIMD multi-core processor architectures |
KR20100134235A (en) | 2009-06-15 | 2010-12-23 | 삼성전자주식회사 | Semiconductor memory device |
US7898864B2 (en) | 2009-06-24 | 2011-03-01 | Sandisk Corporation | Read operation for memory with compensation for coupling based on write-erase cycles |
US8412985B1 (en) | 2009-06-30 | 2013-04-02 | Micron Technology, Inc. | Hardwired remapped memory |
US8412987B2 (en) | 2009-06-30 | 2013-04-02 | Micron Technology, Inc. | Non-volatile memory to store memory remap information |
US8238173B2 (en) | 2009-07-16 | 2012-08-07 | Zikbit Ltd | Using storage cells to perform computation |
US9076527B2 (en) | 2009-07-16 | 2015-07-07 | Mikamonu Group Ltd. | Charge sharing in a TCAM array |
JP4951041B2 (en) | 2009-08-06 | 2012-06-13 | 株式会社東芝 | Semiconductor memory device |
US8059438B2 (en) | 2009-08-28 | 2011-11-15 | International Business Machines Corporation | Content addressable memory array programmed to perform logic operations |
US8077532B2 (en) | 2009-09-02 | 2011-12-13 | Micron Technology, Inc. | Small unit internal verify read in a memory device |
US8482975B2 (en) | 2009-09-14 | 2013-07-09 | Micron Technology, Inc. | Memory kink checking |
US8495465B1 (en) | 2009-10-15 | 2013-07-23 | Apple Inc. | Error correction coding over multiple memory pages |
WO2011048522A2 (en) | 2009-10-21 | 2011-04-28 | Zikbit Ltd. | Neighborhood operations for parallel processing |
US9477636B2 (en) * | 2009-10-21 | 2016-10-25 | Micron Technology, Inc. | Memory having internal processors and data communication methods in memory |
US8650232B2 (en) | 2009-10-26 | 2014-02-11 | Via Technologies, Inc. | System and method for determination of a horizontal minimum of digital values |
KR101634340B1 (en) | 2009-11-03 | 2016-06-28 | 삼성전자주식회사 | Method for programming semiconductor memory device |
US8583896B2 (en) | 2009-11-13 | 2013-11-12 | Nec Laboratories America, Inc. | Massively parallel processing core with plural chains of processing elements and respective smart memory storing select data received from each chain |
KR20110054773A (en) | 2009-11-18 | 2011-05-25 | 삼성전자주식회사 | Semiconductor memory device for improving bit line disturbance |
US8089815B2 (en) | 2009-11-24 | 2012-01-03 | Sandisk Technologies Inc. | Programming memory with bit line floating to reduce channel-to-floating gate coupling |
US8605015B2 (en) | 2009-12-23 | 2013-12-10 | Syndiant, Inc. | Spatial light modulator with masking-comparators |
JP2011146102A (en) | 2010-01-15 | 2011-07-28 | Elpida Memory Inc | Semiconductor device and data processing system |
CN102141905B (en) | 2010-01-29 | 2015-02-25 | 上海芯豪微电子有限公司 | Processor system structure |
US8164942B2 (en) | 2010-02-01 | 2012-04-24 | International Business Machines Corporation | High performance eDRAM sense amplifier |
US8533245B1 (en) | 2010-03-03 | 2013-09-10 | Altera Corporation | Multipliers with a reduced number of memory blocks |
WO2011137189A1 (en) | 2010-04-27 | 2011-11-03 | Cornell Research Foundation | System and methods for mapping and searching objects in multidimensional space |
KR101119371B1 (en) | 2010-04-29 | 2012-03-06 | 주식회사 하이닉스반도체 | Semiconductor memory apparatus and a method of operating thereof |
US8559232B2 (en) | 2010-05-03 | 2013-10-15 | Aplus Flash Technology, Inc. | DRAM-like NVM memory array and sense amplifier design for high temperature and high endurance operation |
US8351278B2 (en) | 2010-06-23 | 2013-01-08 | International Business Machines Corporation | Jam latch for latching memory array output data |
KR101143471B1 (en) | 2010-07-02 | 2012-05-11 | 에스케이하이닉스 주식회사 | Sense amplifier and semiconductor apparatus including the same |
US20120017039A1 (en) | 2010-07-16 | 2012-01-19 | Plx Technology, Inc. | Caching using virtual memory |
US8462532B1 (en) | 2010-08-31 | 2013-06-11 | Netlogic Microsystems, Inc. | Fast quaternary content addressable memory cell |
US8347154B2 (en) | 2010-09-21 | 2013-01-01 | International Business Machines Corporation | Use of hashing function to distinguish random and repeat errors in a memory system |
US8904115B2 (en) | 2010-09-28 | 2014-12-02 | Texas Instruments Incorporated | Cache with multiple access pipelines |
US8332367B2 (en) | 2010-10-20 | 2012-12-11 | International Business Machines Corporation | Parallel data redundancy removal |
KR101148352B1 (en) | 2010-11-02 | 2012-05-21 | 에스케이하이닉스 주식회사 | Semiconductor memory device and method for operating thereof |
JP5528987B2 (en) | 2010-11-11 | 2014-06-25 | ピーエスフォー ルクスコ エスエイアールエル | Semiconductor device |
US8553482B2 (en) | 2010-11-29 | 2013-10-08 | Apple Inc. | Sense amplifier and sense amplifier latch having common control |
US9165023B2 (en) | 2011-01-31 | 2015-10-20 | Freescale Semiconductor, Inc. | Integrated circuit device and method for determining an index of an extreme value within an array of values |
KR20120088973A (en) | 2011-02-01 | 2012-08-09 | 삼성전자주식회사 | Local sense amplifier and semiconductor memory device including the same |
JP2012174016A (en) | 2011-02-22 | 2012-09-10 | Renesas Electronics Corp | Data processor and data processing method thereof |
JP5259765B2 (en) | 2011-03-29 | 2013-08-07 | 株式会社東芝 | Nonvolatile semiconductor memory |
US8725730B2 (en) | 2011-05-23 | 2014-05-13 | Hewlett-Packard Development Company, L.P. | Responding to a query in a data processing system |
US8706958B2 (en) | 2011-09-01 | 2014-04-22 | Thomas Hein | Data mask encoding in data bit inversion scheme |
GB2510286B (en) | 2011-10-28 | 2015-08-19 | Hewlett Packard Development Co | Row shifting shiftable memory |
US8891297B2 (en) | 2011-11-01 | 2014-11-18 | Micron Technology, Inc. | Memory cell sensing |
KR101321481B1 (en) | 2011-11-04 | 2013-10-28 | 에스케이하이닉스 주식회사 | Semiconductor Memory Apparatus and Test Circuit Therefor |
US9830158B2 (en) | 2011-11-04 | 2017-11-28 | Nvidia Corporation | Speculative execution and rollback |
KR20130052971A (en) | 2011-11-14 | 2013-05-23 | 삼성전자주식회사 | Method of operating non-volatile memory devices |
WO2013078085A1 (en) | 2011-11-22 | 2013-05-30 | Mips Technologies, Inc. | Processor with kernel mode access to user space virtual addresses |
US9665371B2 (en) | 2011-11-30 | 2017-05-30 | Intel Corporation | Providing vector horizontal compare functionality within a vector register |
KR101859646B1 (en) | 2011-12-16 | 2018-05-18 | 삼성전자주식회사 | Secure data protecting memory device, data protecting method using the secure data |
WO2013095592A1 (en) | 2011-12-22 | 2013-06-27 | Intel Corporation | Apparatus and method for vector compute and accumulate |
KR20130072869A (en) | 2011-12-22 | 2013-07-02 | 에스케이하이닉스 주식회사 | Precharge circuit and non-volatile memory device |
US20130286705A1 (en) | 2012-04-26 | 2013-10-31 | David B. Grover | Low power content addressable memory hitline precharge and sensing circuit |
US8938603B2 (en) | 2012-05-31 | 2015-01-20 | Samsung Electronics Co., Ltd. | Cache system optimized for cache miss detection |
US20130332707A1 (en) | 2012-06-07 | 2013-12-12 | Intel Corporation | Speed up big-number multiplication using single instruction multiple data (simd) architectures |
GB2513727B (en) | 2012-06-27 | 2015-06-24 | Nordic Semiconductor Asa | Memory protection |
KR102062301B1 (en) | 2013-01-03 | 2020-01-03 | 삼성전자주식회사 | Page copy method in memory device and page management method in memory system |
US20140215185A1 (en) | 2013-01-29 | 2014-07-31 | Atmel Norway | Fetching instructions of a loop routine |
US9158667B2 (en) | 2013-03-04 | 2015-10-13 | Micron Technology, Inc. | Apparatuses and methods for performing logical operations using sensing circuitry |
US9171153B2 (en) | 2013-05-17 | 2015-10-27 | Hewlett-Packard Development Company, L.P. | Bloom filter with memory element |
US8964496B2 (en) | 2013-07-26 | 2015-02-24 | Micron Technology, Inc. | Apparatuses and methods for performing compare operations using sensing circuitry |
US8971124B1 (en) | 2013-08-08 | 2015-03-03 | Micron Technology, Inc. | Apparatuses and methods for performing logical operations using sensing circuitry |
US9153305B2 (en) | 2013-08-30 | 2015-10-06 | Micron Technology, Inc. | Independently addressable memory array address spaces |
US9019785B2 (en) | 2013-09-19 | 2015-04-28 | Micron Technology, Inc. | Data shifting via a number of isolation devices |
US9449675B2 (en) | 2013-10-31 | 2016-09-20 | Micron Technology, Inc. | Apparatuses and methods for identifying an extremum value stored in an array of memory cells |
US9430191B2 (en) | 2013-11-08 | 2016-08-30 | Micron Technology, Inc. | Division operations for memory |
US20150270015A1 (en) | 2014-03-19 | 2015-09-24 | Micron Technology, Inc. | Memory mapping |
US9934856B2 (en) | 2014-03-31 | 2018-04-03 | Micron Technology, Inc. | Apparatuses and methods for comparing data patterns in memory |
US10838865B2 (en) | 2014-05-08 | 2020-11-17 | Micron Technology, Inc. | Stacked memory device system interconnect directory-based cache coherence methodology |
WO2015171905A1 (en) | 2014-05-08 | 2015-11-12 | Micron Technology, Inc. | In-memory lightweight coherency |
US9779019B2 (en) | 2014-06-05 | 2017-10-03 | Micron Technology, Inc. | Data storage layout |
US10074407B2 (en) | 2014-06-05 | 2018-09-11 | Micron Technology, Inc. | Apparatuses and methods for performing invert operations using sensing circuitry |
US9830999B2 (en) | 2014-06-05 | 2017-11-28 | Micron Technology, Inc. | Comparison operations in memory |
US9455020B2 (en) | 2014-06-05 | 2016-09-27 | Micron Technology, Inc. | Apparatuses and methods for performing an exclusive or operation using sensing circuitry |
US9711207B2 (en) | 2014-06-05 | 2017-07-18 | Micron Technology, Inc. | Performing logical operations using sensing circuitry |
US9704540B2 (en) | 2014-06-05 | 2017-07-11 | Micron Technology, Inc. | Apparatuses and methods for parity determination using sensing circuitry |
US9910787B2 (en) | 2014-06-05 | 2018-03-06 | Micron Technology, Inc. | Virtual address table |
US9496023B2 (en) | 2014-06-05 | 2016-11-15 | Micron Technology, Inc. | Comparison operations on logical representations of values in memory |
US9786335B2 (en) | 2014-06-05 | 2017-10-10 | Micron Technology, Inc. | Apparatuses and methods for performing logical operations using sensing circuitry |
US9449674B2 (en) | 2014-06-05 | 2016-09-20 | Micron Technology, Inc. | Performing logical operations using sensing circuitry |
US9711206B2 (en) | 2014-06-05 | 2017-07-18 | Micron Technology, Inc. | Performing logical operations using sensing circuitry |
US9898252B2 (en) | 2014-09-03 | 2018-02-20 | Micron Technology, Inc. | Multiplication operations in memory |
US9904515B2 (en) | 2014-09-03 | 2018-02-27 | Micron Technology, Inc. | Multiplication operations in memory |
US9589602B2 (en) | 2014-09-03 | 2017-03-07 | Micron Technology, Inc. | Comparison operations in memory |
US10068652B2 (en) | 2014-09-03 | 2018-09-04 | Micron Technology, Inc. | Apparatuses and methods for determining population count |
US9747961B2 (en) | 2014-09-03 | 2017-08-29 | Micron Technology, Inc. | Division operations in memory |
US9740607B2 (en) | 2014-09-03 | 2017-08-22 | Micron Technology, Inc. | Swap operations in memory |
US9847110B2 (en) | 2014-09-03 | 2017-12-19 | Micron Technology, Inc. | Apparatuses and methods for storing a data value in multiple columns of an array corresponding to digits of a vector |
US9836218B2 (en) | 2014-10-03 | 2017-12-05 | Micron Technology, Inc. | Computing reduction and prefix sum operations in memory |
US9940026B2 (en) | 2014-10-03 | 2018-04-10 | Micron Technology, Inc. | Multidimensional contiguous memory allocation |
US10163467B2 (en) | 2014-10-16 | 2018-12-25 | Micron Technology, Inc. | Multiple endianness compatibility |
US10147480B2 (en) | 2014-10-24 | 2018-12-04 | Micron Technology, Inc. | Sort operation in memory |
US9779784B2 (en) | 2014-10-29 | 2017-10-03 | Micron Technology, Inc. | Apparatuses and methods for performing logical operations using sensing circuitry |
US10073635B2 (en) | 2014-12-01 | 2018-09-11 | Micron Technology, Inc. | Multiple endianness compatibility |
US9747960B2 (en) | 2014-12-01 | 2017-08-29 | Micron Technology, Inc. | Apparatuses and methods for converting a mask to an index |
US10032493B2 (en) | 2015-01-07 | 2018-07-24 | Micron Technology, Inc. | Longest element length determination in memory |
US10061590B2 (en) | 2015-01-07 | 2018-08-28 | Micron Technology, Inc. | Generating and executing a control flow |
US9583163B2 (en) | 2015-02-03 | 2017-02-28 | Micron Technology, Inc. | Loop structure for operations in memory |
US9741399B2 (en) | 2015-03-11 | 2017-08-22 | Micron Technology, Inc. | Data shift by elements of a vector in memory |
US9898253B2 (en) | 2015-03-11 | 2018-02-20 | Micron Technology, Inc. | Division operations on variable length elements in memory |
US10146537B2 (en) | 2015-03-13 | 2018-12-04 | Micron Technology, Inc. | Vector population count determination in memory |
US10049054B2 (en) | 2015-04-01 | 2018-08-14 | Micron Technology, Inc. | Virtual register file |
US10140104B2 (en) | 2015-04-14 | 2018-11-27 | Micron Technology, Inc. | Target architecture determination |
US9959923B2 (en) | 2015-04-16 | 2018-05-01 | Micron Technology, Inc. | Apparatuses and methods to reverse data stored in memory |
US9704541B2 (en) | 2015-06-12 | 2017-07-11 | Micron Technology, Inc. | Simulating access lines |
US9921777B2 (en) | 2015-06-22 | 2018-03-20 | Micron Technology, Inc. | Apparatuses and methods for data transfer from sensing circuitry to a controller |
US9996479B2 (en) | 2015-08-17 | 2018-06-12 | Micron Technology, Inc. | Encryption of executables in computational memory |
US9905276B2 (en) | 2015-12-21 | 2018-02-27 | Micron Technology, Inc. | Control of sensing components in association with performing operations |
US9952925B2 (en) | 2016-01-06 | 2018-04-24 | Micron Technology, Inc. | Error code calculation on sensing circuitry |
US10048888B2 (en) | 2016-02-10 | 2018-08-14 | Micron Technology, Inc. | Apparatuses and methods for partitioned parallel data movement |
US9892767B2 (en) | 2016-02-12 | 2018-02-13 | Micron Technology, Inc. | Data gathering in memory |
US9971541B2 (en) | 2016-02-17 | 2018-05-15 | Micron Technology, Inc. | Apparatuses and methods for data movement |
US9899070B2 (en) | 2016-02-19 | 2018-02-20 | Micron Technology, Inc. | Modified decode for corner turn |
US10956439B2 (en) | 2016-02-19 | 2021-03-23 | Micron Technology, Inc. | Data transfer with a bit vector operation device |
US10496311B2 (en) * | 2017-01-19 | 2019-12-03 | International Business Machines Corporation | Run-time instrumentation of guarded storage event processing |
US10262701B2 (en) * | 2017-06-07 | 2019-04-16 | Micron Technology, Inc. | Data transfer between subarrays in memory |
US10534553B2 (en) * | 2017-08-30 | 2020-01-14 | Micron Technology, Inc. | Memory array accessibility |
US10332586B1 (en) * | 2017-12-19 | 2019-06-25 | Micron Technology, Inc. | Apparatuses and methods for subrow addressing |
US20230129539A1 (en) * | 2021-10-22 | 2023-04-27 | Micron Technology, Inc. | Authenticated modification of memory system data |
-
2017
- 2017-08-30 US US15/691,484 patent/US10534553B2/en active Active
-
2018
- 2018-08-24 DE DE112018004896.9T patent/DE112018004896T5/en active Pending
- 2018-08-24 WO PCT/US2018/047862 patent/WO2019046111A1/en active Application Filing
- 2018-08-24 CN CN201880056010.3A patent/CN111052068B/en active Active
-
2019
- 2019-08-29 US US16/555,293 patent/US11182085B2/en active Active
-
2021
- 2021-11-19 US US17/531,573 patent/US11886715B2/en active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060036816A1 (en) * | 2004-07-29 | 2006-02-16 | Mcmahan Larry N | Communication among partitioned devices |
CN101095196A (en) * | 2004-11-29 | 2007-12-26 | 拉姆伯斯公司 | Multi-mode memory |
Also Published As
Publication number | Publication date |
---|---|
DE112018004896T5 (en) | 2020-06-18 |
CN111052068B (en) | 2023-11-28 |
US20220083239A1 (en) | 2022-03-17 |
US11182085B2 (en) | 2021-11-23 |
US11886715B2 (en) | 2024-01-30 |
US10534553B2 (en) | 2020-01-14 |
US20190384512A1 (en) | 2019-12-19 |
WO2019046111A1 (en) | 2019-03-07 |
US20190065082A1 (en) | 2019-02-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10236037B2 (en) | Data transfer in sensing components | |
US11238920B2 (en) | Comparison operations in memory | |
US9940985B2 (en) | Comparison operations in memory | |
CN111052068B (en) | memory array accessibility | |
US10074406B2 (en) | Apparatuses and methods for performing logical operations using sensing circuitry | |
KR101954542B1 (en) | Performing logical operations using sensing circuitry | |
US9697876B1 (en) | Vertical bit vector shift in memory | |
US20160266873A1 (en) | Division operations on variable length elements in memory | |
US10042608B2 (en) | Signed division in memory | |
US10854247B2 (en) | Apparatuses and methods to selectively perform logical operations | |
US10622034B2 (en) | Element value comparison in memory | |
US10043570B1 (en) | Signed element compare in memory |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
TA01 | Transfer of patent application right | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20230830 Address after: Illinois, America Applicant after: North Star Franchise Group Co.,Ltd. Address before: Idaho Applicant before: MICRON TECHNOLOGY, Inc. |
|
GR01 | Patent grant | ||
GR01 | Patent grant |