diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2017-03-16 15:12:20 +0100 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2017-03-21 16:15:25 +0100 |
commit | d51538bdbe5ea9e71a7205e39fcef387fbdb4b39 (patch) | |
tree | afdab70fe59d9b6bedbadcd11a00d67e711d3b31 /cpukit | |
parent | dosfs: Fix race condition msdos_dir_read() (diff) | |
download | rtems-d51538bdbe5ea9e71a7205e39fcef387fbdb4b39.tar.bz2 |
dosfs: Fix file name search
Do not use our long file name entry count to optimize the file name
search. The Unicode comparison must be taken into account.
Close #2939.
Diffstat (limited to 'cpukit')
-rw-r--r-- | cpukit/libfs/src/dosfs/msdos_misc.c | 24 |
1 files changed, 7 insertions, 17 deletions
diff --git a/cpukit/libfs/src/dosfs/msdos_misc.c b/cpukit/libfs/src/dosfs/msdos_misc.c index bc1ac0d2e8..21ade4ec1a 100644 --- a/cpukit/libfs/src/dosfs/msdos_misc.c +++ b/cpukit/libfs/src/dosfs/msdos_misc.c @@ -1441,6 +1441,9 @@ msdos_find_file_in_directory ( if ((*MSDOS_DIR_ATTR(entry) & MSDOS_ATTR_LFN_MASK) == MSDOS_ATTR_LFN) { + bool is_first_lfn_entry = + (lfn_start.cln == FAT_FILE_SHORT_NAME); + /* int o;*/ #if MSDOS_FIND_PRINT printf ("MSFS:[4.2] lfn:%c entry:%i checksum:%i\n", @@ -1452,7 +1455,7 @@ msdos_find_file_in_directory ( * If we are not already processing a LFN see if this is * the first entry of a LFN ? */ - if (lfn_start.cln == FAT_FILE_SHORT_NAME) + if (is_first_lfn_entry) { entry_matched = false; @@ -1464,23 +1467,10 @@ msdos_find_file_in_directory ( MSDOS_LAST_LONG_ENTRY) == 0) continue; - /* - * Does the number of entries in the LFN directory - * entry match the number we expect for this - * file name. Note we do not know the number of - * characters in the entry so this is check further - * on when the characters are checked. - */ - if (lfn_entries != (*MSDOS_DIR_ENTRY_TYPE(entry) & - MSDOS_LAST_LONG_ENTRY_MASK)) - continue; - - /* - * Get the checksum of the short entry. - */ lfn_start.cln = dir_offset; lfn_start.ofs = dir_entry; - lfn_entry = lfn_entries; + lfn_entry = (*MSDOS_DIR_ENTRY_TYPE(entry) + & MSDOS_LAST_LONG_ENTRY_MASK); lfn_checksum = *MSDOS_DIR_LFN_CHECKSUM(entry); #if MSDOS_FIND_PRINT @@ -1513,7 +1503,7 @@ msdos_find_file_in_directory ( bytes_in_entry = msdos_long_entry_to_utf8_name ( converter, entry, - (lfn_entry + 1) == lfn_entries, + is_first_lfn_entry, &entry_utf8_normalized[0], sizeof (entry_utf8_normalized)); if (bytes_in_entry > 0) { |