ref: dacdc92bd3e9e87916481fb6ce6dd17de7d64f8d
parent: 58f7efbf6c7b61fa2c86468fe25ed987f15132f6
author: gkostka <[email protected]>
date: Sat Nov 21 12:14:44 EST 2015
Style & indentation improvements in ext4
--- a/lwext4/ext4.c
+++ b/lwext4/ext4.c
@@ -138,11 +138,10 @@
static int ext4_has_children(bool *has_children, struct ext4_inode_ref *enode)
{
- struct ext4_fs *fs = enode->fs;
+ struct ext4_sblock *sb = &enode->fs->sb;
/* Check if node is directory */
- if (!ext4_inode_is_type(&fs->sb, enode->inode,
- EXT4_INODE_MODE_DIRECTORY)) {
+ if (!ext4_inode_is_type(sb, enode->inode, EXT4_INODE_MODE_DIRECTORY)) {
*has_children = false;
return EOK;
}
@@ -156,9 +155,9 @@
bool found = false;
while (it.curr != NULL) {
if (ext4_dir_entry_ll_get_inode(it.curr) != 0) {
- uint16_t name_size = ext4_dir_entry_ll_get_name_length(
- &fs->sb, it.curr);
- if (!ext4_is_dots(it.curr->name, name_size)) {
+ uint16_t nsize;
+ nsize = ext4_dir_entry_ll_get_name_length(sb, it.curr);
+ if (!ext4_is_dots(it.curr->name, nsize)) {
found = true;
break;
}
@@ -181,7 +180,7 @@
}
static int ext4_link(struct ext4_mountpoint *mp, struct ext4_inode_ref *parent,
- struct ext4_inode_ref *child, const char *name,
+ struct ext4_inode_ref *child, const char *nam,
uint32_t name_len, bool rename)
{
/* Check maximum name length */
@@ -189,94 +188,88 @@
return EINVAL;
/* Add entry to parent directory */
- int rc = ext4_dir_add_entry(parent, name, name_len, child);
- if (rc != EOK)
- return rc;
+ int r = ext4_dir_add_entry(parent, nam, name_len, child);
+ if (r != EOK)
+ return r;
/* Fill new dir -> add '.' and '..' entries.
* Also newly allocated inode should have 0 link count.
*/
- if (ext4_inode_is_type(&mp->fs.sb, child->inode,
- EXT4_INODE_MODE_DIRECTORY) && !rename) {
+ bool is_dir = ext4_inode_is_type(&mp->fs.sb, child->inode,
+ EXT4_INODE_MODE_DIRECTORY);
+ if (is_dir && !rename) {
+
#if CONFIG_DIR_INDEX_ENABLE
/* Initialize directory index if supported */
if (ext4_sb_feature_com(&mp->fs.sb, EXT4_FCOM_DIR_INDEX)) {
- rc = ext4_dir_dx_init(child, parent);
- if (rc != EOK)
- return rc;
+ r = ext4_dir_dx_init(child, parent);
+ if (r != EOK)
+ return r;
- ext4_inode_set_flag(child->inode,
- EXT4_INODE_FLAG_INDEX);
+ ext4_inode_set_flag(child->inode, EXT4_INODE_FLAG_INDEX);
child->dirty = true;
} else
#endif
{
- rc = ext4_dir_add_entry(child, ".", strlen("."), child);
- if (rc != EOK) {
- ext4_dir_remove_entry(parent, name, strlen(name));
- return rc;
+ r = ext4_dir_add_entry(child, ".", strlen("."), child);
+ if (r != EOK) {
+ ext4_dir_remove_entry(parent, nam, strlen(nam));
+ return r;
}
- rc = ext4_dir_add_entry(child, "..", strlen(".."), parent);
- if (rc != EOK) {
- ext4_dir_remove_entry(parent, name, strlen(name));
+ r = ext4_dir_add_entry(child, "..", strlen(".."), parent);
+ if (r != EOK) {
+ ext4_dir_remove_entry(parent, nam, strlen(nam));
ext4_dir_remove_entry(child, ".", strlen("."));
- return rc;
+ return r;
}
}
/*New empty directory. Two links (. and ..) */
ext4_inode_set_links_count(child->inode, 2);
-
ext4_fs_inode_links_count_inc(parent);
child->dirty = true;
parent->dirty = true;
- } else {
- /*
- * In case we want to rename a directory,
- * we reset the original '..' pointer.
- */
- if (ext4_inode_is_type(&mp->fs.sb, child->inode,
- EXT4_INODE_MODE_DIRECTORY)) {
- int has_flag_index =
- ext4_inode_has_flag(child->inode,
- EXT4_INODE_FLAG_INDEX);
- struct ext4_dir_search_result result;
- if (!has_flag_index) {
- rc = ext4_dir_find_entry(&result,
- child, "..",
- strlen(".."));
- if (rc != EOK)
- return EIO;
+ return r;
+ }
+ /*
+ * In case we want to rename a directory,
+ * we reset the original '..' pointer.
+ */
+ if (is_dir) {
+ bool idx;
+ idx = ext4_inode_has_flag(child->inode, EXT4_INODE_FLAG_INDEX);
+ struct ext4_dir_search_result res;
+ if (!idx) {
+ r = ext4_dir_find_entry(&res, child, "..", strlen(".."));
+ if (r != EOK)
+ return EIO;
- ext4_dir_entry_ll_set_inode(result.dentry,
- parent->index);
- result.block.dirty = true;
- rc = ext4_dir_destroy_result(child, &result);
- if (rc != EOK)
- return rc;
+ ext4_dir_entry_ll_set_inode(res.dentry, parent->index);
+ res.block.dirty = true;
+ r = ext4_dir_destroy_result(child, &res);
+ if (r != EOK)
+ return r;
- } else {
+ } else {
#if CONFIG_DIR_INDEX_ENABLE
- rc = ext4_dir_dx_reset_parent_inode(child,
- parent->index);
- if (rc != EOK)
- return rc;
+ r = ext4_dir_dx_reset_parent_inode(child, parent->index);
+ if (r != EOK)
+ return r;
#endif
- }
-
- ext4_fs_inode_links_count_inc(parent);
- parent->dirty = true;
}
- if (!rename) {
- ext4_fs_inode_links_count_inc(child);
- child->dirty = true;
- }
+
+ ext4_fs_inode_links_count_inc(parent);
+ parent->dirty = true;
}
+ if (!rename) {
+ ext4_fs_inode_links_count_inc(child);
+ child->dirty = true;
+ }
- return rc;
+ return r;
}
static int ext4_unlink(struct ext4_mountpoint *mp,
@@ -303,8 +296,6 @@
/* If directory - handle links from parent */
if (is_dir) {
- // ext4_assert(ext4_inode_get_links_count(child_inode_ref->inode)
- // == 1);
ext4_fs_inode_links_count_dec(parent);
parent->dirty = true;
}
@@ -578,14 +569,15 @@
* any filetype of the target dir entry will be accepted.
*/
static int ext4_generic_open2(ext4_file *f, const char *path, int flags,
- int filetype, uint32_t *parent_inode,
+ int ftype, uint32_t *parent_inode,
uint32_t *name_off)
{
bool is_goal = false;
- uint32_t inode_mode = EXT4_INODE_MODE_DIRECTORY;
+ uint32_t imode = EXT4_INODE_MODE_DIRECTORY;
uint32_t next_inode;
int r;
+ int len;
struct ext4_mountpoint *mp = ext4_get_mount(path);
struct ext4_dir_search_result result;
struct ext4_inode_ref ref;
@@ -595,6 +587,9 @@
if (!mp)
return ENOENT;
+ struct ext4_fs *const fs = &mp->fs;
+ struct ext4_sblock *const sb = &mp->fs.sb;
+
f->flags = flags;
/*Skip mount point*/
@@ -604,8 +599,7 @@
*name_off = strlen(mp->name);
/*Load root*/
- r = ext4_fs_get_inode_ref(&mp->fs, EXT4_INODE_ROOT_INDEX, &ref);
-
+ r = ext4_fs_get_inode_ref(fs, EXT4_INODE_ROOT_INDEX, &ref);
if (r != EOK)
return r;
@@ -612,17 +606,15 @@
if (parent_inode)
*parent_inode = ref.index;
- int len = ext4_path_check(path, &is_goal);
-
+ len = ext4_path_check(path, &is_goal);
while (1) {
len = ext4_path_check(path, &is_goal);
-
if (!len) {
/*If root open was request.*/
if (is_goal &&
- ((filetype == EXT4_DIRENTRY_DIR) ||
- (filetype == EXT4_DIRENTRY_UNKNOWN)))
+ ((ftype == EXT4_DIRENTRY_DIR) ||
+ (ftype == EXT4_DIRENTRY_UNKNOWN)))
break;
r = ENOENT;
@@ -634,7 +626,6 @@
/*Destroy last result*/
ext4_dir_destroy_result(&ref, &result);
-
if (r != ENOENT)
break;
@@ -643,8 +634,8 @@
/*O_CREAT allows create new entry*/
struct ext4_inode_ref child_ref;
- r = ext4_fs_alloc_inode(&mp->fs, &child_ref,
- is_goal ? filetype : EXT4_DIRENTRY_DIR);
+ r = ext4_fs_alloc_inode(fs, &child_ref,
+ is_goal ? ftype : EXT4_DIRENTRY_DIR);
if (r != EOK)
break;
@@ -662,7 +653,6 @@
}
ext4_fs_put_inode_ref(&child_ref);
-
continue;
}
@@ -670,21 +660,17 @@
*parent_inode = ref.index;
next_inode = ext4_dir_entry_ll_get_inode(result.dentry);
- if (ext4_sb_feature_incom(&mp->fs.sb, EXT4_FINCOM_FILETYPE)) {
- int inode_type =
- ext4_dir_entry_ll_get_inode_type(&mp->fs.sb,
- result.dentry);
- inode_mode = ext4_fs_correspond_inode_mode(inode_type);
+ if (ext4_sb_feature_incom(sb, EXT4_FINCOM_FILETYPE)) {
+ uint8_t t;
+ t = ext4_dir_entry_ll_get_inode_type(sb, result.dentry);
+ imode = ext4_fs_correspond_inode_mode(t);
} else {
struct ext4_inode_ref child_ref;
- r = ext4_fs_get_inode_ref(&mp->fs, next_inode,
- &child_ref);
+ r = ext4_fs_get_inode_ref(fs, next_inode, &child_ref);
if (r != EOK)
break;
- inode_mode = ext4_inode_type(&mp->fs.sb,
- child_ref.inode);
-
+ imode = ext4_inode_type(sb, child_ref.inode);
ext4_fs_put_inode_ref(&child_ref);
}
@@ -693,14 +679,13 @@
break;
/*If expected file error*/
- if (inode_mode != EXT4_INODE_MODE_DIRECTORY &&
- !is_goal) {
+ if (imode != EXT4_INODE_MODE_DIRECTORY && !is_goal) {
r = ENOENT;
break;
}
- if (filetype != EXT4_DIRENTRY_UNKNOWN) {
- if ((inode_mode != ext4_fs_correspond_inode_mode(filetype)) &&
- is_goal) {
+ if (ftype != EXT4_DIRENTRY_UNKNOWN) {
+ bool df = imode != ext4_fs_correspond_inode_mode(ftype);
+ if (df && is_goal) {
r = ENOENT;
break;
}
@@ -710,7 +695,7 @@
if (r != EOK)
break;
- r = ext4_fs_get_inode_ref(&mp->fs, next_inode, &ref);
+ r = ext4_fs_get_inode_ref(fs, next_inode, &ref);
if (r != EOK)
break;
@@ -730,9 +715,7 @@
if (is_goal) {
- if ((f->flags & O_TRUNC) &&
- (inode_mode == EXT4_INODE_MODE_FILE)) {
-
+ if ((f->flags & O_TRUNC) && (imode == EXT4_INODE_MODE_FILE)) {
r = ext4_fs_truncate_inode(&ref, 0);
if (r != EOK) {
ext4_fs_put_inode_ref(&ref);
@@ -741,7 +724,7 @@
}
f->mp = mp;
- f->fsize = ext4_inode_get_size(&f->mp->fs.sb, ref.inode);
+ f->fsize = ext4_inode_get_size(sb, ref.inode);
f->inode = ref.index;
f->fpos = 0;
@@ -774,9 +757,8 @@
name_off);
}
-static int __ext4_create_hardlink(const char *path,
- struct ext4_inode_ref *child_ref,
- bool rename)
+static int ext4_create_hardlink(const char *path,
+ struct ext4_inode_ref *child_ref, bool rename)
{
bool is_goal = false;
uint32_t inode_mode = EXT4_INODE_MODE_DIRECTORY;
@@ -783,6 +765,7 @@
uint32_t next_inode;
int r;
+ int len;
struct ext4_mountpoint *mp = ext4_get_mount(path);
struct ext4_dir_search_result result;
struct ext4_inode_ref ref;
@@ -790,27 +773,24 @@
if (!mp)
return ENOENT;
+ struct ext4_fs *const fs = &mp->fs;
+ struct ext4_sblock *const sb = &mp->fs.sb;
+
/*Skip mount point*/
path += strlen(mp->name);
/*Load root*/
- r = ext4_fs_get_inode_ref(&mp->fs, EXT4_INODE_ROOT_INDEX, &ref);
-
+ r = ext4_fs_get_inode_ref(fs, EXT4_INODE_ROOT_INDEX, &ref);
if (r != EOK)
return r;
- int len = ext4_path_check(path, &is_goal);
-
+ len = ext4_path_check(path, &is_goal);
while (1) {
len = ext4_path_check(path, &is_goal);
-
if (!len) {
/*If root open was request.*/
- if (is_goal)
- r = EINVAL;
- else
- r = ENOENT;
+ r = is_goal ? EINVAL : ENOENT;
break;
}
@@ -834,21 +814,17 @@
}
next_inode = result.dentry->inode;
- if (ext4_sb_feature_incom(&mp->fs.sb, EXT4_FINCOM_FILETYPE)) {
- int inode_type =
- ext4_dir_entry_ll_get_inode_type(&mp->fs.sb,
- result.dentry);
- inode_mode = ext4_fs_correspond_inode_mode(inode_type);
+ if (ext4_sb_feature_incom(sb, EXT4_FINCOM_FILETYPE)) {
+ uint8_t t;
+ t = ext4_dir_entry_ll_get_inode_type(sb, result.dentry);
+ inode_mode = ext4_fs_correspond_inode_mode(t);
} else {
struct ext4_inode_ref child_ref;
- r = ext4_fs_get_inode_ref(&mp->fs, next_inode,
- &child_ref);
+ r = ext4_fs_get_inode_ref(fs, next_inode, &child_ref);
if (r != EOK)
break;
- inode_mode = ext4_inode_type(&mp->fs.sb,
- child_ref.inode);
-
+ inode_mode = ext4_inode_type(sb, child_ref.inode);
ext4_fs_put_inode_ref(&child_ref);
}
@@ -857,11 +833,7 @@
break;
if (inode_mode != EXT4_INODE_MODE_DIRECTORY) {
- if (is_goal)
- r = EEXIST;
- else
- r = ENOENT;
-
+ r = is_goal ? EEXIST : ENOENT;
break;
}
@@ -869,7 +841,7 @@
if (r != EOK)
break;
- r = ext4_fs_get_inode_ref(&mp->fs, next_inode, &ref);
+ r = ext4_fs_get_inode_ref(fs, next_inode, &ref);
if (r != EOK)
break;
@@ -888,8 +860,7 @@
return r;
}
-static int ext4_remove_orig_reference(const char *path,
- uint32_t name_off,
+static int ext4_remove_orig_reference(const char *path, uint32_t name_off,
struct ext4_inode_ref *parent_ref,
struct ext4_inode_ref *child_ref)
{
@@ -940,8 +911,7 @@
EXT4_MP_LOCK(mp);
- r = ext4_generic_open2(&f, path, O_RDONLY,
- EXT4_DIRENTRY_UNKNOWN,
+ r = ext4_generic_open2(&f, path, O_RDONLY, EXT4_DIRENTRY_UNKNOWN,
&parent_inode, &name_off);
if (r != EOK)
goto Finish;
@@ -963,7 +933,7 @@
goto Finish;
}
- r = __ext4_create_hardlink(hardlink_path, &child_ref, false);
+ r = ext4_create_hardlink(hardlink_path, &child_ref, false);
Finish:
if (child_loaded)
@@ -1012,12 +982,11 @@
child_loaded = true;
- r = __ext4_create_hardlink(new_path, &child_ref, true);
+ r = ext4_create_hardlink(new_path, &child_ref, true);
if (r != EOK)
goto Finish;
- r = ext4_remove_orig_reference(path, name_off,
- &parent_ref, &child_ref);
+ r = ext4_remove_orig_reference(path, name_off, &parent_ref, &child_ref);
if (r != EOK)
goto Finish;