Memory device supporting rank-level parallelism and memory system including the same

11113211 · 2021-09-07

Assignee

Inventors

Cpc classification

International classification

Abstract

A memory system may include: a memory controller; a plurality of ranks; and a rank shared bus configured to couple the memory controller and the plurality of ranks. Each of the plurality of ranks may include: a plurality of banks; a rank bus coupled to the plurality of banks and configured to selectively transmit data to the rank shared bus or an intermediate buffer and selectively receive data from the rank shared bus or the intermediate buffer; and an intermediate buffer configured to be selectively coupled to the rank bus or the rank shared bus, according to a first signal from the memory controller.

Claims

1. A memory system comprising one or more of memory modules coupled to a memory controller through a channel, each of the one or more of memory modules comprising a plurality of ranks, each of the plurality of ranks comprising a plurality of memory devices, wherein each of the plurality of memory devices comprises: a cell region; a row control circuit configured to control a row operation of the cell region; a column control circuit configured to control a column operation of the cell region; a command decoder configured to process a command provided from the memory controller and to control the row control circuit and the column control circuit; a data transceiver configured to transmit/receive data to/from the channel according to control of the command decoder; and an intermediate buffer configured to communicate with the column control circuit or the data transceiver according to a first plurality of control signals from the command decoder, wherein the memory device further comprises a path setting circuit including a first selector and a second selector, the first selector configured to couple the column control circuit to the data transceiver or the intermediate buffer, the second selector configured to couple the data transceiver to the column control circuit or the intermediate buffer, so that the path setting circuit sets a first data transmission path between the column control circuit and the intermediate buffer, a second data transmission path between the data transceiver and the intermediate buffer, or a third data transmission path between the column control circuit and the data transceiver, according to a second plurality of control signals from the command decoder.

2. The memory system of claim 1, wherein the plurality of ranks includes a first rank, the first rank including a first plurality of memory devices, the first plurality of memory devices respectively including a first plurality of command decoders, a first plurality of path setting circuits, a first plurality of intermediate buffers, a first plurality of column control circuits, and a first plurality of data transceivers, wherein when the memory controller provides a rank-level command to the first rank, each of the first plurality of command decoders causes a corresponding one of the first plurality of path setting circuits and a corresponding one of the first plurality of intermediate buffers to transmit data between a corresponding one of the first plurality of column control circuits and the corresponding one of the first plurality of intermediate buffers, and when the memory controller provides a channel-level command to the first rank, each of the first plurality of command decoders causes the corresponding one of the first plurality of path setting circuits and the corresponding one of the first plurality of intermediate buffers to transmit data between a corresponding one of the first plurality of data transceivers and the corresponding one of the first plurality of intermediate buffers.

3. The memory system of claim 2, wherein the plurality of ranks further includes a second rank, the rank-level command is a first rank-level command, and the channel-level command is a first channel-level command, and wherein when the memory controller provides the first rank-level command to the first rank, the memory controller provides a second rank-level command or a second channel-level command to the second rank.

Description

BRIEF DESCRIPTION OF THE DRAWINGS

(1) FIG. 1 is a block diagram of a conventional memory system.

(2) FIG. 2 is a block diagram of a memory system according to an embodiment.

(3) FIG. 3 is a block diagram illustrating an intermediate buffer of FIG. 2, according to an embodiment.

(4) FIG. 4 is a block diagram illustrating a path setting unit of FIG. 2, according to an embodiment.

(5) FIG. 5 illustrates an intermediate buffer management table according to an embodiment.

(6) FIG. 6 is a diagram illustrating a memory system according to the embodiment.

(7) FIG. 7 is a plan view illustrating a surface of a memory module of FIG. 6, according to an embodiment.

(8) FIG. 8 is a block diagram illustrating a memory device of FIG. 7, according to an embodiment.

(9) FIG. 9 illustrates percentage changes in a number of instructions processed per cycle (IPC) according to an embodiment.

(10) FIG. 10 illustrates percentage changes in reduction rates of read latency, according to an embodiment.

(11) FIG. 11 illustrates percentage changes in channel utilization, according to an embodiment.

(12) FIG. 12 illustrates percentage changes in active operation reduction rates according to an embodiment.

DETAILED DESCRIPTION

(13) Hereafter, various embodiments will be described in detail with reference to the accompanying drawings.

(14) FIG. 2 is a block diagram of a memory system 2 according to an embodiment.

(15) The memory system 2 includes a plurality of ranks 100 to 400 and a memory controller 600 coupled to the plurality of ranks 100 to 400 through a rank shared bus 500.

(16) The rank shared bus 500 may be referred to as a channel.

(17) In FIG. 2, the memory system 2 includes four ranks, that is, a first rank 100, a second rank 200, a third rank 300, and a fourth rank 400. However, the number of ranks included in the memory system 2 is not limited thereto, and the number of ranks may vary according to embodiments.

(18) The first rank 100 includes a plurality of banks 101 to 108, which are first to eighth banks 101 to 108. The plurality of banks 101 to 108 share a first rank bus 131.

(19) The first rank 100 further includes a second rank bus 132 coupled to the rank shared bus 500.

(20) The first rank 100 further includes a first intermediate buffer 110, a first path setting unit (or a first path setting circuit) 120, and a third rank bus 133. The first intermediate buffer 110 and the first path setting unit 120 are coupled to each other through the third rank bus 133.

(21) The path setting unit 120 sets a signal transmission path. For example, the path setting unit 120 may set a first path between the first rank bus 131 and the intermediate buffer 110, set a second path between the second rank bus 132 and the intermediate buffer 110, or set a third path between the first rank bus 131 and the second rank bus 132.

(22) In an embodiment, a path setting operation of the path setting unit 120 may be controlled according to a command provided from the memory controller 600.

(23) The intermediate buffer 110 may transmit signals to the first rank bus 131 and receive signals from the first rank bus 131 through the first path. The intermediate buffer 110 may transmit signals to the second rank bus 132 and receive signals from the second rank bus 132 through the second path.

(24) The second rank 200 includes a plurality of banks 201 to 208, which are first to eighth banks 201 to 208. The plurality of banks 201 to 208 share a first rank bus 231.

(25) The second rank 200 further includes the first rank bus 231, a second rank bus 232, a third rank bus 233, a second intermediate buffer 210, and a second path setting unit 220. Operations of the respective components of the second rank 200 are performed in the same manner as those of the corresponding components of the first rank 100, and thus descriptions of the operations will be omitted for the interest of brevity.

(26) The third rank 300 includes a plurality of banks 301 to 308, a first rank bus 331, a second rank bus 332, a third rank bus 333, a third intermediate buffer 310, and a third path setting unit 320. Operations of the respective components of the third rank 300 are performed in the same manner as those of the corresponding components of the first rank 100, and thus descriptions of the operations will be omitted for the interest of brevity.

(27) The fourth rank 400 includes a plurality of banks 401 to 408, a first rank bus 431, a second rank bus 432, a third rank bus 433, a fourth intermediate buffer 410, and a fourth path setting unit 420. Operations of the respective components of the fourth rank 400 are performed in the same manner as those of the corresponding components of the first rank 100, and thus descriptions of the operations will be omitted for the interest of brevity.

(28) In an embodiment, the memory controller 600 can provide active, precharge, read, and write commands in the same manner as a memory controller of a conventional memory device does.

(29) The memory controller 600 may provide an additional command in order to exploit rank-level parallelism. In an embodiment, such an additional command includes one or more of a rank-level read command, a rank-level write command, a channel-level read command, and a channel-level write command.

(30) For example, the rank-level read command is a command for reading data from one of the banks 101 to 108 and storing the read data in the first intermediate buffer 110, and the rank-level write command is a command for writing data stored in the first intermediate buffer 110 to one of the banks 101 to 108. Hereinafter, the rank-level read command and the rank-level write command may be referred to as rank-level commands.

(31) For example, the channel-level read command is a command for outputting data read from the first intermediate buffer 110 to the rank shared bus 500, and the channel-level write command is a command for storing data transmitted through the rank shared bus 500 in the first intermediate buffer 110. Hereinafter, the channel-level read command and the channel-level write command may be referred to as channel-level commands.

(32) In the memory system 2, while any one of the ranks 100 to 400 uses the rank shared bus 500, another one of the ranks 100 to 400 can perform an operation relating to a rank-level command using a corresponding one of the intermediate buffers 110, 210, 310, and 410.

(33) For example, while a channel-level read operation or a channel-level write operation is performed on any one of the ranks 100 to 400, a rank-level read operation or a rank-level write operation may be performed on another one of the ranks 100 to 400.

(34) Furthermore, while a rank-level read operation or a rank-level write operation is performed in any one of the ranks 100 to 400, a rank-level read operation or a rank-level write operation may be performed in another one of the ranks 100 to 400.

(35) In a memory system (e.g., the memory system 2 of FIG. 2) according to an embodiment of the present disclosure, since each rank includes an intermediate buffer, a plurality of read/write operations on respective ranks may be performed partially at the same time. Thus, the performance of the memory system according to the embodiment can be improved while power consumption to perform the read/write operations is reduced, compared to a conventional memory system (e.g., the memory system 1 of FIG. 1), which performs the read/write operations sequentially.

(36) In a conventional memory system, a command address (CA) bus through which a general read command or a general write command is transmitted is used less frequently than a data bus. Therefore, although such a CA bus of the conventional memory system is used in a memory system according to an embodiment in order to transfer the rank-level commands and the channel-level commands, a bus competition is unlikely to occur in the memory system according to the embodiment. Thus, the CA bus of the conventional memory system can be used in the memory system according to the embodiment.

(37) FIG. 3 is a block diagram illustrating the first intermediate buffer 110 of FIG. 2 according to an embodiment.

(38) The first intermediate buffer 110 is used when a rank-level command or a channel-level command is executed, and is not used when a general read command or a general write command is executed. That is, when the general real command or the general write command is executed, the memory system 2 performs a read or write operation without using the first intermediate buffer 110 as the conventional memory system does.

(39) Referring back to FIG. 2, the memory controller 600 may determine whether to provide the general read/write command or whether to provide the channel-level command or the rank-level command, when providing a new column command to at least one of the ranks 100 to 400.

(40) The first path setting unit 120 may set a data path coupling a pair of rank buses among the first to third rank buses 131 to 133, according to a type of a command (e.g., the channel-level command or the rank-level command).

(41) The first intermediate buffer 110 may include two or more entries (or entry circuits), and each of the entries may store read or write data based on a rank-level command (e.g., a rank-level read command) or a channel-level command (e.g., a channel-level write command). In an embodiment, each of the entries is a storage circuit having a size sufficiently large to store the read or write data.

(42) Referring to FIG. 3, the first intermediate buffer 110 includes first to fourth entries 111 to 114 and an entry decoder 115 for selecting any one of the first to fourth entries 111 to 114. However, the number of entries of the first intermediate buffer 110 is not limited thereto, and the number of entries may vary according to embodiments.

(43) When the entry decoder 115 is turned on, the entry decoder 115 couples any one of the first to fourth entries 111 to 114 to the third rank bus 133 according to an entry signal ENTRY. In an embodiment, the entry signal ENTRY has a value indicative of the coupled one of the entries 111 to 114 to the third rank bus 133.

(44) The entry decoder 115 is turned off to isolate all of the entries 111 to 114 from the third rank bus 133. The entry decoder 115 is turned on or off according to an on/off signal ON/OFF.

(45) A value of the on/off signal ON/OFF may be determined depending on whether a general command (e.g., a general read command or a general write command) is executed or whether a rank-level command or a channel-level command is executed. In an embodiment, a command decoder (e.g., a command decoder 1141 of FIG. 8) determines the value of the on/off signal ON/OFF and outputs the on/off signal ON/OFF to the entry decoder 115. In an embodiment, a memory controller (e.g., the memory controller 600 of FIG. 2) provides the entry signal ENTRY.

(46) Any one of the first to fourth entries 111 to 114 stores data transmitted through the third rank bus 133 or outputs data stored therein to the third rank bus 133, according to a read/write signal R/W.

(47) The read/write signal R/W may be controlled according to whether a command is the rank-level command or the channel-level command. In an embodiment, a command decoder (e.g., the command decoder 1141 of FIG. 8) generates the read/write signal R/W according to whether the command is the rank-level command or the channel-level command. For example, when a rank-level read operation or a channel-level write operation is performed, the read/write signal R/W and the entry signal ENTRY control a corresponding one of the entries 111 to 114 to store data transmitted through the third rank bus 133. When a rank-level write operation or a channel-level read operation is performed, the read/write signal R/W and the entry signal ENTRY control a corresponding one of the entries 111 to 114 to output stored data to the third rank bus 133.

(48) When the first intermediate buffer 110 includes the plurality of entries 111 to 114, as illustrated in FIG. 3, the memory controller 600 additionally provides a signal indicative of an entry number while providing the rank-level command.

(49) In general, a row address uses a larger number of address bits than a column address. Thus, when a column operation is performed, some address bits may remain unused. The memory controller 600 may provide a signal indicative of the entry number using such unused bits. The entry signal ENTRY may be the same as the entry number or may be different from the entry number. The entry number may be decoded to the entry signal ENTRY at the command decoder 1141 of FIG. 8.

(50) In an embodiment, the memory controller 600 may output a signal indicative of an entry number when providing a channel-level command. When the channel-level command is executed, the memory controller 600 does not access any bank in a rank. Thus, the memory controller 600 may not provide a bank address and a column address, and the signal indicative of the entry number is distinct from a signal indicative of the bank and column addresses.

(51) The memory controller 600 includes an intermediate buffer management table in order to determine whether entries of an intermediate buffer (e.g., the intermediate buffer 110, 210, 310, or 410 of FIG. 2) included in each rank (e.g., the rank 100, 200, 300, or 400 of FIG. 2) are available.

(52) FIG. 5 illustrates an intermediate buffer management table 610 according to an embodiment.

(53) In the intermediate buffer management table 610, an entry storing meaningful data is indicated by the reference character “O,” and an entry storing non-meaningful data is indicated by the reference character “A.” For example, the meaningful data corresponds to data that have been read from a bank or that are to be written into the bank, and the non-meaningful data corresponds to data other than the meaningful data. Because a plurality of ranks Rank 0 to Rank 3 respectively include a plurality of intermediate buffers, each of which includes four entry circuits Entry 0 to Entry 3, the intermediate buffer management table 610 includes information on usage statuses of the plurality of intermediate buffers.

(54) For an entry storing meaningful data, the memory controller 600 may provide a command for reading the data stored in the entry. For example, the command includes the rank-level write command or the channel-level read command.

(55) For an entry storing non-meaningful data, the memory controller 600 may provide a command for writing data to the entry. For example, the command includes the rank-level read command or the channel-level write command.

(56) FIG. 4 is a block diagram illustrating the first path setting unit 120 of FIG. 2 according to an embodiment.

(57) The path setting unit 120 includes a first selector 121, a second selector 122, a first internal bus 123, and a second internal bus 124.

(58) The first selector 121 couples the first rank bus 131 to the first internal bus 123 or the second internal bus 124 according to a first select signal SEL1.

(59) The second selector 122 couples the second rank bus 132 to the first internal bus 123 or the second internal bus 124 according to a second select signal SEL2.

(60) The second internal bus 124 is coupled to the first intermediate buffer 110 through the third rank bus 133.

(61) For example, when a general read or write command is executed, both of the first and second select signals SEL1 and SEL2 are set to a first logic value (e.g., a logic low value 0), such that the first and second rank buses 131 and 132 are coupled to each other via the first internal bus 123.

(62) When a rank-level command is executed, the first select signal SEL1 is set to a second logic value (e.g., a logic high value 1), and the second select signal SEL2 is set to the logic low value 0. Thus, the first and third rank buses 131 and 133 are coupled to each other via the second internal bus 124, and the second rank bus 132 is isolated from the first and third rank buses 131 and 133.

(63) When a channel-level command is executed, the first select signal SEL1 is set to the logic low value 0, and the second select signal SEL2 is set to the logic high value 1. Thus, the second and third rank buses 132 and 133 are coupled to each other via the second internal bus 124, and the first rank bus 131 is isolated from the second and third rank buses 132 and 133.

(64) Referring back to FIG. 2, the first plurality of banks 101 to 108, the first intermediate buffer 110, and the first path setting unit 120, which are included in the first rank 100 are described from a logical point of view.

(65) Physically, a plurality of memory devices (for example, a plurality of DRAM chips) may constitute one rank.

(66) Hereinafter, a memory system according to an embodiment that includes a plurality of ranks will be described with reference to FIGS. 6-8. In such an embodiment, each of the plurality of ranks (e.g., first to fourth ranks 100 to 400 of FIG. 6) includes a plurality of memory devices (e.g., first to eighth memory devices 1100 to 1800 of FIG. 7). Each of the memory devices (e.g., the first memory device 1100) includes a plurality of banks (e.g., first to eighth banks 1101 to 1108 of FIG. 8), a path setting unit (a path setting unit 1120 of FIG. 8), and an intermediate buffer (e.g., an intermediate buffer 1110 of FIG. 8).

(67) For example, the first banks (e.g., the first bank 1101 of FIG. 8) included in the respective memory devices (e.g., the first to eighth memory devices 1100 to 1800 of FIG. 7) collectively function as the first bank 101 in the first rank 100 of FIG. 2, the intermediate buffers (e.g., the intermediate buffer 1110 of FIG. 8) included in the respective memory devices (e.g., the first to eighth memory devices 1100 to 1800 of FIG. 7) collectively function as the first intermediate buffer 110 in the first rank 100 of FIG. 2, and path setting units (e.g., the path setting unit 1120 of FIG. 8) included in the respective memory devices (e.g., the first to eighth memory devices 1100 to 1800 of FIG. 7) collectively function as the first path setting unit 120 in the first rank 100 of FIG. 2.

(68) For example, suppose that each of the memory devices has a data width of 64 bits and eight memory devices constitute one rank.

(69) Assuming that each of the memory devices includes eight banks, a single intermediate buffer, and a single path setting unit, each of the banks processes data on a basis of eight bits, the intermediate buffer and the path setting unit process data on a basis of 64 bits. The rank including the eight memory devices processes data on a basis of 64 bytes.

(70) FIG. 6 is a diagram illustrating a memory system 3 according to an embodiment.

(71) The memory system 3 includes a central processing unit (CPU) 700 and a memory controller 600, which are attached to a printed circuit board (PCB) 800.

(72) Although the memory controller 600 is separate from the CPU 700 in the embodiment shown in FIG. 6, embodiments of the present disclosure are not limited thereto. In an embodiment, the memory controller 600 may be included in the CPU 700.

(73) The memory controller 600 is coupled to a rank shared bus (or a rank shared channel) 500 disposed on the PCB 800.

(74) The rank shared bus 500 has first and second sockets 501 and 502 where first and second memory modules 1000 and 2000 are mounted, respectively. For example, each of the first and second memory modules 1000 and 2000 includes a Single In-line Memory Module (SIMM), a Dual In-line Memory Module (DIMM), or the like.

(75) Memory devices mounted on a first surface of the first memory module 1000 constitute a first rank 100, and memory devices mounted on a second surface of the first memory module 1000 constitute a second rank 200.

(76) Memory devices mounted on a first surface of the second memory module 2000 constitute a third rank 300, and memory devices mounted on a second surface of the second memory module 2000 constitute a fourth rank 400.

(77) FIG. 7 is a plan view illustrating the first surface of the first memory module 1000 of FIG. 6, according to an embodiment.

(78) The first memory module 1000 includes eight memory devices 1100 to 1800 disposed on the first surface.

(79) In the embodiment shown in FIG. 7, each of the memory devices 1100 to 1800 is a DRAM. However, embodiments of the present disclosure are not limited thereto, and different types of memory devices may be used as the memory devices 1100 to 1800.

(80) The memory system 3 and the first and second memory modules 1000 and 2000, which are illustrated in FIGS. 6 and 7, may have substantially the same interface as a conventional memory system and memory modules of the conventional memory system, respectively.

(81) In the embodiment shown in FIG. 7, each of the memory devices 1100 to 1800 includes an intermediate buffer and a path setting unit, which will be described with reference to FIG. 8.

(82) Each of the memory devices 1100 to 1800 may further includes a command decoder that performs a decoding operation, in order to process a command which is additionally provided from the memory controller 600. However, the interface of the memory devices 1100 to 1800 with an external command/address bus and a data bus may not be changed.

(83) Therefore, the exteriors of the memory system 3, the memory module, and the memory device according to the embodiment may be similar to those of the conventional memory system, the conventional memory module, and the conventional memory device, respectively.

(84) This indicates that the memory devices 1100 to 1800 according to the embodiment shown in FIG. 7 can use the same interface as the conventional memory devices in the conventional memory system, resulting in beneficial aspects in terms of compatibility with the conventional memory devices.

(85) FIG. 8 is a block diagram illustrating the first memory device 1100 of FIG. 7 according to an embodiment.

(86) The first memory device 1100 includes a cell region 1109, a row control circuit 1142 for controlling a row operation of the cell region 1109, and a column control circuit 1143 for controlling a column operation of the cell region 1109. The cell region 1109 includes a plurality of banks 1101 to 1108.

(87) The first memory device 1100 further includes the command decoder 1141 that controls the row control circuit 1142 and the column control circuit 1143 using a received command and a received address.

(88) The first memory device 1100 further includes a data transmitter/receiver (or a data transceiver) 1144 that inputs/outputs data according to control of the command decoder 1141.

(89) The first memory device 1100 further includes an intermediate buffer 1110 and a path setting unit (or a path setting circuit) 1120.

(90) The first memory device 1100 includes a first data bus 1131 coupled between the column control circuit 1143 and the path setting unit 1120, a second data bus 1132 coupled between the path setting unit 1120 and the data transmitter/receiver 1144, and a third data bus 1133 coupled between the path setting unit 1120 and the intermediate buffer 1110.

(91) The command decoder 1141 may additionally process a rank-level command and a channel-level command which are provided from the memory controller 600 of FIG. 6.

(92) The command decoder 1141 additionally controls the intermediate buffer 1110 and the path setting unit 1120.

(93) For example, the command decoder 1141 may provide a first plurality of signals (e.g., the read/write signal R/W, the on/off signal ON/OFF and the entry signal ENTRY of FIG. 3) to control the intermediate buffer 1110, and may provide a second plurality of signals (e.g., the first and second select signals SEL1 and SEL2 of FIG. 4) to control the path setting unit 1120, by decoding a command and an address provided from the memory controller 600.

(94) In an embodiment, a rank (e.g., the first rank 100 of FIG. 7) includes a plurality of memory devices (e.g., the first memory device 1100 of FIG. 8), which respectively includes a plurality of command decoders (e.g., the command decoder 1141), a plurality of path setting circuits (e.g., the path setting circuit 1120), a plurality of column control circuits (e.g., the column control circuit 1143), a plurality of intermediate buffers (e.g., the intermediate buffer 1110), and a plurality of data transceivers (e.g., the data transceiver 1144). In this embodiment, when the memory controller 600 provides a rank-level command to the rank, each of the plurality of command decoders causes a corresponding one of the plurality of path setting circuits and a corresponding one of the first plurality of intermediate buffers to transmit data between a corresponding one of the plurality of column control circuits and the corresponding one of the first plurality of intermediate buffers. When the memory controller provides a channel-level command to the rank, each of the plurality of command decoders causes the corresponding one of the plurality of path setting circuits and the corresponding one of the plurality of intermediate buffers to transmit data between a corresponding one of the plurality of data transceivers and the corresponding one of the plurality of intermediate buffers.

(95) Each of the second to eighth memory devices 1200 to 1800 of FIG. 7 has substantially the same configuration as the first memory device 1100 of FIG. 8.

(96) First banks (e.g., the first bank 1101 of FIG. 8) of the first to eighth memory devices 1100 to 1800 of FIG. 7 collectively function as the first bank 101 of FIG. 2, and the second banks of the first to eighth memory devices 1100 to 1800 of FIG. 7 also collectively function as the second bank 102 of FIG. 2, and so on.

(97) Therefore, assuming that the first memory device 1100 of FIG. 8 inputs and outputs data on a basis of 64 bits, each of the first to eighth banks 1101 to 1108 in FIG. 8 may input and output 8-bit data, and each of the first to eighth banks 101 to 108 in FIG. 2 may input and output 8-byte data.

(98) Intermediate buffers (e.g., the intermediate buffer 1110 of FIG. 8) of the first to eighth memory devices 1100 to 1800 of FIG. 7 collectively function as the intermediate buffer 110 of FIG. 2. Path setting units (e.g., the path setting unit 1120 of FIG. 8) of the first to eighth memory devices 1100 to 1800 of FIG. 7 collectively function as the path setting unit 120 of FIG. 2.

(99) Therefore, assuming that each of the intermediate buffer 1110 and the path setting unit 1120 of FIG. 8 has a data width of 64 bits, the intermediate buffer 110 and the path setting unit 120 of FIG. 2 may respectively have a data width of 64 bytes.

(100) First data buses (e.g., the first data bus 1131 of FIG. 8) of the first to eighth memory devices 1100 to 1800 of FIG. 7 collectively function as the first rank bus 131 of FIG. 2. Second data buses (e.g., the second data bus 1132 of FIG. 8) of the first to eighth memory devices 1100 to 1800 of FIG. 7 collectively function as the second rank bus 132 of FIG. 2. Third data buses (e.g., the third data bus 1133 of FIG. 8) of the first to eighth memory devices 1100 to 1800 of FIG. 7 collectively function as the third rank bus 133 of FIG. 2.

(101) Therefore, assuming that each of the first to third data buses 1131 to 1133 of FIG. 8 has a data width of 64 bits, each of the first to third rank buses 131 to 132 of FIG. 2 may have a data width of 64 bytes.

(102) In FIG. 2, components corresponding to data transmitter/receivers (e.g., the data transmitter/receiver 1144 of FIG. 8) of the first to eighth memory devices 1100 to 1800 of FIG. 7 are not shown. However, in an embodiment, the data transmitter/receiver (not shown) is disposed between the second rank bus 132 and the rank shared bust 500.

(103) As described above, the intermediate buffer 110 and the path setting unit 120 of FIG. 2 are configured and operate in substantially the same manner as the intermediate buffer 1110 and the path setting unit 1120 of FIG. 8, respectively, except for a difference in data width between the intermediate buffer 110 and the intermediate buffer 1110 and a difference in data width between the path setting unit 120 and the path setting unit 1120. Thus, descriptions of the configuration and operations of the intermediate buffer 1110 and the path setting unit 1120 in FIG. 8 are omitted herein for the interest of brevity.

(104) FIGS. 9 to 12 are graphs illustrating improvements in performance of a memory system according to an embodiment, compared to performance of a conventional memory system.

(105) In each of the graphs, a horizontal axis indicates types of simulations, and a vertical axis indicates percentage values of performance improvement metrics over the conventional memory system.

(106) FIG. 9 illustrates percentage changes in a number of instructions processed per cycle (IPC), and FIG. 10 illustrates percentage changes in reduction rates of read latency.

(107) As illustrated in FIGS. 9 and 10, the performance of the memory system according to an embodiment of the present disclosure was improved in all of the simulations excluding one simulation tigr, compared to the conventional memory system.

(108) That is, in the remaining simulations for the memory system according to an embodiment, the number of IPC was increased and the read latency was reduced, compared to the conventional memory system.

(109) FIG. 11 illustrates percentage changes in channel utilization.

(110) The channel utilization indicates a ratio of a time during which data are present in a channel of a memory system over an entire operation time of the memory system.

(111) When the time during which data are present in the channel is increased, it may indicate that data are actively transmitted between a memory device and a memory controller included in the memory system, which indicates that the performance of the memory system is improved.

(112) As illustrated in FIG. 11, the channel utilization of the memory system according to an embodiment was increased in all of the simulations.

(113) FIG. 12 shows that a number of active operations in the memory system according to an embodiment was decreased, compared to the conventional memory system.

(114) When the number of active operations decreases while the same number of operations is processed, a waiting time required for performing each of the active operations can be reduced, which indicates that the performance is improved.

(115) Furthermore, performing each of the active operations consumes a large amount of power to charge a word line. Thus, the decrease in the number of active operations may indicate that the power consumption is reduced.

(116) As illustrated in FIG. 12, the number of active operations in the memory system according to an embodiment was decreased in all of the simulations, compared to the conventional memory system.

(117) Thus, the memory system according to an embodiment of the present disclosure can reduce power consumption while the performance thereof is improved.

(118) According to embodiments of the present disclosure, a memory system can exploit rank-level parallelism using intermediate buffers in ranks.

(119) Such a memory system can improve the operation performance and energy efficiency thereof using the rank-level parallelism.

(120) Although various embodiments have been described for illustrative purposes, it will be apparent to those skilled in the art that various changes and modifications may be made without departing from the spirit and scope of the invention as defined in the following claims.