projects
/
yaffs2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix issue with unlinking hardlinks failing sanity check
[yaffs2.git]
/
yaffs_guts.c
diff --git
a/yaffs_guts.c
b/yaffs_guts.c
index 5ea11500ffd506fa3f3a083dea48a62ca27c574f..d4349c92ad2342c151f9f9755791b5751aae0bb9 100644
(file)
--- a/
yaffs_guts.c
+++ b/
yaffs_guts.c
@@
-12,7
+12,7
@@
*/
const char *yaffs_guts_c_version =
*/
const char *yaffs_guts_c_version =
- "$Id: yaffs_guts.c,v 1.10
3 2010-01-01 23:54:03
charles Exp $";
+ "$Id: yaffs_guts.c,v 1.10
4 2010-01-05 22:58:15
charles Exp $";
#include "yportenv.h"
#include "yportenv.h"
@@
-5403,23
+5403,26
@@
static int yaffs_UnlinkWorker(yaffs_Object *obj)
* Instead, we do the following:
* - Select a hardlink.
* - Unhook it from the hard links
* Instead, we do the following:
* - Select a hardlink.
* - Unhook it from the hard links
- * -
Unhook
it from its parent directory (so that the rename can work)
+ * -
Move
it from its parent directory (so that the rename can work)
* - Rename the object to the hardlink's name.
* - Delete the hardlink
*/
yaffs_Object *hl;
* - Rename the object to the hardlink's name.
* - Delete the hardlink
*/
yaffs_Object *hl;
+ yaffs_Object *parent;
int retVal;
YCHAR name[YAFFS_MAX_NAME_LENGTH + 1];
hl = ylist_entry(obj->hardLinks.next, yaffs_Object, hardLinks);
int retVal;
YCHAR name[YAFFS_MAX_NAME_LENGTH + 1];
hl = ylist_entry(obj->hardLinks.next, yaffs_Object, hardLinks);
+ yaffs_GetObjectName(hl, name, YAFFS_MAX_NAME_LENGTH + 1);
+ parent = hl->parent;
+
ylist_del_init(&hl->hardLinks);
ylist_del_init(&hl->hardLinks);
- ylist_del_init(&hl->siblings);
- yaffs_
GetObjectName(hl, name, YAFFS_MAX_NAME_LENGTH + 1
);
+ yaffs_
AddObjectToDirectory(obj->myDev->unlinkedDir, hl
);
- retVal = yaffs_ChangeObjectName(obj,
hl->
parent, name, 0, 0);
+ retVal = yaffs_ChangeObjectName(obj,parent, name, 0, 0);
if (retVal == YAFFS_OK)
retVal = yaffs_DoGenericObjectDeletion(hl);
if (retVal == YAFFS_OK)
retVal = yaffs_DoGenericObjectDeletion(hl);