This Application claims priority of Taiwan Patent Application No. 106135474, filed on Oct. 17, 2017, the entirety of which is incorporated by reference herein.
The present invention relates to data storage devices and methods for operating non-volatile memory.
There are various forms of non-volatile memory (NVM) for long-term data retention, such as flash memory, magnetoresistive RAM, ferroelectric RAM, resistive RAM, spin transfer torque-RAM (STT-RAM), and so on. A non-volatile memory may be combined with a controller to form a data storage device to be accessed by a host.
Considering the wear leveling of the different storage cells of a non-volatile memory, the physical space of a non-volatile memory is dynamically allocated for data storage. The physical space allocated to store a boot code (hereinafter represented by BootISP) may be different in the different non-volatile memories because of the different yield conditions of the different non-volatile memories. A controller of a data storage device needs to perform a time-consuming search of the non-volatile memory to get the boot code BootISP. When the data storage device wakes up from a sleep mode, this time-consuming search can be a considerable inconvenience to the user.
A data storage device in accordance with an exemplary embodiment of the disclosure has a non-volatile memory and a controller. The microprocessor loads boot code from the non-volatile memory to a not-always-on area of the volatile memory according to a script loaded on an always-on area of the volatile memory. The microprocessor executes the boot code loaded on the not-always-on area to load an in-system program from the non-volatile memory to the not-always-on area for execution of the in-system program.
In another exemplary embodiment, a method for operating a non-volatile memory is disclosed, comprising: providing a volatile memory that includes an always-on area and a not-always-on area; loading boot code from the non-volatile memory to the not-always-on area according to a script loaded on the always-on area; and executing the boot code loaded on the not-always-on area to load an in-system program from the non-volatile memory to the not-always-on area for execution of the in-system program.
A detailed description is given in the following embodiments with reference to the accompanying drawings.
The present invention can be more fully understood by reading the subsequent detailed description and examples with references made to the accompanying drawings, wherein:
The following description shows exemplary embodiments of carrying out the invention. This description is made for the purpose of illustrating the general principles of the invention and should not be taken in a limiting sense. The scope of the invention is best determined by reference to the appended claims.
A non-volatile memory for long-term data retention may be a flash memory, a magnetoresistive RAM, a ferroelectric RAM, a resistive RAM, a spin transfer torque-RAM (STT-RAM) and so on. A non-volatile memory may be used to implement a data storage device or a data center. The following discussion is regarding flash memory in particular as an example.
A flash memory is often used as a storage medium in today's data storage devices, for implementations of a memory card, a USB flash device, an SSD and so on. In another exemplary embodiment, a flash memory is packaged with a controller to form a multiple-chip package and named eMMC. A data storage device using a flash memory as a storage medium can be applied to a variety of electronic devices, including a smartphone, a wearable device, a tablet computer, a virtual reality device, etc. A calculation module of an electronic device may be regarded as a host that operates a data storage device equipped on the electronic device to access a flash memory within the data storage device.
A data center may be built with flash memories as the storage medium. For example, a server may operate an array of SSDs to form a data center. The server may be regarded as a host that operates the SSDs to access the flash memories within the SSDs.
The host side distinguishes the flash memory storage contents by logical addresses (for example, according to a logical block address LBA or a global host page number GHP, etc.). In order to optimize the use of the flash memory, the storage space of the flash memory is dynamically allocated to correspond to logical addresses recognized by the host. For example, to avoid a damaged block, different physical areas may be allocated in the different flash memories to store the boot code BootISP.
Generally, the storage space of flash memory is divided into a plurality of blocks. Each block includes a plurality of pages. Each page may be further divided into a plurality of storage units. Multiple channels may be used in flash memory accessing. The multiple channels may be used alternately to access pages of data from the flash memory. In another example, data stored in the different areas corresponding to the different channels may be accessed at the same time. The boot code BootISP may be divided into sections to be stored in the same block or separated into different blocks. Each second of boot code BootISP is accessed according to a channel number and a page number. Alternatively, there may be other implementations of the spatial division of the flash memory.
Generally, the boot code BootISP is loaded from the flash memory prior to an in-system program (ISP). By executing the boot code BootISP, a booting procedure to power on the flash memory to leave a power-off or power-saving mode is completed. In the disclosure, a script BootDS to load the boot code BootISP is provided. The script BootDS is stored to an always-on area of a volatile memory. The volatile memory may be built in or attached to the controller of the flash memory. The script BootDS lists physical parameters which are required to access the flash memory for the boot code BootISP. For example, the physical parameters may indicate a channel, a physical address, and so on to read the boot code BootISP from the flash memory. When the data storage device is awakened from a sleep mode (for example, being switched from a power state S4 to a power state S1 defined in NVMe), the physical parameters for getting the boot code BootISP from the flash memory are obtained from the script BootDS. According to the obtained physical parameters, the controller gets the boot code BootISP without sequentially searching the flash memory. Without the complex searching, the controller efficiently gets the boot code BootISP. Specifically, the storage size of the volatile memory is not always occupied by of the boot code BootISP because the boot code BootISP generally is maintained in the non-volatile memory.
The data storage device 100 includes a flash memory 102 and a controller 104. A host 106 may be coupled to the data storage device 100 to access the flash memory 102 through the controller 104. For a booting procedure, a boot code BootISP and a script BootDS for loading the boot code BootISP are stored in the flash memory 102. The flash memory 102 further stores an in-system program ISP to be loaded and executed after the booting procedure. The controller 104 includes a microprocessor 112, a read-only memory 114 and a volatile memory 116. The read-only memory 114 and/or the volatile memory 116 may be combined into the microprocessor 112 in structure. In some exemplary embodiments, the microprocessor 112, the read-only memory 114 and the volatile memory 116 are separately provided. The read-only memory 114 stores a read-only code (ROM code). The volatile memory 116 may be an SRAM (static random access memory), which is provided for temporary storage of program code, calculation results, mapping relationship between the host 106 and the flash memory 102, and so on. The following description focuses on the booting procedure.
As shown, the volatile memory 116 includes an always-on area 122 and a not-always-on area 124. When the data storage device 100 is switched from a normal operation mode (e.g. a power state S1) to a sleep mode (e.g. a power state S4), the always-on area 122 still has power and important data should be stored in the always-on area 122. In the disclosure, the always-on area 122 is utilized to store the information that is required to wake up the data storage device 100. According to the disclosure, the script BootDS is loaded from the flash memory 102 and stored in the always-on area 122. By executing the script BootDS maintained on the always-on area 122, the microprocessor 112 is directed to access the flash memory 102 for the boot code BootISP. When the data storage device 100 is recovered to the normal operation mode from the sleep mode, the microprocessor 112 loads the boot code BootISP from the flash memory 102 to the not-always-on area 124 for execution. By executing the boot code BootISP, the microprocessor 112 loads the in-system program ISP from the flash memory 102 to the not-always-on area 124 for execution. Compared to the boot code BootISP that contains the cumbersome booting programs, the script BootDS used for marking locations in the flash memory 102 has a relatively small code size. Only a small space of the always-on area 122 is occupied by the script BootDS. There is still plenty of room in the always-on area 122 for other applications. For example, in a smartphone, personal security information may be stored in the always-on area 122 to speed up waking up the data storage device 100.
In an exemplary embodiment, the script BootDS is maintained in the always-on area 122 after the booting procedure of the data storage device 100, to be used when the data storage device 100 is recovered from a sleep mode to a normal operation mode. When the data storage device 100 is started or restarted from a power-off state, the microprocessor 112 operates according to the ROM code provided in the read-only memory 114 to search the flash memory 102 in a preset manner. By searching the flash memory 102, the script BootDS and the boot code BootISP are obtained. The microprocessor 112 loads the script BootDS to the always-on memory 122 and loads the boot code BootISP to the not-always-on area 124. In particular, the physical parameters (indicating locations in the flash memory 102) required for accessing the flash memory 102 for the boot code BootISP are filled to the script BootDS on the always-on area 122. In another exemplary embodiment, the booting procedure is performed earlier than the loading of the script BootDS. When the data storage device 100 is started or restarted from a power-off state, the microprocessor 112 searches the flash memory 102 for the boot code BootISP (without searching the script BootDS) and loads the boot code BootISP to the not-always-on area 124 for execution of the booting procedure. After the booting procedure, the microprocessor 112 loads the script BootDS to the always-on area 122 and writes the physical parameters required for accessing the flash memory 102 for the boot code BootISP to the script BootDS on the always-on area 122.
The script BootDS has a tag “Mode1123_DS”, and indicates an address “0x40180000” on the volatile memory 116 which is the address of the always-on area 122. In addition to a content label “BOOTISP_2017”, the script BootDS includes a field 202 for filling in a variety of physical parameters (including BtDSSecCnt, Scnt, Cnt0, Cnt1, Cnt2, Mode, Block, and three sets of page number and CH/CE number) required for getting the boot code BootISP from the flash memory 102. The script BootDS further uses a field NandCmdScript to manage detailed script steps. The detailed script steps written to the field NandCmdScript depend on the physical parameters filled to the field 202. The field 202 and the field NandCmdScript are filled to the script BootDS on the always-on area 122 when the data storage device 100 is turned on from a power-off state and the flash memory 102 is scanned. The script BootDS further records a waking-up flow InitFormDeviceSleepFlow, which describes the power sequence to wake up the different components of the data storage device 100. The waking-up flow InitFormDeviceSleepFlow further directs to the field NandCmdScript to execute the detailed script steps. The ending tag is “BootDS_Tail”.
The first section Boot1 of boot code also has the tag “Mode1123_DS”. The first section Boot1 of boot code indicates an address “0x40071000” on the volatile memory 116 which is the address of the not-always-on area 124. The first section Boot1 of boot code includes code BootISP1, information FlashInfo about the flash memory 102, and an ending tag “BootISP1_Tail”. In one embodiment, the location of the second section Boot2 of boot code in the flash memory 102 may be recorded in the code BootISP1. The first section Boot1 of boot code may be stored in the flash memory 102 subsequent to the script BootDS. For example, the first section Boot1 of boot code may be stored to the page storing the script BootDS.
The second section Boot2 of boot code has a tag “Mode1123_RT”, and indicates an address “0x40072800” on the volatile memory 116 which is the address of the not-always-on area 124. The second section Boot2 of boot code includes code BootISP2 and an ending tag “BootISP2_Tail”. In one embodiment, the location of the third section Boot3 of boot code in the flash memory 102 may be recorded in the code BootISP2.
The third section Boot3 of boot code has a tag “Mode1123_Ext”, and indicates an address “0x40074000” on the volatile memory 116 which is the address of the not-always-on area 124. The third section Boot3 of boot code includes code BootISP3, an error checking field C_ROMCodeChecksum, an ending tag “BootISP3_Tail”, and other fields (BootISP_HMAC, Super_Lightswitch, Super_Lightswitch_HMAC).
Considering the compatibility of old and new products, an operating flow for the data storage device 100 is proposed.
When the flash memory 102 is an old product and the stored information for booting is as shown in
When a tag ending with “AO” is obtained from the always-on area 122 in step S602, it means that a boot code BootISP composed of three sections Boot1, Boot2, and Boot3 is loaded on the always-on area 122. Step S614 is performed and the microprocessor 112 executes the boot code BootISP loaded on the always-on area 122. Then, the in-system program ISP is loaded from the flash memory 102 to the not-always-on area 124 in step S610 and executed in step S612.
The flow introduced in
Other techniques that load a boot code BootISP on the not-always on area 124 and loads a script BootDS (for loading the boot code BootISP) on the always-on area 122 are within the scope of the disclosure. Based on the above contents, the present invention further relates to methods for operating a non-volatile memory.
While the invention has been described by way of example and in terms of the preferred embodiments, it should be understood that the invention is not limited to the disclosed embodiments. On the contrary, it is intended to cover various modifications and similar arrangements (as would be apparent to those skilled in the art). Therefore, the scope of the appended claims should be accorded the broadest interpretation so as to encompass all such modifications and similar arrangements.
Number | Date | Country | Kind |
---|---|---|---|
106135474 | Oct 2017 | TW | national |