EP3259674A1 - Dram circuit provided with a built-in processor - Google Patents
Dram circuit provided with a built-in processorInfo
- Publication number
- EP3259674A1 EP3259674A1 EP16707914.4A EP16707914A EP3259674A1 EP 3259674 A1 EP3259674 A1 EP 3259674A1 EP 16707914 A EP16707914 A EP 16707914A EP 3259674 A1 EP3259674 A1 EP 3259674A1
- Authority
- EP
- European Patent Office
- Prior art keywords
- memory
- processor
- circuit
- dram
- refresh
- 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
- 230000015654 memory Effects 0.000 claims abstract description 228
- 238000012545 processing Methods 0.000 claims abstract description 33
- 238000000034 method Methods 0.000 claims description 25
- 230000004913 activation Effects 0.000 claims description 10
- 230000003213 activating effect Effects 0.000 claims description 3
- 101000596298 Homo sapiens Modulator of macroautophagy TMEM150B Proteins 0.000 description 13
- 102100035252 Modulator of macroautophagy TMEM150B Human genes 0.000 description 13
- 102100020800 DNA damage-regulated autophagy modulator protein 1 Human genes 0.000 description 10
- 101000931929 Homo sapiens DNA damage-regulated autophagy modulator protein 1 Proteins 0.000 description 10
- 238000004891 communication Methods 0.000 description 8
- 230000008901 benefit Effects 0.000 description 7
- 102100040489 DNA damage-regulated autophagy modulator protein 2 Human genes 0.000 description 6
- 101000968012 Homo sapiens DNA damage-regulated autophagy modulator protein 2 Proteins 0.000 description 6
- 238000012546 transfer Methods 0.000 description 5
- 230000003111 delayed effect Effects 0.000 description 4
- 230000008569 process Effects 0.000 description 4
- 230000009849 deactivation Effects 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 230000000737 periodic effect Effects 0.000 description 3
- 230000002457 bidirectional effect Effects 0.000 description 2
- 230000007717 exclusion Effects 0.000 description 2
- 230000006872 improvement Effects 0.000 description 2
- 238000004519 manufacturing process Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 241000256844 Apis mellifera Species 0.000 description 1
- 101100498818 Arabidopsis thaliana DDR4 gene Proteins 0.000 description 1
- 102100036725 Epithelial discoidin domain-containing receptor 1 Human genes 0.000 description 1
- 101710131668 Epithelial discoidin domain-containing receptor 1 Proteins 0.000 description 1
- 241000153282 Theope Species 0.000 description 1
- 230000002159 abnormal effect Effects 0.000 description 1
- 230000004075 alteration Effects 0.000 description 1
- 239000003990 capacitor Substances 0.000 description 1
- 230000000295 complement effect Effects 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000009977 dual effect Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 230000037452 priming Effects 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 230000001131 transforming effect Effects 0.000 description 1
- 238000010200 validation analysis Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/16—Handling requests for interconnection or transfer for access to memory bus
- G06F13/1668—Details of memory controller
- G06F13/1673—Details of memory controller using buffers
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/16—Handling requests for interconnection or transfer for access to memory bus
- G06F13/1605—Handling requests for interconnection or transfer for access to memory bus based on arbitration
- G06F13/161—Handling requests for interconnection or transfer for access to memory bus based on arbitration with latency improvement
- G06F13/1636—Handling requests for interconnection or transfer for access to memory bus based on arbitration with latency improvement using refresh
Definitions
- the present disclosure relates to the field of random access memory (DRAM) circuits having integrated processors, and methods of communication with such memories.
- DRAM random access memory
- Modern computers generally include a processing circuit, often implemented as a system on a chip (SoC), coupled to one or more Random Access Memory (DRAM) circuits.
- SoC system on a chip
- DRAM Random Access Memory
- Such memories which generally require a periodic refresh operation, are dense and relatively fast access, and are thus used as the main RAM data storage in most computers.
- SoC system on a chip
- DRAM Random Access Memory
- One solution that has been proposed is to provide DRAM circuits having one or more integrated processors, in addition to the processors in the SoC. Such a solution reduces the volume of data transfer between DRAM circuits and the SoC by allowing certain processing tasks to be delegated to the DRAM processors, so that these tasks can be performed while avoiding data transfers between the DRAM circuit and the SoC.
- DRAMs equipped with integrated processors is that the interface with the SoC is time consuming and is expensive to implement.
- the arbitration is done by placing an external processor, including a memory controller, in communication with the internal processor via a control interface formed by electrical links for communicating request and validation signals.
- An object of the present description is to at least partially solve one or more problems of the prior art.
- a memory circuit comprising a memory network comprising one or more memory banks; a first processor; and a processor control interface for receiving data processing commands addressed to the first processor from a central processor, wherein the processor control interface is adapted to indicate to the central processor when the first processor has finished processing. access to one or more memory banks memory network, these memory banks becoming accessible to the central processor.
- the memory circuit is a Random Access Memory (DRAM) circuit further comprising a refresh control circuit adapted to: receiving, from the central processor, refresh transactions to perform refreshing data in at least one memory bank of the memory network; determining if said at least one memory bank is being accessed by the first processor, and if so, delaying the start time of the data refresh operation.
- DRAM Random Access Memory
- the refresh control circuit includes a refresh register waiting and delaying the start time of the ope ⁇ ration data refresh includes state in the refresh register waiting for the refresh operation to wait.
- the processor control interface comprises a set of control registers accessible in the address space of the memory circuit.
- the address space of the memory circuit comprises one or more addresses permanently associated with the set of control registers.
- the address space of the memory circuit comprises one or more addresses associated with the set of control registers, and said one or more addresses are adapted to be transformed into addresses of the memory network during the activating a damper control signal.
- the memory circuit is adapted to receive an activation signal from the central processor to make the set of control registers accessible in the address space of the memory circuit.
- the activation signal is provided via an address bus, and is detectable by the processor control interface.
- the memory access sequence for making the set of control registers accessible is a burst access sequence in which all the words are not written.
- the memory access sequence for making the set of control registers accessible is a plurality of memory accesses to memory cells located in a memory zone in one of the memory banks in a first period. of time.
- the memory circuit is adapted to detect the memory access sequence based on one or more of the following: a period of time in which the memory access sequence is received; and a duration of the memory access sequence.
- a system comprising: a plurality of memory circuits; and a central processor coupled to each of the memory circuits via an N-bit common data bus, each memory circuit including an N-bit bus interface coupled to the N-bit data bus.
- a method for accessing a memory circuit comprising a memory network comprising one or more memory banks; a first processor; and a processor control interface, the method comprising: receiving, by the processor control interface, data processing commands addressed to the first processor from a central processor; indicate, by the processor control interface to the central processor, when the first processor has finished accessing one or more of the memory banks of the memory network, these memory banks becoming accessible by the central processor.
- the memory circuit is a random access dynamic memory (DRAM) circuit, the method further comprising: receiving, by a refresh control circuit, a refresh transaction to perform a refresh operation data in a memory bank of the memory network; determining, by the refresh control circuit, whether the memory bank is being accessed by the first processor and if so, delaying the start time of the data refresh operation.
- DRAM random access dynamic memory
- the processor control interface comprises a set of control registers, the method further comprising: receiving by the processor control interface an activation signal from the central processor to render the set of control registers accessible in an address space of the memory circuit.
- FIG. 1 diagrammatically illustrates a computer system comprising DRAM circuits comprising integrated processors according to an exemplary embodiment
- FIG. 2 schematically illustrates a DRAM data bus according to an example
- FIG. 3 schematically illustrates a DRAM data bus according to an embodiment of the present description
- Figure 4 schematically illustrates a portion of the computer system of Figure 1 in more detail according to an exemplary embodiment
- FIG. 5 schematically illustrates a memory bank of FIG. 4 in more detail according to an exemplary embodiment
- Fig. 6 is a flowchart showing operations in a method of delegating a processing task to a DRAM processor according to an exemplary embodiment
- Figure 7 schematically illustrates a refresh control circuit according to an exemplary embodiment
- Fig. 8 is a flowchart illustrating steps in a refresh control method according to an exemplary embodiment
- Figure 9 schematically illustrates a portion of a DRAM circuit of Figure 4 in more detail according to another embodiment.
- Fig. 10 is a flowchart illustrating operations in a method for rendering a DRAM interface control processor visible in the DRAM address space according to an exemplary embodiment.
- a memory circuit comprising an integrated processor according to an example in which the memory circuit is a DRAM circuit.
- a DRAM circuit is a memory device in which data is stored by an array of memory cells, each memory cell including a capacitor for storing a memory. voltage level representative of a data bit, and a switch for controlling access to the memory cell.
- the principles described herein can be easily applied to other types of memory circuits, which may or may not require a refresh operation.
- An advantage of the embodiments described here is that the integration of one or more processors in the memory circuit does not prevent an interface of an earlier version, having no communication with such an integrated processor, of be used to communicate with the memory circuit.
- FIG. 1 schematically illustrates a computer system 100 according to an exemplary embodiment.
- the computer system 100 comprises a central processing device 102, implemented in this example in the form of a system on a chip (SoC), comprising one or more processors (not shown) and a DDR master interface (DDR MAS ER INTERFACE ) 103 to communicate with a number of DRAM circuits.
- SoC system on a chip
- DDR MAS ER INTERFACE DDR master interface
- FIG. 1 there are four DRAM circuits referenced DRAMO to DRAM3, but in alternative embodiments there could be any number of DRAM circuits.
- the DRAMO DRAM circuit comprises a DRAM (MA) memory array 104 and one or more internal processors (P) 106, which will be referred to in the following DRAM processors.
- the DRAMO DRAM circuit also includes, for example, a DRAM (I) processor control interface 107 associated with each DRAM processor, enabling one or more processors in the SoC 102 to communicate with the corresponding processors 106 and to control them.
- a DDR slave interface 108 is for example provided in the DRAM DRAMO circuit for communications with the DDR master interface 103.
- the DRAM circuits DRAM1, DRAM2 and DRAM3 respectively comprise DRAM memory networks 114, 124, 134 and one or more internal processors (P) 116, 126, 136.
- the DRAM circuits DRAM1, DRAM2, DRAM3 also comprise respectively exemplary DRAM processor control interfaces 117, 127, 137 allowing one or more processors in the SoC 102 to control the processors 116, 126, 136 respectively.
- DDR slave interfaces 118, 128, 138 are for example provided in the DRAM1, DRAM2, DRAM3 circuits for communications with the DDR master interface 103.
- the communications between the DDR master interface 103 and each of the slave interfaces 108, 118, 128, 138 is for example via a link bus 140 comprising an address bus, a data bus, and in some cases one or more other command lines (not shown in Figure 1).
- a link bus 140 comprising an address bus, a data bus, and in some cases one or more other command lines (not shown in Figure 1).
- communications with the DRAMO DRAM3 DRAM circuits on the link bus 140 follow one of the DDR protocols.
- DDR protocol is used herein to refer to any of DDR1, DDR2, DDR3, DDR4, RLDRAM (Reduced Latency Random Access Memory), RLDRAM2, and any protocol similar to these protocols.
- FIG. 2 schematically illustrates a 64-bit data bus (DATA BUS) for connecting a SoC (not shown) to the four DRAMO to DRAM3 DRAM circuits. It can be seen that the data bus is separated so that each DRAMO to DRAM3 receives 16 bits of the 64-bit wide data bus.
- the DRAMO circuit receives the bits 0 to 15, and contains the bytes 0, 1, 8, 9, 16, 17, etc.
- the DRAM1 circuit receives the bits 16 to 31, and contains the multiplets 2, 3, 10, 11, 18, 19, etc.
- the DRAM2 receives the bits 32 to 47, and contains the bytes 4, 5, 12, 13, 20, 21, etc.
- the DRAM3 receives the bits 48 to 63 and contains multiplets 6, 7, 14, 15, 22, 23, etc.
- An advantage of such an arrangement is that it is not necessary to separately address the individual DRAM circuits.
- a disadvantage of providing the data bus arrangement of FIG. 2 is that each DRAM circuit stores discontinuous data, which leads to a high complexity in achieving a processing of these data under the control of SoC processors.
- FIG. 3 schematically illustrates a 64-bit wide data bus (DATA BUS) for connecting a SoC (still not shown) to the four DRAMO to DRAM3 DRAM circuits.
- each DRAM circuit includes a 64-bit bus interface coupled to the 64-bit data bus, and thus each DRAM receives all bits transmitted over the data bus.
- each DRAM circuit contains a portion continuous total memory. More generally, assuming that the data bus of the SoC is N bits, where N is an integer greater than or equal to 2, each of the DRAM circuits also has an N-bit data bus.
- a mechanism is also provided for example to allow the SoC to select the DRAM circuit for each DRAM memory access.
- the SoC is capable of providing a chip select signal CS on an output line.
- the signal CS is for example supplied to each DRAM circuit in order to select one of these DRAM circuits for a given memory access.
- the signal CS is for example a 2-bit signal, the values "00", "01", “10” and "11” being associated with DRAM circuits DRAM0, DRAM1, DRAM2 , DRAM3 respectively. If there is a different number of DRAM circuits, the signal CS may comprise a different number of bits.
- the SoC is capable of providing a chip selection signal CS dedicated to each DRAM circuit.
- the dotted line CS is a 4-bit wide bus comprising a dedicated signal CS [0] supplied to the circuit DRAM0, a dedicated signal CS [1] supplied to the circuit DRAM1, a dedicated signal CS [2] provided to the DRAM2 circuit, and a dedicated signal CS [3] supplied to the circuit DRAM3.
- each of the DRAM circuits is adapted to decode an address range different from the total address range.
- the address decoders 300 to 303 of the DRAM DRAM0 to DRAM3 circuits respectively have, for example, circuits each of which is adapted to decode the corresponding address range.
- such a solution has the disadvantage that it adds complexity to the process of manufacturing since the DRAM circuits are no longer identical to each other.
- An alternative solution is to provide a set of fuses associated with each address decoder 300 to 303 and represented by dashed rectangles 310 to 313 respectively.
- the fuses are, for example, of the laser programmed type, of a voltage applied to their terminals, or of a current which is passed in, and they are programmed after the manufacture of the DRAM circuits so that each DRAM circuit is configured to decode a specific address range.
- the address range accepted by each DRAM circuit could be electrically configured by input signals supplied to input terminals of the DRAM circuit directly after a reset operation or after powering up the devices. circuits.
- the input terminals could be dedicated terminals provided for this particular purpose, or the standard input / output pins of the DRAM circuit could be used during the configuration phase to allow the setting of the address ranges.
- each data line is coupled to more than one of the DRAM circuits is likely to bring a higher electrical capacity for the data lines.
- a buffer could be added on each data line. This could increase the latency of one or more cycle memory access, and would lead to a relatively insignificant percentage increase in overall latency.
- the DRAM circuits are mounted in a memory card conforming to the standards a DIMM (dual inline pin memory module), how the capacity addi ⁇ mentary lines and / or Adding buffer circuits could be masked by such a DIMM module will be clear to those skilled in the art.
- Figure 4 schematically illustrates the SoC 102 and the DRAMO circuit in more detail.
- the other DRAM circuits DRAM1 to DRAM3 have, for example, similar structures.
- the SoC 102 comprises, for example, PI and P2 processors, each capable of accessing the DRAMO DRAM circuit.
- the processors PI, P2 are for example each under the instruction control stored in corresponding instruction memories (not shown in FIG. 4). Although there are two processors in the SoC of the example of Figure 4, in alternative embodiments there could be any number of processors.
- the DRAMO DRAM circuit for example comprises a plurality of sub-memories 406, 408, 410 and 412, and a common DDR slave interface (DDR SLAVE INTERFACE) 414, comprising a DRAM processor control interface (GI) of the DRAM circuit, and a common refresh controller (REFRESH CONTROLER) 416 coupled to each of the sub-memories.
- DDR SLAVE INTERFACE DDR slave interface
- GI DRAM processor control interface
- REFRESH CONTROLER common refresh controller
- the sub-memory 406 is illustrated in detail, and the other sub-memories include for example the same elements.
- the sub-memory 406 comprises for example a memory bank (MEMORY BANK) 418 forming a sub-portion of the memory array of the DRAM DRAMO circuit.
- Sub-memory 406 also includes, for example, a DRAM PROCESSOR 420 coupled to memory bank 418, including a MEMORY ARRAY CONTROL circuit 422 including a local DRAM (LI) processor control interface 423, REFRESH CONTROL 424, INSTRUCTION MEMORY 425, PIPELINE 426, and LOCAL MEMORY 428 of the processor.
- LI local DRAM
- the DRAM processor control interface of the DRAMO circuit is implemented by the global interface 415, and by an interface local 423 in each of the sub-memories.
- the DRAM processor control interface could be implemented by only the global interface 415, or by only one local interface 423 in each sub-memory.
- the refresh control circuit 424 allows control of refresh transactions received by a sub-memory while a data processing operation is in progress by one of the DRAM processors. .
- the memory bank control circuit 422 for example provides a multiplexing between DDR memory requests to this bank and DRAM processor requests.
- the processing pipeline 426 includes, for example, data processing elements that operate under the control of instructions stored in the instruction memory 425. Since the DRAM processors have a complementary role with respect to the SoC processor, they use for example a different set of instructions. For example, DRAM processors use a reduced set of instructions compared to the one used by SoC processors. For example, in some embodiments, one or more instructions to be executed by the DRAM processors are written by a SoC processor directly into the instruction memory of the DRAM processor 425 via the global interface 415 and / or local interface 423. Instead or in addition, one or more instructions to be executed by the DRAM processors are written by a SoC processor directly into the memory bank 418, and the SoC processor can then instruct the DRAM processor to load the data. instructions from the memory bank 418 in its instruction memory 425.
- the local memory 428 for example stores data, temporarily or otherwise, used by the processing pipeline 426 when carrying out operations on the data contained in the memory bank 418.
- the local memory 428 may be one or more other intermediate circuits between the SoC and the DRAM circuits.
- the DRAM circuits are mounted according to DIMM standards known as "fully equipped” or “fully buffered” DIMMs ("fully buffered") an advanced memory buffer (AMB) can be provided, allowing additional complex processing functions.
- AMB advanced memory buffer
- FIG. 5 schematically illustrates the memory bank
- the memory bank 418 comprises for example a block of memory rows DRAM (MEMORY ROWS) 502, and an access register (ACCESS REGISTER) 504.
- DRAM MEMORY ROWS
- ACCESS REGISTER an access register
- the memory bank 418 is selected by a part of the address.
- the row to be read from the memory bank 418 is then identified on the basis of the address, and the datum of the row is loaded into the access register 504.
- One or more words constituting this row can then be read in the register. 504 access and provided either to a SoC 102 processor, or to the local memory 428 of the processor 420 in the case where an internal processing operation is to be performed.
- the memory bank 418 is selected by a part of the address.
- the row to write memory bank 418 is then identified on the basis of the address, and loaded into the access register 504.
- One or more words forming this row can then be written into the access register by a processor of the access register. SoC 102, or in the local memory 428 of the processor 420 in the case where an internal processing operation is to be performed.
- SoC 102 SoC 102, or in the local memory 428 of the processor 420 in the case where an internal processing operation is to be performed.
- the access register 504 must be reused to access another row of the memory bank 502 or if an operation of refresh must be performed, the contents of the access register 504 is rewritten in the corresponding row of the memory bank 418.
- data row transfer operations from the memory rows 502 to the access register 504 or from the access register 504 to the memory rows 502 of the memory bank are relatively slow operations carried out on several clock cycles and must not be interrupted once they have been started.
- a DRAM processor starts to load the access register of a memory bank with one of the rows of this memory bank, this operation taking several cycles;
- one of the SoC processors requests that another row of the memory bank be loaded in the same access register, the SoC processor waiting for this loading operation to be completed in a number of cycles. established.
- the DDR protocols do not allow a request from a SoC processor to be ignored or delayed, and the circuitry of the bank also does not allow a load operation in a memory bank to be canceled at the same time. middle of an operation.
- the DDR protocol does not define any mechanism by which a DRAM circuit informs the SoC processor that accesses it:
- the SoC processor is likely to consider that, after the set number of cycles associated with the loading operation, the access register contains the requested data, whereas in fact this it's not the case.
- Fig. 6 is a flowchart illustrating operations in a method of accessing a DRAM circuit according to an embodiment of the present disclosure.
- one or more processors of the SoC load data to be processed by one or more DRAM processors in a corresponding memory bank of the DRAM circuit. For example, if the processor 420 of the sub-memory 406 of FIG. 4 is to perform the processing operation, the data is, for example, loaded into the memory bank 418.
- one or more of the SoC processors use the DRAM processor control interface of the DRAM circuit to indicate to the one or more DRAM processors that they can begin processing the data.
- each DRAM processor is dedicated to a given memory bank in its sub-memory. Alternatively, in some cases, more than one DRAM processor may be able to access the same memory bank.
- an arbitration procedure may be implemented between the DRAM processors to allow the DRAM processors to correctly access the memory bank.
- next operation 604 the time when the data processing by the DRAM processor is completed is determined.
- the next operation is operation 605, in which the memory bank becomes accessible by the SoC processor.
- the DRAM processor control interface is used to inform the software running on the SoC processors that the DRAM processors have finished processing the data in the memory bank.
- the DRAM processor control interface includes a register accessed by the SoC processors and including a status bit indicating whether the DRAM processors have completed their task, or at least the portion of it that they needed. to access the memory bench.
- the DRAM processors When the DRAM processors have finished processing the data in the memory bank and have released it so that it becomes reachable to the SoC processors, the DRAM processors are for example configured not to access the memory bank again until to receive the instruction from the SoC processors to perform another processing operation.
- SoC processors may be allowed to stop, during this process, processing by a DRAM processor to quickly access the data stored in the memory bank concerned. For example, this may be appropriate in the case where there is a high priority task at realize by a SoC processor. This is for example obtained by activating a stop command via the DRAM processor control interface. For example, after receiving a stop command, the DRAM processor takes several cycles to complete one or more current access operations, and informs the SoC processor, through the DRAM processor control interface, of the when the memory bank is ready to be accessed.
- An advantage of the DRAM access method described in connection with FIG. 6 is that it ensures that the DRAM processors never compete with the SoC processors.
- the SoC processors are able to access the memory banks of the DRAM circuit in a normal deterministic manner according to the DDR type protocols.
- Fig. 7 schematically illustrates the refresh control circuit (REFRESH CONTROL) 424 of the DRAM sub-memory in more detail according to an exemplary embodiment.
- DRAMs require periodic refresh operations to prevent loss of data.
- some DRAM technologies may typically require that within 64 ms all lines of a memory bank have been refreshed.
- a refresh control system integrated in a SoC 102 memory controller generates periodic refresh transactions, which in some cases may be transmitted as refresh packets grouping a plurality of refresh transactions for a given DRAM circuit.
- the refresh control circuit 424 advantageously allows delaying refresh operations until the end of access to a memory bank (DRAM MEMORY BANK) by a DRAM processor.
- the refresh control circuit 424 receives refresh transactions (REFRESH), and for example includes a refresh refresh register (REFRESH PENDING) 702, and a delayed refresh counter (DELAYED REFRESH COUNTER) 704.
- REFRESH PENDING refresh refresh register
- DELAYED REFRESH COUNTER delayed refresh counter
- Fig. 8 is a flowchart showing operations in a process of processing refresh transactions. This method is for example carried out locally by a refresh control circuit 424 of each of the sub-memories 406 to 412 of the DRAM circuit.
- a circuit DRAM as DRAM0 circuit of Figure 4
- the refresh controller 416 received a refresh transaction, the refresh controller 416 to spread refreshed the transaction ⁇ ment to the refresh control circuit 424 of each sub-memories 406, 408, 410, 412 and that the refresh control circuits 424 that are capable of immediately performing the refresh operation do so.
- the refresh control circuit 424 of one of the sub-memories receives a refresh transaction while its memory bank is occupied by a memory bank access by the DRAM processor 420.
- the refreshed counter ⁇ ment 704 stores the delayed refresh transaction and indicates, for example in the refresh register in the queue 702, a refresh transaction is pending.
- the refresh transaction is for example started as soon as access to the current memory bank is completed.
- the register refresh pending 702 is for example reset only once refreshed ⁇ ment operation has been completed.
- the standby refresh register 702 is for example accessible by the DRAM processors and also by the SoC processors, and these processors are for example arranged not to attempt to access the memory bank until the refresh register pending has been reset.
- the status bit of the DRAM processor control interface is for example used to indicate that a processing operation has been completed and also indicates to the SoC that there are no more transactions. refreshment pending.
- Figure 9 schematically illustrates a portion of the sub-memory 406 of Figure 4 in more detail according to an exemplary embodiment.
- the memory bank 418 is for example coupled to an address bus (ADDR BUS) and to a data bus (DATA BUS) via a bidirectional multiplexer 902.
- the bidirectional multiplexer has for example ports one input coupled to the memory bank 418, and the other coupled to the DRAM (DRAM PROCESSOR CONTROL INTERFACE) processor control interface 904, which corresponds, for example, to the global interface 415 and / or at the local interface 423.
- DRAM PROCESSOR CONTROL INTERFACE DRAM PROCESSOR CONTROL INTERFACE
- Another input / output port of the multiplexer 902 is coupled to the data bus, and may be coupled to the bench memory 418 or at the interface 904 based on a selection signal provided by an address decoder 906.
- the interface 904 comprises, for example, one or more control registers 908 and optionally shared memory 910.
- the purpose of the shared memory 910 is, for example, to make it possible to pass information to or from the DRAM processor without having access to it. Stop.
- the interface 904 allows for example at least one or more of the following functions:
- DRAM control processor interfaces also allows ⁇ tent such that operations are carried out by a subset of one or more processors DRAM of a given DRAM circuit, or globally by all processors DRAM of a circuit Given DRAM.
- the interface 904 is for example part of the addressable memory space of the DRAM circuit.
- the addressable memory space of the DRAM circuit is larger than the addressable space in the memory banks of the DRAM circuit to allow the address locations of the interface 904 to be permanently accessible by the processors. SoC.
- the address decoder 906 for example controls the multiplexer 902 to couple the data bus to the interface 904 if the address is in the address range associated with the interface 904.
- the address locations of the interface 904 are initially visible to the SoC, and are then made inaccessible by a specific disable command if the interface 904 is not needed, which implies for example, the DRAM processor should not be used.
- a certain address range corresponds to the memory space of the DRAM processor control interface 904.
- this address range can be converted to standard DRAM memory space if the disable command is enabled.
- the address locations of the interface 904 are initially invisible to the SoC, and are then made accessible by a specific activation command if the interface is to be used, as will be described. now with reference to Figure 10.
- Fig. 10 is a flowchart illustrating the operations in a method for making the DRAM processor control interface accessible in the address space of a DRAM circuit.
- an operation réinitia ⁇ lisation DRAM is performed, or the DRAM circuit is energized.
- a certain address range corresponds to a space of standard DRAM addresses DRAM circuit imme ⁇ ment after a reset or a power up of the circuit DRAM.
- an operation 1002 it is determined, for example by the DRAM processor control interface 904 and / or the address decoder 906, whether an interface enable command has been received. If such a command is received, the next operation is operation 1003.
- step 1003 the DRAM processor control interface is made visible in the address space of the DRAM circuit by transforming the address range into the memory space of the DRAM 904 processor control interface.
- the deactivation or activation command corresponds for example to a signal transmitted from the SoC to the address decoder 906 via a dedicated input pin of the DRAM circuit, as represented by a dashed line. 914 in Figure 9.
- the deactivation or activation command corresponds for example to a value contained in one or more CONTROL REGISTERS 916, which are present in certain DRAM circuits for special transactions such as MRS commands (register setting fashion).
- the address decoder (ADDR DEC) 906 controls the multiplexer 902 to couple the data bus to the interface 904 when the address on the address bus is in the range of addresses defined by the address registers. Control 916.
- one or more new registers could be added, which are for example configured to be accessible using an MRS transaction.
- the activation or deactivation signal may be transmitted by the SoC on the standard memory buses of the DRAM circuit, for example using the address bus.
- the address decoder 906 and / or the interface 904 are adapted to detect a specific sequence of commands from the SoC, which will be called here magic sequence.
- the magic sequence is for example a command sequence corresponding to a dummy memory address, in other words a sequence that follows the standard protocol for communicating with the DRAM circuit, but which can be distinguished from a real memory access. It is for example selected to be a sequence of commands that is very unlikely to occur, or even none, in normal operation of the DRAM circuit. Rather than one sequence magically, in some embodiments there may be several, and the address range of the interface 906 depends for example what magic sequence is applied.
- the DRAM circuit comprises for example a clock cycle counter, or a refresh counter, which counts the number of clock cycles or transactions of refreshments that were received.
- a sequence is excluded so as not to be considered a magic sequence if:
- pilot software that handles the DRAM processors and can generate the magic sequence is usually activated just after the operating system has been loaded, and before the applications are loaded;
- An example of a magic sequence can be multiple consecutive accesses by a SoC processor, once the cache memory has already been activated, of the same area of the memory without any other intermediate access to other areas of the memory.
- the cache is typically activated very early during a boot sequence, since the SoC processors tend to operate slowly until the memory cache has been enabled. Once the cache has been activated, it is unlikely that multiple consecutive hits will occur in the same memory area.
- a magic sequence consists in defining certain memory zones that can not be cached, and then making multiple consecutive accesses to these zones.
- modern processors generally include a MMU (memory management module), which allows to give the indication that a memory area can not be cached.
- MMU memory management module
- an application would have no reason to ask for some of the memory to be cached, which would lead to a marked decrease in performance, with no benefit in return.
- the magic sequence is for example detected by the presence of multiple memory accesses to a given DRAM area.
- the memory can be cached in double write mode, as will now be described in more detail.
- a read allocation operation in read allocation mode involves:
- a write operation can be performed using one of two modes, a "write allocation” mode (of the English "write allocate”), or a mode “double writing” (of English "write through”).
- a writing operation according to the write allocation mode involves:
- the data is written from the cache to the main memory when the cache line needs to be removed from the cache and used to update the main memory.
- a write operation according to the double write mode involves:
- the data is also written to the main memory.
- the double-write mode may use write-in transactions in which some words of the transaction are not written since the burst length is greater than that of the data to be written.
- the write allocation mode uses only burst write transactions in which all the words of the transaction are written.
- a processor of the SoC is able to specify, via the MMU, whether the access to each page of the memory must be:
- double write mode able to be cached using read allocation or double write, which is usually referred to as "double write” mode.
- the dual-write mode is however used in certain hardware configurations, for example if a frame buffer is present, this frame buffer being read by a display processor not having the capacity to perform bus spying, and by therefore not able to recover the data to read in the cache of a processor.
- processors are able to use bus spying to retrieve the data to be read into the cache of another processor. Therefore, there is generally no need to use the double write mode.
- the magic sequence may correspond to an access made using the double-write mode, detectable by the fact that burst access is achieved, in which some words are not written.
- the write enable signal is disabled for at least one data value.
- a magic sequence is a series of memory accesses using abnormal locations in space and time.
- the cache when the cache is used, repeated accesses to the same memory addresses are made using the cache instead of the memory bank of the DRAM circuit. Therefore, the presence of repeated accesses in a relatively small area of a memory bank, for example in a few words, and in a relatively short period of time, for example several hundred microseconds, may be recognized as an unlikely event interpreted as a magic sequence.
- An advantage of the embodiments described herein is that a DRAM circuit having an internal processor can operate according to a DDR protocol, while at the same time enabling performance improvement by reducing to a certain extent the data transfer operations between the circuit DRAM and SoC.
- the interface can be made without dedicated hardware in the central processor.
- the interface is for example made by software executed by the central processor, the software realizing an access exclusion protocol prohibiting the central processor from accessing one or more memory banks of the memory network when the internal processor is performing an operation.
- the central processor can know when the operations are being performed by the internal processor, since the central processor is responsible for the direction of the data processing commands to the internal processor, and can access, by the intermediate processor control interface, to data indicating when the internal processor has completed an operation.
- the access exclusion protocol therefore does not allow simultaneous access attempts by the central and internal processors, thus avoiding the need for collision arbitration between these processors.
- An advantage of the delay mechanism of the refresh operations in the memory circuit is that refresh operations can be generated conventionally by the central processor, for example by a central processor memory controller.
- the memory controller therefore does not need to know the operations that are being executed by the internal processor of the memory circuit.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Dram (AREA)
- Advance Control (AREA)
- Executing Machine-Instructions (AREA)
Abstract
Description
Claims
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR1551343A FR3032814B1 (en) | 2015-02-18 | 2015-02-18 | DRAM CIRCUIT WITH INTEGRATED PROCESSOR |
PCT/FR2016/050327 WO2016132052A1 (en) | 2015-02-18 | 2016-02-12 | Dram circuit provided with a built-in processor |
Publications (2)
Publication Number | Publication Date |
---|---|
EP3259674A1 true EP3259674A1 (en) | 2017-12-27 |
EP3259674B1 EP3259674B1 (en) | 2020-12-16 |
Family
ID=53269680
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP16707914.4A Active EP3259674B1 (en) | 2015-02-18 | 2016-02-12 | Dram circuit provided with a built-in processor |
Country Status (6)
Country | Link |
---|---|
US (1) | US10324870B2 (en) |
EP (1) | EP3259674B1 (en) |
JP (1) | JP6710219B2 (en) |
CN (1) | CN107257964B (en) |
FR (1) | FR3032814B1 (en) |
WO (1) | WO2016132052A1 (en) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2022079381A1 (en) | 2020-10-16 | 2022-04-21 | Upmem | Semiconductor device comprising a stack of chips, and chips for such a stack |
US11775312B2 (en) | 2021-04-09 | 2023-10-03 | Rochester Institute Of Technology | Look-up table containing processor-in-memory cluster for data-intensive applications |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR3055715B1 (en) * | 2016-09-08 | 2018-10-05 | Upmem | METHODS AND DEVICES FOR CONTOURING INTERNAL CACHE OF ADVANCED DRAM MEMORY CONTROLLER |
EP3662474B1 (en) * | 2017-07-30 | 2023-02-22 | NeuroBlade Ltd. | A memory-based distributed processor architecture |
WO2020255087A1 (en) | 2019-06-20 | 2020-12-24 | Smolka John Michael | Memory module and processor contained in the memory module |
CN112286863B (en) * | 2020-11-18 | 2023-08-18 | 合肥沛睿微电子股份有限公司 | Processing and memory circuit |
FR3131020A1 (en) | 2021-12-22 | 2023-06-23 | Orange | Module and method for securing computer equipment |
Family Cites Families (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH03109661A (en) * | 1989-09-22 | 1991-05-09 | Hitachi Ltd | Data processor |
KR940004434A (en) * | 1992-08-25 | 1994-03-15 | 윌리엄 이. 힐러 | Smart Dynamic Random Access Memory and Its Processing Method |
US5666485A (en) * | 1995-06-07 | 1997-09-09 | Samsung Electronics Inc. | Software driver for a system bus |
US5768618A (en) * | 1995-12-21 | 1998-06-16 | Ncr Corporation | Method for performing sequence of actions in device connected to computer in response to specified values being written into snooped sub portions of address space |
JP3189727B2 (en) * | 1997-04-15 | 2001-07-16 | 日本電気株式会社 | Packet-type memory LSI with built-in coprocessor, memory system using the same, and control method therefor |
JPH117763A (en) * | 1997-06-13 | 1999-01-12 | Nec Ic Microcomput Syst Ltd | Method for refresh control to dram and circuit therefor |
US5999474A (en) * | 1998-10-01 | 1999-12-07 | Monolithic System Tech Inc | Method and apparatus for complete hiding of the refresh of a semiconductor memory |
US6463001B1 (en) * | 2000-09-15 | 2002-10-08 | Intel Corporation | Circuit and method for merging refresh and access operations for a memory device |
KR100510505B1 (en) * | 2002-12-23 | 2005-08-26 | 삼성전자주식회사 | Semiconductor memory device for performing refresh operation without external refresh commend and refresh control method thereof |
US7353329B2 (en) * | 2003-09-29 | 2008-04-01 | Intel Corporation | Memory buffer device integrating refresh logic |
US7200062B2 (en) * | 2004-08-31 | 2007-04-03 | Micron Technology, Inc. | Method and system for reducing the peak current in refreshing dynamic random access memory devices |
US8234460B2 (en) * | 2009-06-04 | 2012-07-31 | Micron Technology, Inc. | Communication between internal and external processors |
US8380916B2 (en) * | 2009-06-04 | 2013-02-19 | Micron Technology, Inc. | Control of page access in memory |
US8719516B2 (en) * | 2009-10-21 | 2014-05-06 | Micron Technology, Inc. | Memory having internal processors and methods of controlling memory access |
US8438358B1 (en) * | 2009-12-16 | 2013-05-07 | Applied Micro Circuits Corporation | System-on-chip with memory speed control core |
EP2761469B1 (en) * | 2011-09-30 | 2019-11-13 | Intel Corporation | Non-volatile random access memory (nvram) as a replacement for traditional mass storage |
US20130262791A1 (en) * | 2012-03-27 | 2013-10-03 | International Business Machines Corporation | Host-side support of dynamically changing frequency in memory systems |
US9911485B2 (en) * | 2013-11-11 | 2018-03-06 | Qualcomm Incorporated | Method and apparatus for refreshing a memory cell |
US9293188B2 (en) * | 2014-02-03 | 2016-03-22 | Advanced Micro Devices, Inc. | Memory and memory controller for high reliability operation and method |
-
2015
- 2015-02-18 FR FR1551343A patent/FR3032814B1/en not_active Expired - Fee Related
-
2016
- 2016-02-12 EP EP16707914.4A patent/EP3259674B1/en active Active
- 2016-02-12 CN CN201680010586.7A patent/CN107257964B/en active Active
- 2016-02-12 US US15/551,418 patent/US10324870B2/en active Active
- 2016-02-12 WO PCT/FR2016/050327 patent/WO2016132052A1/en active Application Filing
- 2016-02-12 JP JP2017544346A patent/JP6710219B2/en active Active
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2022079381A1 (en) | 2020-10-16 | 2022-04-21 | Upmem | Semiconductor device comprising a stack of chips, and chips for such a stack |
FR3115395A1 (en) | 2020-10-16 | 2022-04-22 | Upmem | SEMICONDUCTOR DEVICE COMPRISING A STACK OF CHIPS AND CHIPS OF SUCH A STACK |
US11775312B2 (en) | 2021-04-09 | 2023-10-03 | Rochester Institute Of Technology | Look-up table containing processor-in-memory cluster for data-intensive applications |
Also Published As
Publication number | Publication date |
---|---|
FR3032814A1 (en) | 2016-08-19 |
CN107257964A (en) | 2017-10-17 |
CN107257964B (en) | 2020-11-13 |
US10324870B2 (en) | 2019-06-18 |
JP2018511860A (en) | 2018-04-26 |
US20180039586A1 (en) | 2018-02-08 |
FR3032814B1 (en) | 2018-02-02 |
WO2016132052A1 (en) | 2016-08-25 |
JP6710219B2 (en) | 2020-06-17 |
EP3259674B1 (en) | 2020-12-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3259674B1 (en) | Dram circuit provided with a built-in processor | |
US20210151095A1 (en) | Refresh command control for host assist of row hammer mitigation | |
US11074961B2 (en) | Method of performing internal processing operation of memory device | |
CN107533509B (en) | Memory device specific self-refresh entry and exit | |
US20190066759A1 (en) | Row hammer mitigation with randomization of target row selection | |
US9471517B1 (en) | Memory system, memory module and method to backup and restore system using command address latency | |
US20150149735A1 (en) | Memory system | |
US20220121398A1 (en) | Perfect row hammer tracking with multiple count increments | |
US7782703B2 (en) | Semiconductor memory having a bank with sub-banks | |
US20220293162A1 (en) | Randomization of directed refresh management (drfm) pseudo target row refresh (ptrr) commands | |
FR3047348A1 (en) | ||
US20160148673A1 (en) | First data in response to second read request | |
US11610624B2 (en) | Memory device skipping refresh operation and operation method thereof | |
US9236112B1 (en) | Apparatuses and methods for reducing cycle times in successive memory accesses | |
EP1594065A1 (en) | System on a chip with an arbiter, and storage key including it | |
US12056371B2 (en) | Memory device having reduced power noise in refresh operation and operating method thereof | |
US20230236732A1 (en) | Memory device | |
FR2627298A1 (en) | COMPUTER SYSTEM WITH ANTEMEMORY AND METHOD FOR ACCESSING DATA IN SUCH A SYSTEM | |
KR20100067057A (en) | A non-volatile memory device capable of initiating transactions | |
FR2769727A1 (en) | METHOD AND SYSTEM FOR CONTROLLING SHARED ACCESS TO A RAM | |
EP1603049A1 (en) | Interface of functional modules in a chip system | |
FR2869700A1 (en) | MANAGING INDEXED REGISTERS IN A SYSTEM ON A CHIP | |
KR20240131091A (en) | Method for performing power loss protection (plp) operation, plp module, and electronic device | |
FR2922037A1 (en) | Data i.e. bank data, securing method for e.g. static RAM of programmable electronic circuit in airplane, involves instantiating memory accesses with addresses, and providing read data at output based on result of parity control on read data | |
CN114721980A (en) | Accelerator, computing system including the same, and method of operating the same |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE INTERNATIONAL PUBLICATION HAS BEEN MADE |
|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: REQUEST FOR EXAMINATION WAS MADE |
|
17P | Request for examination filed |
Effective date: 20170725 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
AX | Request for extension of the european patent |
Extension state: BA ME |
|
DAV | Request for validation of the european patent (deleted) | ||
DAX | Request for extension of the european patent (deleted) | ||
RAP1 | Party data changed (applicant data changed or rights of an application transferred) |
Owner name: UPMEM |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: EXAMINATION IS IN PROGRESS |
|
17Q | First examination report despatched |
Effective date: 20190926 |
|
GRAP | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOSNIGR1 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: GRANT OF PATENT IS INTENDED |
|
INTG | Intention to grant announced |
Effective date: 20200710 |
|
GRAS | Grant fee paid |
Free format text: ORIGINAL CODE: EPIDOSNIGR3 |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE PATENT HAS BEEN GRANTED |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: FG4D Free format text: NOT ENGLISH |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R096 Ref document number: 602016049805 Country of ref document: DE |
|
REG | Reference to a national code |
Ref country code: IE Ref legal event code: FG4D Free format text: LANGUAGE OF EP DOCUMENT: FRENCH |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: REF Ref document number: 1346221 Country of ref document: AT Kind code of ref document: T Effective date: 20210115 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: RS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: NO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210316 Ref country code: FI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: GR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: MK05 Ref document number: 1346221 Country of ref document: AT Kind code of ref document: T Effective date: 20201216 |
|
REG | Reference to a national code |
Ref country code: NL Ref legal event code: MP Effective date: 20201216 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: BG Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210316 Ref country code: LV Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: SE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: HR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: NL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
REG | Reference to a national code |
Ref country code: LT Ref legal event code: MG9D |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: RO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: PT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210416 Ref country code: EE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: CZ Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: SM Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: LT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: AT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: PL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R097 Ref document number: 602016049805 Country of ref document: DE |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MC Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210416 |
|
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
REG | Reference to a national code |
Ref country code: BE Ref legal event code: MM Effective date: 20210228 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: CH Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210228 Ref country code: AL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: IT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: LU Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210212 Ref country code: LI Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210228 |
|
26N | No opposition filed |
Effective date: 20210917 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: DK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: ES Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 Ref country code: IE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210212 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210416 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: BE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210228 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: GB Payment date: 20230221 Year of fee payment: 8 Ref country code: DE Payment date: 20230216 Year of fee payment: 8 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: CY Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: HU Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT; INVALID AB INITIO Effective date: 20160212 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: FR Payment date: 20240221 Year of fee payment: 9 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: TR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R119 Ref document number: 602016049805 Country of ref document: DE |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20201216 |
|
GBPC | Gb: european patent ceased through non-payment of renewal fee |
Effective date: 20240212 |