/[public]/fat-epoc/trunk/fat-epoc-2.6.22.diff
ViewVC logotype

Annotation of /fat-epoc/trunk/fat-epoc-2.6.22.diff

Parent Directory Parent Directory | Revision Log Revision Log


Revision 306 - (hide annotations)
Sat Sep 29 23:55:30 2007 UTC (17 years, 1 month ago) by frodo
File size: 5892 byte(s)
(Frodo) Release 1.6: fixed comma/semicolon confusion

1 frodo 303 diff -up -r linux-2.6.22.org/fs/fat/dir.c linux-2.6.22/fs/fat/dir.c
2     --- linux-2.6.22.org/fs/fat/dir.c 2007-09-29 15:55:34.000000000 +0200
3     +++ linux-2.6.22/fs/fat/dir.c 2007-09-29 15:56:24.000000000 +0200
4     @@ -241,6 +241,7 @@ static int fat_parse_long(struct inode *
5     {
6     struct msdos_dir_slot *ds;
7     unsigned char id, slot, slots, alias_checksum;
8     + int epoc = MSDOS_SB(dir->i_sb)->options.epoc;
9    
10     if (!*unicode) {
11     *unicode = (wchar_t *)__get_free_page(GFP_KERNEL);
12     @@ -287,6 +288,8 @@ parse_long:
13     }
14     if ((*de)->name[0] == DELETED_FLAG)
15     return PARSE_INVALID;
16     + if (epoc && ((*de)->name[0] == EOD_FLAG))
17     + return PARSE_EOF;
18     if ((*de)->attr == ATTR_EXT)
19     goto parse_long;
20     if (IS_FREE((*de)->name) || ((*de)->attr & ATTR_VOLUME))
21     @@ -320,6 +323,7 @@ int fat_search_long(struct inode *inode,
22     unsigned short opt_shortname = sbi->options.shortname;
23     loff_t cpos = 0;
24     int chl, i, j, last_u, err;
25     + int epoc = sbi->options.epoc;
26    
27     err = -ENOENT;
28     while(1) {
29     @@ -329,6 +333,9 @@ parse_record:
30     nr_slots = 0;
31     if (de->name[0] == DELETED_FLAG)
32     continue;
33     + if (epoc && (de->name[0] == EOD_FLAG))
34     + goto EODir;
35     +
36     if (de->attr != ATTR_EXT && (de->attr & ATTR_VOLUME))
37     continue;
38     if (de->attr != ATTR_EXT && IS_FREE(de->name))
39     @@ -456,6 +463,8 @@ static int __fat_readdir(struct inode *i
40     int chi, chl, i, i2, j, last, last_u, dotoffset = 0;
41     loff_t cpos;
42     int ret = 0;
43     + int epoc = MSDOS_SB(sb)->options.epoc;
44     +
45    
46     lock_kernel();
47    
48     @@ -486,6 +495,8 @@ GetNew:
49     parse_record:
50     long_slots = 0;
51     /* Check for long filename entry */
52     + if (epoc && (de->name[0] == EOD_FLAG))
53     + goto EODir;
54     if (isvfat) {
55     if (de->name[0] == DELETED_FLAG)
56     goto RecEnd;
57     @@ -809,7 +820,10 @@ static int fat_get_short_entry(struct in
58     struct buffer_head **bh,
59     struct msdos_dir_entry **de)
60     {
61     + int epoc = MSDOS_SB(dir->i_sb)->options.epoc;
62     while (fat_get_entry(dir, pos, bh, de) >= 0) {
63     + if (epoc && ((*de)->name[0] == EOD_FLAG))
64     + return -ENOENT;
65     /* free entry or long name entry or volume label */
66     if (!IS_FREE((*de)->name) && !((*de)->attr & ATTR_VOLUME))
67     return 0;
68     @@ -1187,6 +1201,25 @@ error:
69     return err;
70     }
71    
72     +int fat_write_zero_entry(struct inode *dir, loff_t curr)
73     +{
74     + struct msdos_dir_entry *de = NULL;
75     + struct buffer_head *bh = NULL;
76     + loff_t pos;
77     + int err = 0;
78     +
79     + pos = curr;
80     + if (fat_get_entry(dir,&pos,&bh,&de) < 0)
81     + return 0;
82     +
83     + de->name[0] = EOD_FLAG;
84     + mark_buffer_dirty(bh);
85     + if (IS_DIRSYNC(dir))
86     + err = sync_dirty_buffer(bh);
87     + brelse(bh);
88     + return err;
89     +}
90     +
91     int fat_add_entries(struct inode *dir, void *slots, int nr_slots,
92     struct fat_slot_info *sinfo)
93     {
94     @@ -1196,6 +1229,8 @@ int fat_add_entries(struct inode *dir, v
95     struct msdos_dir_entry *de;
96     int err, free_slots, i, nr_bhs;
97     loff_t pos, i_pos;
98     + int epoc = sbi->options.epoc;
99     + int last_entry = 0;
100    
101     sinfo->nr_slots = nr_slots;
102    
103     @@ -1209,7 +1244,9 @@ int fat_add_entries(struct inode *dir, v
104     if (pos >= FAT_MAX_DIR_SIZE)
105     goto error;
106    
107     - if (IS_FREE(de->name)) {
108     + if (epoc && (de->name[0] == EOD_FLAG))
109     + last_entry = 1;
110     + if (last_entry || IS_FREE(de->name)) {
111     if (prev != bh) {
112     get_bh(bh);
113     bhs[nr_bhs] = prev = bh;
114     @@ -1239,6 +1276,17 @@ found:
115     err = 0;
116     pos -= free_slots * sizeof(*de);
117     nr_slots -= free_slots;
118     +
119     + /* We need to write an end-of-directory slot. And we do it first,
120     + * because we want to keep the directory in a readble state.
121     + * Note that there is no need to remove it on error, as it is beyond
122     + * the visible end of directory anyway.
123     + */
124     + if (epoc && !nr_slots && last_entry)
125     + err = fat_write_zero_entry(dir, pos + free_slots * sizeof(*de));
126     + if (err)
127     + goto error;
128     +
129     if (free_slots) {
130     /*
131     * Second stage: filling the free entries with new entries.
132     Only in linux-2.6.22/fs/fat: dir.c.orig
133     diff -up -r linux-2.6.22.org/fs/fat/inode.c linux-2.6.22/fs/fat/inode.c
134     --- linux-2.6.22.org/fs/fat/inode.c 2007-09-29 15:55:34.000000000 +0200
135     +++ linux-2.6.22/fs/fat/inode.c 2007-09-29 15:56:24.000000000 +0200
136     @@ -856,6 +856,7 @@ enum {
137     Opt_charset, Opt_shortname_lower, Opt_shortname_win95,
138     Opt_shortname_winnt, Opt_shortname_mixed, Opt_utf8_no, Opt_utf8_yes,
139     Opt_uni_xl_no, Opt_uni_xl_yes, Opt_nonumtail_no, Opt_nonumtail_yes,
140     + Opt_epoc,
141     Opt_obsolate, Opt_flush, Opt_err,
142     };
143    
144     @@ -878,6 +879,7 @@ static match_table_t fat_tokens = {
145     {Opt_showexec, "showexec"},
146     {Opt_debug, "debug"},
147     {Opt_immutable, "sys_immutable"},
148     + {Opt_epoc, "epoc"},
149     {Opt_obsolate, "conv=binary"},
150     {Opt_obsolate, "conv=text"},
151     {Opt_obsolate, "conv=auto"},
152     @@ -1037,6 +1039,10 @@ static int parse_options(char *options,
153     case Opt_flush:
154     opts->flush = 1;
155     break;
156     + case Opt_epoc:
157     + opts->epoc = 1;
158     + break;
159     +
160    
161     /* msdos specific */
162     case Opt_dots:
163     Only in linux-2.6.22/fs/fat: inode.c.orig
164     diff -up -r linux-2.6.22.org/include/linux/msdos_fs.h linux-2.6.22/include/linux/msdos_fs.h
165     --- linux-2.6.22.org/include/linux/msdos_fs.h 2007-09-29 15:55:56.000000000 +0200
166     +++ linux-2.6.22/include/linux/msdos_fs.h 2007-09-29 15:57:26.000000000 +0200
167     @@ -44,6 +44,7 @@
168     #define CASE_LOWER_EXT 16 /* extension is lower case */
169    
170     #define DELETED_FLAG 0xe5 /* marks file as deleted when in name[0] */
171     +#define EOD_FLAG 0x00 /* marks end of directory when in name[0] for old fats */
172     #define IS_FREE(n) (!*(n) || *(n) == DELETED_FLAG)
173    
174     /* valid file mode bits */
175     @@ -206,6 +207,7 @@ struct fat_mount_options {
176     atari:1, /* Use Atari GEMDOS variation of MS-DOS fs */
177     flush:1, /* write things quickly */
178     nocase:1, /* Does this need case conversion? 0=need case conversion*/
179 frodo 306 + epoc:1, /* Filename starting with 0x00 marks end of dir? */
180 frodo 303 usefree:1; /* Use free_clusters for FAT32 */
181     };
182    

frodo@frodo.looijaard.name
ViewVC Help
Powered by ViewVC 1.1.26