The invention relates in general to a control method and a control system, and more particularly to a control method for a storage device of a driving recorder and a storage device control system.
A file system is a system for managing files in a storage device (e.g., an SD card or a hard drive) to efficiently conduct the storage device. A file allocation table (FAT) is a common file system.
The directory entry 930 records a file name and a starting data cluster number in the storage device 900. The FAT 920 records a FAT chain of the data clusters. For example, the directory entry 930 indicates that a file FA is stored in the storage device 900, and the data of the file FA is stored in the data cluster 940 numbered “13”. In the FAT 920, the position corresponding to the data cluster 940 numbered “13” shows “14”, which indicates that subsequent data of the file FA is stored in the data cluster 940 numbered “14”. In the FAT 920, the position corresponding to the data cluster 940 numbered “14” shows “15”, which indicates that subsequent data of the file FA is stored in the data cluster 940 numbered “15”, and so forth. In the FAT 920, the position corresponding to the data cluster 940 numbered “20” shows “EOC”, which indicates that the data cluster 940 numbered “20” is end of cluster-chain (EOC) of the data cluster 940.
However, unexpected power disconnections caused by car accidents may result in a reading failure due to an incomplete FAT chain. For example, as shown in
The invention is directed to a control method for a storage device of a driving recorder and a storage device control system, which configure a storage device according to a predetermined file allocation table (FAT) and a predetermined directory entry to prevent reading failures caused by unexpected power disconnections.
According to an aspect of the present invention, a control method for a storage device of a driving recorder is provided. The control method for a storage device of a driving recorder includes steps of: configuring a directory entry of a storage device according to a predetermined directory entry stored in a storage unit; configuring a file allocation table (FAT) of the storage device according to a predetermined FAT stored in the storage unit; and controlling a controller to write data to the storage device according to the directory entry and the FAT.
According to another aspect of the present invention, a storage device control system is provided. The storage device control system includes a storage unit, a controller and a processor. The storage unit stores a predetermined directory entry and a predetermined FAT. The controller writes data to a storage device. The processor performs steps of: configuring a directory entry of the storage device according to the predetermined directory file; configuring a FAT of the storage device according to the predetermined FAT; and controlling the controller to write data to the storage device according to the directory file and the FAT.
According to another embodiment of the present invention, a control method for a storage device of a driving recorder is provided. The method includes configuring a directory entry of the storage device according to a predetermined directory entry stored in a storage unit; configuring a file allocation table (FAT) of the storage device according to a predetermined FAT stored in the storage unit; and controlling a controller to write data to the storage device according to the directory entry and the FAT, wherein entries in the FAT correspond to respective predetermined clusters in the storage device and wherein each entry in the FAT remains unchanged after new data is written to the respective predetermined clusters in the storage device.
According to one aspect of the present invention, the data comprises data from at least two files, and the FAT is configured to cause the two files to be stored in interleaved clusters.
According to another aspect of the present invention, the at least two files are video files having a same bit rate, and wherein configuring the FAT of the storage device comprises allocating a same number of the predetermined clusters to each of the at least two files.
According to still another aspect of the present invention, the at least two files are video files having bit rates different from each other, and wherein configuring the FAT of the storage device comprises allocating the predetermined clusters to each of the at least two files according to the bit rates of the at least two files.
According to another embodiment, a storage device control system is provided. The system includes a storage unit, storing a predetermined directory entry and a predetermined file allocation table (FAT); a controller, writing data to a storage device; and a processor, performing steps of: configuring a directory entry of the storage device according to the predetermined directory entry; configuring a FAT of the storage device according to the predetermined FAT; and controlling the controller to write data to the storage device according to the directory entry and the FAT, wherein entries in the FAT correspond to respective predetermined clusters in the storage device and wherein each entry in the FAT remains unchanged after new data is written to the respective predetermined clusters in the storage device.
The above and other aspects of the invention will become better understood with regard to the following detailed description of the non-limiting embodiments. The following description is made with reference to the accompanying drawings.
In view of issues of a storage device of a driving recorder of the prior art, the present invention provides a control method for a storage device of a driving recorder and a storage device control system, which configure a file allocation table (FAT) and a directory entry of a storage device according to a predetermined FAT and a predetermined directory entry to prevent reading failures caused by an unexpected power disconnection.
As shown in
In other words, the data of the file FC is preset to be stored in the data clusters numbered “11” to “15”, and the data of the file FD is preset to be stored in the data clusters numbered “16” to “20”. It should be noted that, although the directory entry 430 and the FAT 420 are already configured, in the storage device 400, the data clusters corresponding to the file FC and the file FD (i.e., the data clusters numbered “11” to “20”) are not stored with the data corresponding to the file FC and the file FD, as shown in
For example, as the driving recorder starts recording, the processor 130 selects a file for writing data therein according to the directory entry 430 (step S704). In one embodiment, the file names in the directory entry 430 carry time information, and so the processor 130 can select an oldest file for writing data therein according to the file names in the directory entry 430. Taking
Next, the processor 130 changes the file name in the directory entry 430 corresponding to the file (step S705). In continuation of the above example, the processor 130 changes, in the directory entry 430, the file name of the file that the processor 130 selects for writing data therein from “FC” to “FE”, as shown in
The processor 130 controls the controller 120 to write data to the data clusters in the storage device 400 configured for the file (step S706). In continuation of the above example, the processor 130 controls the controller 120 to write data sequentially to the data clusters numbered “11” to “15” in the storage device 400, as shown in
Next, the processor 130 determines whether to continue writing data (step S707). If data is continued to be written, steps S704 to S706 are repeated; if not, the process ends.
It is known from the above that, during the process in which the processor 130 writes data to the storage device 400, the FAT 420 is not updated. Thus, even if the driving recorder encounters an unexpected power disconnection, the FAT chain corresponding to a file in the FAT is kept intact, and the data in the file in the storage device 400 can still be completely read.
Further, in the prior art, a processor needs to spend time on searching for empty data clusters for writing data therein. After multiple operations of writing and deleting a file, empty data clusters are usually in fragments, and so file writing performance is reduced. Compared to the prior art, the data clusters of files in the present invention are pre-configured and do not change, meaning that the processor need not spend time on searching for empty clusters for writing data therein, thereby enhancing the file writing performance. In one embodiment, the clusters of files may be configured as being consecutive (as shown in
Further, in the prior art, a processor needs to determine whether an available space is sufficient before writing data. If the available space is insufficient, the processor needs to delete the file name and a starting data cluster corresponding to at least one file from the directory entry, and also delete the FAT chain corresponding to the least one file from the FAT, reducing the file writing performance. Compared to the prior art, the processor 130 of the present invention is not required to determine whether an available space is sufficient before writing data, nor is the processor required to delete the file name and the starting data cluster from the directory file and the FAT chain from the FAT, thereby further enhancing the file writing performance.
In this regard,
However, when multiple files are written to SD storage 1110 at the same time in this fashion, an undesirable phenomenon results which reduces the efficiency of a contiguous SD write operation. More specifically, the SD write operation is based on cluster and, as such, when F File X and R File X are written to SD storage 1110 at (substantially) the same time, the actual behavior is that after F File X is written to several clusters, the system will switch to write R File X to several clusters. The system will continue to switch between the two files as indicated by numbers 1-8 in
In order to address the random write issue explained with reference to
As an example, assume that the bit rate ratio of F File X and R File X is 1:1. In such a case, FAT 1230 is formatted or configured such that each successive cluster of F File X and R File X is interleaved with one another equally, resulting in data clusters stored as shown in the plurality of data clusters 1250 and at 1260.
Of course, the bit rate ratio of F File X and R File X can also be enlarged by K times, generally represented as K:K (e.g., with K=2). In such a case, the cluster list of the two video files can be interleaved as shown in
From the foregoing, those skilled in the art will appreciate that an undesirable random write phenomenon can occur when storing multiple files in per-file, separate, but contiguous allocated clusters. This phenomenon causes SD write performance to decline. The interleaved approach described herein addresses this defect. Further, according to the bit rate ratio between video files, the cluster list interleaving of each (video) file is configured during formatting. When the file is recorded, the system switches SD write between files according to the bit rate ratio. And, significantly, SD random write is avoided, resulting in continuous cluster write that enables SD write efficiency to be maintained.
As noted with respect to the embodiments of
The interleaved approach may also use the bit rate ratio between (video) files to be recorded substantially at the same time to configure the allocation of each cluster. In the formatting stage, the cluster list is interleaved. When this file group (e.g., F File X and R File X) is recorded at substantially the same time, the system interlaces SD write to different files according to the ratio of the number of clusters configured. This combination can achieve continuous cluster write and maintain the efficiency of SD write.
Finally, it is noted that the described cluster list interleaved mechanism is not limited to only two video files (e.g., F File X and R File X) but can also be applied to three or more interleaved video file clusters.
While the invention has been described by way of example and in terms of the above embodiments, it is to be understood that the invention is not limited thereto. On the contrary, it is intended to cover various modifications and similar arrangements and procedures, and the scope of the appended claims therefore should be accorded the broadest interpretation so as to encompass all such modifications and similar arrangements and procedures.
Number | Date | Country | Kind |
---|---|---|---|
106121373 | Jun 2017 | TW | national |
This application is a continuation-in-part of U.S. application Ser. No. 15/709,813, filed Sep. 20, 2017, which claims the benefit of Taiwan application Serial No. 106121373, filed Jun. 27, 2017, the subject matter of both which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5367671 | Feigenbaum et al. | Nov 1994 | A |
5461483 | Nakajima | Oct 1995 | A |
5574907 | Jernigan et al. | Nov 1996 | A |
5581311 | Kuroiwa | Dec 1996 | A |
5661800 | Nakashima et al. | Aug 1997 | A |
5717886 | Miyauchi | Feb 1998 | A |
6247126 | Beelitz | Jun 2001 | B1 |
6604170 | Suzuki | Aug 2003 | B1 |
6675276 | Schulze et al. | Jan 2004 | B2 |
7856452 | Itoh | Dec 2010 | B2 |
8468290 | Abe | Jun 2013 | B2 |
8713283 | Sinclair | Apr 2014 | B2 |
8768986 | Kishikawa et al. | Jul 2014 | B2 |
20030093611 | Schulze et al. | May 2003 | A1 |
20050050108 | Sawant et al. | Mar 2005 | A1 |
20060020745 | Conley | Jan 2006 | A1 |
20070162525 | Abe | Jul 2007 | A1 |
20080080323 | Katsuo et al. | Apr 2008 | A1 |
20080172426 | Patel et al. | Jul 2008 | A1 |
20090322905 | Matsuda | Dec 2009 | A1 |
20110055297 | Maeda et al. | Mar 2011 | A1 |
20110196904 | Kishikawa et al. | Aug 2011 | A1 |
20120173595 | Salters | Jul 2012 | A1 |
20130036257 | Suda et al. | Feb 2013 | A1 |
20130110889 | Shogome | May 2013 | A1 |
20140279950 | Shapiro et al. | Sep 2014 | A1 |
Number | Date | Country |
---|---|---|
200839773 | Oct 2008 | TW |
Entry |
---|
“Method for providing extensible dos-fat system structures on one-time programmable media”, https://scholar.google.com/scholar?hl=en&as, Apr. 30, 2020, 3 pages. |
InnovatonQ Plus-IP.com, https://iq.ip.com/discover, Apr. 30, 2020, 1 page. |
Number | Date | Country | |
---|---|---|---|
20200363973 A1 | Nov 2020 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15709813 | Sep 2017 | US |
Child | 16985288 | US |