This application claims priority under 35 U.S.C. § 119 to Korean Patent Application No. 10-2018-0140105 filed on Nov. 14, 2018, in the Korean Intellectual Property Office, the disclosure of which is incorporated by reference herein in its entirety.
Embodiments of the disclosure relate to a storage device and an electronic device, and more particularly, relate to a storage device and an electronic device for performing map scheduling.
As information communication technologies develop, various types of electronic devices are being used to exchanging information. An electronic device may include a storage device for storing data indicating a large amount of information. The storage device may store data based on various technologies and may output the stored data in response to a request of a user or a host. As semiconductor technologies are applied to the storage device, the performance of the storage device is being improved.
As the electronic device processes and generates a large amount of data, the storage device may include a high-capacity memory for processing a large amount of data. A dynamic random-access memory (DRAM) may be used as a memory included in the storage device. Upon designing the storage device, the memory causes higher costs than any other components included in the storage device.
Accordingly, a volatile-memory free storage device is being developed to satisfy a demand of a consumer on a low-priced storage device. For example, a technology is being developed which allows the storage device to use any other volatile memory present outside the storage device.
Embodiments of the disclosure provide a storage device and an electronic device configured to perform map scheduling for improving a map hit rate upon being provided with map data from a host memory buffer outside the storage device.
According to an example embodiment, a storage device may include a controller and a memory. In response to a request of a host, the controller may generate a first list as a result of counting the number of first page numbers included in a first range among page numbers included in a logical address received from the host and the number of second page numbers included in a second range not overlapping the first range. The controller may generate a second list as a result of respectively grouping the first page numbers and the second page numbers based on the first list. The controller may translate the logical address to a physical address based on the second list and the first map data. The memory may store the first map data to be provided to the controller. The first map data may match the first page numbers and the second page numbers with respective physical addresses.
According to another example embodiment, a storage device includes a nonvolatile memory that stores a first logical-to-physical (L2P) address translation. The first L2P address translation includes a plurality of entries. Each of the entries maps a different logical address, among logical addresses within the first L2P address translation, to a corresponding physical address, among physical addresses within the first L2P address translation. A controller: (1) receives the entries from the nonvolatile memory and (2) creates a second L2P address translation in which each of predetermined ranges of the logical addresses is indexed according to a number of entries having a logical address within the range.
The above and other objects and features of the disclosure will become apparent by describing in detail example embodiments thereof with reference to the accompanying drawings.
Below, embodiments of the disclosure may be described in detail and clearly to such an extent that an ordinary one in the art easily implements the disclosure.
Referring to
The host memory 1100 may store data processed or to be processed by the host 1300 for operations of the electronic device 1000. For example, the host memory 1100 may include a volatile memory such as a static random-access memory (SRAM), a dynamic RAM (DRAM), a synchronous DRAM (SDRAM), etc., or various non-volatile memories such as a phase-change RAM (PRAM), a magneto-resistive RAM (MRAM), a resistive RAM (ReRAM), a ferroelectric RAM (FRAM), etc. Alternatively, the host memory 1100 may include heterogeneous memories.
The host memory 1100 may support a direct memory access (DMA) operation. Without intervention of the host 1300, a component of the electronic device 1000 or any other electronic device outside the electronic device 1000 may directly access the host memory 1100 and may use a storage space of the host memory 1100. For example, as will be described with reference to
The storage device 1200 may store data regardless of whether a power is supplied. For example, the storage device 1200 may be a storage medium, which includes non-volatile memories, such as a hard disk drive (HDD), a solid-state drive (SSD), a secure digital (SD) card, a universal serial bus (USB) memory device, etc.
The storage device 1200 may store data received from the host 1300 based on a logical address received from the host 1300. The storage device 1200 may store the data received from the host 1300 in the non-volatile memories included in the storage device 1200.
The storage device 1200 may include a flash translation layer (FTL) for translating a logical address received from the host 1300 to a physical address. For example, the storage device 1200 may include at least one processor core for implementing the flash translation layer.
Without intervention of the host 1300, the storage device 1200 may access the host memory 1100 and may use a memory area of the host memory 1100. For example, the storage device 1200 may use the memory area of the host memory 1100 as a buffer. Exemplary configurations and operations of the storage device 1200 will be more fully described with reference to
The host 1300 may control overall operations of the electronic device 1000. The host 1300 which is a central control device may process operations necessary for an operation of the electronic device 1000. For example, the host 1300 may be one of a general-purpose processor, a workstation processor, an application processor, etc. To process operations of the electronic device 1000, the host 1300 may include a single processor core (or a single core) or may include a plurality of processor cores (or a multi-core). For example, the host 1300 may include a multi-core such as a dual-core, a quad-core, a hexa-core, or the like.
The user interface 1400 may transfer a command or data between the user and the electronic device 1000. The user interface 1400 may include various devices for transferring a command or data. For example, the user interface 1400 may include input devices such as a keyboard, a mouse, a touch panel, and a microphone and output devices such as a speaker and a display device.
A bus 1500 may provide a communication path between the components of the electronic device 1000. For example, the host memory 1100, the storage device 1200, the host 1300, and the user interface 1400 may exchange data with each other through the bus 1500. The bus 1500 may be configured to support various communication formats which are used in the electronic device 1000. The communication formats of the bus 1500 may support various interface protocols.
Referring to
As described with reference to
The storage device 1200 may perform a logical to physical address translation (hereinafter referred to as “address translation”) based on the received logical address ADDR. That is, the storage device 1200 may translate the received logical address ADDR to a physical address corresponding to the logical address ADDR. For example, the translated physical address may indicate a physical area (e.g., a page) of a memory area corresponding to the received logical address ADDR.
The storage device 1200 may access the host memory 1100 and may control some operations of the host memory 1100. For example, the storage device 1200 may control operations of the host memory 1100 through a DMA operation.
For example, under control of the storage device 1200, the host memory buffer 1110 may receive and/or output map data to be used for the address translation of the storage device 1200. For example, the host memory buffer 1110 may store a logical to physical (L2P) table LP1 including map data loaded from any other L2P table stored in the storage device 1200. Alternatively, the host memory buffer 1110 may output or flush map data included in the L2P table LP1 to the storage device 1200.
Hereinafter, the L2P table means a data table indicating matching between a logical address ADDR and a physical address for translating the logical address ADDR to the physical address. Hereinafter, the map data may mean all or a part of the L2P table as data extracted from the L2P table.
Referring to
The host memory buffer controller 1210 may communicate with the host memory 1100 for accessing the host memory 1100 of
In detail, the host memory buffer controller 1210 may transmit map data of the L2P table LP1 received from the host memory buffer 1110 to the processor core 1260. Alternatively, depending on a request of the processor core 1260, the host memory buffer controller 1210 may output map data to be stored in the host memory buffer 1110 to the host memory buffer 1110.
The internal buffer 1220 may store data to be processed by the processor core 1260 and the scheduler 1250. For example, the internal buffer 1220 may include a volatile memory such as an SRAM.
In response to a request of the processor core 1260, the internal buffer 1220 may store and/or output map data to be used for address translation. For example, the internal buffer 1220 may store an L2P table LP2 including map data to be used for address translation. The L2P table LP2 may be updated by map data loaded from the non-volatile memory 1240. The internal buffer 1220 may output map data included in the L2P table LP2 to the processor core 1260. The internal buffer 1220 may flush the L2P table LP2 to the non-volatile memory 1240.
The host interface 1230 may arbitrate communication between the host 1300 of
The host interface 1230 may provide various communication formats for arbitrating communication between the host 1300 and the storage device 1200. For example, the host interface 1230 may support communication protocols such as universal serial bus (USB), advanced technology attachment (ATA), serial ATA (SATA), serial attached SCSI (SAS), parallel ATA (PATA), high speed interchip (HSIC), small computer system interface (SCSI), Firewire, peripheral component interconnection (PCI), PCI express (PCIe), non-volatile memory express (NVMe), universal flash storage (UFS), secure digital (SD), multimedia card (MMC), and embedded MMC (eMMC).
The non-volatile memory 1240 may store or output data requested by the host 1300. For example, the non-volatile memory 1240 may include a flash memory, a PRAM, an MRAM, a ReRAM, a FRAM, etc. for implementing the memory area described with reference to
The non-volatile memory 1240 may store an L2P table LP3 to be used for translation of the logical address ADDR. The L2P table LP3 may include all mapping data necessary to translate the logical address ADDR received from the host 1300. For example, a designer of the storage device 1200 may store the L2P table LP3 in the non-volatile memory 1240 upon designing the storage device 1200.
The scheduler 1250 may perform map scheduling based on the logical address ADDR received from the host 1300. The scheduler 1250 may provide a scheduled logical address (a scheduled list to be described with reference to
An on-chip bus 1270 may provide a communication path between the components of the storage device 1200. The on-chip bus 1270 may be configured to support various communication formats which are used in the electronic device 1000. The communication formats of the on-chip bus 1270 may support various interface protocols.
Designing of the storage device 1200 including the high-capacity internal buffer 1220 may cause a lot of costs and an increase in the size of the storage device 1200. Accordingly, it may be difficult to include the high-capacity internal buffer 1220 or a separate memory in the storage device 1200 upon designing a small-sized, cheap high-performance storage device 1200.
Instead, the storage device 1200 may secure sufficient buffer capacity by using the host memory buffer 1110 outside the storage device 1200 as a buffer. Accordingly, as the host memory buffer 1110 is provided to the storage device 1200, the storage device 1200 may operate with high performance despite a design for a low-priced, small-sized storage device.
As described with reference to
For example, the processor core 1260 may request, from the internal buffer 1220, map data to be used to translate the logical address ADDR received from the host 1300. In a first operation OP1, the internal buffer 1220 may provide the processor core 1260 with map data included in the L2P table LP2 in response to a request of the processor core 1260.
For example, the processor core 1260 may request, from the host memory buffer 1110, map data to be used to translate the logical address ADDR received from the host 1300. In a second operation OP2, the host memory buffer 1110 may provide the processor core 1260 with map data included in the L2P table LP1 in response to a request of the processor core 1260.
For example, to obtain the map data for the second operation OP2, the non-volatile memory 1240 may perform a third operation OP3. In the third operation OP3, the map data may be loaded onto the host memory buffer 1110 from the non-volatile memory 1240. That is, the non-volatile memory 1240 may output map data included in the L2P table LP3 to the host memory buffer 1110, and the host memory buffer 1110 may store the map data received from the non-volatile memory 1240 as a portion of the L2P table LP1.
For example, a fourth operation OP4 may be performed to secure a storage space for the third operation OP3. In the fourth operation OP4, the host memory buffer 1110 may flush the map data of the L2P table LP1 to the non-volatile memory 1240. For example, the host memory buffer 1110 may flush all or a portion of the map data of the L2P table LP1 to the non-volatile memory 1240.
The first to fourth operations OP1 to OP4 which are performed over time will be more fully described with reference to
In operation S110, the processor core 1260 may request, from the internal buffer 1220, map data to be used to translate the logical address ADDR received from the host 1300.
In operation S120, when the map data requested in operation S110 are included in the L2P table LP2 stored in the internal buffer 1220 (in the case of a map hit), operation S180 may be performed. When the map data requested in operation S110 are not included in the L2P table LP2 stored in the internal buffer 1220 (in the case of a map miss), operation S130 may be performed.
In operation S130, the processor core 1260 may request, from the host memory buffer 1110, map data to be used to translate the logical address ADDR received from the host 1300.
In operation S140, when the map data requested in operation S130 are included in the L2P table LP1 stored in the host memory buffer 1110 (in the case of a map hit), operation S180 may be performed. When the map data requested in operation S130 are not included in the L2P table LP1 stored in the host memory buffer 1110 (in the case of a map miss), operation S150 may be performed.
In operation S150, the host memory 1100 may determine whether sufficient storage space is present in the host memory buffer 1110. In detail, the host memory 1100 may determine whether a storage space to store map data to be loaded from the non-volatile memory 1240 is present in the host memory buffer 1110. For example, the map data may be provided from the non-volatile memory 1240 in the unit of specific data (hereinafter referred to as a “loading data unit”). The data loading unit will be more fully described with reference to
When a storage space, the capacity of which is greater than the loading data unit, is present in the host memory buffer 1110, operation S170 may be performed. When a storage space, the capacity of which is smaller than the loading data unit, is present in the host memory buffer 1110, operation S160 may be performed.
In operation S160, the map data stored in the L2P table LP1 stored in the host memory buffer 1110 may be flushed to the non-volatile memory 1240 (the fourth operation OP4 of
In operation S170, map data to be provided to the processor core 1260 may be loaded onto the host memory buffer 1110 from the non-volatile memory 1240 (the third operation OP3 of
In operation S180, one, at which the map hit occurs, from among the internal buffer 1220 and the host memory buffer 1110 may provide map data to the processor core 1260 (the first operation OP1 or the second operation OP2 of
It may be understood that the operations of
For example, in the case where an input/output operation of the internal buffer 1220 is faster in speed than an input/output operation of the host memory buffer 1110, the storage device 1200 may first use the internal buffer 1220 as a buffer. To this end, the storage device 1200 may perform the additional operations for using the internal buffer 1220 as a buffer prior to operation S150 to operation S170.
Referring to
The write log circuit 1252 may receive the logical address ADDR from the host 1300 through the L2P provider 1251. For example, the logical address ADDR may include logical page numbers LPN of a random placement corresponding to a write command of the host 1300. An exemplary logical address ADDR will be more fully described with reference to
The write log circuit 1252 may generate a scheduled list based on the received logical address ADDR. For example, the write log circuit 1252 may rearrange logical page numbers of the logical address ADDR to generate the scheduled list. The scheduler 1250 may provide the scheduled list to the processor core 1260. Exemplary map scheduling of the write log circuit 1252 for generating a scheduled list based on the logical address ADDR will be more fully described with reference to
Referring to
However, in
For example, the logical address ADDR may include maximum “1024” logical page numbers LPN (e.g., LPN1 to LPN1024). Below, for better description, an example of the logical address ADDR including 5 logical page numbers LPN will be described, but it may be understood the number of logical page numbers LPN included in the logical address ADDR may be variously changed. For example, the logical address ADDR may include one logical page number to 1024 logical page numbers.
For example, to translate the logical address ADDR received from the host 1300, the processor core 1260 may request map data (i.e., physical page numbers PPN1 to PPN5 corresponding to the requested logical page numbers LPN) corresponding to logical page numbers LPN of the logical address ADDR. Below, it is assumed that map data corresponding to the requested logical page numbers LPN are not included in the L2P table LP1 of the host memory buffer 1110 and the L2P table LP2 of the internal buffer 1220 (i.e., it is assumed that a map miss continuously occur at the internal buffer 1220 and the host memory buffer 1110).
Under this assumption, in the case where address translation is performed directly based on the received logical address ADDR, the host memory buffer 1110 may repeatedly perform operations (in particular, operation S170) of
The host memory 1100 may load map data from the non-volatile memory 1240 in the loading data unit. In an L2P table, one item indicating matching between one logical page number LPN and one physical page number PPN may have a specific size. For example, sizes of the loading data unit and one item may be determined upon designing the storage device 1200 in consideration of a capacity of the host memory buffer 1110, a communication format between the host memory 1100 and the processor core 1260, etc.
For example, in the case where the determined size of the loading data unit is “256[B]” and the determined size of the item of the L2P table is “4[B]”, the host memory 1100 may load map data including 64 (=256/4) items from the L2P table LP3 of the non-volatile memory 1240 onto the host memory buffer 1110 through one loading operation. Also, the host memory 1100 may load items for continuous logical page numbers LPN in consideration of a locality.
In the example of
Accordingly, the host memory 1100 may update the L2P table LP1 through five loading operations in response to a request of the processor core 1260. The host memory 1100 may provide the loaded map data to the processor core 1260 for address translation. However, the example described with reference to
Below, exemplary operations of the write log circuit 1252 included in the scheduler 1250 will be described with reference to
Referring to
In the example of
For example, since the number of logical page numbers LPN classified as a range of the logical page numbers LPN1 to LPN64 is “2” (i.e., LPN1 and LPN5), the write log circuit 1252 may generate a count of “2” corresponding to index “1”.
For example, since the number of logical page numbers LPN classified as a range of the logical page numbers LPN65 to LPN128 is “1” (i.e., LPN65), the write log circuit 1252 may generate a count of “1” corresponding to index “2”.
For example, since the number of logical page numbers LPN classified as a range of the logical page numbers LPN129 to LPN192 is “1” (i.e., LPN192), the write log circuit 1252 may generate a count of “1” corresponding to index “3”.
For example, since the number of logical page numbers LPN classified as a range of the logical page numbers LPN961 to LPN1024 is “1” (i.e., LPN1023), the write log circuit 1252 may generate a count of “1” corresponding to index “16”.
Referring to
The write log circuit 1252 may place an item of a logical page number LPN matched with an index of the last order (e.g., with index “16”) in consideration of the sum of counts recorded at the counting list in the scheduled list. However, hereinafter, the term “placement” means to include a logical page number LPN in an item of the scheduled list.
For example, the sum of counts recorded at the counting list may be “5”. In this case, as illustrated in
The write log circuit 1252 may further place logical page numbers LPN in the scheduled list in consideration of an order of an index and a count. For example, in the case where the number of logical page numbers LPN matched with an index is not less than “2” (i.e., a count corresponding to an index is not less than “2”), the write log circuit 1252 may place a logical page number LPN matched with the index in the scheduled list and then may decrease the count associated with the index, within the counting list, by as much as “1”. In the example illustrated by
Afterwards, the write log circuit 1252 may place logical page numbers LPN in the scheduled list depending on an order of an index (an order from index “1” to index “16”). However, in the case of an index, in which a count of the counting list remains after being decremented, the write log circuit 1252 may leave open (i.e., unscheduled) as many items of the scheduled list as the remaining count.
For example, in the example illustrated by
The write log circuit 1252 may place the logical page number LPN65 matched with index “2” as the third item of the scheduled list and may place the logical page number LPN192 matched with index “3” as the fourth item of the scheduled list.
In the example of
The map scheduling described with reference to
Example map scheduling is described with reference to
However, hereinafter, to continuously place logical page numbers LPN means to group the logical page numbers LPN. Hereinafter, grouping means to generate a group of logical page numbers LPN as a group capable of being loaded from the non-volatile memory 1240 at the same time.
For example, the disclosure may perform all types of operations for generating a scheduled list configured such that logical page numbers LPN classified as the same range are grouped based on a counting list and the grouped logical page numbers LPN are loaded from the non-volatile memory 1240.
The processor core 1260 may request map data from a host memory buffer for translating the logical address ADDR received from the host 1300. Below, it is assumed that map data corresponding to the requested logical page numbers LPN are not included in the L2P table LP1 of the host memory buffer 1110 and the L2P table LP2 of the internal buffer 1220 (i.e., it is assumed that a map miss continuously occur at the internal buffer 1220 and the host memory buffer 1110).
Under this assumption, in the case where address translation is performed based on a scheduled list, the host memory buffer 1110 may repeatedly perform operations (in particular, operation S170) of
In the example of
As in the above description, the host memory 1100 may further load map data including 64 continuous items, in each of three iterations, to obtain the physical page numbers PPN3, PPN5, and PPN1 corresponding to the logical page numbers LPN65, LPN192, and LPN1023.
Accordingly, the host memory 1100 may update the L2P table LP1 through a maximum of four loading operations in response to a request of the processor core 1260. However, the example described with reference to
The host memory 1100 may provide the loaded map data to the processor core 1260 for address translation. Afterwards, the processor core 1260 may perform address translation based on map data provided from the host memory 1100. That is, the processor core 1260 may perform an operation corresponding to the flash translation layer in response to a request of the host 1300.
Referring to
According to an embodiment of the disclosure, a time taken for a storage device to translate a logical address received from a host may decrease and, thus, a speed at which the storage device operates in response to a request of the host may increase.
As is traditional in the field, embodiments may be described and illustrated in terms of blocks which carry out a described function or functions. These blocks, which may be referred to herein as units or modules or the like, are physically implemented by analog and/or digital circuits such as logic gates, integrated circuits, microprocessors, microcontrollers, memory circuits, passive electronic components, active electronic components, optical components, hardwired circuits and the like, and may optionally be driven by firmware and/or software. The circuits may, for example, be embodied in one or more semiconductor chips, or on substrate supports such as printed circuit boards and the like. The circuits constituting a block may be implemented by dedicated hardware, or by a processor (e.g., one or more programmed microprocessors and associated circuitry), or by a combination of dedicated hardware to perform some functions of the block and a processor to perform other functions of the block. Each block of the embodiments may be physically separated into two or more interacting and discrete blocks without departing from the scope of the disclosure. Likewise, the blocks of the embodiments may be physically combined into more complex blocks without departing from the scope of the disclosure.
While the disclosure has been described with reference to exemplary embodiments thereof, it will be apparent to those of ordinary skill in the art that various changes and modifications may be made thereto without departing from the spirit and scope of the disclosure as set forth in the following claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2018-0140105 | Nov 2018 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
6697076 | Trivedi et al. | Feb 2004 | B1 |
9213632 | Song et al. | Dec 2015 | B1 |
9690695 | Cheng | Jun 2017 | B2 |
10007433 | Hahn | Jun 2018 | B2 |
20150098271 | Lasser | Apr 2015 | A1 |
20150186270 | Peng | Jul 2015 | A1 |
20160085796 | Ki | Mar 2016 | A1 |
20160246726 | Hahn | Aug 2016 | A1 |
20160267016 | Lee et al. | Sep 2016 | A1 |
20160328183 | Hsieh | Nov 2016 | A1 |
20170075600 | Jung | Mar 2017 | A1 |
20180039578 | Yun et al. | Feb 2018 | A1 |
20180275899 | Munsil | Sep 2018 | A1 |
20180373642 | Yang | Dec 2018 | A1 |
20190087284 | Kim | Mar 2019 | A1 |
20200089618 | Kim | Mar 2020 | A1 |
Number | Date | Country |
---|---|---|
101297442 | Aug 2013 | KR |
Number | Date | Country | |
---|---|---|---|
20200151109 A1 | May 2020 | US |