The present disclosure relates generally to memory controllers, and more particularly to memory controllers for memory devices having double data rate read and/or write data buses.
Electronic systems can be employed in environments having higher reliability requirements than typical industrial applications. For example, some applications, such as systems employed in space, can require an integrated circuit be “radiation hardened” (rad hard) with respect to ionizing radiation.
Current space systems are typically designed with integrated circuited devices fabricated on technology nodes several generations behind their commercial counterparts. In the case of systems with memory devices, one conventional approach can incorporate a large number of static random access memory (SRAM) devices having speeds well below their commercial counterparts. Such SRAM devices can be used in parallel (for error correcting/redundancy), requiring a large bus and introducing wait states.
The space community is facing a huge initiative to modernize their electronic design. Conventional high reliability designs have largely been in 100 MHz (clock speed) or less domain. Currently, advances in radiation hardened field programmable gate arrays (FPGAs) have produced high reliability FPGAs operating at clock speeds of 250 MHz to 400 MHz. Conventionally, rad hard memory solutions do not match the performance of such FPGA devices.
A common memory type included in systems is a first-in-first-out (FIFO) memory. A FIFO memory can allow data to be written into and read out from its array at independent data rates. FIFOs are ubiquitous constructs needed for data manipulation tasks such as clock domain crossing and low latency memory buffering.
Monitoring the status of a FIFO memory can be an important feature to avoid any data under or over flows, and is achieved by the full and empty flags. As the name applies, a full flag is asserted when a FIFO memory is full. Similarly, an empty flag is asserted when a FIFO memory is empty.
In a similar fashion, a read operation can be indicated by appropriate control signals at the read port 1803-1 (RENB, RCSB) timed according to a read clock RCLK. A write pointer circuit 1807 can generate a sequence of read addresses to access read data. Corresponding read data can be output from DPRAM array 1811 via driver 1821 as output read data (DATAOUT).
DPRAM array 1811 enables independent access to storage locations for input and output ports (1803-0/1) to operate independently. FIFO control logic 1819 can manage read and write pointers to enable first-in-first-out type accesses. Further, FIFO control logic 1819 can assert a full flag (Full) and an empty flag (Empty), if such conditions arise. In addition, FIFO control logic 1819 can assert error flags in the event a read or write access cannot be completed.
Another important set of flags sometimes implemented with FIFO memories are the almost full and almost empty flags. Such flags can be used by a system to either stop sending (PUSH) or stop receiving (POP) data to ensure data in transit can be properly handled. A value less than the maximum count for almost full and a value greater than zero for almost empty can be used to generate these flags, respectively.
Another common memory type can be a dual port memory. A dual port memory can have two totally independent ports that can have simultaneous access capability to any stored data. Each port can write and read data into and out of any memory location.
As can be seen, each port (portL 1903-0 and portR 1903-1) can have its own associated control lines (portL(R)_wr_n, portL(R)_ce_n, port(R)_rst_n), data lines (portL(R)_io) and address lines (portL(R)_add). Operations are initiated by a low to high transition on the clock signals for each port (portL_clk, portR_clk). Writing to, or reading from, the selected address is controlled by the write/read selection signals (portL_wr_n, portR_wr_n). Output enables (portL_oe_n, portR_oe_n) are asynchronous signals and control the data flow, since inputs/outputs (I/Os) are bi-directional. Chip enables (portL_ce_n, portR_ce_n) are available for ease of depth expansion. Control circuits 1919-0/1 can control accesses for their respective ports. Addresses for different ports (portL(R)_add) can be decoded by corresponding address decoders 1937-0/1. Write data for different ports can be stored in different input registers (1907-0/1) prior to being written into DPRAM array 1911. Similarly, read data for different ports can be stored in output registers 1917-0/1, before being driven on device outputs by corresponding drivers 1921-0/1.
Data collisions between the two ports can occur and is avoided to ensure data integrity. When different data is simultaneously written to the same memory location by both ports (a collision), unknown data ends up being stored (the data can be old, new or transitional data). A similar situation exists when one port is writing data and the other port is reading data simultaneously from the same memory location. Unknown data can be read out (the can be the old stored data or the newly written data). Arbitration is generally implemented to avoid collisions and in most cases is through customer implemented external logic to the dual port SRAM.
Various embodiments will now be described that include memory controllers and methods for high reliability (e.g., radiation hardened) memory devices and systems. Such memory controllers can enable control devices to utilize memory devices having high speed interfaces, such as double data rate (DDR) read and write buses.
In the embodiments below, like sections are referred to with the same reference character but with the leading digit(s) corresponding to the figure number.
Referring to
In the embodiment shown, memory device interface 106 includes a clock output CLK, a command output CMD, an address output ADD, a write data output D, and a read data input Q. A clock output CLK can output one or more periodic signals to control timing of accesses to memory device(s) 108. A command output CMD can output one or more command signals (e.g., read enable, write enable) to indicate a type of access to memory device(s) 108. In one embodiment, an address output ADD can provide address values for read and write accesses to the memory device(s) 108. In one embodiment, a write data output D can be separate from a read data output Q (i.e., the data bus is not bi-directional).
Referring to
It is understood that address and/or command signals can be transmitted according to various timing conventions, including but not limited to DDR speed and/or single data rate (SDR) speeds (i.e., one request per clock cycle).
Referring still to
In a very particular embodiment, controller device 100 can be implemented with high reliability circuits/processes, including but not limited to, rad hard circuits/processes. In a very particular embodiment, a controller device 100 can be implemented all, or in part, with one or more rad hard field programmable gate arrays (FPGAs).
In this way, an interface can enable a QDR type memory device to be utilized with controllers having non-QDR interfaces.
A controller interface 202 can use SDR signals to make read and write requests to memory device 208. Controller logic 204 can include a control circuit 212, a write data error detection and correction (EDAC) circuit 214, a read data EDAC circuit 215, D-Q type flip-flops (FFs) 216-0 to -5, multiplexers (MUXs) 218-0/1 and a delay circuit 220.
A controller interface 202 can operate according to a SDR based protocol making read and write command requests. In particular embodiments, a controller interface 202 can include one or more buffer memories to queue read/write commands and store the corresponding address and data values. Such values can then be used to commence operations to memory device 208.
Referring still to
FFs 216-0/1 and MUX 218-0 can generate a timing signal QDR_K for memory device 208 based on a master clock signal received at controller interface CLK0.
Write data EDAC circuit 214 can receive high and low words of write data (along with error correction bits), and perform error correction, if needed. FFs 216-2/3 and MUX 218-1 can output write data from EDAC circuit 214 according to a clock received at CLK270. This can result in write data (QDR_D) being output to memory device 208 at a double data rate.
FFs 216-4/5 can receive read data (QDR-Q) (which can include error correction bits) at a double data rate, and forward such read data to read data EDAC circuit 215 according to a timing signal generated by delay circuit 220. In the embodiment shown, delay circuit 220 can delay a read data clock signal (QDR_CQ), which can be synchronous to output read data, to generate the timing signal for FFs 216-4/5. Read data EDAC circuit 215 can receive high and low words of read data (along with error correction bits), and perform error correction, if needed. Such read data can then be output at a single data rate speed on controller read data outputs (USER_QRL/H). In the particular embodiment shown, such read data can be output with a read data valid signal (output on USER_QR_VLD), as well as error flags (USER_QRL/H_ERR) which can indicate errors in the read data.
A write data path through a controller device 200 can generate address, data and control signals required to execute write operations to memory device 208. Memory device addresses (QDR_ADD) can use DDR formatting for two-burst word operations and SDR formatting for four-word burst operations. In one embodiment, write enable signal (QDR_W_N) may use SDR formatting. In contrast, write data values (QDR_D) utilize DDR signaling to achieve the required two-word or four-word burst with their associated clock periods. Signals utilized for write operations can be center-aligned with respect to edges of master clock (QDR_K, and QDR_KB, if included).
In the particular embodiment of
A read path can be similar to the write path. Once a read address (QDR_ADD) and read enable signal (QDR_R_N) have been output to a memory device 208, read data clock signals (QDR_CQ and QDR_CQB, if included) can be used as strobes to capture DDR read data values (QDR_Q) output from memory device 208. The timing and synchronization of DDR data to SDR format can be handed by a built-in input SERDES block.
A memory device 208 can include clock generating circuit 222, D-Q FFs 216-6 to -11, MUXs 218-2/3 and memory array section 224. Clock generating circuit 222 can adjust a master clock signal QDR_K to generate an internal timing clock CLK_K. In the particular embodiment shown, clock generating circuit 222 can be a delayed lock loop (DLL) circuit. However, alternate embodiments can include phase locked loop (PLL) and similar circuits. Further, such a circuit can generate various other clock signals (e.g., QDR_CQ).
FFs 216-6/7 can receive write data (QDR-D) at a double data rate, and forward such write data to memory array section 224 according to timing signal CLK_K. According to address and write enable signals (e.g., QDR_ADD, QDR_W_N), such data can be written into memory locations of memory array section 224.
FFs 216-8/9 and MUX 218-2 can generate a read data clock QDR_CQ for controller device 200 based on an internal clock CLK_K.
In response to address and read command data (QDR_ADD, QDR_R_N), FFs 216-10/11 and MUX 218-3 can receive read data from memory array section 224, and output such data as DDR read data (QDR_Q) for controller device 200.
Memory array section 224 can include memory cell arrays, address decoders, control circuits, etc. to enable access to storage locations. In some embodiments, memory array section 224 can include high reliability memory cells.
Referring now to
Referring still to
As understood from
It is understood that a 2-word burst operation can be similar to the 4-word burst operation shown, except that an address bus can also operate at a double data rate, with read and write addresses being presented on different edges of the same clock cycle.
Referring back to
As noted above, in some embodiments, a state machine 426 can ensure that read/write operations are performed concurrently for maximum bandwidth.
Upon predetermined conditions (e.g., power-on or reset) 428-0 a state machine can issue dummy read and write commands for a predetermined number of cycles 428-1/2. Dummy read and write commands can continue to be issued (428-2) until a read or write command is active. Upon receiving an active read command (0.1), state machine 426 can proceed to a read state 428-3, and generate output signals to a memory device to execute a read operation. Upon receiving an active write command (1.0), state machine 426 can proceed to a write state 428-4, and generate output signals to a memory device to execute a write operation. From read or write states (428-3/4), state machine 426 can proceed between dummy, read and write states according to received commands, or the absence of such commands.
Upon predetermined conditions (e.g., power-on or reset) 528-0 a state machine can issue dummy read and write commands 528-2 until a predetermined number of cycles has passed (N from 528-1). After the predetermined number of cycles has passed (Y from 528-1), a state machine 526 can check if operations are idle (i.e., no read or write commands received at a controller interface).
If operations are idle (Y from 528-5), a state machine 526 can execute a dummy operation opposite to that previous executed (528-6, 528-7, 528-8).
If operations are not idle (N from 528-5), a state machine 526 can execute a read operation (528-3), if the previous operation was a write operation (Y from 530-0), or queue the read operation (530-1) if the previous operation was not a write operation (N from 530-0). Similarly, a state machine 526 can execute a write operation (528-4), if the previous operation was a read operation (Y from 530-2), or queue the write operation (530-3) if the previous operation was not a read operation (N from 530-2).
In a particular embodiment, an active signal at a RESET input can bring a state machine (e.g., 426/526) to the dummy R/W state (428-1/2, 528-2) by resetting all the registers.
Address register 632 can capture addresses issued from a controller device (on QDR_ADD) at an SDR rate or DDR rate with respect to QDR_K. Write data (on QDR_D) can be received at a DDR rate with respect to QDR_K. Read data can be output on QDR_Q at a DDR rate with respect to QDR_K.
In one very particular embodiment, a memory device 608 can be a radiation hardened QDRII+® SRAM memory manufactured by Cypress Semiconductor Corporation of San Jose, Calif.
While
A QDR memory device 708′ can be one like that shown in
An important EDAC parameter can be the Minimum Hamming Distance (MD). MD determines the random error detecting and random error correcting capabilities of EDAC. The greater the distance, the less likely an error will be made in the decoding process. In some embodiments, a Hamming distance of at least 4 is required for single error correction and double error detection.
While
A controller device 900 can include a first buffer memory 948-0, a second buffer memory 948-1, a FIFO controller 950, a QDR memory controller 952, and a physical layer section 954.
A physical layer section 954 can transmit and receive signals from a QDR type memory device (not shown). A physical layer section 954 can write data to the memory device, read data from the memory device, provide control signals to operate the memory device, and transfer read and write data clocks from a clock domain of the memory device to the clock domain of the controller device 900.
In the particular embodiment shown, physical layer section 954 can include clock generating circuits 922-0/1, FFs 916-0 to -5, and MUXs 918-0/1. FFs (916-0 to -5) can ensure that data can be sent to, and received from, a memory device on both edges of a clock (QDR_K for write data, QDR_CQ for read data). Clock generating circuits (922-0/1) which can be PLLs or DLLs, can center-align write data to a write data clock (QDR_K) and align a read data clock (QDR_CQ) to read data, to ensure an optimum data valid window capture.
A QDR memory controller 952 can provide an interface between a FIFO controller 950 and physical layer 954. One main function of QDR memory controller 952 can be to ensure that data and timing are aligned according to the specification of the corresponding memory device(s). In particular, QDR memory controller 952 can receive read and write requests from controller interface 902, and translate them into QDR memory device access signals, including DDR data rates. A QDR memory controller 952 can also include EDAC circuits, as described herein or equivalents, to perform error detection and/or correction one read or write data transferred through the QDR memory controller 952. In one very particular embodiment, a QDR memory controller 952 can provide single error correction and double error detection (SECDED).
A QDR memory controller 952 can also implement synchronization and training sequences to optimize signal transfer conditions. Other functions can include generating phased clocks, and data path sequencing.
A FIFO controller 950 can implement FIFO functionality for the controller device 900. A FIFO controller 950 can include a controller interface 902 for synchronous read and write operations.
In the embodiment shown, a FIFO controller 950 can operate in conjunction with first buffer memory 948-0, which can operate as a write buffer, and a second buffer memory 948-1, which can operate as a read buffer RAM. According to FIFO controller 950, data flow can be automatic and controlled by read and write counters in conjunction with a full flag (full) and an empty flag (empty). In the embodiment shown, FIFO controller 950 can also provide an almost full flag (almost full) and an almost empty flag (almost_empty) for early warnings to a controlling device.
To implement separate FIFO read and write ports, a controller device 900 includes the write and read buffer RAMs 948-0/1. In a write buffer RAM 948-0 operation, as soon as write data is available, a write command (W_EN) can be issued to the QDR memory controller 952, with a write address and write data from the write buffer RAM 948-0. Value “port_w_addr”, which is an address pointer, can be incremented with each write cycle (i.e., FIFO write), and the corresponding pointer “qdr_wb_addr” is used to read data from write buffer RAM 948-0 to the QDR memory controller 952, which subsequently writes it to the memory device (not shown) via QDR_D, QDR_ADD, QDR_W_N.
To reduce latency in a FIFO read operation, FIFO controller 950 can maintain a copy of the data in the write buffer RAM 948-0 in the read buffer RAM 948-1. As long as a read buffer RAM 948-1 has storage space, data written into the write buffer RAM 948-0 can be mirrored into the read buffer RAM 948-1. Once the read buffer RAM 948-1 gets full, every following read command (POP) will result in the FIFO controller initiating a read command to the QDR memory controller 952 to readout data from the QDR memory device. A value “port_r_addr” is an address pointer that is incremented on each read cycle and the corresponding address “qdr_rb_addr” is used to write data from the QDR memory device to the read buffer RAM 948-1. The values “port_r_addr” and “qdr_rb_addr” can work in a round robin fashion.
In one very particular embodiment, a controller device 900 can be implemented on a Virtex-5QV FPGA manufactured by Xilinx of San Jose, Calif., by configuring the device with configuration data. Components of a physical layer section 954 can be built into the FPGA architecture.
In
Referring to
In the absence of a RESET state, state machine 1126-A can check for a read clock transition 1156-4 or a write clock transition 1158-0. If no read clock transition occurs (N from 1156-4) or no write clock transition occurs (N from 1158-0), a state machine can return to an idle state 1156-2.
If a read clock transition occurs (Y from 1156-4), a state machine can check to see if a read pointer is the same as a write pointer (1156-5). If such a state exists (Y from 1156-5), a FIFO device state can be considered empty (1156-6), and an empty flag can be asserted (1156-7). If a read pointer is not the same as a write pointer (N from 1156-5), a state machine can check to see of a read enable signal is asserted (1156-8), indicating a read operation. If a read enable is not asserted (N from 1156-8), a device can return to an idle state (1156-2). If a read enable is asserted (Y from 1156-8), a FIFO state can be set to “POP” (1156-9), which can initiate a read operation using the read pointer value. A read pointer can be incremented (1156-10), and a state machine can return to an idle state (1156-2).
If a write clock transition occurs (Y from 1158-0), a state machine can check to see if a difference between a read pointer and a write pointer has reached a maximum value (1158-1). If such a state exists (Y from 1158-1), a FIFO device state can be considered full (1158-2), and a full flag can be asserted (1158-4). If a maximum difference between a read pointer and write pointer has not been reached (N from 1158-1), a state machine can check to see of a write enable signal is asserted (1158-4), indicating a write operation. If a write enable is not asserted (N from 1158-4), a device can return to an idle state (1156-2). If a write enable is asserted (Y from 1158-4), a FIFO state can be set to “PUSH” (1158-5) which can initiate a wrote operation using the write pointer value. A write pointer can be incremented (1158-6), and a state machine can return to an idle state (1156-2).
Referring to
In the absence of a RESET state, state machine 1126-B can check for read/write clock transitions as in the case of
If a read clock transition occurs (Y from 1156-4), a state machine can enter a read state 1160-3. A read address can then be incremented 1160-4, to point to a next read location. A state machine 1126-B can then check to see if the read block RAM is full 1160-5. If the read block RAM is not full (N from 1160-5), a state machine can return to an idle state.
If the read block RAM is full (N from 1160-5), a state machine can determine if a two or four word burst operation is taking place (1160-6/9). A read operation can be made to a QDR memory device corresponding to the burst (1160-7/10), and the read address for the write block RAM can be incremented accordingly (1160-8/11).
If a write transition occurs (Y from 1158-0), a state machine can enter a write state 1162-0. A write address can then be incremented 1162-1, to point to a write read location.
A state machine can determine if a two or four word burst operation is taking place (1162-0/1164-0). A write operation can be made to a QDR memory device by reading an appropriate amount of data from the write block RAM (1162-4/5/6, 1164-1/2/3).
A state machine can then check to see if a read block RAM full flag is set (1162-4, 1164-4). If the flag is not set (N from 1162-4, 1164-4), write data is not replicated in the read block RAM and a state machine can return to the idle state 1156-3.
If the read block RAM full flag is not set (Y from 1162-4, 1164-4), a state machine can determine if a write operation will result in the read block RAM being full (1162-9/1164-5). If the read block RAM will be full (Y from 1162-9/1164-5), a state machine can enter a no read mirror state (1164-8), in which data in a write block RAM will no longer be replicated in a read block RAM. A read block RAM full flag can also be set 1164-9.
If there is room in a read block RAM (N from 1162-8, 1164-5), a state machine can write the incoming write data to a QDR (1162-9/1164-6), and a write read address for the read block RAM can be incremented accordingly (1162-10/1164-7).
A controller device like that of
Having described a controller device according to one embodiment in
A read enable signal (FIFO_R_EN_N) can be asserted prior to time t1, to indicate read operations. Starting at time t1, on consecutive rising transitions of RCLK, read accesses can be initiated. In the particular embodiment shown, a read latency can be two cycles, thus read data (Q0, Q1, Q2, Q3, Q4) can start to be output at time t2.
At about time t0, write operations can write data to fourth-to-last (D LAST-3) and third-to-last available locations (D LAST-2). In response, at time t1, an almost full flag (FIFO_AFULL_N) can be asserted low.
It is assumed that no read operations occur between times t0 and t2.
At about time t2, write operations can write data to second-to-last (D LAST-1) and last available locations (D LAST), filling the FIFO. In response, at time t3, a full flag (FIFO_FULL_N) can be asserted low.
At about time t0, a read operation can read two data values (Q0, Q1). Such data values can be valid at time t2. Further, the read operation frees two storage locations, thus the FIFO is no longer full. Consequently, the full flag (FIFO_FULL_N) can be de-asserted high at time t3.
It is assumed that no write operations occur between times t0 and t1.
At about time t1, a second read operation can read two more data values (Q2, Q3). Such data values can be valid at time t4. Further, the read operation frees two storage locations, thus four FIFO locations can be available. Consequently, the almost full flag (FIFO_AFULL_N) can be de-asserted high at time t5.
In
At about time t0 (cycle 0), a write operation can write data two data values (D0, D1) into the empty FIFO. In the embodiment shown, a latency for an almost full flag can be 14 cycles. Thus, at time t2 (cycle 14), an empty flag (FIFO_EMPTY_N) can be de-asserted high.
It is assumed that no other read or write operations occur between times t0 and t3.
At about time t3 (cycle 20), another write operation can write two more data values (D2, D3) into the FIFO. Consequently, at time t4 (cycle 34), an almost empty flag (FIFO_AEMPTY_N) can be de-asserted high.
At about time t0, read operations can start with read clock RCLK transitioning high, while a read enable (FIFO_R_EN_N) is asserted low. Such an operation reads out the 10th/9th data values (Q LAST-9, Q LAST-8). On each subsequent rising transition of RCLK (t1, t2, t3, t4), two more data values are read out.
Read data are output after time t2, with a read valid signal (FIFO_QR_VALID) being asserted low.
Referring still to
It is noted that following the read operation at time t4, RCLK continues to transition high two more times, while a read enable (FIFO_R_EN_N) is asserted, indicating two more read operations. However, because the FIFO is empty, such read operations are invalid.
Another alternate embodiment can include a controller device to enable multi-port memory operations with QDR type memory devices, as described herein, or equivalents.
A controller device 1300 can include buffer write memories 1348-0/1, buffer read memories 1348-2/3, write arbitration logic 1366, read arbitration logic 1368, a QDR memory controller 1352, and a physical layer section 1354.
A physical layer section 1354 and QDR memory controller 1352 can operate like those shown in
Buffer memories 1348-0 to -3 and arbitration logic 1366/1368 can implement dual port functionality. Controller interface 1302 can employ synchronous read and write operations. As shown in
It is noted that arbitration logic (1366/1368) can depart from conventional dual port collision hardware, where both ports of a RAM can be accessed at same location at the same time (such as
Having described a controller device according to one embodiment in
Embodiments of the invention can enable the use of high reliability QDR type memory device to be used in various high reliability applications, such as space applications. In particular embodiments, controller devices can enable a radiation hardened QDRII+® SRAM memory manufactured by Cypress Semiconductor Corporation of San Jose, Calif., to be implemented with numerous system interfaces, including but not limited to: SDR interfaces, FIFO interfaces and multi-port interfaces. This can enable higher density and/or higher memory performance than conventional approaches. Such an implementation may provide for any of: operating frequencies as high 250 MHz, two cycle latency reads, 1 cycle latency writes, burst access operations (e.g., two word, four word), HSTL-15 compliant I/Os, or wide I/Os (e.g., x18, x36).
Controller devices as described herein, or equivalents, can enable one QDR memory device, which has been qualified for a high reliability environment, to be used as any of various memory types (e.g., SDR, FIFO, dual port).
It should be appreciated that in the foregoing description of exemplary embodiments, various features are sometimes grouped together in a single embodiment, figure, or description thereof for the purpose of streamlining the disclosure aiding in the understanding of one or more of the various inventive aspects. This method of disclosure, however, is not to be interpreted as reflecting an intention that the invention requires more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive aspects lie in less than all features of a single foregoing disclosed embodiment. Thus, the claims following the detailed description are hereby expressly incorporated into this detailed description, with each claim standing on its own as a separate embodiment of this invention.
It is also understood that the embodiments of the invention may be practiced in the absence of an element and/or step not specifically disclosed. That is, an inventive feature of the invention may be elimination of an element.
Accordingly, while the various aspects of the particular embodiments set forth herein have been described in detail, the present invention could be subject to various changes, substitutions, and alterations without departing from the spirit and scope of the invention.