EP3259674A1 - Dram circuit provided with a built-in processor - Google Patents

Dram circuit provided with a built-in processor

Info

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
Application number
EP16707914.4A
Other languages
German (de)
French (fr)
Other versions
EP3259674B1 (en
Inventor
Fabrice Devaux
Jean-François ROY
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Upmem SAS
Original Assignee
Upmem SAS
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Upmem SAS filed Critical Upmem SAS
Publication of EP3259674A1 publication Critical patent/EP3259674A1/en
Application granted granted Critical
Publication of EP3259674B1 publication Critical patent/EP3259674B1/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • G06F13/1668Details of memory controller
    • G06F13/1673Details of memory controller using buffers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • G06F13/1605Handling requests for interconnection or transfer for access to memory bus based on arbitration
    • G06F13/161Handling requests for interconnection or transfer for access to memory bus based on arbitration with latency improvement
    • G06F13/1636Handling 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

The invention relates to a memory circuit comprising: a memory network comprising at least one memory bank (418); a first processor (420); and a processor control interface for receiving instructions for processing data addressed to the first processor from a central processor (P1, P2), the processor control interface being designed to indicate to the central processor when the first processor has finished accessing at least one memory bank of the memory network, said memory banks becoming accessible for the central processor.

Description

CIRCUIT DRAM MUNI D ' UN PROCESSEUR INTEGRE  DRAM CIRCUIT WITH INTEGRATED PROCESSOR
Domaine Field
La présente description concerne le domaine des circuits DRAM (mémoire dynamique à accès aléatoire) munis de processeurs intégrés, et des procédés de communication avec de telles mémoires.  The present disclosure relates to the field of random access memory (DRAM) circuits having integrated processors, and methods of communication with such memories.
Arrière-plan Background
Les ordinateurs modernes comprennent en général un circuit de traitement, souvent mis en oeuvre sous forme d'un système sur une puce (SoC) , couplé à un ou plusieurs circuits de mémoire dynamique à accès aléatoire (DRAM) . De telles mémoires, qui nécessitent en général une opération de rafraîchissement périodique, sont denses et d'accès relativement rapide, et sont ainsi utilisées comme stockage de données RAM principal dans la plupart des ordinateurs. Cependant, vu les quantités toujours croissantes de données à transférer entre le SoC et les circuits DRAM, de tels transferts de données ont tendance à ralentir les opérations de l'ordinateur et conduisent à une consommation d'énergie relativement élevée.  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. 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. However, in view of the ever increasing amounts of data to be transferred between the SoC and the DRAM circuits, such data transfers tend to slow down the operations of the computer and lead to relatively high power consumption.
Une solution qui a été proposée est de fournir des circuits DRAM ayant un ou plusieurs processeurs intégrés, en plus des processeurs se trouvant dans le SoC. Une telle solution réduit le volume de transfert de données entre les circuits DRAM et le SoC en autorisant de déléguer certaines tâches de traitement aux processeurs DRAM, de sorte que ces tâches peuvent être réalisées tout en évitant des transferts de données entre le circuit DRAM et le SoC. 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.
Toutefois, une difficulté pour obtenir des circuits However, a difficulty in obtaining circuits
DRAM munis de processeurs intégrés est que l'interface avec le SoC est consommatrice de temps et est coûteuse à mettre en oeuvre . DRAMs equipped with integrated processors is that the interface with the SoC is time consuming and is expensive to implement.
La demande internationale publiée sous le numéro WO2010/141221 décrit un système et un procédé pour arbitrer l'accès à une matrice mémoire associée à un processeur interne. The international application published under the number WO2010 / 141221 describes a system and a method for arbitrating access to a memory array associated with an internal processor.
L'arbitrage se fait par la mise en communication d'un processeur externe, comprenant un contrôleur mémoire, avec le processeur interne par l'intermédiaire d'une interface de contrôle formée par des liaisons électriques pour communiquer des signaux de requête et de validation. 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.
Un problème dans des systèmes tels que celui décrit dans la publication WO2010/141221 est que le processeur externe incorporant le contrôleur mémoire doit être modifié pour permettre aux signaux de commande d'arbitrage d'être transférés vers et à partir du processeur interne, ce qui conduit à un système complexe et coûteux.  A problem in systems such as that described in WO2010 / 141221 is that the external processor incorporating the memory controller must be modified to allow the arbitration control signals to be transferred to and from the internal processor, which leads to a complex and expensive system.
Résumé  summary
Un objet de la présente description est de résoudre au moins partiellement un ou plusieurs problèmes de l'art antérieur .  An object of the present description is to at least partially solve one or more problems of the prior art.
Selon un aspect, on prévoit un circuit mémoire comprenant un réseau mémoire comprenant un ou plusieurs bancs mémoire ; un premier processeur ; et une interface de contrôle de processeur pour recevoir des commandes de traitement de données adressées au premier processeur à partir d'un processeur central, dans lequel l'interface de contrôle de processeur est adaptée à indiquer au processeur central quand le premier processeur a fini d'accéder à un ou plusieurs bancs mémoire du réseau mémoire, ces bancs mémoire devenant accessibles pour le processeur central. According to one aspect, there is provided 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.
Selon un mode de réalisation, le circuit mémoire est un circuit de mémoire dynamique à accès aléatoire (DRAM) comprenant en outre un circuit de contrôle de rafraîchissement adapté : à recevoir, à partir du processeur central, des transactions de rafraîchissement pour réaliser des opérations de rafraîchissement de données dans au moins un banc mémoire du réseau mémoire ; à déterminer si ledit au moins un banc mémoire est en train d'être accédé par le premier processeur, et si oui, à retarder l'instant de début de l'opération de rafraîchissement de données .  According to one embodiment, 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.
Selon un mode de réalisation, le circuit de contrôle de rafraîchissement comprend un registre de rafraîchissement en attente, et le fait de retarder l'instant de début de l'opé¬ ration de rafraîchissement de données comprend d'indiquer dans le registre de rafraîchissement en attente que l'opération de rafraîchissement est en attente. According to one embodiment, 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.
Selon un mode de réalisation, l'interface de contrôle de processeur comprend un ensemble de registres de contrôle accessible dans l'espace d'adresses du circuit mémoire.  According to one embodiment, the processor control interface comprises a set of control registers accessible in the address space of the memory circuit.
Selon un mode de réalisation, l'espace d'adresses du circuit mémoire comprend une ou plusieurs adresses associées de façon permanente à l'ensemble de registres de contrôle.  According to one embodiment, the address space of the memory circuit comprises one or more addresses permanently associated with the set of control registers.
Selon un mode de réalisation, l'espace d'adresses du circuit mémoire comprend une ou plusieurs adresses associées à l'ensemble de registres de contrôle, et lesdites une ou plusieurs adresses sont adaptées à être transformées en adresses du réseau mémoire lors de l'activation d'un signal de commande de désactivation de registre.  According to one embodiment, 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.
Selon un mode de réalisation, le circuit mémoire est adapté à recevoir un signal d'activation provenant du processeur central pour rendre l'ensemble de registres de contrôle accessible dans l'espace d'adresses du circuit mémoire. Selon un mode de réalisation, le signal d'activation est fourni par l'intermédiaire d'un bus d'adresses, et est détectable par l'interface de contrôle de processeur. According to one embodiment, 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. According to one embodiment, the activation signal is provided via an address bus, and is detectable by the processor control interface.
Selon un mode de réalisation, la séquence d'accès mémoire pour rendre l'ensemble de registres de contrôle accessible est une séquence d'accès en salve dans laquelle tous les mots ne sont pas écrits.  According to one embodiment, 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.
Selon un mode de réalisation, la séquence d'accès mémoire pour rendre l'ensemble de registres de contrôle accessible est une pluralité d'accès mémoire à des cellules mémoires se trouvant dans une zone mémoire dans l'un des bancs mémoire dans une première période de temps.  According to one embodiment, 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.
Selon un mode de réalisation, le circuit mémoire est adapté à détecter la séquence d'accès mémoire sur la base d'un ou plusieurs des éléments suivants : une période de temps dans laquelle la séquence d'accès mémoire est reçue ; et une durée de la séquence d'accès mémoire.  According to one embodiment, 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.
Selon un autre aspect, on prévoit un système comprenant : une pluralité de circuits mémoire ; et un processeur central couplé à chacun des circuits mémoire par l'intermédiaire d'un bus de données commun de N bits, chaque circuit mémoire comprenant une interface de bus de N bits couplée au bus de données de N bits .  In another aspect, there is provided 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.
Selon un autre aspect, on prévoit un procédé pour accéder à un circuit mémoire comprenant un réseau mémoire comportant un ou plusieurs bancs mémoire ; un premier processeur ; et une interface de contrôle de processeur, le procédé comprenant : recevoir, par l'interface de contrôle de processeur, des commandes de traitement de données adressées au premier processeur à partir d'un processeur central ; indiquer, par l'interface de contrôle de processeur au processeur central, quand le premier processeur a fini d'accéder à un ou plusieurs des bancs mémoire du réseau mémoire, ces bancs mémoire devenant accessibles par le processeur central. Selon un mode de réalisation, le circuit mémoire est un circuit de mémoire dynamique à accès aléatoire (DRAM) , le procédé comprenant en outre : recevoir, par un circuit de contrôle de rafraîchissement, une transaction de rafraîchis- sèment pour réaliser une opération de rafraîchissement de données dans un banc mémoire du réseau mémoire ; déterminer, par le circuit de contrôle de rafraîchissement, si le banc mémoire est en train d'être accédé par le premier processeur et si oui, retarder l'instant de début de l'opération de rafraîchissement de données . According to another aspect, there is provided 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. According to one embodiment, 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.
Selon un mode de réalisation, l'interface de contrôle de processeur comprend un ensemble de registres de contrôle, le procédé comprenant en outre : recevoir par 1 ' interface de contrôle de processeur un signal d'activation à partir du processeur central pour rendre l'ensemble de registres de contrôle accessible dans un espace d'adresses du circuit mémoire .  According to one embodiment, 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.
Brève description des dessins  Brief description of the drawings
Les caractéristiques et avantages susmentionnés, et d'autres, apparaîtront clairement à la lecture de la description détaillée suivante de modes de réalisation, donnée à titre d'illustration et non de limitation, en faisant référence aux dessins joints dans lesquels :  The foregoing and other features and advantages will become apparent from the following detailed description of embodiments, given by way of illustration and not limitation, with reference to the accompanying drawings in which:
la figure 1 illustre schématiquement un système informatique comprenant des circuits DRAM comportant des processeurs intégrés selon un exemple de réalisation ;  FIG. 1 diagrammatically illustrates a computer system comprising DRAM circuits comprising integrated processors according to an exemplary embodiment;
la figure 2 illustre schématiquement un bus de données DRAM selon un exemple ;  FIG. 2 schematically illustrates a DRAM data bus according to an example;
la figure 3 illustre schématiquement un bus de données DRAM selon un mode de réalisation de la présente description ;  FIG. 3 schematically illustrates a DRAM data bus according to an embodiment of the present description;
la figure 4 illustre schématiquement une partie du système informatique de la figure 1 plus en détail selon un exemple de réalisation ;  Figure 4 schematically illustrates a portion of the computer system of Figure 1 in more detail according to an exemplary embodiment;
la figure 5 illustre schématiquement un banc mémoire de la figure 4 plus en détail selon un exemple de réalisation ; la figure 6 est un organigramme représentant des opérations dans un procédé de délégation d'une tâche de traitement à un processeur DRAM selon un exemple de réalisation ; 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;
la figure 7 illustre schématiquement un circuit de contrôle de rafraîchissement selon un exemple de réalisation ;  Figure 7 schematically illustrates a refresh control circuit according to an exemplary embodiment;
la figure 8 est un organigramme illustrant des étapes dans un procédé de contrôle de rafraîchissement selon un exemple de réalisation ;  Fig. 8 is a flowchart illustrating steps in a refresh control method according to an exemplary embodiment;
la figure 9 illustre schématiquement une partie d'un circuit DRAM de la figure 4 plus en détail selon un autre exemple de réalisation ; et  Figure 9 schematically illustrates a portion of a DRAM circuit of Figure 4 in more detail according to another embodiment; and
la figure 10 est un organigramme illustrant des opérations dans un procédé pour rendre un processeur de contrôle d'interface DRAM visible dans l'espace d'adresse DRAM selon un exemple de réalisation.  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.
Description détaillée detailed description
La présente description décrit des modes de réalisation d'un circuit mémoire comprenant un processeur intégré selon un exemple dans lequel le circuit mémoire est un circuit DRAM. Bien que cela ne soit pas représenté dans les figures, l'homme de l'art comprendra qu'un circuit DRAM est un dispositif mémoire dans lequel des données sont mémorisées par un réseau de cellules mémoire, chaque cellule mémoire comprenant un condensateur pour mémoriser un niveau de tension représentatif d'un bit de données, et un commutateur pour contrôler l'accès à la cellule mémoire. Cependant, les principes décrits ici peuvent être facilement appliqués à d'autres types de circuits mémoire, qui peuvent nécessiter ou pas une opération de rafraîchissement. Un avantage des modes de réalisation décrits ici est que l'intégration d'un ou plusieurs processeurs dans le circuit mémoire n'empêche pas une interface d'une version antérieure, n'ayant pas prévu de communication avec un tel processeur intégré, d'être utilisée pour communiquer avec le circuit mémoire. La figure 1 illustre schématiquement un système informatique 100 selon un exemple de réalisation. Le système informatique 100 comprend un dispositif de traitement central 102, mis en oeuvre dans cet exemple sous forme d'un système sur une puce (SoC) , comprenant un ou plusieurs processeurs (non illustrés) et une interface maître DDR (DDR MAS ER INTERFACE) 103 pour communiquer avec un certain nombre de circuits DRAM. The present description describes embodiments of a memory circuit comprising an integrated processor according to an example in which the memory circuit is a DRAM circuit. Although this is not shown in the figures, those skilled in the art will understand that 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. However, 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. Figure 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.
Dans l'exemple de la figure 1 il y a quatre circuits DRAM référencés DRAMO à DRAM3, mais dans des variantes de réalisation il pourrait y avoir un nombre de quelconque de circuits DRAM.  In the example of FIG. 1 there are four DRAM circuits referenced DRAMO to DRAM3, but in alternative embodiments there could be any number of DRAM circuits.
Le circuit DRAM DRAMO comprend un réseau mémoire DRAM (MA) 104 et un ou plusieurs processeurs internes (P) 106, qui seront appelés dans la suite processeurs DRAM. Le circuit DRAM DRAMO comprend aussi par exemple une interface de contrôle de processeur DRAM (I) 107 associée à chaque processeur DRAM, permettant à un ou plusieurs processeurs dans le SoC 102 de communiquer avec les processeurs correspondants 106 et de les contrôler. Une interface esclave DDR 108 est par exemple prévue dans le circuit DRAM DRAMO pour des communications avec l'interface maître DDR 103.  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.
De façon similaire, les circuits DRAM DRAM1, DRAM2 et DRAM3 comprennent respectivement des réseaux mémoires DRAM 114, 124, 134 et un ou plusieurs processeurs internes (P) 116, 126, 136. Les circuits DRAM DRAM1, DRAM2, DRAM3 comprennent aussi respectivement par exemple des interfaces de contrôle de processeur DRAM 117, 127, 137 permettant à un ou plusieurs processeurs se trouvant dans le SoC 102 de contrôler les processeurs 116, 126, 136 respectivement. Des interfaces esclaves DDR 118, 128, 138 sont par exemple prévues dans les circuits DRAM1, DRAM2, DRAM3 pour des communications avec l'interface maître DDR 103.  Similarly, 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.
Les communications entre l'interface maître DDR 103 et chacune des interfaces esclaves 108, 118, 128, 138 se fait par exemple par l'intermédiaire d'un bus de liaison 140 comprenant un bus d'adresses, un bus de données, et dans certains cas une ou plusieurs autres lignes de commande (non illustrées en figure 1) . Les communications avec les circuits DRAM DRAMO à DRAM3 sur le bus de liaison 140 respectent par exemple l'un des protocoles DDR. 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). For example, communications with the DRAMO DRAM3 DRAM circuits on the link bus 140 follow one of the DDR protocols.
Le terme "protocole DDR" est utilisé ici pour désigner un protocole quelconque parmi DDR1, DDR2, DDR3, DDR4, RLDRAM (mémoire à accès aléatoire à latence réduite) , RLDRAM2, et tout protocole similaire à ces protocoles.  The term "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.
La figure 2 illustre schématiquement un bus de données d'une largeur de 64 bits (DATA BUS) pour connecter un SoC (non illustré) aux quatre circuits DRAM DRAMO à DRAM3. On peut voir que le bus de données est séparé de telle sorte que chaque circuit DRAMO à DRAM3 reçoive 16 bits du bus de données de 64 bits de large. Par exemple, le circuit DRAMO reçoit les bits 0 à 15, et contient les multiplets 0, 1, 8, 9, 16, 17, etc., le circuit DRAM1 reçoit les bits 16 à 31, et contient les multiplets 2, 3, 10, 11, 18, 19, etc., le circuit DRAM2 reçoit les bits 32 à 47, et contient les multiplets 4, 5, 12, 13, 20, 21, etc., et le circuit DRAM3 reçoit les bits 48 à 63, et contient les multiplets 6, 7, 14, 15, 22, 23, etc.. Un avantage d'un tel agencement est qu'il n'est pas nécessaire d'adresser séparément les circuits DRAM individuels. Cependant, lorsqu'un processeur est intégré dans chaque circuit DRAM, un inconvénient du fait de prévoir l'agencement de bus de données de la figure 2 est que chaque circuit DRAM mémorise des données discontinues, ce qui conduit à une forte complexité pour réaliser un traitement de ces données sous le contrôle des processeurs SoC.  Figure 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. For example, 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., and 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. However, when a processor is integrated in each DRAM circuit, 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.
La figure 3 illustre schématiquement un bus de données de 64 bits de large (DATA BUS) pour connecter un SoC (encore non illustré) aux quatre circuits DRAM DRAMO à DRAM3. Dans cet exemple, chaque circuit DRAM comprend une interface de bus à 64 bits couplée au bus de données à 64 bits, et ainsi chaque circuit DRAM reçoit la totalité des bits transmis sur le bus de données. Ainsi, chaque circuit DRAM contient une portion continue de la mémoire totale. Plus généralement, en supposant que le bus de données du SoC est de N bits, où N est un entier supérieur ou égal à 2, chacun des circuits DRAM a aussi un bus de données de N bits . Figure 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. In this example, 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. Thus, 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.
Un mécanisme est aussi par exemple prévu pour permettre au SoC de sélectionner le circuit DRAM pour chaque accès mémoire DRAM.  A mechanism is also provided for example to allow the SoC to select the DRAM circuit for each DRAM memory access.
Dans un mode de réalisation, le SoC, ou un circuit additionnel de décodage d'adresse, est capable de fournir un signal de sélection de puce CS sur une ligne de sortie. Comme cela est représenté par une ligne en pointillés CS en figure 3, le signal CS est par exemple fourni à chaque circuit DRAM afin de sélectionner l'un de ces circuits DRAM pour un accès mémoire donné. Dans le cas où il y a quatre circuits DRAM, le signal CS est par exemple un signal de 2 bits, les valeurs "00", "01", "10" et "11" étant associées aux circuits DRAM DRAM0, DRAM1, DRAM2, DRAM3 respectivement. S'il y a un nombre différent de circuits DRAM, le signal CS peut comprendre un nombre de bits différent .  In one embodiment, the SoC, or an additional address decode circuit, is capable of providing a chip select signal CS on an output line. As represented by a dashed line CS in FIG. 3, 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. In the case where there are four DRAM circuits, 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.
Dans un autre mode de réalisation, le SoC, ou un circuit additionnel de décodage d'adresse, est capable de fournir un signal de sélection de puce CS dédié à chaque circuit DRAM. Dans ce cas, la ligne en pointillé CS est un bus de 4 bits de largeur comprenant un signal dédié CS[0] fourni au circuit DRAM0, un signal dédié CS[1] fourni au circuit DRAM1, un signal dédié CS[2] fourni au circuit DRAM2, et un signal dédié CS[3] fourni au circuit DRAM3.  In another embodiment, the SoC, or an additional address decode circuit, is capable of providing a chip selection signal CS dedicated to each DRAM circuit. In this case, 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.
Dans une variante de réalisation, chacun des circuits DRAM est adapté à décoder une plage d'adresses différente de la plage d'adresses totale. Pour cela, les décodeurs d'adresses 300 à 303 des circuits DRAM DRAM0 à DRAM3 ont respectivement par exemple des circuits dont chacun est adapté à décoder la plage d'adresse correspondante. Cependant, une telle solution présente l'inconvénient qu'elle ajoute de la complexité au processus de fabrication puisque les circuits DRAM ne sont plus identiques entre eux. In an alternative embodiment, each of the DRAM circuits is adapted to decode an address range different from the total address range. For this purpose, 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. However, 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.
Une solution alternative consiste à prévoir un ensemble de fusibles associé à chaque décodeur d'adresse 300 à 303 et représenté par des rectangles en pointillés 310 à 313 respectivement. Les fusibles sont par exemple du type programmé par laser, par une tension appliquée à leurs bornes, ou par un courant qu'on fait passer dedans, et ils sont programmés après la fabrication des circuits DRAM de telle sorte que chaque circuit DRAM est configuré pour décoder une plage d'adresses spécifique .  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.
Dans encore une autre solution alternative, la plage d'adresses acceptée par chaque circuit DRAM pourrait être configurée électriquement par des signaux d'entrée fournis à des bornes d'entrée du circuit DRAM directement après une opération de réinitialisation ou après une mise sous tension des circuits. Les bornes d'entrée pourraient être des bornes dédiées prévues dans ce but particulier, ou bien les broches d'entrée/sortie standards du circuit DRAM pourraient être utilisées pendant la phase de configuration pour permettre de définir les plages d' adresses .  In still another alternative solution, 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.
On notera que le bus de données de la figure 3 dans lequel chaque ligne de données est couplée à plus d'un seul des circuits DRAM est susceptible d'amener une capacité électrique supérieure pour les lignes de données. Pour résoudre cela, un circuit tampon pourrait être ajouté sur chaque ligne de données. Cela pourrait augmenter la latence d'un accès mémoire d'un cycle ou plus, et conduirait à une augmentation relativement peu significative en pourcentage de la latence globale. En plus ou à la place, si les circuits DRAM sont montés dans un module mémoire se conformant à l'une des normes DIMM (module mémoire à double rangée de broches) , la façon dont la capacité supplé¬ mentaire des lignes et/ou l'ajout des circuits tampons pourraient être masqués par un tel module DIMM apparaîtra clairement à l'homme de l'art. La figure 4 illustre schématiquement le SoC 102 et le circuit DRAMO plus en détail. Les autres circuits DRAM DRAM1 à DRAM3 ont par exemple des structures similaires. Note that the data bus of FIG. 3 in which 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. To solve this, 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. In addition or instead, if 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.
Le SoC 102 comprend par exemple des processeurs PI et P2, capables chacun d'accéder au circuit DRAM DRAMO. Les processeurs PI, P2 sont par exemple chacun sous le contrôle d'instruction mémorisées dans des mémoires d'instructions correspondantes (non illustrées en figure 4). Bien qu'il y ait deux processeurs dans le SoC de l'exemple de la figure 4, dans des variantes de réalisation il pourrait y avoir un nombre quelconque de processeurs .  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.
Le circuit DRAM DRAMO comprend par exemple une pluralité de sous-mémoires 406, 408, 410 et 412, et une interface esclave DDR commune (DDR SLAVE INTERFACE) 414, comprenant une interface globale de contrôle de processeur DRAM (GI) du circuit DRAM, et un contrôleur de rafraîchissement commun (REFRESH CONTROLER) 416 couplé à chacune des sous- mémoires . Bien que dans les exemples de la figure 4 il y ait quatre sous-mémoires, il pourrait y avoir un nombre quelconque M de sous-mémoires.  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. Although in the examples of FIG. 4 there are four sub-memories, there could be any number M of sub-memories.
La sous-mémoire 406 est illustrée en détail, et les autres sous-mémoires comprennent par exemple les mêmes éléments. La sous-mémoire 406 comprend par exemple un banc mémoire (MEMORY BANK) 418 formant une sous-portion du réseau mémoire du circuit DRAM DRAMO. La sous-mémoire 406 comprend aussi par exemple un processeur (DRAM PROCESSOR) 420 couplé au banc mémoire 418, comprenant un circuit de contrôle de banc mémoire (MEMORY ARRAY CONTROL) 422 comprenant une interface de contrôle de processeur DRAM locale (LI) 423, un circuit de contrôle de rafraîchissement (REFRESH CONTROL) 424, une mémoire d'instructions (INSTRUCTION MEMORY) 425, un pipeline de traitement (PIPELINE) 426, et une mémoire locale (LOCAL MEMORY) 428 du processeur.  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.
Dans le mode de réalisation de la figure 4, 1 ' interface de contrôle de processeur DRAM du circuit DRAMO est mise en oeuvre par l'interface globale 415, et par une interface locale 423 dans chacune des sous-mémoires. Cependant dans des variantes de réalisation, l'interface de contrôle de processeur DRAM pourrait être mise en oeuvre par seulement l'interface globale 415, ou par seulement une interface locale 423 dans chaque sous-mémoire. In the embodiment of FIG. 4, 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. However, in alternative embodiments, 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.
Comme cela sera décrit plus en détail ci-après, le circuit de contrôle de rafraîchissement 424 permet un contrôle de transactions de rafraîchissement reçues par une sous-mémoire pendant qu'une opération de traitement de données est en cours par l'un des processeurs DRAM.  As will be described in more detail below, 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. .
Le circuit de contrôle de banc mémoire 422 assure par exemple un multiplexage entre des requêtes de mémoire DDR à destination de ce banc et des requêtes de processeur DRAM.  The memory bank control circuit 422 for example provides a multiplexing between DDR memory requests to this bank and DRAM processor requests.
Le pipeline de traitement 426 comprend par exemple des éléments de traitement de données qui opèrent sous le contrôle d'instructions mémorisées dans la mémoire d'instruction 425. Etant donné que les processeurs DRAM ont un rôle complémentaire en ce qui concerne le processeur SoC, ils utilisent par exemple un jeu d'instructions différent. Par exemple, les processeurs DRAM utilisent un ensemble d'instructions réduit comparé à celui utilisé par les processeurs SoC. Par exemple, dans certains modes de réalisation, une ou plusieurs instructions à exécuter par les processeurs DRAM sont écrites par un processeur SoC directement dans la mémoire d'instructions du processeur DRAM 425 par l'intermédiaire de l'interface globale 415 et/ou de l'interface locale 423. A la place ou en plus, une ou plusieurs instructions à exécuter par les processeurs DRAM sont écrites par un processeur SoC directement dans la banque mémoire 418, et le processeur SoC peut ensuite donner instruction au processeur DRAM de charger les instructions à partir du banc mémoire 418 dans sa mémoire d'instructions 425.  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.
La mémoire locale 428 mémorise par exemple des données, temporairement ou autrement, utilisées par le pipeline de traitement 426 lors de la réalisation d'opérations sur les données contenues dans le banc mémoire 418. Bien que cela ne soit pas illustré en figure 4, il peut y avoir un ou plusieurs autres circuits intermédiaires entre le SoC et les circuits DRAM. Par exemple, dans le cas où les circuits DRAM sont montés conformément aux normes DIMM dites "complètement équipés de registres" (de l'anglais "fully registered") ou "complètement équipés de tampons" (de l'anglais "fully buffered") , un tampon mémoire avancé (AMB) peut être prévu, permettant des fonctions de traitement complexes additionnelles . 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. Although not illustrated in FIG. 4, there may be one or more other intermediate circuits between the SoC and the DRAM circuits. For example, in the case where 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.
La figure 5 illustre schématiquement le banc mémoire Figure 5 schematically illustrates the memory bank
418 de la figure 4 plus en détail selon un mode de réalisation. Comme cela est illustré, le banc mémoire 418 comprend par exemple un bloc de rangées mémoire DRAM (MEMORY ROWS) 502, et un registre d'accès (ACCESS REGISTER) 504. 418 of Figure 4 in more detail according to one embodiment. As illustrated, the memory bank 418 comprises for example a block of memory rows DRAM (MEMORY ROWS) 502, and an access register (ACCESS REGISTER) 504.
Pendant une opération de lecture, à une adresse dans le banc mémoire 418 du circuit DRAM DRAM0, le banc mémoire 418 est sélectionné par une partie de l'adresse. La rangée à lire du banc mémoire 418 est ensuite identifiée sur la base de l'adresse, et la donnée de la rangée est chargée dans le registre d'accès 504. Un ou plusieurs mots constituant cette rangée peuvent ensuite être lus dans le registre d'accès 504 et fournis soit à un processeur du SoC 102, soit à la mémoire locale 428 du processeur 420 dans le cas où une opération de traitement interne doit être réalisée.  During a read operation, at an address in the memory bank 418 DRAM DRAM0 circuit, 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.
Pendant une opération d'écriture à une adresse dans le banc mémoire 418 du circuit DRAM DRAM0, le banc mémoire 418 est sélectionné par une partie de l'adresse. La rangée à écrire du banc mémoire 418 est ensuite identifiée sur la base de l'adresse, et chargée dans le registre d'accès 504. Un ou plusieurs mots formant cette rangée peuvent alors être écrits dans le registre d'accès par un processeur du SoC 102, ou dans la mémoire locale 428 du processeur 420 dans le cas où une opération de traitement interne doit être réalisée. Lorsque le registre d'accès 504 doit être réutilisé pour accéder à une autre rangée du banc mémoire 502 ou si une opération de rafraîchissement doit être réalisée, le contenu du registre d'accès 504 est réécrit dans la rangée correspondante du banc mémoire 418. During a write operation to an address in the memory bank 418 of the DRAM DRAM0 circuit, 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. When 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.
Il faut aussi noter que les opérations de transfert de rangées de données à partir des rangées mémoires 502 vers le registre d'accès 504 ou à partir du registre d'accès 504 vers les rangées mémoires 502 du banc mémoire sont des opérations relativement lentes réalisées sur plusieurs cycles d'horloge et qui ne doivent pas être interrompues une fois qu'elles ont été démarrées.  It should also be noted that the 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.
En outre, il n'est pas possible pour les processeurs SoC PI, P2 et/ou le processeur DRAM interne d'accéder, d'une manière finement entrelacée, à un même banc mémoire d'un circuit DRAM. Par exemple, le scénario suivant illustre cela:  In addition, it is not possible for the SoC processors PI, P2 and / or the internal DRAM processor to access, in a finely interlaced manner, to the same memory bank of a DRAM circuit. For example, the following scenario illustrates this:
- un processeur DRAM commence à charger le registre d'accès d'un banc mémoire avec une des rangées de ce banc mémoire, cette opération prenant plusieurs cycles ; et  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; and
- avant la fin de l'opération de chargement, un des processeurs SoC demande qu'une autre rangée du banc mémoire soit chargée dans le même registre d'accès, le processeur SoC attendant que cette opération de chargement soit achevée dans un nombre de cycles établi.  before the end of the loading operation, 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.
Cela crée un problème potentiel puisque les protocoles DDR ne permettent pas qu'une requête provenant d'un processeur SoC soit ignorée ou retardée, et la circuiterie du banc ne permet pas non plus qu'une opération de chargement dans un banc mémoire soit annulée au milieu d'une opération. En outre, le protocole DDR ne définit aucun mécanisme permettant à un circuit DRAM d'informer le processeur SoC qui accède à celui-ci :  This creates a potential problem since 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. In addition, the DDR protocol does not define any mechanism by which a DRAM circuit informs the SoC processor that accesses it:
- qu'il est incapable de traiter la requête d'accès mémoire tout de suite ;  - that he is unable to process the memory access request right away;
que les données demandées ne vont pas être disponibles immédiatement ;  that the requested data will not be available immediately;
- du temps nécessaire pour que les données demandées deviennent disponibles. Par conséquent, dans les cas mis en avant précédemment, le processeur SoC est susceptible de considérer que, après le nombre établi de cycles associé à l'opération de chargement, le registre d'accès contient les données demandées, alors qu'en fait ce n'est pas le cas. - the time required for the requested data to become available. Therefore, in the cases previously put forward, 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.
Ce problème est résolu au moins partiellement en définissant un protocole d'accès à utiliser par les processeurs SoC et les processeurs DRAM qui est aussi compatible avec un protocole DDR, comme on va le décrire maintenant plus en détail en faisant référence à la figure 6.  This problem is at least partially solved by defining an access protocol to be used by the SoC processors and DRAM processors that is also compatible with a DDR protocol, as will now be described in more detail with reference to FIG.
La figure 6 est un organigramme illustrant des opérations dans un procédé d'accès à un circuit DRAM selon un mode de réalisation de la présente description.  Fig. 6 is a flowchart illustrating operations in a method of accessing a DRAM circuit according to an embodiment of the present disclosure.
Dans une opération 601, un ou plusieurs processeurs du SoC chargent des données à traiter par un ou plusieurs processeurs DRAM dans une banque mémoire correspondante du circuit DRAM. Par exemple, si le processeur 420 de la sous- mémoire 406 de la figure 4 doit réaliser l'opération de traitement, les données sont par exemple chargées dans la banque mémoire 418.  In an operation 601, 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.
Dans une opération 602, un ou plusieurs des processeurs SoC utilisent l'interface de contrôle de processeur DRAM du circuit DRAM pour indiquer auxdits un ou plusieurs processeurs DRAM qu'ils peuvent commencer à traiter les données.  In an operation 602, 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.
Dans une opération 603, le traitement des données par les processeurs DRAM est réalisé, et pendant ce traitement, le logiciel s 'exécutant sur les processeurs du SoC s'abstient d'accéder au banc mémoire correspondant. Dans le cas où l'un des processeurs SoC essaye d'accéder au banc mémoire pendant que l'un des processeurs DRAM est en train de traiter des données dans ce banc mémoire, une réponse indéfinie est par exemple fournie, et dans certains modes de réalisation un drapeau indicateur d'erreur peut être placé dans un registre de l'interface de contrôle de processeur DRAM pour indiquer que cette erreur est survenue, et pour faciliter le débogage. Dans certains modes de réalisation, chaque processeur DRAM est dédié à un banc mémoire donné dans sa sous-mémoire. En variante, dans certains cas, plus qu'un seul processeur DRAM peut être capable d'accéder au même banc mémoire. Dans de tels cas, une procédure d'arbitrage peut être mise en oeuvre entre les processeurs DRAM afin de permettre aux processeurs DRAM d'accéder correctement à la banque mémoire. L'homme de l'art réalisera qu'une telle procédure d'arbitrage n'est pas contrainte par l'interface DDR utilisée pour les communications avec le SoC, et par conséquent toute procédure d'arbitrage appropriée peut être mise en oeuvre. In an operation 603, the data processing by the DRAM processors is performed, and during this processing, the software running on the processors of the SoC abstains from accessing the corresponding memory bank. In the case where one of the SoC processors tries to access the memory bank while one of the DRAM processors is processing data in this memory bank, an indefinite response is for example provided, and in some modes of Making an error flag can be placed in a DRAM processor control interface register to indicate that this error has occurred, and to facilitate debugging. In some embodiments, 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. In such cases, an arbitration procedure may be implemented between the DRAM processors to allow the DRAM processors to correctly access the memory bank. Those skilled in the art will realize that such an arbitration procedure is not constrained by the DDR interface used for communications with the SoC, and therefore any suitable arbitration procedure can be implemented.
Dans une opération suivante 604, on détermine le moment où le traitement de données par le processeur DRAM est terminé. Lorsqu'il est terminé, l'opération suivante est l'opération 605, dans laquelle le banc mémoire devient accessible par le processeur SoC. Par exemple, l'interface de contrôle de processeur DRAM est utilisée pour informer le logiciel s 'exécutant sur les processeurs SoC que les processeurs DRAM ont finis de traiter les données dans le banc mémoire. Par exemple, l'interface de contrôle de processeur DRAM comprend un registre accessible par les processeurs SoC et comprenant un bit d'état indiquant si les processeurs DRAM ont fini leur tâche, ou du moins la partie de celle-ci à laquelle ils avaient besoin d'accéder au banc mémoire. Lorsque les processeurs DRAM ont terminé le traitement des données dans le banc mémoire et l'ont libéré de sorte qu'il devient accessible de nouveau aux processeurs SoC, les processeurs DRAM sont par exemple configurés pour ne pas accéder de nouveau au banc mémoire jusqu'à recevoir l'instruction provenant des processeurs SoC de réaliser une autre opération de traitement.  In a next operation 604, the time when the data processing by the DRAM processor is completed is determined. When it is complete, the next operation is operation 605, in which the memory bank becomes accessible by the SoC processor. For example, 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. For example, 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. 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.
Dans certains cas, les processeurs SoC peuvent être autorisés à stopper, au cours de celui-ci, le traitement par un processeur DRAM afin d'accéder rapidement aux données mémorisées dans le banc mémoire concerné. Par exemple, cela peut être approprié dans le cas où il y a une tâche à haute priorité à réaliser par un processeur SoC. Cela est par exemple obtenu en activant une commande d'arrêt par l'intermédiaire de l'interface de contrôle de processeur DRAM. Par exemple, après avoir reçu une commande d'arrêt, le processeur DRAM prend plusieurs cycles pour achever une ou plusieurs opérations d'accès courant, et informe le processeur SoC, par 1 ' intermédiaire de 1 ' interface de contrôle de processeur DRAM, du moment où le banc mémoire est prêt à être accédé . In some cases, 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.
Un avantage du procédé d'accès aux mémoires DRAM décrit en relation avec la figure 6 est qu'il assure que les processeurs DRAM ne sont jamais en compétition avec les processeurs SoC. En outre, les processeurs SoC sont capables d'accéder aux bancs mémoire du circuit DRAM d'une manière déterministe normale conformément aux protocoles de type DDR.  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. In addition, 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.
Bien sûr, les processeurs SoC se verront refuser Of course, SoC processors will be denied
1 ' accès à certains bancs mémoire pendant que les processeurs DRAM sont en train de traiter des données. Cependant, puisqu'il est probable qu'il y ait plusieurs bancs mémoire dans chaque circuit DRAM, plusieurs circuits DRAM dans un module DIMM, et potentiellement plusieurs modules DIMM, le fonctionnement des processeurs SoC a peu de chance d'être bloqué. En effet, les résultats des opérations de traitement demandées précédemment par d'autres processeurs DRAM ont de fortes chances d'être disponibles pour la collecte. 1 access to some memory banks while the DRAM processors are processing data. However, since there are likely to be multiple memory banks in each DRAM, multiple DRAMs in a DIMM, and potentially multiple DIMMs, the operation of the SoC processors is unlikely to be blocked. Indeed, the results of processing operations previously requested by other DRAM processors are likely to be available for collection.
La figure 7 illustre schématiquement le circuit de contrôle de rafraîchissement (REFRESH CONTROL) 424 de la sous- mémoire DRAM plus en détail selon un exemple de réalisation.  Fig. 7 schematically illustrates the refresh control circuit (REFRESH CONTROL) 424 of the DRAM sub-memory in more detail according to an exemplary embodiment.
Comme cela a été mentionné précédemment, les circuits DRAM demandent des opérations de rafraîchissement périodiques afin d'empêcher la perte de données. Par exemple, certaines technologies DRAM peuvent typiquement nécessiter que dans un délai de 64 ms toutes les lignes d'un banc mémoire aient été rafraîchies. Par exemple, un système de contrôle de rafraîchissement intégré dans un contrôleur mémoire du SoC 102 génère des transactions de rafraîchissement périodiques, qui dans certains cas peuvent être transmises sous forme de paquets de rafraîchissement regroupant une pluralité de transactions de rafraîchissement pour un circuit DRAM donné. As previously mentioned, DRAMs require periodic refresh operations to prevent loss of data. For example, some DRAM technologies may typically require that within 64 ms all lines of a memory bank have been refreshed. For example, 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.
On notera qu'il y a généralement une certaine tolérance dans la périodicité du rafraîchissement, ce qui permet de retarder des opérations de rafraîchissement, par exemple d'au moins quelques dizaines de microsecondes. Dans certains cas, il suffit que l'opération de rafraîchissement soit exécutée avant qu'une transaction de rafraîchissement suivante arrive. En outre, une opération de rafraîchissement ne modifie pas les données contenues dans un banc mémoire.  It should be noted that there is generally a certain tolerance in the periodicity of the refresh, which makes it possible to delay refreshing operations, for example at least a few tens of microseconds. In some cases, it is sufficient that the refresh operation is executed before a next refresh transaction arrives. In addition, a refresh operation does not modify the data contained in a memory bank.
Le circuit de contrôle de rafraîchissement 424 permet avantageusement de retarder des opérations de rafraîchissement jusqu'à la fin d'un accès à un banc mémoire (DRAM MEMORY BANK) par un processeur DRAM.  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.
Le circuit de contrôle de rafraîchissement 424 reçoit des transactions de rafraîchissement (REFRESH) , et par exemple comprend un registre de rafraîchissement en attente (REFRESH PENDING) 702, et un compteur de rafraîchissement retardé (DELAYED REFRESH COUNTER) 704.  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.
L'opération ou le fonctionnement du circuit de contrôle de rafraîchissement 424 de la figure 7 va maintenant être décrit plus en détail en faisant référence à la figure 8.  The operation or operation of the refresh control circuit 424 of Fig. 7 will now be described in more detail with reference to Fig. 8.
La figure 8 est un organigramme représentant des opérations dans un procédé de traitement de transactions de rafraîchissement. Ce procédé est par exemple réalisé localement par un circuit de contrôle de rafraîchissement 424 de chacune des sous-mémoires 406 à 412 du circuit DRAM. Initialement, on suppose qu'un circuit DRAM, comme le circuit DRAM0 de la figure 4, a reçu une transaction de rafraîchissement, que le contrôleur de rafraîchissement 416 à propagé la transaction de rafraîchis¬ sement vers le circuit de contrôle de rafraîchissement 424 de chacune des sous-mémoires 406, 408, 410, 412 et que les circuits de contrôle de rafraîchissement 424 qui sont capables de réaliser immédiatement l'opération de rafraîchissement le font. Dans une opération 801, le circuit de contrôle de rafraîchissement 424 de l'une des sous-mémoires reçoit une transaction de rafraîchissement pendant que son banc mémoire est occupé par un accès de banc mémoire par le processeur DRAM 420. 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. Initially, it is assumed that a circuit DRAM, as DRAM0 circuit of Figure 4, 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. In an operation 801, 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.
Dans une opération 802, le compteur de rafraîchis¬ sement retardé 704 mémorise la transaction de rafraîchissement et indique, par exemple dans le registre de rafraîchissement en attente 702, qu'une transaction de rafraîchissement est en attente. La transaction de rafraîchissement est par exemple lancée dès que l'accès au banc mémoire courant est terminé. Le registre de rafraîchissement en attente 702 est par exemple réinitialisé seulement une fois que l'opération de rafraîchis¬ sement a été achevée. Le registre de rafraîchissement en attente 702 est par exemple accessible par les processeurs DRAM et aussi par les processeurs SoC, et ces processeurs sont par exemple agencés pour ne pas tenter d'accéder au banc mémoire jusqu'à ce que le registre de rafraîchissement en attente ait été réinitialisé. Dans certains modes de réalisation, le bit d'état de l'interface de contrôle de processeurs DRAM est par exemple utilisé pour indiquer qu'une opération de traitement a été terminée et indique aussi au SoC qu'il n'y a plus de transactions de rafraîchissement en attente. In an operation 802, 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. In some embodiments, 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.
La figure 9 illustre schématiquement une partie de la sous-mémoire 406 de la figure 4 plus en détail selon un exemple de réalisation.  Figure 9 schematically illustrates a portion of the sub-memory 406 of Figure 4 in more detail according to an exemplary embodiment.
Le banc mémoire 418 est par exemple couplé à un bus d'adresses (ADDR BUS) et à un bus de données (DATA BUS) par l'intermédiaire d'un multiplexeur bidirectionnel 902. En particulier, le multiplexeur bidirectionnel a par exemple des ports d'entrée/sortie, l'un étant couplé au banc mémoire 418, et l'autre étant couplé à l'interface de contrôle de processeur DRAM (DRAM PROCESSOR CONTROL INTERFACE) 904, qui correspond par exemple à l'interface globale 415 et/ou à l'interface locale 423. Un autre port d'entrée/sortie du multiplexeur 902 est couplé au bus de données, et peut être couplé soit au banc mémoire 418 soit à l'interface 904 sur la base d'un signal de sélection fourni par un décodeur d'adresses 906. 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. In particular, 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. 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.
L'interface 904 comprend par exemple un ou plusieurs registres de contrôle 908 et optionnellement de la mémoire partagée 910. Le but de la mémoire partagée 910 est par exemple de permettre de faire passer des informations à destination ou en provenance du processeur DRAM sans l'arrêter. L'interface 904 permet par exemple au moins une ou plusieurs des fonctions suivantes :  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:
- initialiser des processeurs DRAM dans un circuit - initialize DRAM processors in a circuit
DRAM donné ; Given DRAM;
- communiquer des paramètres aux processeurs DRAM et lancer l'exécution de programmes par les processeurs DRAM ;  - communicate parameters to the DRAM processors and start the execution of programs by the DRAM processors;
lire les résultats et des informations d'état concernant les processeurs DRAM ; et  read results and status information about DRAM processors; and
- stopper les processeurs DRAM.  - stop the DRAM processors.
D'autres fonctions non listées ici peuvent aussi être mise en oeuvre en utilisant l'interface de contrôle de processeur DRAM.  Other functions not listed here can also be implemented using the DRAM processor control interface.
Les interfaces de contrôle de processeur DRAM permet¬ tent aussi par exemple que des opérations soient réalisées par un sous-ensemble d'un ou plusieurs des processeurs DRAM d'un circuit DRAM donné, ou globalement par la totalité des processeurs DRAM d'un circuit DRAM donné. 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.
L'interface 904 fait par exemple partie de l'espace mémoire adressable du circuit DRAM.  The interface 904 is for example part of the addressable memory space of the DRAM circuit.
Dans certains modes de réalisation, l'espace mémoire adressable du circuit DRAM est plus grand que l'espace adressable dans les bancs mémoire du circuit DRAM afin de permettre que les emplacements d'adresses de l'interface 904 soient accessibles en permanence par les processeurs du SoC. Dans un tel cas, le décodeur d'adresse 906 contrôle par exemple le multiplexeur 902 pour coupler le bus de données à l'interface 904 si l'adresse est dans la plage d'adresses associée à l'interface 904. En variante, dans certains modes de réalisation les emplacements d'adresses de l'interface 904 sont initialement visibles pour le SoC, et sont ensuite rendus inaccessibles par une commande de désactivation spécifique si l'interface 904 n'est pas nécessaire, ce qui implique par exemple que le processeur DRAM ne doit pas être utilisé. Par exemple, dans de tels modes de réalisation, immédiatement après une réinitia¬ lisation ou une mise sous tension du circuit DRAM, une certaine plage d'adresse correspond à l'espace mémoire de l'interface de contrôle de processeur DRAM 904. Cependant, cette plage d'adresses peut être transformée en un espace mémoire DRAM standard si la commande de désactivation est activée. In some embodiments, 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. In such a case, 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. Alternatively, in some embodiments 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. For example, in such embodiments, immediately after réinitia ¬ lisation or powering up the DRAM circuit, a certain address range corresponds to the memory space of the DRAM processor control interface 904. However, this address range can be converted to standard DRAM memory space if the disable command is enabled.
Dans d'autres modes de réalisation, les emplacements d'adresses de l'interface 904 sont initialement invisibles pour le SoC, et sont ensuite rendus accessibles par une commande d'activation spécifique si l'interface doit être utilisée, comme on va le décrire maintenant en faisant référence à la figure 10.  In other embodiments, 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.
La figure 10 est un organigramme illustrant les opérations dans un procédé pour rendre 1 ' interface de contrôle de processeur DRAM accessible dans l'espace d'adresses d'un circuit DRAM.  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.
Dans une opération 1001, une opération de réinitia¬ lisation DRAM est réalisée, ou bien le circuit DRAM est mis sous tension. Initialement, une certaine plage d'adresses correspond à un espace d'adresses DRAM standard du circuit DRAM immédia¬ tement à la suite d'une réinitialisation ou d'une mise sous tension du circuit DRAM. In an operation 1001, an operation réinitia ¬ lisation DRAM is performed, or the DRAM circuit is energized. Initially, 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.
Dans une opération 1002, on détermine, par exemple par l'interface de contrôle de processeur DRAM 904 et/ou le décodeur d'adresses 906, si une commande d'activation d'interface a été reçue. Si une telle commande est reçue, l'opération suivante est l'opération 1003.  In 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.
Dans l'opération 1003, l'interface de contrôle de processeur DRAM est rendue visible dans l'espace d'adresses du circuit DRAM en transformant la plage d'adresses dans l'espace mémoire de l'interface de contrôle de processeurs DRAM 904. In 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.
La commande de désactivation ou d'activation correspond par exemple à un signal transmis à partir du SoC au décodeur d'adresses 906 par l'intermédiaire d'une broche d'entrée dédiée du circuit DRAM, comme cela est représenté par une ligne en pointillés 914 en figure 9.  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.
En variante, la commande de désactivation ou d'activation correspond par exemple à une valeur contenue dans un ou plusieurs registres de contrôle (CONTROL REGISTERS) 916, qui sont présents dans certains circuits DRAM pour des transactions spéciales comme des commandes MRS (réglage de registre de mode). Par exemple, le décodeur d'adresses (ADDR DEC) 906 contrôle le multiplexeur 902 pour coupler le bus de données à l'interface 904 lorsque l'adresse sur le bus d'adresses est dans la plage d'adresses définie par les registres de contrôle 916. Plutôt que de faire usage de registres existants présents dans certains circuits DRAM, un ou plusieurs nouveaux registres pourraient être ajoutés, qui sont par exemple configurés pour être accessibles en utilisant une transaction MRS.  As a variant, 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). For example, 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. Rather than making use of existing registers present in some DRAM circuits, one or more new registers could be added, which are for example configured to be accessible using an MRS transaction.
Dans encore une autre variante, le signal d'activation ou de désactivation peut être transmis par le SoC sur les bus mémoire standards du circuit DRAM, en utilisant par exemple le bus d'adresses. Pour cela, le décodeur d'adresses 906 et/ou l'interface 904 sont adaptés pour détecter une séquence spécifique de commandes provenant du SoC, qui va être appelée ici séquence magique. La séquence magique est par exemple une séquence de commandes correspondant à une adresse mémoire fictive, en d'autre terme une séquence qui respecte le protocole standard pour communiquer avec le circuit DRAM, mais qui peut être distinguée d'un accès mémoire réel. Elle est par exemple sélectionnée pour être une séquence de commandes qui a très peu de chances d'avoir lieu, ou même aucune, dans un fonctionnement normal du circuit DRAM. Plutôt qu'il y ait une seule séquence magique, dans certains modes de réalisation il peut y en avoir plusieurs, et la plage d'adresses de l'interface 906 dépend par exemple de quelle séquence magique est appliquée. In yet another variant, 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. For this, 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.
Dans certains modes de réalisation, pour éviter de fausses détections positives de la séquence magique, le circuit DRAM comprend par exemple un compteur de cycles d'horloge, ou un compteur de rafraîchissement, qui compte le nombre de cycles d'horloge ou de transactions de rafraîchissement qui ont été reçus . Une séquence est ensuite par exemple exclue pour ne pas être considérée comme séquence magique si :  In some embodiments, to avoid false positive detections of the magic sequence, 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. For example, a sequence is excluded so as not to be considered a magic sequence if:
- elle arrive avant un premier instant, c'est-à-dire avant un premier nombre de cycles d'horloge ou d'opérations de rafraîchissement, par exemple avant qu'une séquence d'amorçage ait été complètement terminée, ce qui signifie qu'elle a pu être générée accidentellement pendant l'amorçage ;  it arrives before a first moment, that is to say before a first number of clock cycles or refresh operations, for example before a boot sequence has been completely completed, which means that it could have been generated accidentally during priming;
- elle arrive après un deuxième instant, c'est-à-dire après un deuxième nombre de cycles d'horloge ou d'opérations de rafraîchissement, par exemple longtemps après qu'une séquence d'amorçage ait été achevée, alors que le pilote logiciel qui gère les processeurs DRAM et peut générer la séquence magique est généralement activé juste après que le système d'exploitation a été chargé, et avant que les applications soient chargées ;  it arrives after a second instant, that is to say after a second number of clock cycles or refresh operations, for example long after a boot sequence has been completed, while the 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;
- elle prend plus d'un certain temps pour survenir, c'est-à-dire, plus qu'un certain nombre de cycles d'horloge ou d'opérations de rafraîchissement, tandis que la séquence magique réelle est susceptible de se produire sur une période de temps relativement resserrée.  it takes more than a certain time to occur, that is, more than a certain number of clock cycles or refresh operations, while the actual magic sequence is likely to occur on a relatively short period of time.
Un exemple de séquence magique peut être de multiples accès consécutifs par un processeur SoC, une fois que la mémoire cache a déjà été activée, d'une même zone de la mémoire sans aucun autre accès intermédiaire à d'autres zones de la mémoire. En particulier, la mémoire cache est généralement activée très tôt pendant une séquence d'amorçage, puisque les processeurs SoC ont tendance à fonctionner lentement jusqu'à ce que la mémoire cache ait été activée. Une fois que le cache a été activé, il est peu probable que de multiples accès consécutifs aient lieu dans la même zone mémoire. 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. In particular, 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.
Un autre exemple de séquence magique consiste à définir certaines zones mémoire ne pouvant être mises en cache, puis à faire de multiples accès consécutifs à ces zones. En particulier, les processeurs modernes comprennent en général un MMU (module de gestion mémoire) , qui permet de donner l'indication qu'une zone mémoire ne peut pas être mise en cache. Normalement, une application n'aurait aucune raison de demander qu'une partie de la mémoire ne puisse être mise en cache, puis que cela conduirait à une diminution prononcée des performances, sans aucun avantage en retour. Si le cache est actif, ce qui implique que le cache doit être utilisé, il y a peu de chances que de multiples accès consécutifs soient faits dans une même zone de mémoire DRAM. Par conséquent, la séquence magique est par exemple détectée par la présence de multiples accès mémoire à une zone de mémoire DRAM donnée.  Another example of a magic sequence consists in defining certain memory zones that can not be cached, and then making multiple consecutive accesses to these zones. In particular, modern processors generally include a MMU (memory management module), which allows to give the indication that a memory area can not be cached. Normally, 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. If the cache is active, which implies that the cache must be used, it is unlikely that multiple consecutive accesses will be made in the same DRAM. As a result, the magic sequence is for example detected by the presence of multiple memory accesses to a given DRAM area.
Dans encore un autre exemple de séquence magique, on peut utiliser le fait que la mémoire puisse être mise en cache en mode de double écriture, comme cela va maintenant être décrit plus en détail.  In yet another example of a magic sequence, it can be used that the memory can be cached in double write mode, as will now be described in more detail.
Lorsqu'une zone mémoire peut être mise en cache, une opération de lecture selon un mode à "allocation de lecture" (de l'anglais "read allocate") implique :  When a memory area can be cached, a read allocation operation in read allocation mode involves:
a. vérifier si la zone cible de l'opération de lecture est déjà dans le cache ;  at. check if the target area of the read operation is already in the cache;
b. (i) si la zone cible est déjà en cache, la ligne de cache est lue, et l'opération de lecture est terminée ;  b. (i) if the target area is already cached, the cache line is read, and the read operation is complete;
b. (ii) si la zone cible n'est pas déjà en cache, la zone cible est chargée dans le cache, cette ligne de cache est ensuite lue, et l'opération de lecture est terminée.  b. (ii) if the target area is not already cached, the target area is loaded into the cache, that cache line is then read, and the read operation is complete.
Une opération d'écriture peut être réalisée en utilisant l'un de deux modes, un mode "allocation d'écriture" (de l'anglais "write allocate"), ou un mode "double écriture" (de l'anglais "write through") . 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").
Une opération d'écriture selon le mode à allocation d'écriture implique :  A writing operation according to the write allocation mode involves:
a. vérifier si la zone cible de l'opération d'écriture est déjà en cache ;  at. check if the target area of the write operation is already cached;
b. (i) si la zone cible est déjà en cache, la ligne de cache correspondante est écrite, et l'opération d'écriture est terminée;  b. (i) if the target area is already cached, the corresponding cache line is written, and the write operation is complete;
b. (ii) si la zone cible n'est pas déjà en cache, la zone cible est chargée dans une ligne de cache, la ligne de cache est écrite, puis l'opération d'écriture est terminée ;  b. (ii) if the target area is not already cached, the target area is loaded into a cache line, the cache line is written, and then the write operation is complete;
c. les données sont écrites à partir du cache dans la mémoire principale lorsque la ligne de cache doit être retirée du cache et utilisée pour mettre à jour la mémoire principale.  vs. 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.
Une opération d'écriture selon le mode de double écriture implique :  A write operation according to the double write mode involves:
a. vérifier si la zone cible de l'opération d'écriture est déjà en cache ;  at. check if the target area of the write operation is already cached;
b. si la zone cible est déjà en cache, la ligne de cache correspondante est écrite ;  b. if the target area is already cached, the corresponding cache line is written;
c. que la zone cible soit ou pas déjà en cache, les données sont aussi écrites dans la mémoire principale.  vs. whether or not the target area is already cached, the data is also written to the main memory.
Le mode de double écriture peut utiliser des transactions d'écriture en phase dans lesquelles certains mots de la transaction ne sont pas écrits puisque la longueur de salve est supérieure à celle des données à écrire. Le mode à allocation d'écriture par contre utilise seulement des transactions d'écriture en salve dans lesquelles tous les mots de la transaction sont écrits.  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, on the other hand, uses only burst write transactions in which all the words of the transaction are written.
Un processeur du SoC est par exemple capable de spécifier, par l'intermédiaire du MMU, si l'accès à chaque page de la mémoire doit être :  For example, a processor of the SoC is able to specify, via the MMU, whether the access to each page of the memory must be:
1) apte à être mis en cache ; ou 2) apte à être mis en cache en utilisant l'allocation de lecture et l'allocation d'écriture, ce qui est appelé généralement mode "allocation d'écriture" ; ou 1) able to be cached; or 2) able to be cached using read allocation and write allocation, which is generally called "write allocation"mode; or
3) apte à être mis en cache en utilisant l'allocation de lecture ou la double écriture, ce qui est en général appelé mode "double écriture".  3) able to be cached using read allocation or double write, which is usually referred to as "double write" mode.
Parmi ces modes, c'est en général le mode à allocation d'écriture qui donne les meilleures performances. Le mode double écriture est toutefois utilisé dans certaines configurations matérielles, par exemple si un tampon de trame est présent, ce tampon de trame étant lu par un processeur d'affichage n'ayant pas la capacité de réaliser d'espionnage de bus, et par conséquent pas capable de récupérer les données à lire dans le cache d'un processeur.  Among these modes, it is generally the write allocation mode that gives the best performance. 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.
Dans les SoC modernes, les processeurs sont capables d'utiliser un espionnage de bus afin de récupérer les données à lire dans le cache d'un autre processeur. Par conséquent, il n'y a en général pas besoin d'utiliser le mode double écriture.  In modern SoCs, 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.
Par conséquent, la séquence magique peut correspondre à un accès fait en utilisant le mode de double écriture, détectable par le fait qu'un accès en salve est réalisé, dans lequel certains mots ne sont pas écrits. Par exemple, le signal d' activâtion d'écriture est désactivé pour au moins une valeur de données .  Therefore, 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. For example, the write enable signal is disabled for at least one data value.
Un autre exemple de séquence magique est une série d'accès mémoire utilisant des emplacements anormaux dans l'espace et dans le temps. En particulier, lorsque le cache est utilisé, des accès répétés aux mêmes adresses mémoire sont réalisés en utilisant le cache au lieu du banc mémoire du circuit DRAM. Par conséquent, la présence d'accès répétés dans une zone relativement petite d'un banc mémoire, par exemple dans quelques mots, et dans une période de temps relativement courte, par exemple de plusieurs centaines de microsecondes, peut être reconnue comme un événement improbable interprété comme séquence magique . Un avantage des modes de réalisation décrits ici est qu'un circuit DRAM ayant un processeur interne peut opérer selon un protocole DDR, tout en permettant en même temps une amélioration de performances en réduisant dans une certaine mesure les opérations de transfert de données entre le circuit DRAM et le SoC. De plus, en réalisant l'interface de contrôle de processeur par un ensemble de registres de contrôle accessible dans l'espace d'adresses du circuit mémoire, l'interface peut être réalisée sans matériel dédié dans le processeur central. Une telle solution peut donc être appliquée à une réalisation existante d'un processeur central sans nécessiter de modifications au matériel. En particulier, l'interface est par exemple réalisée par un logiciel exécuté par le processeur central, le logiciel réalisant un protocole d'exclusion d'accès interdisant au processeur central d'accéder à un ou plusieurs bancs mémoire du réseau mémoire lorsque le processeur interne est en train d'effectuer une opération. Par exemple, le processeur central peut savoir quand les opérations sont en train d'être effectuées par le processeur interne, car le processeur central est responsable de la direction des commandes de traitement de données vers le processeur interne, et peut accéder, par l'intermédiaire de l'interface de contrôle de processeur, à des données indiquant quand le processeur interne a terminé une opération. Le protocole d'exclusion d'accès ne permet donc pas de tentatives d'accès simultanés de la part des processeurs central et interne, évitant donc le besoin d'arbitrage de collision entre ces processeurs. Another example of a magic sequence is a series of memory accesses using abnormal locations in space and time. In particular, 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. In addition, by performing the processor control interface with a set of control registers accessible in the address space of the memory circuit, the interface can be made without dedicated hardware in the central processor. Such a solution can therefore be applied to an existing embodiment of a central processor without requiring modifications to the hardware. In particular, 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. For example, 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.
Un avantage du mécanisme de retard des opérations de rafraîchissement dans le circuit mémoire est que des opérations de rafraîchissement peuvent être générées de façon classique par le processeur central, par exemple par un contrôleur mémoire du processeur central. Le contrôleur mémoire n'a donc pas besoin de connaître les opérations qui sont en cours d'exécution par le processeur interne du circuit mémoire. Avec la description ainsi faite d'au moins un mode de réalisation illustratif, diverses altérations, modifications et améliorations apparaîtront facilement à l'homme de l'art. 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. With the description thus made of at least one illustrative embodiment, various alterations, modifications and improvements will readily occur to those skilled in the art.
Par exemple, il apparaîtra clairement à l'homme de l'art que bien qu'on ait décrit des modes de réalisation dans lequel il y a une interface de contrôle de processeur DRAM pour chaque processeur DRAM, dans certains modes de réalisation une telle interface pourrait être partagée entre plusieurs processeurs .  For example, it will be apparent to those skilled in the art that although embodiments have been described in which there is a DRAM processor control interface for each DRAM processor, in some embodiments such an interface could be shared between multiple processors.
En outre, il apparaîtra clairement à l'homme de l'art que divers éléments décrits en relation avec les divers modes de réalisation pourraient être combinés, dans des variantes de réalisation, selon des combinaisons quelconques.  In addition, it will be apparent to those skilled in the art that various elements described in connection with the various embodiments could be combined, in alternative embodiments, in any combination.

Claims

REVENDICATIONS
1. Circuit mémoire comprenant : A memory circuit comprising:
un réseau mémoire (104) comprenant un ou plusieurs bancs mémoire (418) ;  a memory array (104) including one or more memory banks (418);
un premier processeur (420) ; et  a first processor (420); and
une interface de contrôle de processeur (904) pour recevoir des commandes de traitement de données adressées au premier processeur à partir d'un processeur central (PI, P2), l'interface de contrôle de processeur (904) étant adaptée à indiquer au processeur central quand le premier processeur a fini d'accéder à un ou plusieurs bancs mémoire du réseau mémoire, ces bancs mémoire devenant accessibles pour le processeur central, l'interface de contrôle de processeur (904) comprenant un ensemble de registres de contrôle (908) accessible dans l'espace d'adresses du circuit mémoire.  a processor control interface (904) for receiving data processing commands addressed to the first processor from a central processor (PI, P2), the processor control interface (904) being adapted to indicate to the processor central when the first processor has finished accessing one or more memory banks of the memory network, these memory banks becoming accessible to the central processor, the processor control interface (904) comprising a set of control registers (908) accessible in the address space of the memory circuit.
2. Circuit mémoire selon la revendication 1, dans lequel le circuit mémoire est un circuit de mémoire dynamique à accès aléatoire (DRAM) comprenant en outre un circuit de contrôle de rafraîchissement (424) adapté :  The memory circuit of claim 1, wherein the memory circuit is a Random Access Memory (DRAM) circuit further comprising a refresh control circuit (424) adapted:
à recevoir, à partir du processeur central, des transactions de rafraîchissement pour réaliser des opérations de rafraîchissement de données dans au moins un banc mémoire (418) du réseau mémoire ;  receiving, from the central processor, refresh transactions for performing data refresh operations in at least one memory bank (418) of the memory network;
à déterminer si ledit au moins un banc mémoire (418) est en train d'être accédé par le premier processeur, et si oui, à retarder l'instant de début de l'opération de rafraîchissement de données .  determining whether said at least one memory bank (418) is being accessed by the first processor, and if so, delaying the start time of the data refresh operation.
3. Circuit mémoire selon la revendication 2, dans lequel le circuit de contrôle de rafraîchissement (424) comprend un registre de rafraîchissement en attente (702), et dans lequel le fait de retarder l'instant de début de l'opération de rafraîchissement de données comprend d'indiquer dans le registre de rafraîchissement en attente (702) que l'opération de rafraîchissement est en attente. A memory circuit according to claim 2, wherein the refresh control circuit (424) comprises a standby refresh register (702), and wherein delaying the start time of the refresh operation of data includes indicating in the refresh refresh register (702) that the refresh operation is pending.
4. Circuit mémoire selon l'une quelconque des revendications 1 à 3, dans lequel l'interface de contrôle de processeur (904) ne comprend pas de ligne de commande dédiée entre le premier processeur (420) et le processeur central (PI, P2) . A memory circuit according to any one of claims 1 to 3, wherein the processor control interface (904) does not include a dedicated command line between the first processor (420) and the central processor (PI, P2 ).
5. Circuit mémoire selon la revendication 4, dans lequel l'espace d'adresses du circuit mémoire comprend une ou plusieurs adresses associées de façon permanente à l'ensemble de registres de contrôle (908) .  The memory circuit of claim 4, wherein the memory circuit address space includes one or more addresses permanently associated with the set of control registers (908).
6. Circuit mémoire selon la revendication 4, dans lequel l'espace d'adresses du circuit mémoire comprend une ou plusieurs adresses associées à l'ensemble de registres de contrôle (908), et dans lequel lesdites une ou plusieurs adresses sont adaptées à être transformées en adresses du réseau mémoire lors de l'activation d'un signal de commande de désactivation de registre.  The memory circuit of claim 4, wherein the address space of the memory circuit comprises one or more addresses associated with the set of control registers (908), and wherein said one or more addresses are adapted to be transformed into addresses of the memory network when activating a damper control signal.
7. Circuit mémoire selon la revendication 4, adapté à recevoir un signal d' activâtion provenant du processeur central (PI, P2) pour rendre l'ensemble de registres de contrôle accessible dans l'espace d'adresses du circuit mémoire.  7. Memory circuit according to claim 4, adapted to receive an activation signal from the central processor (PI, P2) to make the set of control registers accessible in the address space of the memory circuit.
8. Circuit mémoire selon la revendication 7, dans lequel le signal d'activation est fourni par l'intermédiaire d'un bus d'adresses, et est détectable par l'interface de contrôle de processeur.  The memory circuit of claim 7, wherein the activation signal is provided via an address bus, and is detectable by the processor control interface.
9. Circuit mémoire selon la revendication 8, dans lequel la séquence d'accès mémoire pour rendre l'ensemble de registres de contrôle accessible est une séquence d'accès en salve dans laquelle tous les mots ne sont pas écrits.  The memory circuit of claim 8, wherein 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.
10. Circuit mémoire selon la revendication 8, dans lequel la séquence d'accès mémoire pour rendre l'ensemble de registres de contrôle accessible est une pluralité d'accès mémoire à des cellules mémoires se trouvant dans une zone mémoire dans l'un des bancs mémoire dans une première période de temps . The memory circuit of claim 8, wherein the memory access sequence for making the set of control registers accessible is a plurality of memory accesses to memory cells in a memory area in one of the banks. memory in a first period of time.
11. Circuit mémoire selon l'une quelconque des revendications 8 à 10, dans lequel le circuit mémoire est adapté à détecter la séquence d'accès mémoire sur la base d'un ou plusieurs des éléments suivants : The memory circuit of any one of claims 8 to 10, wherein the memory circuit is adapted to detect the memory access sequence based on one or more of the following:
une période de temps dans laquelle la séquence d'accès mémoire est reçue ; et  a period of time in which the memory access sequence is received; and
une durée de la séquence d'accès mémoire.  a duration of the memory access sequence.
12. Système comprenant :  12. System comprising:
une pluralité de circuits mémoire selon l'une quelconque des revendications 1 à 11 ; et  a plurality of memory circuits according to any one of claims 1 to 11; and
un processeur central (PI, P2) couplé à chacun des circuits mémoire par l'intermédiaire d'un bus de données commun de N bits, chaque circuit mémoire comprenant une interface de bus de N bits couplée au bus de données de N bits .  a central processor (PI, P2) 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.
13. Procédé pour accéder à un circuit mémoire comprenant un réseau mémoire (104) comportant un ou plusieurs bancs mémoire (418) ; un premier processeur (420) ; et une interface de contrôle de processeur (904) comprenant un ensemble de registres de contrôle (908) accessible dans l'espace d'adresses du circuit mémoire, le procédé comprenant :  A method for accessing a memory circuit comprising a memory array (104) having one or more memory banks (418); a first processor (420); and a processor control interface (904) comprising a set of control registers (908) accessible in the address space of the memory circuit, the method comprising:
recevoir, par l'interface de contrôle de processeur (904) , des commandes de traitement de données adressées au premier processeur (420) à partir d'un processeur central (PI, P2) ;  receiving, via the processor control interface (904), data processing commands addressed to the first processor (420) from a central processor (PI, P2);
indiquer, par l'interface de contrôle de processeur indicate, through the processor control interface
(904) au processeur central (PI, P2), quand le premier processeur a fini d'accéder à un ou plusieurs des bancs mémoire (418) du réseau mémoire (104) , ces bancs mémoire devenant accessibles par le processeur central (PI, P2) . (904) to the central processor (PI, P2), when the first processor has finished accessing one or more of the memory banks (418) of the memory array (104), these memory banks becoming accessible by the central processor (PI, P2).
14. Procédé selon la revendication 13, dans lequel le circuit mémoire est un circuit de mémoire dynamique à accès aléatoire (DRAM) , le procédé comprenant en outre :  The method of claim 13, wherein the memory circuit is a Random Access Memory (DRAM) circuit, the method further comprising:
recevoir, par un circuit de contrôle de rafraîchis¬ sement (424) , une transaction de rafraîchissement pour réaliser une opération de rafraîchissement de données dans un banc mémoire (418) du réseau mémoire (104) ; receiving, by a refreshed ¬ ment control circuit (424), a refresh transaction to realize a data refresh operation in a memory bank (418) of the memory array (104);
déterminer, par le circuit de contrôle de rafraî¬ chissement (424), si le banc mémoire (418) est en train d'être accédé par le premier processeur (420) et si oui, retarder l'instant de début de l'opération de rafraîchissement de données . determining, by the control circuit rafraî ¬ chissement (424), if the memory bank (418) is being accessed by the first processor (420) and if so, to delay the start time of the operation data refresh.
15. Procédé selon la revendication 13 ou 14, comprenant en outre :  The method of claim 13 or 14, further comprising:
recevoir par l'interface de contrôle de processeur receive through the processor control interface
(904) un signal d'activation à partir du processeur central (PI, P2) pour rendre l'ensemble de registres de contrôle accessible dans un espace d'adresses du circuit mémoire. (904) an activation signal from the central processor (PI, P2) for making the set of control registers accessible in an address space of the memory circuit.
EP16707914.4A 2015-02-18 2016-02-12 Dram circuit provided with a built-in processor Active EP3259674B1 (en)

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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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

Cited By (3)

* Cited by examiner, † Cited by third party
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