ref: 0226bd4bb492f371832bd791faa83029b2298248
parent: 6de80f736dbaff57b01154597dd4776b031ec347
author: root <[email protected]>
date: Tue Oct 6 08:43:15 EDT 2015
FIX: the ext4_block reference is freed before the EA data is put onto the acl block.
--- a/lwext4/ext4_xattr.c
+++ b/lwext4/ext4_xattr.c
@@ -505,7 +505,7 @@
{
int ret = EOK;
- uint64_t xattr_block;
+ uint64_t xattr_block = 0;
xattr_block = ext4_inode_get_file_acl(xattr_ref->inode_ref->inode,
&xattr_ref->fs->sb);
if (!xattr_block) {
@@ -529,7 +529,7 @@
xattr_ref->inode_ref->dirty = true;
xattr_ref->block_loaded = true;
xattr_ref->ea_size += sizeof(struct ext4_xattr_header);
-}
+ }
Finish:
return ret;
@@ -615,6 +615,10 @@
block_entry = EXT4_XATTR_BFIRST(&xattr_ref->block);
block_data = (char *)header + block_size_rem;
block_size_rem -= sizeof(struct ext4_xattr_header);
+ ext4_inode_set_file_acl(xattr_ref->inode_ref->inode,
+ &xattr_ref->fs->sb,
+ 0);
+ xattr_ref->inode_ref->dirty = true;
}
}
}
@@ -777,7 +781,7 @@
ref->ea_size = 0;
if (xattr_block) {
rc = ext4_block_get(fs->bdev,
- &inode_ref->block, xattr_block);
+ &ref->block, xattr_block);
if (rc != EOK)
return EIO;
@@ -807,11 +811,11 @@
void ext4_fs_put_xattr_ref(struct ext4_xattr_ref *ref)
{
+ ext4_xattr_write_to_disk(ref);
if (ref->block_loaded) {
ext4_block_set(ref->fs->bdev, &ref->block);
ref->block_loaded = false;
}
- ext4_xattr_write_to_disk(ref);
ext4_xattr_purge_items(ref);
ref->inode_ref = NULL;
ref->fs = NULL;