A claim for priority under 35 U.S.C. §119 is made to Korean Patent Application No. 10-2012-0005764 filed Jan. 18, 2012 and Korean Patent Application No. 10-2013-0001708 filed Jan. 7, 2013, in the Korean Intellectual Property Office, the entire contents of which are hereby incorporated by reference.
1. Field of the Invention
The inventive concepts described herein relate to a memory system and a mobile device including a host and a flash memory-based storage device.
2. Description of the Related Art
Semiconductor memory devices may be divided into volatile memory devices (e.g., DRAM, SRAM, etc.) and nonvolatile memory devices (e.g., EEPROM, FRAM, PRAM, MRAM, etc.). While the volatile memory devices lose stored data at power-off, the nonvolatile memory devices may retain stored data even at power-off. In particular, a flash memory may have advantages such as a fast programming speed, a low power, a mass data storage capacity, and so on. Hence, a flash memory-based data storage device may be widely used.
Flash memory-based data storage devices may include a solid state drive (SSD) replacing a conventional hard disk drive, a memory card such as an SD card or a multimedia card (MMC), and so on. Since such a semiconductor memory device becomes compact, it may be embedded in a portable electronic device. For example, embedded memory devices may include eSSD (embedded SSD), eMMC (embedded MMC), and so on. The eSSD may be applied to a laptop computer, a tablet PC, or an e-book. The eMMC may be applied to a mobile device.
One aspect of embodiments of the inventive concept is directed to provide a memory system which comprises a storage device including a flash memory; and a host configured to request a storage device state and user pattern information via a user interface, to analyze the user pattern information, to set up a parameter of the storage device such that the storage device operates an optimization operation, according to the analyzing result, and to provide a command for the optimization operation to the storage device.
In example embodiments, the storage device state is at least one of a P/E cycle and a background operation state. The user pattern information is at least one of the amount of data written, a memory access type, and a memory access time. The host calculates an expected value of lifetime of the storage device using the P/E cycle and provides the calculated result to a user. The host provides the user with a recommend level for the optimization operation of the storage device.
In other example embodiments, the user interface is an application. The host informs a user of a progress state of the storage device via the application and guides an operation setup on the storage device.
In still other example embodiments, the host performs self-diagnosis and self-healing operations on the storage device. The self-healing operation is accomplished by switching hot data and cold data, performing a data reclaim operation, controlling an over-provisioning area, changing a parameter, or by changing a program condition.
Another aspect of embodiments of the inventive concept is directed to provide an operating method of a mobile device which includes a storage device and a host. The operating method comprises requesting a storage device state and user pattern information via a user interface; analyzing the user pattern information; setting up a parameter of the storage device such that the storage device operates an optimization operation, according to the analyzing result; and providing a command for the optimization operation to the storage device.
The operating method further comprises providing a recommend level for the optimization operation to a user. The operating method further comprises informing a user of a progress state of the storage device via the application; and guiding an operation setup on the storage device. The operating method further comprises calculating an expected value of lifetime of the storage device using the P/E cycle to provide the calculated result to a user. The operating method further comprises performing self-diagnosis and self-healing operations on the storage device.
The above and other objects and features will become apparent from the following description with reference to the following figures, wherein like reference numerals refer to like parts throughout the various figures unless otherwise specified, and wherein
Embodiments will be described in detail with reference to the accompanying drawings. The inventive concept, however, may be embodied in various different forms, and should not be construed as being limited only to the illustrated embodiments. Rather, these embodiments are provided as examples so that this disclosure will be thorough and complete, and will fully convey the concept of the inventive concept to those skilled in the art. Accordingly, known processes, elements, and techniques are not described with respect to some of the embodiments of the inventive concept. Unless otherwise noted, like reference numerals denote like elements throughout the attached drawings and written description, and thus descriptions will not be repeated. In the drawings, the sizes and relative sizes of layers and regions may be exaggerated for clarity.
It will be understood that, although the terms “first”, “second”, “third”, etc., may be used herein to describe various elements, components, regions, layers and/or sections, these elements, components, regions, layers and/or sections should not be limited by these terms. These terms are only used to distinguish one element, component, region, layer or section from another region, layer or section. Thus, a first element, component, region, layer or section discussed below could be termed a second element, component, region, layer or section without departing from the teachings of the inventive concept.
Spatially relative terms, such as “beneath”, “below”, “lower”, “under”, “above”, “upper” and the like, may be used herein for ease of description to describe one element or feature's relationship to another element(s) or feature(s) as illustrated in the figures. It will be understood that the spatially relative terms are intended to encompass different orientations of the device in use or operation in addition to the orientation depicted in the figures. For example, if the device in the figures is turned over, elements described as “below” or “beneath” or “under” other elements or features would then be oriented “above” the other elements or features. Thus, the exemplary terms “below” and “under” can encompass both an orientation of above and below. The device may be otherwise oriented (rotated 90 degrees or at other orientations) and the spatially relative descriptors used herein interpreted accordingly. In addition, it will also be understood that when a layer is referred to as being “between” two layers, it can be the only layer between the two layers, or one or more intervening layers may also be present.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the inventive concept. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items. Also, the term “exemplary” is intended to refer to an example or illustration.
It will be understood that when an element or layer is referred to as being “on”, “connected to”, “coupled to”, or “adjacent to” another element or layer, it can be directly on, connected, coupled, or adjacent to the other element or layer, or intervening elements or layers may be present. In contrast, when an element is referred to as being “directly on,” “directly connected to”, “directly coupled to”, or “immediately adjacent to” another element or layer, there are no intervening elements or layers present.
The term “unit” or “module”, as used herein, means, but is not limited to, a software or hardware component, such as a field programmable gate array (FPGA) or an application specific integrated circuit (ASIC), which performs certain tasks. A unit or module may advantageously be configured to reside in the addressable storage medium and configured to execute on one or more processors. Thus, a unit or module may include, by way of example, components, such as software components, object-oriented software components, class components and task components, processes, functions, attributes, procedures, subroutines, segments of program code, drivers, firmware, microcode, circuitry, data, databases, data structures, tables, arrays, and variables. The functionality provided for in the components and units or modules may be combined into fewer components and units or modules or further separated into additional components and units or modules.
Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art to which this inventive concept belongs. It will be further understood that terms, such as those defined in commonly used dictionaries, should be interpreted as having a meaning that is consistent with their meaning in the context of the relevant art and/or the present specification and will not be interpreted in an idealized or overly formal sense unless expressly so defined herein.
I. Memory System Controlling Storage Device Via User Interface
The memory system 100 may be configured to control an operating characteristic of the storage device 120 or perform an optimization operation via the user interface 1111. For example, the memory system 100 may provide a user with information associated with a state of a storage device, a user pattern, predicted lifetime, optimization of a storage device, OS optimization, firmware update, initialization of a storage device, etc. via the user interface 1111, and may control the storage device 120 according to a demand of a user.
The memory system 100 may be applied to a variety of user devices. For example, the inventive concept may be applied to a computer or a tablet PC which uses a solid state drive (SSD) as its storage device. Also, the inventive concept may be applied to a mobile device which uses a memory card such as an embedded multi-media card (hereinafter, referred to as eMMC) or a micro SD card as its storage device.
Below, there will be described a method of improving the performance and reliability of a storage device by adjusting an operating characteristic of a storage device or performing an optimization operation via a user interface.
II. Operating Characteristic Controlling Method of Storage Device Using User Interface
Referring to
The host 1100 may include, as illustrated in
The configuration controller 1110 may receive an input command and output a configuration command corresponding thereto. Here, the input command may be a command for controlling the operating characteristics of the storage device 1200 according to the use environment. The input command may be provided from an outside thereof. For example, the input command may be inputted from a user through a user interface (UI) or the like included in the configuration controller 1110. The user interface may be an input unit connected to the configuration controller 1110 such that the user can input the input command. The user interface may be a screen of a display unit, for example, a touch panel, such that the user interface is generated from the configuration controller 1110 and is displayed on a display unit connected to the host 1100 such that the user can input the user command through the touch panel of the display unit.
The host controller 1120 may output a command associated with a content read/write operation to a storage controller 1230 to allow the host 1100 to process contents stored in the storage device 1200 or store new contents in the storage device 1200. Here, the processing the contents in the host 1100 may be referred to as displaying or printing the contents in the form of image and document, playing back the contents in the form of audio and/or video, and installing or executing the contents in the form of application such as computer program. Here, the host may have a functional unit (not illustrated) to perform the processing operation of the host 1100. It is possible that the functional unit may have a mechanical structure and/or an electrical circuit element to perform the processing operation as described above.
The storage controller 1230 receives the command associated with the contents from the host controller 1120 and controls contents 1240 stored in the storage device 1200 according to the received command. For example, when the received command is a read command, the storage controller 1230 may provide the contents 1240 stored in the storage device 1200 to the host 1100, and when the received command is a write command, the storage controller 1230 may receive new contents from the host 1100 and store the received contents in the storage device 1200.
Although
The storage device 1200 may include an adaptation controller (or feature adaption layer) 1210 and the storage controller 1230. The storage device 1200 may store firmware 1220 and the contents 1240. Here, the firmware 1220 may be installed in the storage device 1200 to drive the storage device 1200. The contents 1240 may be stored in a separate memory area (not illustrated) included in the storage device 1200.
Referring to
Meanwhile, each of the modules 1221, 1222 and 1223 may include a plurality of features. Here, one feature may be a group of small units constituting the firmware 1220, and various features may be combined to implement one functional unit module 1221, 1222 or 1223.
For example, when the first module 1221 is a module associated with the read/write operation of the storage device 1200, the first module 1221 may include a first feature (FEATURE 1) to preferentially process a read command over a write command among the commands received from the host 1100, and a second feature (FEATURE 2) to preferentially process a write command over a read command among the commands received from the host 1100.
The read command may have a higher priority than that of the write command in the first feature (FEATURE 1) such that the firmware 1220 may process the read command having a higher priority before processing the write command or such that the write command may not interfere with the processing of the read command. The write command may have a higher priority than that of the reading command in the second feature (FEATURE 2) such that the firmware 1220 may process the write command having a higher priority before processing the read command or such that the read command may not interfere with the processing of the write command.
The term of “preferentially process a command” may be referred to as “process a command having a higher priority,” “process a command without being interrupted by other commands,” “process a command by interrupting other command,” “process a command by delaying processing of other commands,” “delay other commands until a command is completed,” or “not generating other commands when a command is generated,” for example.
Further, when the second module 1222 is a module associated with the operating frequency of the storage device 1200, the second module 1222 may include a third feature (FEATURE A) to drive the storage device 1200 at a low frequency (e.g., low clock frequency), a fourth feature (FEATURE B) to drive the storage device 1200 at a high frequency (e.g., high clock frequency), and a fifth feature (FEATURE C) to drive the storage device 1200 at a configuration frequency received from the host 1100.
Further, when the third module 1223 is a module associated with the garbage collection of the storage device 1200, the third module 1223 may include a sixth feature (FEATURE a) to allow the storage device 1200 to perform garbage collection, a seventh feature (FEATURE b) to stop the garbage collection of the storage device 1200, and an eighth feature (FEATURE c) to allow the storage device 1200 to perform garbage collection at a configuration frequency received from the host 1100.
Whether or not to enable each feature is determined by the adaptation controller 1210. The adaptation controller 1210 may receive a configuration command from the configuration controller 1110 of the host 1100 and enable a feature corresponding to the configuration command.
When the corresponding feature is enabled according to the configuration command, operating characteristics of the storage device 1200 can be set or determined. Thus, the storage controller 1230 sends/receives the contents 1240 to/from the host 1100 while driving the storage device 1200 according to the set characteristics.
Hereinafter, an operation of a memory system according to an embodiment of the present general inventive concept will be described in detail with reference to
As described above, the configuration controller 1110 of the host 1100 may include the user interface 1111 to receive the input command from the user. The user interface 1111 of
Referring to
There are one or more different categories in the contents 1240. When the contents 1240 stored in the storage device 1200 are one category, for example, e-books, the host 1100 may send more read commands than write commands to the storage device 1200 during performing the operation on the e-books. Accordingly, in this use environment, the storage device 1200 is required to preferentially process a read command over a write command. In this case, the user may enable the first button 111a included in the user interface 1111 to generate a configuration command such that the storage device 1200 preferentially processes a read command over a write command.
It is possible that the host 1100 automatically controls the user interface 1111 to select the first button 111a to generate a read command more than a write command such that a user does not have to manually enable the first button 111a when the category, that is the e-books, is selected by the user. This may be applied to other categories of the contents 1240 or user environments hereinafter.
Although not illustrated, the host 1100 may have another user interface such that the user can select one of the categories of the contents 1240. According to the user selection through the another user interface, the host 1100 may perform an operation associated with the selected category of the contents 1240. This may also be applied to other categories of the contents 1240 or user environments hereinafter.
Referring to
When the contents 1240 stored in the storage device 1200 are another category, for example, documents or word processing documents, the host 1100 may send more write commands than read commands to the storage device 1200 during performing the operation on the documents. In this case, the user may enable the second button 111b, and the adaptation controller 1210 may enable the second feature (FEATURE 2) and disable the first feature (FEATURE 1) of the first module 1221 through a process similar to that as described above.
When the read operation and the write operation are expected to be balanced or equally performed in view of the characteristics of the contents 1240 stored in the storage device 1200, the user may enable the third button 111c, and the adaptation controller 1210 may enable or disable both the first feature (FEATURE 1) and the second feature (FEATURE 2) through a process similar to that as described above.
Referring back to
When a state of the storage device 1200, for example, a drive environment of the storage device 1200, is a high temperature environment, when the storage device 1200 is continuously driven at a high frequency, the performance of the storage device 1200 may deteriorate. Accordingly, in this case, the user may enable the sixth button 111f included in the user interface 1111 to generate a configuration command such that the storage device 1200 is driven at different driving frequency, for example, at a relatively low driving frequency.
Referring to
On the other hand, when the drive environment of the storage device 1200 is a low temperature environment, the storage device 1200 is required to be driven at a high frequency to generate heat to thereby maintain the performance of the storage device 1200. In this case, the user may enable the fourth button 111d included in the user interface 1111, thereby disabling the fourth feature (FEATURE B) and enabling the third feature (FEATURE A). When there is no need to separately set the driving frequency of the storage device 1200, the user may enable the fifth button 111e included in the user interface 1111, thereby disabling or enabling both the third feature (FEATURE A) and the fourth feature (FEATURE B).
Further, when the user intends to manually set the driving frequency of the storage device 1200, the user may input a configuration frequency to the first input section 111g included in the user interface 1111 to thereby generate a configuration command such that the storage device 1200 is driven at the configuration frequency.
Referring to
Referring again back to
If the state of the storage device 1200 requires a garbage collection, the user may enable the seventh button 111h included in the user interface 1111 to generate a configuration command such that the garbage collection is performed in the storage device 1200.
Referring to
When the state of the storage device 1200 requires no garbage collection, the user may enable the eighth button 111i included in the user interface 1111, thereby disabling the sixth feature (FEATURE a) and enabling the seventh feature (FEATURE b). It is possible that the host 1100 or the storage device 1200 may automatically enable the eighth button 111i according to the state of the storage device 1200.
Further, when the user intends to manually set a garbage collection cycle of the storage device 1200, the user may input a configuration cycle to the second input section 111j included in the user interface 1111 to thereby generate a configuration command such that the storage device 1200 performs a garbage collection according to the configuration cycle.
Referring to
Although the operation of the memory system according to an embodiment of the present general inventive concept has been described using the exemplary functions of some features, the present general inventive concept is not limited thereto. The operation of the memory system according to embodiment of the present general inventive concept can be extended to other operations than the above-described examples. Further, although the user interface 1111 that can be included in the configuration controller 1110 has been illustrated as an example in
Meanwhile, although the input command has been inputted from the user through the user interface 1111 in the above-described examples, it may be also modified such that the host 1100 and the storage device 1200 can perform the operations thereof. For example, the host 1100 or the storage device 1200 may further include a sensor (not illustrated) to sense a state of the storage device 1200 corresponding to one or more operational functions of the storage device 1200 such that the input command is generated from the sensor (not illustrated) and provided to the configuration controller 1110 of the host 1100.
Further, although the adaptation controller 1210 and the storage controller 1230 are illustrated as separate elements, the present general inventive concept is not limited thereto. That is, the adaptation controller 1210 and the storage controller 1230 may be implemented as one integrated unit if necessary.
In this embodiment, the storage device 1200 may be a semiconductor apparatus, for example, a solid state drive (SSD), in which a controller and a non-volatile memory device are integrated into one semiconductor device, but the present general inventive concept is not limited thereto.
Referring again to
In an embodiment of the present general inventive concept, the first interface and the second interface may be different interfaces. For example, any one of the first interface and the second interface may have a short-range wireless communication mode, such as Bluetooth, near field communication (NFC), and radio frequency identification (RFID), and the other one of the first interface and the second interface may have a wired communication mode such as universal serial bus (USB), AT attachment (ATA), and serial ATA (SATA).
However, in an embodiment of the present general inventive concept, the first interface and the second interface may be the same interface. For example, the first interface and the second interface may be serial advanced technology attachment (SATA) interfaces. In this case, the configuration command may be provided from the configuration controller 1110 to the adaptation controller 1210 in the form of a SATA command through the SATA interface.
Referring to
A configuration controller (device configuration layer) 2110 of the host 2100 may receive an input command and output a first configuration command (CONFIGURATION COMMAND-1) and a second configuration command (CONFIGURATION COMMAND-2) corresponding thereto. Here, the first configuration command (CONFIGURATION COMMAND-1) may be a command to determine whether to enable each of a plurality of features included in the first storage 2300, and the second configuration command (CONFIGURATION COMMAND-2) may be a command to determine whether to enable each of a plurality of features included in the second storage 2400.
A first adaptation controller (feature adaptation layer) 2310 included in the first storage 2300 may receive the first configuration command (CONFIGURATION COMMAND-1) from the configuration controller 2110 and determine whether to enable each feature (FEATURE 1-4). Further, a second adaptation controller (feature adaptation layer) 2410 included in the second storage 2400 may receive the second configuration command (CONFIGURATION COMMAND-2) from the configuration controller 2110 and determine whether to enable each feature (FEATURE 1-4).
Here, the first configuration command (CONFIGURATION COMMAND-1) and the second configuration command (CONFIGURATION COMMAND-2) may be different from each other according to the environments in which the first storage 300 and the second storage 2400 are operated. Accordingly, as illustrated, the enabled feature (FEATURE 1, 3, 4) of the first storage 2300 may be different from the enabled feature (FEATURE 2) of the second storage 2400.
For example, when the contents stored in the first storage 2300 are one type or category of contents, such as e-books, the first adaptation controller 2310 may enable a first feature (FEATURE 1) and disable a second feature (FEATURE 2) included in a firmware module 2320 according to the first configuration command (CONFIGURATION COMMAND-1). Thus, among the commands inputted to the first storage 2300, a read command may be processed first.
Further, when the contents stored in the second storage 2400 are another type or category of contents, such as word processing documents, the second adaptation controller 2410 may enable a second feature (FEATURE 2) and disable a first feature (FEATURE 1) included in a firmware module 2420 according to the second configuration command (CONFIGURATION COMMAND-2). Thus, among the commands inputted to the second storage 2400, a write command may be processed first.
As described above, the enabled feature (FEATURE 1, 3, 4) of the first storage 2300 and the enabled feature (FEATURE 2) of the second storage 2400 may be modified in any way according to the environments in which the first storage 300 and the second storage 2400 are operated.
III. Optimization Operation Method of Storage Device Using User Interface
A memory system according to an embodiment of the inventive concept may perform an optimization operation on a storage device using a user interface. The inventive concept may analyze a state of a storage device and a user pattern and provide a user with optimization information on the storage device. With the inventive concept, a setup suitable for the user or required by the user may be applied to the storage device, so that the performance, reliability and lifetime of the storage device are improved.
The user interface 3110 may include various application programs executed at the host 3100. For example, the user interface 3100 may be an application. A user may perform functions such as OS optimization, firmware update, initialization of a storage device, adjusting of an over provisioning area, and so on via the application. Also, the user may analyze a state of a storage device and a user pattern via the application.
The operating system 3120 may control software and/or hardware resources of the host 3100, and may manage program execution of a processor (not shown). In the case that files or data are stored at the storage device 3200, the file system 3121 may perform organization and management on the files or data. The input/output driver 3122 may enable the storage device 3200 to operate compatibly with the host 3100.
As a flash memory-based data storage device, the storage device 3200 may include a flash memory 3210 and a storage controller 3220. The storage device 3200 may be an embedded MMC (hereinafter, referred to as eMMC), an embedded SSD (hereinafter, referred to as eSSD), a memory card, an ATA bus device, an SATA bus device, a memory stick device, a hybrid drive device, or a universal serial bus flash memory.
The flash memory 3210 may be connected with a storage controller 3220 via an address/data bus. The flash memory 3210 may perform an erase operation by the memory block and a read or write operation by the page. The flash memory 3210 may include a data area 3211 and a meta area 3212. User data or main data may be stored at the data area 3211, and meta data (e.g., address mapping information) needed to drive the flash memory 3210 other than the user data may be stored at the meta area 3212.
The storage controller 3220 may control read, write and erase operations of the flash memory 3210. The storage controller 3220 may include a CPU and a random access memory. The CPU may drive firmware 3221 using the random access memory. The firmware 3221 may be a combination of software and hardware. The performance of the storage device 3200 may be improved via firmware update.
Herein, the user interface 3110, the file system 3121, and the input/output driver 3122 may be driven at a host 3100, and the firmware 3221 may be driven at a storage device 3200. The firmware 3221 may be stored at an area (e.g., a meta area) of a flash memory 3210, and may be loaded on a random access memory of the storage device 3200 during driving. The firmware 3221 can be loaded on the host 3100 according to the storage device 3200.
A user may issue a command (hereinafter, referred to as an optimization command) for an optimization operation to the storage device 3200 via the user interface 3110. The user interface 3110 may request the optimization command at the input/output driver 3122, and the input/output driver 3122 may send the optimization command to the firmware 3221 of the storage device 3220. When analysis of a user pattern is required, the user interface 3110 may request it at an operating system 3120 to collect the user pattern. When state information of the storage device 3200 is required, the input/output driver 3122 may request it at the firmware 3221 of the storage device 3200 to collect data.
The memory system 3000 of the inventive concept may collect a state of a storage device and a user pattern via the user interface 3110, and may issue an optimization command to the storage device 3200. The inventive concept may control the storage device 3200 based on information obtained by analyzing the user pattern. The performance and reliability of the storage device 3200 may be improved by applying the setup suitable for a user or required by the user to the storage device 3200.
The memory system 3000 according to the inventive concept may improve the performance and reliability of the storage device 3200 via an optimization operation such as user pattern-based dynamic parameter control, user-specific parameter guide, and self-diagnosis and self-healing. A method of performing the optimization operation of the memory system 3000 will be more fully described with reference to
In operation S110, whether an analysis of a user pattern is required may be determined. For example, a user or the memory system 3000 may determine whether an analysis of a user pattern is required. If an analysis of a user pattern is not required, the method may be ended. If an analysis of a user pattern is required, the method proceeds to operation S120.
In operation S120, storage device state information (e.g., P/E cycle information) of a storage device may be requested at the storage device 3200 via a user interface 3110 (or, an application), and user pattern information may be requested at an operating system 3120. That is, in the case that an analysis on a user pattern and a state of a storage device is required, the user pattern information and the storage device state information may be requested at an input/output driver 3122 and firmware 3221.
Herein, the user pattern information may mean a memory use history of a user such as memory usage, a memory access type, a memory access time, and so on, and the storage device state information may mean P/E cycle information.
In operation S130, dynamic parameters of the storage device 3200 may be decided by analyzing the user pattern information and the storage device state information. Herein, the dynamic parameters may be a setting value needed for the storage device 3200 to perform an optimization operation. For example, the dynamic parameters may include a garbage collection level, a wear-leveling level, an allowable lifetime range, and so on.
Garbage collection may be performed to obtain a free block in a flash memory 3210. The flash memory 3210 may operate efficiently at a state in which it is organized by a basic storage unit (e.g., by the memory block or page). However, if the flash memory 3210 is erased or is programmed with various sizes of data during a long time, a data storage space may be fragmented. Thus, it is possible to obtain a free block of the flash memory 3210 through the garbage collection (e.g., collecting of valid data and erasing of invalid data). The garbage collection level may mean an execution frequency of a garbage collection operation or the number of free blocks to be obtained.
Wear-leveling may enable the whole memory blocks to experience an erase operation uniformly to prevent a specific memory block of the flash memory 3210 from being worn out faster than other memory blocks. Lifetime of the storage device 3200 may be lengthened via the wear-leveling. The wear-leveling level may mean an execution frequency of a wear-leveling operation.
The allowable lifetime range may indicate an expected value of lifetime of the flash memory 3210. The storage device 3200 may have an expected value of lifetime to secure the reliability of the user, and the expected value of lifetime may be decided by analyzing the user pattern and the storage device state.
In operation S140, a host 3100 may issue an optimization command to the storage device 3200, and the storage device 3200 may perform an optimization operation. Herein, the optimization operation of the storage device 3200 may mean a garbage collection operation, a wear-leveling operation, a firmware setup value adjusting operation, and so on. The performance and reliability of the storage device 3200 may be improved through the optimization operation.
The memory system 3000 according to an embodiment of the inventive concept may improve the performance and reliability of the storage device 3200 by analyzing user pattern information (e.g., usage, an access type, and an access time), deciding setup values needed for an optimization operation of the storage device 3200, and providing the setup values decided to the storage device 3200.
In operation S210, whether setting on a user-specific parameter is required may be determined. For example, a user or the memory system 300 may decide whether setting on a user-specific parameter is required. If setting on a user-specific parameter is not required, the method may be ended. If setting on a user-specific parameter is required, the method proceeds to operation S220.
In operation S220, current state information associated with the lifetime and performance of the storage device 3200 may be provided to a user via a user interface 3110. The memory system 3000 may analyze history data associated with the lifetime and performance of the storage device 3200 to provide the user with the current state information of the storage device 3200.
In operation S230, a variation in the lifetime and performance of the storage device 3200 according to setup of the user may be predicted via the user interface 3110, and an expected value of lifetime may be provided to the user. The memory system 3000 may provide the user with an expected value on a variation in the lifetime or performance together with the current state information associated with the lifetime or performance of the storage device 3200.
In operation S240, the memory system 3000 may guide the user to set up parameters of the storage device 3200 such that the storage device 3200 operates at an optimal condition, via the user interface 3110.
The memory system 3000 may inform the user of a recommend level at which the storage device 3200 optimally operates according to current and expected state information of the storage device 3200. The user may decide an operation of the storage device 3200 in a direction the user wants, based on the recommend level. For example, it is possible to set a warranty period of the storage device 3200 or execution frequency and time of garbage collection.
In
The self-healing by data rearrangement may include hot/cold data switch for changing locations of hot data (e.g., frequently accessed data) and cold data (e.g., occasionally accessed data), data reclaim for preventing an error from affecting a periphery by changing a location of data at which an error is generated, and over-provisioning for securing a reserved space provided to firmware by adjusting a size of a usable space of the user, and so on.
The self-healing by changing parameters may include changing of a default parameter for changing a read level necessary to divide a physical state of data into “1” and “0”, changing of a program condition of data, and so on.
The memory system 3000 according to the inventive concept may set or change a self-healing method via a user interface 3110. For this, the user interface 3110 of the inventive concept may include a mode for the hot/cold data switch, the data reclaim, the over-provisioning, the changing of the default mode, and the changing of the program condition of data.
As described above, the memory system 3000 according to an embodiment of the inventive concept may provide an application type of service for improving the performance and reliability of the storage device 3200, and may perform functions such as OS optimization, firmware update, initialization of a storage device, adjusting of an over-provisioning area, and so on. Also, the storage device 3200 of the inventive concept may be managed in view of user's intention and a user pattern and a storage device state other than a benchmarking result.
Works such as garbage collection, wear-leveling, adjusting of a firmware setup value, etc. may be utilized to perform an optimization operation on the storage device 3200. Also, it is possible to provide a user with information associated with a work progress state and an expected effect after work execution.
In
In
The memory system 3000 according to an embodiment of the inventive concept may perform an optimization operation on the storage device 3200 via application installation, setup of a user interface UI, a loop operation, and so on.
The storage device 3200 may have a P/E cycle warranty number decided according to a maker. That is, referring to
The memory system 3000 according to an embodiment of the inventive concept may recommend optimization setup on the storage device 3200 using an available P/E cycle (PE2−PE1) and a warranty period (T2−T1) of the storage device 3200. A user may decide a recommend level on a performance enhancement level of the storage device 3200 in a direction the user wants, based on the optimization setup.
Referring to
As described above, the recommend level may be calculated using an available P/E cycle of the storage device 3200. The recommend level may be a level decided such that the remaining warranty period is sufficiently utilized. The recommend level may be dynamically changed via periodic checking of a state of a storage device at a loop operation, which will be described later, and information on a use time input by a user.
In
In operation S410, the memory system 3000 may be at an initial state where the application 3110 is installed. In operation S420, whether a user sets an operating condition of a storage device 3200 via the application 3110 may be determined.
If user's setting does not exist, the memory system 3000 may operate at the initial state where the application 3110 is installed. That is, in operation S442, the memory system 3000 may request a current P/E cycle at the storage device 3200 and write data usage of a memory at an operating system 3120. In operation S443, the memory system 3000 may calculate a recommend level based on the requested information to provide the user with the recommend level.
Returning to operation S420, if user's setting exists, that is, if the user inputs adjusting on application execution and performance enhancement level, there may be performed a loop operation for executing background garbage collection.
Operation S430 may be performed to check a garbage collection condition and perform garbage collection. In operation S431, a user pattern and a storage device state may be checked. In operation S432, whether garbage collection is required may be determined. If garbage collection is not required, there may be performed an operation which is the same as the case that user's setting does not exist. If garbage collection is required, the method proceeds to operation S433, in which the garbage collection is performed.
A garbage collection execution condition may be decided in view of a P/E cycle, the amount of data written, a storage device self-request, trade-off relationship between performance and lifetime, and so on. That is, as described above, the memory system 3000 may analyze a user pattern or periodically check a storage device state for performance enhancement and lifetime guarantee of the storage device 3200, and may dynamically set the garbage collection execution condition using the collected information.
For example, a P/E cycle may be checked through comparison with a P/E cycle, allowed today or this week, using warranty lifetime and current P/E cycle information. The amount of data written may be decided according to whether the amount of data written in the past days or weeks exceeds a threshold value. The storage device state may be checked by reading state information through which a storage device automatically informs a host whether garbage collection is currently required. The storage device 3200 may check whether garbage collection is required, via embedded algorithm.
In operation S440, a recommend level may be calculated based on a P/E cycle change amount after execution of the garbage collection. Continuing to refer to
In operation S450, whether to finish the loop operation may be determined. In the case that the loop operation is not finished, the method proceeds to operation S420.
As described above, the memory system 3000 according to an embodiment of the inventive concept may perform an optimization operation on the storage device 3200 via application installation, setup of a user interface UI, a loop operation, and so on. That is, the memory system 3000 may analyze a storage device state and a user pattern using a user interface to provide a user with optimization information on the storage device 3200. With the inventive concept, a setup suitable for the user or required by the user may be applied to the storage device 3200, so that the performance and reliability of the storage device 3200 are improved.
IV. Optimization Operation Method of Mobile Device Using eMMC
The host 4100 may include an application 4110, an operating system 4120, a processor 4130, a random access memory 4140, and an eMMC driver 4150. The eMMC 4200 may include a flash memory 4210 and an eMMC controller 4220. The eMMC controller 4220 may include a CPU 4221 and a random access memory 4222. The CPU 4221 may drive eMMC firmware 4223 using the random access memory 4222.
The host 4100 may perform functions such as OS optimization, firmware update, initialization of a storage device, adjusting of an over-provisioning area, and so on via the application 4110. The host 4100 may analyze an eMMC state and a user pattern to perform an optimization operation on the eMMC 4200.
If a condition for garbage collection is satisfied, in operation S510, an eMMC driver 4150 may be requested by an application 4110 to perform garbage collection. For example, in case of an eMMC, URGENT_BKOPS or BKOPS_STATUS information may be read, and execution of the garbage collection may be requested.
The following table 1 may show a background operation status BKOPS_STATUS. In the table 1, there may be defined an interface in which the eMMC determines status information indicating whether a background operation is required and sends a determination result to an application.
For the application 4110 to control an execution frequency of a background operation, there may be required an interface and a function for adjusting a BKOPS_STATUS determining level of the eMMC 4200. For this, an interface for BKOPS_STATUS may be newly added.
In operation S520, an eMMC driver 4150 may issue a command to the eMMC 4200 to perform garbage collection. In operation S530, the application 4110 may determine whether a garbage collection operation of the eMMC 4200 is ended, via the eMMC driver 4150. In the case that the garbage collection operation of the eMMC 4200 is not ended, in operation S535, status information of the eMMC 4200 may be sent to a user. Afterwards, the method proceeds to operation S530. In the case that the garbage collection operation of the eMMC 4200 is ended, in operation S540, the user may be guided such that the eMMC 4200 operates at an optimal condition according to the status information of the eMMC 4200.
A mobile device 4000 according to an embodiment of the inventive concept may collect a user pattern and eMMC status information via the application 4110, and may issue an optimization operation execution command to the eMMC 4200 via the application 4110. With the inventive concept, it is possible to control the eMMC 4200 using information obtained by analyzing the user pattern. Also, the performance and reliability of the eMMC 4200 may be improved by applying a setup suitable for a user or required by the user to the eMMC 4200.
V. Applications of Memory System and Mobile Device
Hereinafter, a memory system according to an embodiment of the present general inventive concept and application examples thereof will be described with reference to
Referring to
The controller 5200 is connected to a host and the non-volatile memory device 5100. In response to a request transmitted from the host, the controller 5200 is configured to access the non-volatile memory device 5100. For example, the controller 5200 is configured to control read, write, erase and background operations of the non-volatile memory device 5100. The controller 5200 is configured to provide an interface between the non-volatile memory device 5100 and the host. The controller 5200 is configured to operate a firmware to control the non-volatile memory device 5100.
The controller 5200 may further include well-known components such as a random access memory (RAM), a processing unit, a host interface, and a memory interface. The RAM is used as at least one of an operation memory of the processing unit, a cache memory between the non-volatile memory device 5100 and the host, and a buffer memory between the non-volatile memory device 5100 and the host. The processing unit controls all operations of the controller 5200.
The host interface includes a protocol to perform data exchange between the host and the controller 5200. For example, the controller 5200 is configured to perform communication with an external device (for example, host) through at least one of various interface protocols such as a universal serial bus (USB) protocol, a multimedia card (MMC) protocol, a peripheral component interconnection (PCI) protocol, a PCI-express (PCI-E) protocol, an advanced technology attachment (ATA) protocol, a serial-ATA protocol, a parallel-ATA protocol, a small computer small interface (SCSI) protocol, an enhanced small disk interface (ESDI) protocol, and an integrated drive electronics (IDE) protocol. The memory interface interfaces with the non-volatile memory device 1100. For example, the memory interface includes a NAND interface or NOR interface.
The memory system 5000 may be configured to additionally include an error correction block. The error correction block is configured to detect and correct an error of data read from the non-volatile memory device 5100 using an error correction code (ECC). As an example, the error correction block is provided as a component of the controller 5200. The error correction block may be provided as a component of the non-volatile memory device 5100.
As another example, the memory system 5000 is provided as one of various components of an electronic apparatus, such as a computer, ultra mobile PC (UMPC), workstation, net-book, personal digital assistants (PDA), portable computer, web tablet, wireless phone, mobile phone, smart phone, e-book, portable multimedia player (PMP), portable game console, navigation device, black box, digital camera, 3-dimensional television, digital audio recorder, digital audio player, digital picture recorder, digital picture player, digital video recorder, digital video player, apparatus capable of transmitting and receiving information in wireless environment, one of various electronic apparatuses constituting the home network, one of various electronic apparatuses constituting the computer network, one of various electronic apparatuses constituting the telematics network, radio-frequency identification (RFID) device, and one of various components forming the computing system.
Specifically, the non-volatile memory device 5100 or the memory system 5000 may be mounted as various types of packages. For example, the non-volatile memory device 5100 or the memory system 5000 may be mounted as a package such as package on package (PoP), ball grid arrays (BGAs), chip scale packages (CSPs), plastic leaded chip carrier(PLCC), plastic dual in line package (PDIP), die in waffle pack, die in wafer form, chip on board (COB), ceramic dual in line package (CERDIP), plastic metric quad flat pack (MQFP), small outline (SOIC), shrink small outline package (SSOP), thin small outline (TSOP), thin quad flat pack (TQFP), system in package (SIP), multi-chip package (MCP), wafer-level fabricated package (VVFP), wafer-level processed stack package (WSP).
Referring to
Although
Referring to
The memory system 6000 is electrically connected to the central processing unit 7100, the RAM 7200, the user interface 7300 and the power supply 7400 via a system bus 7500. The data provided through the user interface 7300 or processed by the central processing unit 7100 is stored in the memory system 6000.
Although
For instance, the computing system 7000 may be configured to include both of the memory systems 5000 and 6000 described with reference to
The inventive concept may not be limited to a flash memory device. The inventive concept may be applied to all storage devices which perform address conversion via a translation layer.
While the inventive concept has been described with reference to exemplary embodiments, 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 present invention. Therefore, it should be understood that the above embodiments are not limiting, but illustrative.
Number | Date | Country | Kind |
---|---|---|---|
10-2012-0005764 | Jan 2012 | KR | national |
10-2013-0001708 | Jan 2013 | KR | national |