2 * JFFS2 -- Journalling Flash File System, Version 2.
4 * Copyright © 2001-2007 Red Hat, Inc.
6 * Created by David Woodhouse <dwmw2@infradead.org>
8 * For licensing information, see the file 'LICENCE' in this directory.
12 #include <linux/kernel.h>
14 #include <linux/crc32.h>
15 #include <linux/slab.h>
16 #include <linux/pagemap.h>
17 #include <linux/mtd/mtd.h>
22 int jffs2_do_new_inode(struct jffs2_sb_info *c, struct jffs2_inode_info *f,
23 uint32_t mode, struct jffs2_raw_inode *ri)
25 struct jffs2_inode_cache *ic;
27 ic = jffs2_alloc_inode_cache();
32 memset(ic, 0, sizeof(*ic));
35 f->inocache->pino_nlink = 1; /* Will be overwritten shortly for directories */
36 f->inocache->nodes = (struct jffs2_raw_node_ref *)f->inocache;
37 f->inocache->state = INO_STATE_PRESENT;
39 jffs2_add_ino_cache(c, f->inocache);
40 D1(printk(KERN_DEBUG "jffs2_do_new_inode(): Assigned ino# %d\n", f->inocache->ino));
41 ri->ino = cpu_to_je32(f->inocache->ino);
43 ri->magic = cpu_to_je16(JFFS2_MAGIC_BITMASK);
44 ri->nodetype = cpu_to_je16(JFFS2_NODETYPE_INODE);
45 ri->totlen = cpu_to_je32(PAD(sizeof(*ri)));
46 ri->hdr_crc = cpu_to_je32(crc32(0, ri, sizeof(struct jffs2_unknown_node)-4));
47 ri->mode = cpu_to_jemode(mode);
49 f->highest_version = 1;
50 ri->version = cpu_to_je32(f->highest_version);
55 /* jffs2_write_dnode - given a raw_inode, allocate a full_dnode for it,
56 write it to the flash, link it into the existing inode/fragment list */
58 struct jffs2_full_dnode *jffs2_write_dnode(struct jffs2_sb_info *c, struct jffs2_inode_info *f,
59 struct jffs2_raw_inode *ri, const unsigned char *data,
60 uint32_t datalen, int alloc_mode)
63 struct jffs2_full_dnode *fn;
69 unsigned long cnt = 2;
71 D1(if(je32_to_cpu(ri->hdr_crc) != crc32(0, ri, sizeof(struct jffs2_unknown_node)-4)) {
72 printk(KERN_CRIT "Eep. CRC not correct in jffs2_write_dnode()\n");
76 vecs[0].iov_base = ri;
77 vecs[0].iov_len = sizeof(*ri);
78 vecs[1].iov_base = (unsigned char *)data;
79 vecs[1].iov_len = datalen;
81 if (je32_to_cpu(ri->totlen) != sizeof(*ri) + datalen) {
82 printk(KERN_WARNING "jffs2_write_dnode: ri->totlen (0x%08x) != sizeof(*ri) (0x%08zx) + datalen (0x%08x)\n", je32_to_cpu(ri->totlen), sizeof(*ri), datalen);
85 fn = jffs2_alloc_full_dnode();
87 return ERR_PTR(-ENOMEM);
89 /* check number of valid vecs */
90 if (!datalen || !data)
93 flash_ofs = write_ofs(c);
95 jffs2_dbg_prewrite_paranoia_check(c, flash_ofs, vecs[0].iov_len + vecs[1].iov_len);
97 if ((alloc_mode!=ALLOC_GC) && (je32_to_cpu(ri->version) < f->highest_version)) {
99 D1(printk(KERN_DEBUG "jffs2_write_dnode : dnode_version %d, "
100 "highest version %d -> updating dnode\n",
101 je32_to_cpu(ri->version), f->highest_version));
102 ri->version = cpu_to_je32(++f->highest_version);
103 ri->node_crc = cpu_to_je32(crc32(0, ri, sizeof(*ri)-8));
106 ret = jffs2_flash_writev(c, vecs, cnt, flash_ofs, &retlen,
107 (alloc_mode==ALLOC_GC)?0:f->inocache->ino);
109 if (ret || (retlen != sizeof(*ri) + datalen)) {
110 printk(KERN_NOTICE "Write of %zd bytes at 0x%08x failed. returned %d, retlen %zd\n",
111 sizeof(*ri)+datalen, flash_ofs, ret, retlen);
113 /* Mark the space as dirtied */
115 /* Don't change raw->size to match retlen. We may have
116 written the node header already, and only the data will
117 seem corrupted, in which case the scan would skip over
118 any node we write before the original intended end of
120 jffs2_add_physical_node_ref(c, flash_ofs | REF_OBSOLETE, PAD(sizeof(*ri)+datalen), NULL);
122 printk(KERN_NOTICE "Not marking the space at 0x%08x as dirty because the flash driver returned retlen zero\n", flash_ofs);
124 if (!retried && alloc_mode != ALLOC_NORETRY) {
125 /* Try to reallocate space and retry */
127 struct jffs2_eraseblock *jeb = &c->blocks[flash_ofs / c->sector_size];
131 D1(printk(KERN_DEBUG "Retrying failed write.\n"));
133 jffs2_dbg_acct_sanity_check(c,jeb);
134 jffs2_dbg_acct_paranoia_check(c, jeb);
136 if (alloc_mode == ALLOC_GC) {
137 ret = jffs2_reserve_space_gc(c, sizeof(*ri) + datalen, &dummy,
138 JFFS2_SUMMARY_INODE_SIZE);
141 mutex_unlock(&f->sem);
142 jffs2_complete_reservation(c);
144 ret = jffs2_reserve_space(c, sizeof(*ri) + datalen, &dummy,
145 alloc_mode, JFFS2_SUMMARY_INODE_SIZE);
150 flash_ofs = write_ofs(c);
151 D1(printk(KERN_DEBUG "Allocated space at 0x%08x to retry failed write.\n", flash_ofs));
153 jffs2_dbg_acct_sanity_check(c,jeb);
154 jffs2_dbg_acct_paranoia_check(c, jeb);
158 D1(printk(KERN_DEBUG "Failed to allocate space to retry failed write: %d!\n", ret));
160 /* Release the full_dnode which is now useless, and return */
161 jffs2_free_full_dnode(fn);
162 return ERR_PTR(ret?ret:-EIO);
164 /* Mark the space used */
165 /* If node covers at least a whole page, or if it starts at the
166 beginning of a page and runs to the end of the file, or if
167 it's a hole node, mark it REF_PRISTINE, else REF_NORMAL.
169 if ((je32_to_cpu(ri->dsize) >= PAGE_CACHE_SIZE) ||
170 ( ((je32_to_cpu(ri->offset)&(PAGE_CACHE_SIZE-1))==0) &&
171 (je32_to_cpu(ri->dsize)+je32_to_cpu(ri->offset) == je32_to_cpu(ri->isize)))) {
172 flash_ofs |= REF_PRISTINE;
174 flash_ofs |= REF_NORMAL;
176 fn->raw = jffs2_add_physical_node_ref(c, flash_ofs, PAD(sizeof(*ri)+datalen), f->inocache);
177 if (IS_ERR(fn->raw)) {
178 void *hold_err = fn->raw;
179 /* Release the full_dnode which is now useless, and return */
180 jffs2_free_full_dnode(fn);
181 return ERR_CAST(hold_err);
183 fn->ofs = je32_to_cpu(ri->offset);
184 fn->size = je32_to_cpu(ri->dsize);
187 D1(printk(KERN_DEBUG "jffs2_write_dnode wrote node at 0x%08x(%d) with dsize 0x%x, csize 0x%x, node_crc 0x%08x, data_crc 0x%08x, totlen 0x%08x\n",
188 flash_ofs & ~3, flash_ofs & 3, je32_to_cpu(ri->dsize),
189 je32_to_cpu(ri->csize), je32_to_cpu(ri->node_crc),
190 je32_to_cpu(ri->data_crc), je32_to_cpu(ri->totlen)));
193 jffs2_dbg_acct_sanity_check(c,NULL);
199 struct jffs2_full_dirent *jffs2_write_dirent(struct jffs2_sb_info *c, struct jffs2_inode_info *f,
200 struct jffs2_raw_dirent *rd, const unsigned char *name,
201 uint32_t namelen, int alloc_mode)
203 struct jffs2_full_dirent *fd;
210 D1(printk(KERN_DEBUG "jffs2_write_dirent(ino #%u, name at *0x%p \"%s\"->ino #%u, name_crc 0x%08x)\n",
211 je32_to_cpu(rd->pino), name, name, je32_to_cpu(rd->ino),
212 je32_to_cpu(rd->name_crc)));
214 D1(if(je32_to_cpu(rd->hdr_crc) != crc32(0, rd, sizeof(struct jffs2_unknown_node)-4)) {
215 printk(KERN_CRIT "Eep. CRC not correct in jffs2_write_dirent()\n");
219 if (strnlen(name, namelen) != namelen) {
220 /* This should never happen, but seems to have done on at least one
221 occasion: https://dev.laptop.org/ticket/4184 */
222 printk(KERN_CRIT "Error in jffs2_write_dirent() -- name contains zero bytes!\n");
223 printk(KERN_CRIT "Directory inode #%u, name at *0x%p \"%s\"->ino #%u, name_crc 0x%08x\n",
224 je32_to_cpu(rd->pino), name, name, je32_to_cpu(rd->ino),
225 je32_to_cpu(rd->name_crc));
227 return ERR_PTR(-EIO);
230 vecs[0].iov_base = rd;
231 vecs[0].iov_len = sizeof(*rd);
232 vecs[1].iov_base = (unsigned char *)name;
233 vecs[1].iov_len = namelen;
235 fd = jffs2_alloc_full_dirent(namelen+1);
237 return ERR_PTR(-ENOMEM);
239 fd->version = je32_to_cpu(rd->version);
240 fd->ino = je32_to_cpu(rd->ino);
241 fd->nhash = full_name_hash(name, namelen);
243 memcpy(fd->name, name, namelen);
247 flash_ofs = write_ofs(c);
249 jffs2_dbg_prewrite_paranoia_check(c, flash_ofs, vecs[0].iov_len + vecs[1].iov_len);
251 if ((alloc_mode!=ALLOC_GC) && (je32_to_cpu(rd->version) < f->highest_version)) {
253 D1(printk(KERN_DEBUG "jffs2_write_dirent : dirent_version %d, "
254 "highest version %d -> updating dirent\n",
255 je32_to_cpu(rd->version), f->highest_version));
256 rd->version = cpu_to_je32(++f->highest_version);
257 fd->version = je32_to_cpu(rd->version);
258 rd->node_crc = cpu_to_je32(crc32(0, rd, sizeof(*rd)-8));
261 ret = jffs2_flash_writev(c, vecs, 2, flash_ofs, &retlen,
262 (alloc_mode==ALLOC_GC)?0:je32_to_cpu(rd->pino));
263 if (ret || (retlen != sizeof(*rd) + namelen)) {
264 printk(KERN_NOTICE "Write of %zd bytes at 0x%08x failed. returned %d, retlen %zd\n",
265 sizeof(*rd)+namelen, flash_ofs, ret, retlen);
266 /* Mark the space as dirtied */
268 jffs2_add_physical_node_ref(c, flash_ofs | REF_OBSOLETE, PAD(sizeof(*rd)+namelen), NULL);
270 printk(KERN_NOTICE "Not marking the space at 0x%08x as dirty because the flash driver returned retlen zero\n", flash_ofs);
273 /* Try to reallocate space and retry */
275 struct jffs2_eraseblock *jeb = &c->blocks[flash_ofs / c->sector_size];
279 D1(printk(KERN_DEBUG "Retrying failed write.\n"));
281 jffs2_dbg_acct_sanity_check(c,jeb);
282 jffs2_dbg_acct_paranoia_check(c, jeb);
284 if (alloc_mode == ALLOC_GC) {
285 ret = jffs2_reserve_space_gc(c, sizeof(*rd) + namelen, &dummy,
286 JFFS2_SUMMARY_DIRENT_SIZE(namelen));
289 mutex_unlock(&f->sem);
290 jffs2_complete_reservation(c);
292 ret = jffs2_reserve_space(c, sizeof(*rd) + namelen, &dummy,
293 alloc_mode, JFFS2_SUMMARY_DIRENT_SIZE(namelen));
298 flash_ofs = write_ofs(c);
299 D1(printk(KERN_DEBUG "Allocated space at 0x%08x to retry failed write.\n", flash_ofs));
300 jffs2_dbg_acct_sanity_check(c,jeb);
301 jffs2_dbg_acct_paranoia_check(c, jeb);
304 D1(printk(KERN_DEBUG "Failed to allocate space to retry failed write: %d!\n", ret));
306 /* Release the full_dnode which is now useless, and return */
307 jffs2_free_full_dirent(fd);
308 return ERR_PTR(ret?ret:-EIO);
310 /* Mark the space used */
311 fd->raw = jffs2_add_physical_node_ref(c, flash_ofs | dirent_node_state(rd),
312 PAD(sizeof(*rd)+namelen), f->inocache);
313 if (IS_ERR(fd->raw)) {
314 void *hold_err = fd->raw;
315 /* Release the full_dirent which is now useless, and return */
316 jffs2_free_full_dirent(fd);
317 return ERR_CAST(hold_err);
321 jffs2_dbg_acct_sanity_check(c,NULL);
327 /* The OS-specific code fills in the metadata in the jffs2_raw_inode for us, so that
328 we don't have to go digging in struct inode or its equivalent. It should set:
329 mode, uid, gid, (starting)isize, atime, ctime, mtime */
330 int jffs2_write_inode_range(struct jffs2_sb_info *c, struct jffs2_inode_info *f,
331 struct jffs2_raw_inode *ri, unsigned char *buf,
332 uint32_t offset, uint32_t writelen, uint32_t *retlen)
335 uint32_t writtenlen = 0;
337 D1(printk(KERN_DEBUG "jffs2_write_inode_range(): Ino #%u, ofs 0x%x, len 0x%x\n",
338 f->inocache->ino, offset, writelen));
341 struct jffs2_full_dnode *fn;
342 unsigned char *comprbuf = NULL;
343 uint16_t comprtype = JFFS2_COMPR_NONE;
345 uint32_t datalen, cdatalen;
349 D2(printk(KERN_DEBUG "jffs2_commit_write() loop: 0x%x to write to 0x%x\n", writelen, offset));
351 ret = jffs2_reserve_space(c, sizeof(*ri) + JFFS2_MIN_DATA_LEN,
352 &alloclen, ALLOC_NORMAL, JFFS2_SUMMARY_INODE_SIZE);
354 D1(printk(KERN_DEBUG "jffs2_reserve_space returned %d\n", ret));
358 datalen = min_t(uint32_t, writelen, PAGE_CACHE_SIZE - (offset & (PAGE_CACHE_SIZE-1)));
359 cdatalen = min_t(uint32_t, alloclen - sizeof(*ri), datalen);
361 comprtype = jffs2_compress(c, f, buf, &comprbuf, &datalen, &cdatalen);
363 ri->magic = cpu_to_je16(JFFS2_MAGIC_BITMASK);
364 ri->nodetype = cpu_to_je16(JFFS2_NODETYPE_INODE);
365 ri->totlen = cpu_to_je32(sizeof(*ri) + cdatalen);
366 ri->hdr_crc = cpu_to_je32(crc32(0, ri, sizeof(struct jffs2_unknown_node)-4));
368 ri->ino = cpu_to_je32(f->inocache->ino);
369 ri->version = cpu_to_je32(++f->highest_version);
370 ri->isize = cpu_to_je32(max(je32_to_cpu(ri->isize), offset + datalen));
371 ri->offset = cpu_to_je32(offset);
372 ri->csize = cpu_to_je32(cdatalen);
373 ri->dsize = cpu_to_je32(datalen);
374 ri->compr = comprtype & 0xff;
375 ri->usercompr = (comprtype >> 8 ) & 0xff;
376 ri->node_crc = cpu_to_je32(crc32(0, ri, sizeof(*ri)-8));
377 ri->data_crc = cpu_to_je32(crc32(0, comprbuf, cdatalen));
379 fn = jffs2_write_dnode(c, f, ri, comprbuf, cdatalen, ALLOC_NORETRY);
381 jffs2_free_comprbuf(comprbuf, buf);
385 mutex_unlock(&f->sem);
386 jffs2_complete_reservation(c);
388 /* Write error to be retried */
390 D1(printk(KERN_DEBUG "Retrying node write in jffs2_write_inode_range()\n"));
395 ret = jffs2_add_full_dnode_to_inode(c, f, fn);
397 jffs2_mark_node_obsolete(c, f->metadata->raw);
398 jffs2_free_full_dnode(f->metadata);
403 D1(printk(KERN_DEBUG "Eep. add_full_dnode_to_inode() failed in commit_write, returned %d\n", ret));
404 jffs2_mark_node_obsolete(c, fn->raw);
405 jffs2_free_full_dnode(fn);
407 mutex_unlock(&f->sem);
408 jffs2_complete_reservation(c);
411 mutex_unlock(&f->sem);
412 jffs2_complete_reservation(c);
414 printk(KERN_WARNING "Eep. We didn't actually write any data in jffs2_write_inode_range()\n");
418 D1(printk(KERN_DEBUG "increasing writtenlen by %d\n", datalen));
419 writtenlen += datalen;
424 *retlen = writtenlen;
428 int jffs2_do_create(struct jffs2_sb_info *c, struct jffs2_inode_info *dir_f, struct jffs2_inode_info *f, struct jffs2_raw_inode *ri, const char *name, int namelen)
430 struct jffs2_raw_dirent *rd;
431 struct jffs2_full_dnode *fn;
432 struct jffs2_full_dirent *fd;
436 /* Try to reserve enough space for both node and dirent.
437 * Just the node will do for now, though
439 ret = jffs2_reserve_space(c, sizeof(*ri), &alloclen, ALLOC_NORMAL,
440 JFFS2_SUMMARY_INODE_SIZE);
441 D1(printk(KERN_DEBUG "jffs2_do_create(): reserved 0x%x bytes\n", alloclen));
447 ri->data_crc = cpu_to_je32(0);
448 ri->node_crc = cpu_to_je32(crc32(0, ri, sizeof(*ri)-8));
450 fn = jffs2_write_dnode(c, f, ri, NULL, 0, ALLOC_NORMAL);
452 D1(printk(KERN_DEBUG "jffs2_do_create created file with mode 0x%x\n",
453 jemode_to_cpu(ri->mode)));
456 D1(printk(KERN_DEBUG "jffs2_write_dnode() failed\n"));
457 /* Eeek. Wave bye bye */
458 mutex_unlock(&f->sem);
459 jffs2_complete_reservation(c);
462 /* No data here. Only a metadata node, which will be
463 obsoleted by the first data write
467 mutex_unlock(&f->sem);
468 jffs2_complete_reservation(c);
470 ret = jffs2_init_security(&f->vfs_inode, &dir_f->vfs_inode);
473 ret = jffs2_init_acl_post(&f->vfs_inode);
477 ret = jffs2_reserve_space(c, sizeof(*rd)+namelen, &alloclen,
478 ALLOC_NORMAL, JFFS2_SUMMARY_DIRENT_SIZE(namelen));
482 D1(printk(KERN_DEBUG "jffs2_reserve_space() for dirent failed\n"));
486 rd = jffs2_alloc_raw_dirent();
488 /* Argh. Now we treat it like a normal delete */
489 jffs2_complete_reservation(c);
493 mutex_lock(&dir_f->sem);
495 rd->magic = cpu_to_je16(JFFS2_MAGIC_BITMASK);
496 rd->nodetype = cpu_to_je16(JFFS2_NODETYPE_DIRENT);
497 rd->totlen = cpu_to_je32(sizeof(*rd) + namelen);
498 rd->hdr_crc = cpu_to_je32(crc32(0, rd, sizeof(struct jffs2_unknown_node)-4));
500 rd->pino = cpu_to_je32(dir_f->inocache->ino);
501 rd->version = cpu_to_je32(++dir_f->highest_version);
503 rd->mctime = ri->ctime;
506 rd->node_crc = cpu_to_je32(crc32(0, rd, sizeof(*rd)-8));
507 rd->name_crc = cpu_to_je32(crc32(0, name, namelen));
509 fd = jffs2_write_dirent(c, dir_f, rd, name, namelen, ALLOC_NORMAL);
511 jffs2_free_raw_dirent(rd);
514 /* dirent failed to write. Delete the inode normally
515 as if it were the final unlink() */
516 jffs2_complete_reservation(c);
517 mutex_unlock(&dir_f->sem);
521 /* Link the fd into the inode's list, obsoleting an old
523 jffs2_add_fd_to_list(c, fd, &dir_f->dents);
525 jffs2_complete_reservation(c);
526 mutex_unlock(&dir_f->sem);
532 int jffs2_do_unlink(struct jffs2_sb_info *c, struct jffs2_inode_info *dir_f,
533 const char *name, int namelen, struct jffs2_inode_info *dead_f,
536 struct jffs2_raw_dirent *rd;
537 struct jffs2_full_dirent *fd;
541 if (!jffs2_can_mark_obsolete(c)) {
542 /* We can't mark stuff obsolete on the medium. We need to write a deletion dirent */
544 rd = jffs2_alloc_raw_dirent();
548 ret = jffs2_reserve_space(c, sizeof(*rd)+namelen, &alloclen,
549 ALLOC_DELETION, JFFS2_SUMMARY_DIRENT_SIZE(namelen));
551 jffs2_free_raw_dirent(rd);
555 mutex_lock(&dir_f->sem);
557 /* Build a deletion node */
558 rd->magic = cpu_to_je16(JFFS2_MAGIC_BITMASK);
559 rd->nodetype = cpu_to_je16(JFFS2_NODETYPE_DIRENT);
560 rd->totlen = cpu_to_je32(sizeof(*rd) + namelen);
561 rd->hdr_crc = cpu_to_je32(crc32(0, rd, sizeof(struct jffs2_unknown_node)-4));
563 rd->pino = cpu_to_je32(dir_f->inocache->ino);
564 rd->version = cpu_to_je32(++dir_f->highest_version);
565 rd->ino = cpu_to_je32(0);
566 rd->mctime = cpu_to_je32(time);
568 rd->type = DT_UNKNOWN;
569 rd->node_crc = cpu_to_je32(crc32(0, rd, sizeof(*rd)-8));
570 rd->name_crc = cpu_to_je32(crc32(0, name, namelen));
572 fd = jffs2_write_dirent(c, dir_f, rd, name, namelen, ALLOC_DELETION);
574 jffs2_free_raw_dirent(rd);
577 jffs2_complete_reservation(c);
578 mutex_unlock(&dir_f->sem);
582 /* File it. This will mark the old one obsolete. */
583 jffs2_add_fd_to_list(c, fd, &dir_f->dents);
584 mutex_unlock(&dir_f->sem);
586 uint32_t nhash = full_name_hash(name, namelen);
589 /* We don't actually want to reserve any space, but we do
590 want to be holding the alloc_sem when we write to flash */
591 mutex_lock(&c->alloc_sem);
592 mutex_lock(&dir_f->sem);
594 for (fd = dir_f->dents; fd; fd = fd->next) {
595 if (fd->nhash == nhash &&
596 !memcmp(fd->name, name, namelen) &&
597 !fd->name[namelen]) {
599 D1(printk(KERN_DEBUG "Marking old dirent node (ino #%u) @%08x obsolete\n",
600 fd->ino, ref_offset(fd->raw)));
601 jffs2_mark_node_obsolete(c, fd->raw);
602 /* We don't want to remove it from the list immediately,
603 because that screws up getdents()/seek() semantics even
604 more than they're screwed already. Turn it into a
605 node-less deletion dirent instead -- a placeholder */
611 mutex_unlock(&dir_f->sem);
614 /* dead_f is NULL if this was a rename not a real unlink */
615 /* Also catch the !f->inocache case, where there was a dirent
616 pointing to an inode which didn't exist. */
617 if (dead_f && dead_f->inocache) {
619 mutex_lock(&dead_f->sem);
621 if (S_ISDIR(OFNI_EDONI_2SFFJ(dead_f)->i_mode)) {
622 while (dead_f->dents) {
623 /* There can be only deleted ones */
626 dead_f->dents = fd->next;
629 printk(KERN_WARNING "Deleting inode #%u with active dentry \"%s\"->ino #%u\n",
630 dead_f->inocache->ino, fd->name, fd->ino);
632 D1(printk(KERN_DEBUG "Removing deletion dirent for \"%s\" from dir ino #%u\n",
633 fd->name, dead_f->inocache->ino));
636 jffs2_mark_node_obsolete(c, fd->raw);
637 jffs2_free_full_dirent(fd);
639 dead_f->inocache->pino_nlink = 0;
641 dead_f->inocache->pino_nlink--;
642 /* NB: Caller must set inode nlink if appropriate */
643 mutex_unlock(&dead_f->sem);
646 jffs2_complete_reservation(c);
652 int jffs2_do_link (struct jffs2_sb_info *c, struct jffs2_inode_info *dir_f, uint32_t ino, uint8_t type, const char *name, int namelen, uint32_t time)
654 struct jffs2_raw_dirent *rd;
655 struct jffs2_full_dirent *fd;
659 rd = jffs2_alloc_raw_dirent();
663 ret = jffs2_reserve_space(c, sizeof(*rd)+namelen, &alloclen,
664 ALLOC_NORMAL, JFFS2_SUMMARY_DIRENT_SIZE(namelen));
666 jffs2_free_raw_dirent(rd);
670 mutex_lock(&dir_f->sem);
672 /* Build a deletion node */
673 rd->magic = cpu_to_je16(JFFS2_MAGIC_BITMASK);
674 rd->nodetype = cpu_to_je16(JFFS2_NODETYPE_DIRENT);
675 rd->totlen = cpu_to_je32(sizeof(*rd) + namelen);
676 rd->hdr_crc = cpu_to_je32(crc32(0, rd, sizeof(struct jffs2_unknown_node)-4));
678 rd->pino = cpu_to_je32(dir_f->inocache->ino);
679 rd->version = cpu_to_je32(++dir_f->highest_version);
680 rd->ino = cpu_to_je32(ino);
681 rd->mctime = cpu_to_je32(time);
686 rd->node_crc = cpu_to_je32(crc32(0, rd, sizeof(*rd)-8));
687 rd->name_crc = cpu_to_je32(crc32(0, name, namelen));
689 fd = jffs2_write_dirent(c, dir_f, rd, name, namelen, ALLOC_NORMAL);
691 jffs2_free_raw_dirent(rd);
694 jffs2_complete_reservation(c);
695 mutex_unlock(&dir_f->sem);
699 /* File it. This will mark the old one obsolete. */
700 jffs2_add_fd_to_list(c, fd, &dir_f->dents);
702 jffs2_complete_reservation(c);
703 mutex_unlock(&dir_f->sem);