Universal Flash Storage (UFS) or Non-Volatile Memory Host Controller Interface Specification (NVMHCIS) is a non-volatile storage specification for digital cameras, mobile phones and consumer electronic devices. It was designed to bring higher data transfer speed and increased reliability to flash memory storage, while reducing market confusion and removing the need for different adapters for different types of cards. The standard encompasses both packages permanently attached (embedded) within a device and removable UFS memory cards.
The following summary is illustrative only and is not intended to be limiting in any way. That is, the following summary is provided to introduce concepts, highlights, benefits and advantages of the novel and non-obvious techniques described herein. Select, not all, implementations are described further in the detailed description below. Thus, the following summary is not intended to identify essential features of the claimed subject matter, nor is it intended for use in determining the scope of the claimed subject matter.
Therefore, the main purpose of the present disclosure is to provide a method and a device for saving power to enable the system clock to be turned off adaptively when the device is idle and enable the external devices to still communicate with the device during the period when the system clock is turned off.
In an exemplary embodiment, a method for searching a buffer of a non-volatile storage host controller is provided. The method includes obtaining a command-based identifier of a command when a system level setting of a first format is enabled; and checking a format information on whether the first format or a second format is used to execute the command according to the identifier.
In another exemplary embodiment, a system for searching a buffer of a non-volatile storage is provided. The system includes a host and a non-volatile storage coupled to the host. The host is configured to obtain a command-based identifier of a command when a system level setting of a 2 double word physical region description table (2DW PRDT) format is enabled; and check whether to use the 2DW PRDT format or a 4 double word physical region description table (4DW PRDT) format to execute the command according to the identifier.
These and other objectives of the present invention will no doubt become obvious to those of ordinary skill in the art after reading the following detailed description of the preferred embodiment that is illustrated in the various figures and drawings.
Universal flash storage (UFS) host controller interface (HCI) is used to provide a universal hardware interface to UFS, making it convenient for the host controller driver to use different host controller implementations that follow HCI specification.
Therefore, the problem of using various hardware interfaces can be reduced, and the software driver can be compatible. A host and a device can communicate through UFS protocol information units (UPIUs).
When the host sends a read command to the device, the device needs to return data to the host, and the device transmits data to the host through DATA IN UPIU. When the host sends a write command to the device, the host needs to write data to the device, and the host transmits data to the device through DATA OUT UPIU. When the UFS host writes data to the device, it considers whether the device can receive the data at this time (because the device may not have enough space to receive the host data at one time). After it sends the write command to the device, the data will not be transmitted to the device immediately but will wait for notification from the device. When the device is ready to receive data, the device informs the host through READY TO TRANSFER UPIU (RTT). When the host receives the RTT, it starts transmitting data according to the RTT information. The RTT includes the amount of data to be transmitted each time, and the host transmits the data according to the RTT. Therefore, the host can only send DATA OUT UPIU after receiving the RTT from the device.
Besides, Out of Order (OOO) data transfer feature is defined in UFS specification. The OOO feature allows data blocks to be written to or read from the memory in a different order than a sequential order. For example, the data to be transferred contains a first portion 102, a middle portion 104, and a last portion 106. Without OOO, the data to be transferred would be transmitted according to the order. When OOO is applied, the host may transfer the middle portion 104 in the beginning, followed with the last portion 106 and the first portion 102 as shown in
To address this issue, UFSHCI defines a 2 double word physical region description table (2DW PRDT) format to ease the implementation of out of order (OOO) feature. In the OOO mode, the host has to find the corresponding physical region description (PRD) buffer by data buffer offset in RTT/DATA IN UPIU. By setting common data size (CDS) to a logic block size(bLogicalBlockSize)*N (n is a positive integer), the host can easily find the corresponding PRD buffer using simple division (shifter) instead of a complicated searching algorithm. The size of CDS is normally 4 KB, but the maximum can be 256 KB Usually, the CDS may be set as 4 KB, 8 KB or 16 KB but the present embodiment is not limited thereto.
However, the 2DW PRDT format is a system-wise setting. Once enabled, all transfer requests have to adopt the 2DW PRDT format, but UFS specification only guarantees data buffer offset alignment to the logic block size (bLogicalBlockSize) for certain commands, such as READ/WRITE commands. In practical usage, data buffer offset alignment is not implemented on some devices.
In an embodiment of the present invention, a 2DW PRDT format identifier on the command basis is provided. The 2DW PRDT format identifier in this embodiment is included in the command and is used for checking whether the 2DW PRDT format is applied when executing the command.
The main function of UFS transport protocol (UTP) layer is to transmit UFS protocol information units (UPIUs). UPIU is the basic exchange data unit between the host and the device.
A physical region description table (PRDT) is used when the host system communicates with the UFS device to perform data transfers. The PRDT essentially describes the physical memory regions in the host that will be involved in the data transfer operation.
In step S202, a descriptor is obtained in a command such as ready to transfer (RTT) or DATA IN UFS protocol information unit (UPIU).
In step S204, the descriptor is checked to determine if it needs PRD. If it needs PRD, then go to step S206. In step S206, if the 2DWPRDTEN of the system-wise setting is 1, indicating that the 2DW mode can be used, then go to step S208. If the 2DWPRDTEN of the system-wise setting is 0, indicating that the 4DW mode needs to be used, then go to step S212.
In step S208, whether the 2DW mode is selected or not can be decided according to a command-based identifier of the command. In one embodiment, a reserved bit in UFS transfer protocol (UTP) transfer request descriptor of a command is used as the identifier for determining whether the 2DW mode is applied for this command. If the reserved bit is 1, then the 2DW mode is selected in this command and go to step S210. If the reserved bit is 0, then the 4DW mode is selected in this command and go to step S212.
In another embodiment, a value of a register carried by each command is used as the identifier for determining whether the 2DW mode is applied. If the data in the value of the register is 1, then the 2DW mode is selected in this command and go to step S210. If the value in the register is 0, then the 4DW mode is selected in this command and go to step S212. To be clear, those embodiments mentioned above are merely examples of the present invention. All the hardware-based or software-based identifier can be used for determining whether the 2DW mode is applied for the command shall be covered in the present invention.
In step S210, the PRD offset is checked using the 2DW mode, and the PRD is obtained in step S214. In step S212, the PRD offset is checked using the 4DW mode, and the PRD is obtained in step S214.
A UFS transport protocol (UTP) transfer request list contains a series of data structures named UTP transfer request descriptor (UTRD). UTRD details a command to be executed and related data. The UFS host software initiates a command by inserting a UTRD into this list. In one embodiment, the commands are dispatched based on the order specified by a doorbell register mechanism, where each command corresponds to a slot, and the retrieval order is determined by the doorbell register from the lowest to the highest bit.
In the other embodiment, the MCQ (Multiple Command Queue) architecture operates on the concept of queues, where UTRDs are inserted and retrieved in order.
However, the order in which they are executed may change. At this time, the host controller manages all data transfer operations related to this command on behalf of the processor. Completion of the command will generate an interrupt or update the status field in the UTRD.
In DW2, the last data byte count (LDBC) is set for the 2DW mode to provide the data bytes for the last PRD The size of LDBC is normally 4B (4 bytes), but the maximum can be 256 KB. Common data size (CDS) is set for the 2DW mode to provide the data bytes for the PRD. The size of CDS is normally 4 KB, but the maximum can be 256 KB. Usually, the CDS may be set as 4 KB, 8 KB or 16 KB but the present embodiment is not limited thereto. Each UTRD defines the size of LDBC and CDS, so that they can be used in the 2DW mode. The size of write/read data transferred is CDS*N+LDBC, thus the host can find the data position in the memory with a simple division and searching algorithm.
The method for searching a buffer of a UFS host controller is command-based by setting a value in the 27th bit (original a reserved bit) of DW0 to be 1b (2DW mode) or 0b (4DW mode). In another embodiment, a register carried with the request command can be set to be 1 for the 2DW mode or 0 for the 4DW mode. The host uses the 2 DW PRDT format with a last data byte count (LDBC) and a common data size (CDS) if the 2 DW PRDT format is to be used. The 2DW PRDT format is applied when the data buffer offset of UPIU is a multiple of a common data size (CDS). If the data buffer offset or the data transfer size is not a multiple of the CDS, then only LDBC is used to transfer data in the 2DW mode.
To be noted, this method for searching a buffer mentioned above can be applied on Non-Volatile Memory Express (NVMe) as well. Using a command-based identifier to determine whether the 2DW mode or the 4DW mode be applied to a command when executing.
In another embodiment, a system for searching a buffer of the non-volatile storage host controller is provided. The system includes a host and a non-volatile storage coupled to the host. The host is configured to execute the methods mentioned above.
In conclusion, the method and the system for searching a buffer of the non-volatile storage host controller are implemented in the embodiments of the present invention. The method can be implemented based on the reserved bit in the UTRD or implemented based on the register carried by the command. Therefore, the method is command-based and can change flexibly between the 2DW mode and the 4DW mode for each command. If the command uses the 2DW mode, the data buffer offset is checked whether it is a multiple of the CDS to provide a solution with LDBC only or a solution with CDS and LDBC.
Those skilled in the art will readily observe that numerous modifications and alterations of the device and method may be made while retaining the teachings of the invention. Accordingly, the above disclosure should be construed as limited only by the metes and bounds of the appended claims.
This application claims the benefit of U.S. Provisional Application No. 63/487,627, filed on Mar. 1, 2023. The content of the application is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
63487627 | Mar 2023 | US |