diff options
Diffstat (limited to 'fs/hpfs/ea.c')
| -rw-r--r-- | fs/hpfs/ea.c | 136 |
1 files changed, 69 insertions, 67 deletions
diff --git a/fs/hpfs/ea.c b/fs/hpfs/ea.c index 45e53d972b42..d8b84d113c89 100644 --- a/fs/hpfs/ea.c +++ b/fs/hpfs/ea.c | |||
| @@ -24,7 +24,7 @@ void hpfs_ea_ext_remove(struct super_block *s, secno a, int ano, unsigned len) | |||
| 24 | } | 24 | } |
| 25 | if (hpfs_ea_read(s, a, ano, pos, 4, ex)) return; | 25 | if (hpfs_ea_read(s, a, ano, pos, 4, ex)) return; |
| 26 | if (ea->indirect) { | 26 | if (ea->indirect) { |
| 27 | if (ea->valuelen != 8) { | 27 | if (ea_valuelen(ea) != 8) { |
| 28 | hpfs_error(s, "ea->indirect set while ea->valuelen!=8, %s %08x, pos %08x", | 28 | hpfs_error(s, "ea->indirect set while ea->valuelen!=8, %s %08x, pos %08x", |
| 29 | ano ? "anode" : "sectors", a, pos); | 29 | ano ? "anode" : "sectors", a, pos); |
| 30 | return; | 30 | return; |
| @@ -33,7 +33,7 @@ void hpfs_ea_ext_remove(struct super_block *s, secno a, int ano, unsigned len) | |||
| 33 | return; | 33 | return; |
| 34 | hpfs_ea_remove(s, ea_sec(ea), ea->anode, ea_len(ea)); | 34 | hpfs_ea_remove(s, ea_sec(ea), ea->anode, ea_len(ea)); |
| 35 | } | 35 | } |
| 36 | pos += ea->namelen + ea->valuelen + 5; | 36 | pos += ea->namelen + ea_valuelen(ea) + 5; |
| 37 | } | 37 | } |
| 38 | if (!ano) hpfs_free_sectors(s, a, (len+511) >> 9); | 38 | if (!ano) hpfs_free_sectors(s, a, (len+511) >> 9); |
| 39 | else { | 39 | else { |
| @@ -76,24 +76,24 @@ int hpfs_read_ea(struct super_block *s, struct fnode *fnode, char *key, | |||
| 76 | unsigned pos; | 76 | unsigned pos; |
| 77 | int ano, len; | 77 | int ano, len; |
| 78 | secno a; | 78 | secno a; |
| 79 | char ex[4 + 255 + 1 + 8]; | ||
| 79 | struct extended_attribute *ea; | 80 | struct extended_attribute *ea; |
| 80 | struct extended_attribute *ea_end = fnode_end_ea(fnode); | 81 | struct extended_attribute *ea_end = fnode_end_ea(fnode); |
| 81 | for (ea = fnode_ea(fnode); ea < ea_end; ea = next_ea(ea)) | 82 | for (ea = fnode_ea(fnode); ea < ea_end; ea = next_ea(ea)) |
| 82 | if (!strcmp(ea->name, key)) { | 83 | if (!strcmp(ea->name, key)) { |
| 83 | if (ea->indirect) | 84 | if (ea->indirect) |
| 84 | goto indirect; | 85 | goto indirect; |
| 85 | if (ea->valuelen >= size) | 86 | if (ea_valuelen(ea) >= size) |
| 86 | return -EINVAL; | 87 | return -EINVAL; |
| 87 | memcpy(buf, ea_data(ea), ea->valuelen); | 88 | memcpy(buf, ea_data(ea), ea_valuelen(ea)); |
| 88 | buf[ea->valuelen] = 0; | 89 | buf[ea_valuelen(ea)] = 0; |
| 89 | return 0; | 90 | return 0; |
| 90 | } | 91 | } |
| 91 | a = fnode->ea_secno; | 92 | a = le32_to_cpu(fnode->ea_secno); |
| 92 | len = fnode->ea_size_l; | 93 | len = le32_to_cpu(fnode->ea_size_l); |
| 93 | ano = fnode->ea_anode; | 94 | ano = fnode->ea_anode; |
| 94 | pos = 0; | 95 | pos = 0; |
| 95 | while (pos < len) { | 96 | while (pos < len) { |
| 96 | char ex[4 + 255 + 1 + 8]; | ||
| 97 | ea = (struct extended_attribute *)ex; | 97 | ea = (struct extended_attribute *)ex; |
| 98 | if (pos + 4 > len) { | 98 | if (pos + 4 > len) { |
| 99 | hpfs_error(s, "EAs don't end correctly, %s %08x, len %08x", | 99 | hpfs_error(s, "EAs don't end correctly, %s %08x, len %08x", |
| @@ -106,14 +106,14 @@ int hpfs_read_ea(struct super_block *s, struct fnode *fnode, char *key, | |||
| 106 | if (!strcmp(ea->name, key)) { | 106 | if (!strcmp(ea->name, key)) { |
| 107 | if (ea->indirect) | 107 | if (ea->indirect) |
| 108 | goto indirect; | 108 | goto indirect; |
| 109 | if (ea->valuelen >= size) | 109 | if (ea_valuelen(ea) >= size) |
| 110 | return -EINVAL; | 110 | return -EINVAL; |
| 111 | if (hpfs_ea_read(s, a, ano, pos + 4 + ea->namelen + 1, ea->valuelen, buf)) | 111 | if (hpfs_ea_read(s, a, ano, pos + 4 + ea->namelen + 1, ea_valuelen(ea), buf)) |
| 112 | return -EIO; | 112 | return -EIO; |
| 113 | buf[ea->valuelen] = 0; | 113 | buf[ea_valuelen(ea)] = 0; |
| 114 | return 0; | 114 | return 0; |
| 115 | } | 115 | } |
| 116 | pos += ea->namelen + ea->valuelen + 5; | 116 | pos += ea->namelen + ea_valuelen(ea) + 5; |
| 117 | } | 117 | } |
| 118 | return -ENOENT; | 118 | return -ENOENT; |
| 119 | indirect: | 119 | indirect: |
| @@ -138,16 +138,16 @@ char *hpfs_get_ea(struct super_block *s, struct fnode *fnode, char *key, int *si | |||
| 138 | if (!strcmp(ea->name, key)) { | 138 | if (!strcmp(ea->name, key)) { |
| 139 | if (ea->indirect) | 139 | if (ea->indirect) |
| 140 | return get_indirect_ea(s, ea->anode, ea_sec(ea), *size = ea_len(ea)); | 140 | return get_indirect_ea(s, ea->anode, ea_sec(ea), *size = ea_len(ea)); |
| 141 | if (!(ret = kmalloc((*size = ea->valuelen) + 1, GFP_NOFS))) { | 141 | if (!(ret = kmalloc((*size = ea_valuelen(ea)) + 1, GFP_NOFS))) { |
| 142 | printk("HPFS: out of memory for EA\n"); | 142 | printk("HPFS: out of memory for EA\n"); |
| 143 | return NULL; | 143 | return NULL; |
| 144 | } | 144 | } |
| 145 | memcpy(ret, ea_data(ea), ea->valuelen); | 145 | memcpy(ret, ea_data(ea), ea_valuelen(ea)); |
| 146 | ret[ea->valuelen] = 0; | 146 | ret[ea_valuelen(ea)] = 0; |
| 147 | return ret; | 147 | return ret; |
| 148 | } | 148 | } |
| 149 | a = fnode->ea_secno; | 149 | a = le32_to_cpu(fnode->ea_secno); |
| 150 | len = fnode->ea_size_l; | 150 | len = le32_to_cpu(fnode->ea_size_l); |
| 151 | ano = fnode->ea_anode; | 151 | ano = fnode->ea_anode; |
| 152 | pos = 0; | 152 | pos = 0; |
| 153 | while (pos < len) { | 153 | while (pos < len) { |
| @@ -164,18 +164,18 @@ char *hpfs_get_ea(struct super_block *s, struct fnode *fnode, char *key, int *si | |||
| 164 | if (!strcmp(ea->name, key)) { | 164 | if (!strcmp(ea->name, key)) { |
| 165 | if (ea->indirect) | 165 | if (ea->indirect) |
| 166 | return get_indirect_ea(s, ea->anode, ea_sec(ea), *size = ea_len(ea)); | 166 | return get_indirect_ea(s, ea->anode, ea_sec(ea), *size = ea_len(ea)); |
| 167 | if (!(ret = kmalloc((*size = ea->valuelen) + 1, GFP_NOFS))) { | 167 | if (!(ret = kmalloc((*size = ea_valuelen(ea)) + 1, GFP_NOFS))) { |
| 168 | printk("HPFS: out of memory for EA\n"); | 168 | printk("HPFS: out of memory for EA\n"); |
| 169 | return NULL; | 169 | return NULL; |
| 170 | } | 170 | } |
| 171 | if (hpfs_ea_read(s, a, ano, pos + 4 + ea->namelen + 1, ea->valuelen, ret)) { | 171 | if (hpfs_ea_read(s, a, ano, pos + 4 + ea->namelen + 1, ea_valuelen(ea), ret)) { |
| 172 | kfree(ret); | 172 | kfree(ret); |
| 173 | return NULL; | 173 | return NULL; |
| 174 | } | 174 | } |
| 175 | ret[ea->valuelen] = 0; | 175 | ret[ea_valuelen(ea)] = 0; |
| 176 | return ret; | 176 | return ret; |
| 177 | } | 177 | } |
| 178 | pos += ea->namelen + ea->valuelen + 5; | 178 | pos += ea->namelen + ea_valuelen(ea) + 5; |
| 179 | } | 179 | } |
| 180 | return NULL; | 180 | return NULL; |
| 181 | } | 181 | } |
| @@ -202,13 +202,13 @@ void hpfs_set_ea(struct inode *inode, struct fnode *fnode, const char *key, | |||
| 202 | if (ea->indirect) { | 202 | if (ea->indirect) { |
| 203 | if (ea_len(ea) == size) | 203 | if (ea_len(ea) == size) |
| 204 | set_indirect_ea(s, ea->anode, ea_sec(ea), data, size); | 204 | set_indirect_ea(s, ea->anode, ea_sec(ea), data, size); |
| 205 | } else if (ea->valuelen == size) { | 205 | } else if (ea_valuelen(ea) == size) { |
| 206 | memcpy(ea_data(ea), data, size); | 206 | memcpy(ea_data(ea), data, size); |
| 207 | } | 207 | } |
| 208 | return; | 208 | return; |
| 209 | } | 209 | } |
| 210 | a = fnode->ea_secno; | 210 | a = le32_to_cpu(fnode->ea_secno); |
| 211 | len = fnode->ea_size_l; | 211 | len = le32_to_cpu(fnode->ea_size_l); |
| 212 | ano = fnode->ea_anode; | 212 | ano = fnode->ea_anode; |
| 213 | pos = 0; | 213 | pos = 0; |
| 214 | while (pos < len) { | 214 | while (pos < len) { |
| @@ -228,68 +228,70 @@ void hpfs_set_ea(struct inode *inode, struct fnode *fnode, const char *key, | |||
| 228 | set_indirect_ea(s, ea->anode, ea_sec(ea), data, size); | 228 | set_indirect_ea(s, ea->anode, ea_sec(ea), data, size); |
| 229 | } | 229 | } |
| 230 | else { | 230 | else { |
| 231 | if (ea->valuelen == size) | 231 | if (ea_valuelen(ea) == size) |
| 232 | hpfs_ea_write(s, a, ano, pos + 4 + ea->namelen + 1, size, data); | 232 | hpfs_ea_write(s, a, ano, pos + 4 + ea->namelen + 1, size, data); |
| 233 | } | 233 | } |
| 234 | return; | 234 | return; |
| 235 | } | 235 | } |
| 236 | pos += ea->namelen + ea->valuelen + 5; | 236 | pos += ea->namelen + ea_valuelen(ea) + 5; |
| 237 | } | 237 | } |
| 238 | if (!fnode->ea_offs) { | 238 | if (!le16_to_cpu(fnode->ea_offs)) { |
| 239 | /*if (fnode->ea_size_s) { | 239 | /*if (le16_to_cpu(fnode->ea_size_s)) { |
| 240 | hpfs_error(s, "fnode %08x: ea_size_s == %03x, ea_offs == 0", | 240 | hpfs_error(s, "fnode %08x: ea_size_s == %03x, ea_offs == 0", |
| 241 | inode->i_ino, fnode->ea_size_s); | 241 | inode->i_ino, le16_to_cpu(fnode->ea_size_s)); |
| 242 | return; | 242 | return; |
| 243 | }*/ | 243 | }*/ |
| 244 | fnode->ea_offs = 0xc4; | 244 | fnode->ea_offs = cpu_to_le16(0xc4); |
| 245 | } | 245 | } |
| 246 | if (fnode->ea_offs < 0xc4 || fnode->ea_offs + fnode->acl_size_s + fnode->ea_size_s > 0x200) { | 246 | if (le16_to_cpu(fnode->ea_offs) < 0xc4 || le16_to_cpu(fnode->ea_offs) + le16_to_cpu(fnode->acl_size_s) + le16_to_cpu(fnode->ea_size_s) > 0x200) { |
| 247 | hpfs_error(s, "fnode %08lx: ea_offs == %03x, ea_size_s == %03x", | 247 | hpfs_error(s, "fnode %08lx: ea_offs == %03x, ea_size_s == %03x", |
| 248 | (unsigned long)inode->i_ino, | 248 | (unsigned long)inode->i_ino, |
| 249 | fnode->ea_offs, fnode->ea_size_s); | 249 | le32_to_cpu(fnode->ea_offs), le16_to_cpu(fnode->ea_size_s)); |
| 250 | return; | 250 | return; |
| 251 | } | 251 | } |
| 252 | if ((fnode->ea_size_s || !fnode->ea_size_l) && | 252 | if ((le16_to_cpu(fnode->ea_size_s) || !le32_to_cpu(fnode->ea_size_l)) && |
| 253 | fnode->ea_offs + fnode->acl_size_s + fnode->ea_size_s + strlen(key) + size + 5 <= 0x200) { | 253 | le16_to_cpu(fnode->ea_offs) + le16_to_cpu(fnode->acl_size_s) + le16_to_cpu(fnode->ea_size_s) + strlen(key) + size + 5 <= 0x200) { |
| 254 | ea = fnode_end_ea(fnode); | 254 | ea = fnode_end_ea(fnode); |
| 255 | *(char *)ea = 0; | 255 | *(char *)ea = 0; |
| 256 | ea->namelen = strlen(key); | 256 | ea->namelen = strlen(key); |
| 257 | ea->valuelen = size; | 257 | ea->valuelen_lo = size; |
| 258 | ea->valuelen_hi = size >> 8; | ||
| 258 | strcpy(ea->name, key); | 259 | strcpy(ea->name, key); |
| 259 | memcpy(ea_data(ea), data, size); | 260 | memcpy(ea_data(ea), data, size); |
| 260 | fnode->ea_size_s += strlen(key) + size + 5; | 261 | fnode->ea_size_s = cpu_to_le16(le16_to_cpu(fnode->ea_size_s) + strlen(key) + size + 5); |
| 261 | goto ret; | 262 | goto ret; |
| 262 | } | 263 | } |
| 263 | /* Most the code here is 99.9993422% unused. I hope there are no bugs. | 264 | /* Most the code here is 99.9993422% unused. I hope there are no bugs. |
| 264 | But what .. HPFS.IFS has also bugs in ea management. */ | 265 | But what .. HPFS.IFS has also bugs in ea management. */ |
| 265 | if (fnode->ea_size_s && !fnode->ea_size_l) { | 266 | if (le16_to_cpu(fnode->ea_size_s) && !le32_to_cpu(fnode->ea_size_l)) { |
| 266 | secno n; | 267 | secno n; |
| 267 | struct buffer_head *bh; | 268 | struct buffer_head *bh; |
| 268 | char *data; | 269 | char *data; |
| 269 | if (!(n = hpfs_alloc_sector(s, fno, 1, 0, 1))) return; | 270 | if (!(n = hpfs_alloc_sector(s, fno, 1, 0))) return; |
| 270 | if (!(data = hpfs_get_sector(s, n, &bh))) { | 271 | if (!(data = hpfs_get_sector(s, n, &bh))) { |
| 271 | hpfs_free_sectors(s, n, 1); | 272 | hpfs_free_sectors(s, n, 1); |
| 272 | return; | 273 | return; |
| 273 | } | 274 | } |
| 274 | memcpy(data, fnode_ea(fnode), fnode->ea_size_s); | 275 | memcpy(data, fnode_ea(fnode), le16_to_cpu(fnode->ea_size_s)); |
| 275 | fnode->ea_size_l = fnode->ea_size_s; | 276 | fnode->ea_size_l = cpu_to_le32(le16_to_cpu(fnode->ea_size_s)); |
| 276 | fnode->ea_size_s = 0; | 277 | fnode->ea_size_s = cpu_to_le16(0); |
| 277 | fnode->ea_secno = n; | 278 | fnode->ea_secno = cpu_to_le32(n); |
| 278 | fnode->ea_anode = 0; | 279 | fnode->ea_anode = cpu_to_le32(0); |
| 279 | mark_buffer_dirty(bh); | 280 | mark_buffer_dirty(bh); |
| 280 | brelse(bh); | 281 | brelse(bh); |
| 281 | } | 282 | } |
| 282 | pos = fnode->ea_size_l + 5 + strlen(key) + size; | 283 | pos = le32_to_cpu(fnode->ea_size_l) + 5 + strlen(key) + size; |
| 283 | len = (fnode->ea_size_l + 511) >> 9; | 284 | len = (le32_to_cpu(fnode->ea_size_l) + 511) >> 9; |
| 284 | if (pos >= 30000) goto bail; | 285 | if (pos >= 30000) goto bail; |
| 285 | while (((pos + 511) >> 9) > len) { | 286 | while (((pos + 511) >> 9) > len) { |
| 286 | if (!len) { | 287 | if (!len) { |
| 287 | if (!(fnode->ea_secno = hpfs_alloc_sector(s, fno, 1, 0, 1))) | 288 | secno q = hpfs_alloc_sector(s, fno, 1, 0); |
| 288 | goto bail; | 289 | if (!q) goto bail; |
| 290 | fnode->ea_secno = cpu_to_le32(q); | ||
| 289 | fnode->ea_anode = 0; | 291 | fnode->ea_anode = 0; |
| 290 | len++; | 292 | len++; |
| 291 | } else if (!fnode->ea_anode) { | 293 | } else if (!fnode->ea_anode) { |
| 292 | if (hpfs_alloc_if_possible(s, fnode->ea_secno + len)) { | 294 | if (hpfs_alloc_if_possible(s, le32_to_cpu(fnode->ea_secno) + len)) { |
| 293 | len++; | 295 | len++; |
| 294 | } else { | 296 | } else { |
| 295 | /* Aargh... don't know how to create ea anodes :-( */ | 297 | /* Aargh... don't know how to create ea anodes :-( */ |
| @@ -298,26 +300,26 @@ void hpfs_set_ea(struct inode *inode, struct fnode *fnode, const char *key, | |||
| 298 | anode_secno a_s; | 300 | anode_secno a_s; |
| 299 | if (!(anode = hpfs_alloc_anode(s, fno, &a_s, &bh))) | 301 | if (!(anode = hpfs_alloc_anode(s, fno, &a_s, &bh))) |
| 300 | goto bail; | 302 | goto bail; |
| 301 | anode->up = fno; | 303 | anode->up = cpu_to_le32(fno); |
| 302 | anode->btree.fnode_parent = 1; | 304 | anode->btree.fnode_parent = 1; |
| 303 | anode->btree.n_free_nodes--; | 305 | anode->btree.n_free_nodes--; |
| 304 | anode->btree.n_used_nodes++; | 306 | anode->btree.n_used_nodes++; |
| 305 | anode->btree.first_free += 12; | 307 | anode->btree.first_free = cpu_to_le16(le16_to_cpu(anode->btree.first_free) + 12); |
| 306 | anode->u.external[0].disk_secno = fnode->ea_secno; | 308 | anode->u.external[0].disk_secno = cpu_to_le32(le32_to_cpu(fnode->ea_secno)); |
| 307 | anode->u.external[0].file_secno = 0; | 309 | anode->u.external[0].file_secno = cpu_to_le32(0); |
| 308 | anode->u.external[0].length = len; | 310 | anode->u.external[0].length = cpu_to_le32(len); |
| 309 | mark_buffer_dirty(bh); | 311 | mark_buffer_dirty(bh); |
| 310 | brelse(bh); | 312 | brelse(bh); |
| 311 | fnode->ea_anode = 1; | 313 | fnode->ea_anode = 1; |
| 312 | fnode->ea_secno = a_s;*/ | 314 | fnode->ea_secno = cpu_to_le32(a_s);*/ |
| 313 | secno new_sec; | 315 | secno new_sec; |
| 314 | int i; | 316 | int i; |
| 315 | if (!(new_sec = hpfs_alloc_sector(s, fno, 1, 1 - ((pos + 511) >> 9), 1))) | 317 | if (!(new_sec = hpfs_alloc_sector(s, fno, 1, 1 - ((pos + 511) >> 9)))) |
| 316 | goto bail; | 318 | goto bail; |
| 317 | for (i = 0; i < len; i++) { | 319 | for (i = 0; i < len; i++) { |
| 318 | struct buffer_head *bh1, *bh2; | 320 | struct buffer_head *bh1, *bh2; |
| 319 | void *b1, *b2; | 321 | void *b1, *b2; |
| 320 | if (!(b1 = hpfs_map_sector(s, fnode->ea_secno + i, &bh1, len - i - 1))) { | 322 | if (!(b1 = hpfs_map_sector(s, le32_to_cpu(fnode->ea_secno) + i, &bh1, len - i - 1))) { |
| 321 | hpfs_free_sectors(s, new_sec, (pos + 511) >> 9); | 323 | hpfs_free_sectors(s, new_sec, (pos + 511) >> 9); |
| 322 | goto bail; | 324 | goto bail; |
| 323 | } | 325 | } |
| @@ -331,13 +333,13 @@ void hpfs_set_ea(struct inode *inode, struct fnode *fnode, const char *key, | |||
| 331 | mark_buffer_dirty(bh2); | 333 | mark_buffer_dirty(bh2); |
| 332 | brelse(bh2); | 334 | brelse(bh2); |
| 333 | } | 335 | } |
| 334 | hpfs_free_sectors(s, fnode->ea_secno, len); | 336 | hpfs_free_sectors(s, le32_to_cpu(fnode->ea_secno), len); |
| 335 | fnode->ea_secno = new_sec; | 337 | fnode->ea_secno = cpu_to_le32(new_sec); |
| 336 | len = (pos + 511) >> 9; | 338 | len = (pos + 511) >> 9; |
| 337 | } | 339 | } |
| 338 | } | 340 | } |
| 339 | if (fnode->ea_anode) { | 341 | if (fnode->ea_anode) { |
| 340 | if (hpfs_add_sector_to_btree(s, fnode->ea_secno, | 342 | if (hpfs_add_sector_to_btree(s, le32_to_cpu(fnode->ea_secno), |
| 341 | 0, len) != -1) { | 343 | 0, len) != -1) { |
| 342 | len++; | 344 | len++; |
| 343 | } else { | 345 | } else { |
| @@ -349,17 +351,17 @@ void hpfs_set_ea(struct inode *inode, struct fnode *fnode, const char *key, | |||
| 349 | h[1] = strlen(key); | 351 | h[1] = strlen(key); |
| 350 | h[2] = size & 0xff; | 352 | h[2] = size & 0xff; |
| 351 | h[3] = size >> 8; | 353 | h[3] = size >> 8; |
| 352 | if (hpfs_ea_write(s, fnode->ea_secno, fnode->ea_anode, fnode->ea_size_l, 4, h)) goto bail; | 354 | if (hpfs_ea_write(s, le32_to_cpu(fnode->ea_secno), fnode->ea_anode, le32_to_cpu(fnode->ea_size_l), 4, h)) goto bail; |
| 353 | if (hpfs_ea_write(s, fnode->ea_secno, fnode->ea_anode, fnode->ea_size_l + 4, h[1] + 1, key)) goto bail; | 355 | if (hpfs_ea_write(s, le32_to_cpu(fnode->ea_secno), fnode->ea_anode, le32_to_cpu(fnode->ea_size_l) + 4, h[1] + 1, key)) goto bail; |
| 354 | if (hpfs_ea_write(s, fnode->ea_secno, fnode->ea_anode, fnode->ea_size_l + 5 + h[1], size, data)) goto bail; | 356 | if (hpfs_ea_write(s, le32_to_cpu(fnode->ea_secno), fnode->ea_anode, le32_to_cpu(fnode->ea_size_l) + 5 + h[1], size, data)) goto bail; |
| 355 | fnode->ea_size_l = pos; | 357 | fnode->ea_size_l = cpu_to_le32(pos); |
| 356 | ret: | 358 | ret: |
| 357 | hpfs_i(inode)->i_ea_size += 5 + strlen(key) + size; | 359 | hpfs_i(inode)->i_ea_size += 5 + strlen(key) + size; |
| 358 | return; | 360 | return; |
| 359 | bail: | 361 | bail: |
| 360 | if (fnode->ea_secno) | 362 | if (le32_to_cpu(fnode->ea_secno)) |
| 361 | if (fnode->ea_anode) hpfs_truncate_btree(s, fnode->ea_secno, 1, (fnode->ea_size_l + 511) >> 9); | 363 | if (fnode->ea_anode) hpfs_truncate_btree(s, le32_to_cpu(fnode->ea_secno), 1, (le32_to_cpu(fnode->ea_size_l) + 511) >> 9); |
| 362 | else hpfs_free_sectors(s, fnode->ea_secno + ((fnode->ea_size_l + 511) >> 9), len - ((fnode->ea_size_l + 511) >> 9)); | 364 | else hpfs_free_sectors(s, le32_to_cpu(fnode->ea_secno) + ((le32_to_cpu(fnode->ea_size_l) + 511) >> 9), len - ((le32_to_cpu(fnode->ea_size_l) + 511) >> 9)); |
| 363 | else fnode->ea_secno = fnode->ea_size_l = 0; | 365 | else fnode->ea_secno = fnode->ea_size_l = cpu_to_le32(0); |
| 364 | } | 366 | } |
| 365 | 367 | ||
