BEFS: logging cleanup
Summary: - all printk(KERN_foo converted to pr_foo() - add pr_fmt and remove redundant prefixes - convert befs_() to va_format (based on patch by Joe Perches) - remove non standard %Lu - use __func__ for all debugging [akpm@linux-foundation.org: fix printk warnings, reported by Fengguang] Signed-off-by: Fabian Frederick <fabf@skynet.be> Cc: Joe Perches <joe@perches.com> Cc: Fengguang Wu <fengguang.wu@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
91a52ab7d6
commit
dac52fc182
|
@ -3,5 +3,5 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
obj-$(CONFIG_BEFS_FS) += befs.o
|
obj-$(CONFIG_BEFS_FS) += befs.o
|
||||||
|
ccflags-$(CONFIG_BEFS_DEBUG) += -DDEBUG
|
||||||
befs-objs := datastream.o btree.o super.o inode.o debug.o io.o linuxvfs.o
|
befs-objs := datastream.o btree.o super.o inode.o debug.o io.o linuxvfs.o
|
||||||
|
|
|
@ -88,8 +88,11 @@ enum befs_err {
|
||||||
|
|
||||||
/****************************/
|
/****************************/
|
||||||
/* debug.c */
|
/* debug.c */
|
||||||
|
__printf(2, 3)
|
||||||
void befs_error(const struct super_block *sb, const char *fmt, ...);
|
void befs_error(const struct super_block *sb, const char *fmt, ...);
|
||||||
|
__printf(2, 3)
|
||||||
void befs_warning(const struct super_block *sb, const char *fmt, ...);
|
void befs_warning(const struct super_block *sb, const char *fmt, ...);
|
||||||
|
__printf(2, 3)
|
||||||
void befs_debug(const struct super_block *sb, const char *fmt, ...);
|
void befs_debug(const struct super_block *sb, const char *fmt, ...);
|
||||||
|
|
||||||
void befs_dump_super_block(const struct super_block *sb, befs_super_block *);
|
void befs_dump_super_block(const struct super_block *sb, befs_super_block *);
|
||||||
|
|
|
@ -137,7 +137,7 @@ befs_bt_read_super(struct super_block *sb, befs_data_stream * ds,
|
||||||
struct buffer_head *bh = NULL;
|
struct buffer_head *bh = NULL;
|
||||||
befs_disk_btree_super *od_sup = NULL;
|
befs_disk_btree_super *od_sup = NULL;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_btree_read_super()");
|
befs_debug(sb, "---> %s", __func__);
|
||||||
|
|
||||||
bh = befs_read_datastream(sb, ds, 0, NULL);
|
bh = befs_read_datastream(sb, ds, 0, NULL);
|
||||||
|
|
||||||
|
@ -162,11 +162,11 @@ befs_bt_read_super(struct super_block *sb, befs_data_stream * ds,
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_btree_read_super()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
return BEFS_OK;
|
return BEFS_OK;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
befs_debug(sb, "<--- befs_btree_read_super() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -195,16 +195,16 @@ befs_bt_read_node(struct super_block *sb, befs_data_stream * ds,
|
||||||
{
|
{
|
||||||
uint off = 0;
|
uint off = 0;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_bt_read_node()");
|
befs_debug(sb, "---> %s", __func__);
|
||||||
|
|
||||||
if (node->bh)
|
if (node->bh)
|
||||||
brelse(node->bh);
|
brelse(node->bh);
|
||||||
|
|
||||||
node->bh = befs_read_datastream(sb, ds, node_off, &off);
|
node->bh = befs_read_datastream(sb, ds, node_off, &off);
|
||||||
if (!node->bh) {
|
if (!node->bh) {
|
||||||
befs_error(sb, "befs_bt_read_node() failed to read "
|
befs_error(sb, "%s failed to read "
|
||||||
"node at %Lu", node_off);
|
"node at %llu", __func__, node_off);
|
||||||
befs_debug(sb, "<--- befs_bt_read_node() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
|
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
@ -221,7 +221,7 @@ befs_bt_read_node(struct super_block *sb, befs_data_stream * ds,
|
||||||
node->head.all_key_length =
|
node->head.all_key_length =
|
||||||
fs16_to_cpu(sb, node->od_node->all_key_length);
|
fs16_to_cpu(sb, node->od_node->all_key_length);
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_btree_read_node()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
return BEFS_OK;
|
return BEFS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -252,7 +252,7 @@ befs_btree_find(struct super_block *sb, befs_data_stream * ds,
|
||||||
befs_off_t node_off;
|
befs_off_t node_off;
|
||||||
int res;
|
int res;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_btree_find() Key: %s", key);
|
befs_debug(sb, "---> %s Key: %s", __func__, key);
|
||||||
|
|
||||||
if (befs_bt_read_super(sb, ds, &bt_super) != BEFS_OK) {
|
if (befs_bt_read_super(sb, ds, &bt_super) != BEFS_OK) {
|
||||||
befs_error(sb,
|
befs_error(sb,
|
||||||
|
@ -263,7 +263,7 @@ befs_btree_find(struct super_block *sb, befs_data_stream * ds,
|
||||||
this_node = kmalloc(sizeof (befs_btree_node),
|
this_node = kmalloc(sizeof (befs_btree_node),
|
||||||
GFP_NOFS);
|
GFP_NOFS);
|
||||||
if (!this_node) {
|
if (!this_node) {
|
||||||
befs_error(sb, "befs_btree_find() failed to allocate %u "
|
befs_error(sb, "befs_btree_find() failed to allocate %zu "
|
||||||
"bytes of memory", sizeof (befs_btree_node));
|
"bytes of memory", sizeof (befs_btree_node));
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
@ -274,7 +274,7 @@ befs_btree_find(struct super_block *sb, befs_data_stream * ds,
|
||||||
node_off = bt_super.root_node_ptr;
|
node_off = bt_super.root_node_ptr;
|
||||||
if (befs_bt_read_node(sb, ds, this_node, node_off) != BEFS_OK) {
|
if (befs_bt_read_node(sb, ds, this_node, node_off) != BEFS_OK) {
|
||||||
befs_error(sb, "befs_btree_find() failed to read "
|
befs_error(sb, "befs_btree_find() failed to read "
|
||||||
"node at %Lu", node_off);
|
"node at %llu", node_off);
|
||||||
goto error_alloc;
|
goto error_alloc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -285,7 +285,7 @@ befs_btree_find(struct super_block *sb, befs_data_stream * ds,
|
||||||
/* if no match, go to overflow node */
|
/* if no match, go to overflow node */
|
||||||
if (befs_bt_read_node(sb, ds, this_node, node_off) != BEFS_OK) {
|
if (befs_bt_read_node(sb, ds, this_node, node_off) != BEFS_OK) {
|
||||||
befs_error(sb, "befs_btree_find() failed to read "
|
befs_error(sb, "befs_btree_find() failed to read "
|
||||||
"node at %Lu", node_off);
|
"node at %llu", node_off);
|
||||||
goto error_alloc;
|
goto error_alloc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -298,11 +298,11 @@ befs_btree_find(struct super_block *sb, befs_data_stream * ds,
|
||||||
kfree(this_node);
|
kfree(this_node);
|
||||||
|
|
||||||
if (res != BEFS_BT_MATCH) {
|
if (res != BEFS_BT_MATCH) {
|
||||||
befs_debug(sb, "<--- befs_btree_find() Key %s not found", key);
|
befs_debug(sb, "<--- %s Key %s not found", __func__, key);
|
||||||
*value = 0;
|
*value = 0;
|
||||||
return BEFS_BT_NOT_FOUND;
|
return BEFS_BT_NOT_FOUND;
|
||||||
}
|
}
|
||||||
befs_debug(sb, "<--- befs_btree_find() Found key %s, value %Lu",
|
befs_debug(sb, "<--- %s Found key %s, value %llu", __func__,
|
||||||
key, *value);
|
key, *value);
|
||||||
return BEFS_OK;
|
return BEFS_OK;
|
||||||
|
|
||||||
|
@ -310,7 +310,7 @@ befs_btree_find(struct super_block *sb, befs_data_stream * ds,
|
||||||
kfree(this_node);
|
kfree(this_node);
|
||||||
error:
|
error:
|
||||||
*value = 0;
|
*value = 0;
|
||||||
befs_debug(sb, "<--- befs_btree_find() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -343,7 +343,7 @@ befs_find_key(struct super_block *sb, befs_btree_node * node,
|
||||||
char *thiskey;
|
char *thiskey;
|
||||||
fs64 *valarray;
|
fs64 *valarray;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_find_key() %s", findkey);
|
befs_debug(sb, "---> %s %s", __func__, findkey);
|
||||||
|
|
||||||
*value = 0;
|
*value = 0;
|
||||||
|
|
||||||
|
@ -355,7 +355,7 @@ befs_find_key(struct super_block *sb, befs_btree_node * node,
|
||||||
|
|
||||||
eq = befs_compare_strings(thiskey, keylen, findkey, findkey_len);
|
eq = befs_compare_strings(thiskey, keylen, findkey, findkey_len);
|
||||||
if (eq < 0) {
|
if (eq < 0) {
|
||||||
befs_debug(sb, "<--- befs_find_key() %s not found", findkey);
|
befs_debug(sb, "<--- %s %s not found", __func__, findkey);
|
||||||
return BEFS_BT_NOT_FOUND;
|
return BEFS_BT_NOT_FOUND;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -373,8 +373,8 @@ befs_find_key(struct super_block *sb, befs_btree_node * node,
|
||||||
findkey_len);
|
findkey_len);
|
||||||
|
|
||||||
if (eq == 0) {
|
if (eq == 0) {
|
||||||
befs_debug(sb, "<--- befs_find_key() found %s at %d",
|
befs_debug(sb, "<--- %s found %s at %d",
|
||||||
thiskey, mid);
|
__func__, thiskey, mid);
|
||||||
|
|
||||||
*value = fs64_to_cpu(sb, valarray[mid]);
|
*value = fs64_to_cpu(sb, valarray[mid]);
|
||||||
return BEFS_BT_MATCH;
|
return BEFS_BT_MATCH;
|
||||||
|
@ -388,7 +388,7 @@ befs_find_key(struct super_block *sb, befs_btree_node * node,
|
||||||
*value = fs64_to_cpu(sb, valarray[mid + 1]);
|
*value = fs64_to_cpu(sb, valarray[mid + 1]);
|
||||||
else
|
else
|
||||||
*value = fs64_to_cpu(sb, valarray[mid]);
|
*value = fs64_to_cpu(sb, valarray[mid]);
|
||||||
befs_debug(sb, "<--- befs_find_key() found %s at %d", thiskey, mid);
|
befs_debug(sb, "<--- %s found %s at %d", __func__, thiskey, mid);
|
||||||
return BEFS_BT_PARMATCH;
|
return BEFS_BT_PARMATCH;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -428,7 +428,7 @@ befs_btree_read(struct super_block *sb, befs_data_stream * ds,
|
||||||
|
|
||||||
uint key_sum = 0;
|
uint key_sum = 0;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_btree_read()");
|
befs_debug(sb, "---> %s", __func__);
|
||||||
|
|
||||||
if (befs_bt_read_super(sb, ds, &bt_super) != BEFS_OK) {
|
if (befs_bt_read_super(sb, ds, &bt_super) != BEFS_OK) {
|
||||||
befs_error(sb,
|
befs_error(sb,
|
||||||
|
@ -437,7 +437,7 @@ befs_btree_read(struct super_block *sb, befs_data_stream * ds,
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((this_node = kmalloc(sizeof (befs_btree_node), GFP_NOFS)) == NULL) {
|
if ((this_node = kmalloc(sizeof (befs_btree_node), GFP_NOFS)) == NULL) {
|
||||||
befs_error(sb, "befs_btree_read() failed to allocate %u "
|
befs_error(sb, "befs_btree_read() failed to allocate %zu "
|
||||||
"bytes of memory", sizeof (befs_btree_node));
|
"bytes of memory", sizeof (befs_btree_node));
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
@ -452,7 +452,7 @@ befs_btree_read(struct super_block *sb, befs_data_stream * ds,
|
||||||
kfree(this_node);
|
kfree(this_node);
|
||||||
*value = 0;
|
*value = 0;
|
||||||
*keysize = 0;
|
*keysize = 0;
|
||||||
befs_debug(sb, "<--- befs_btree_read() Tree is EMPTY");
|
befs_debug(sb, "<--- %s Tree is EMPTY", __func__);
|
||||||
return BEFS_BT_EMPTY;
|
return BEFS_BT_EMPTY;
|
||||||
} else if (res == BEFS_ERR) {
|
} else if (res == BEFS_ERR) {
|
||||||
goto error_alloc;
|
goto error_alloc;
|
||||||
|
@ -467,7 +467,8 @@ befs_btree_read(struct super_block *sb, befs_data_stream * ds,
|
||||||
*keysize = 0;
|
*keysize = 0;
|
||||||
*value = 0;
|
*value = 0;
|
||||||
befs_debug(sb,
|
befs_debug(sb,
|
||||||
"<--- befs_btree_read() END of keys at %Lu",
|
"<--- %s END of keys at %llu", __func__,
|
||||||
|
(unsigned long long)
|
||||||
key_sum + this_node->head.all_key_count);
|
key_sum + this_node->head.all_key_count);
|
||||||
brelse(this_node->bh);
|
brelse(this_node->bh);
|
||||||
kfree(this_node);
|
kfree(this_node);
|
||||||
|
@ -478,8 +479,8 @@ befs_btree_read(struct super_block *sb, befs_data_stream * ds,
|
||||||
node_off = this_node->head.right;
|
node_off = this_node->head.right;
|
||||||
|
|
||||||
if (befs_bt_read_node(sb, ds, this_node, node_off) != BEFS_OK) {
|
if (befs_bt_read_node(sb, ds, this_node, node_off) != BEFS_OK) {
|
||||||
befs_error(sb, "befs_btree_read() failed to read "
|
befs_error(sb, "%s failed to read node at %llu",
|
||||||
"node at %Lu", node_off);
|
__func__, (unsigned long long)node_off);
|
||||||
goto error_alloc;
|
goto error_alloc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -492,11 +493,13 @@ befs_btree_read(struct super_block *sb, befs_data_stream * ds,
|
||||||
|
|
||||||
keystart = befs_bt_get_key(sb, this_node, cur_key, &keylen);
|
keystart = befs_bt_get_key(sb, this_node, cur_key, &keylen);
|
||||||
|
|
||||||
befs_debug(sb, "Read [%Lu,%d]: keysize %d", node_off, cur_key, keylen);
|
befs_debug(sb, "Read [%llu,%d]: keysize %d",
|
||||||
|
(long long unsigned int)node_off, (int)cur_key,
|
||||||
|
(int)keylen);
|
||||||
|
|
||||||
if (bufsize < keylen + 1) {
|
if (bufsize < keylen + 1) {
|
||||||
befs_error(sb, "befs_btree_read() keybuf too small (%u) "
|
befs_error(sb, "%s keybuf too small (%zu) "
|
||||||
"for key of size %d", bufsize, keylen);
|
"for key of size %d", __func__, bufsize, keylen);
|
||||||
brelse(this_node->bh);
|
brelse(this_node->bh);
|
||||||
goto error_alloc;
|
goto error_alloc;
|
||||||
};
|
};
|
||||||
|
@ -506,13 +509,13 @@ befs_btree_read(struct super_block *sb, befs_data_stream * ds,
|
||||||
*keysize = keylen;
|
*keysize = keylen;
|
||||||
keybuf[keylen] = '\0';
|
keybuf[keylen] = '\0';
|
||||||
|
|
||||||
befs_debug(sb, "Read [%Lu,%d]: Key \"%.*s\", Value %Lu", node_off,
|
befs_debug(sb, "Read [%llu,%d]: Key \"%.*s\", Value %llu", node_off,
|
||||||
cur_key, keylen, keybuf, *value);
|
cur_key, keylen, keybuf, *value);
|
||||||
|
|
||||||
brelse(this_node->bh);
|
brelse(this_node->bh);
|
||||||
kfree(this_node);
|
kfree(this_node);
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_btree_read()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
|
|
||||||
return BEFS_OK;
|
return BEFS_OK;
|
||||||
|
|
||||||
|
@ -522,7 +525,7 @@ befs_btree_read(struct super_block *sb, befs_data_stream * ds,
|
||||||
error:
|
error:
|
||||||
*keysize = 0;
|
*keysize = 0;
|
||||||
*value = 0;
|
*value = 0;
|
||||||
befs_debug(sb, "<--- befs_btree_read() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -547,26 +550,26 @@ befs_btree_seekleaf(struct super_block *sb, befs_data_stream * ds,
|
||||||
befs_off_t * node_off)
|
befs_off_t * node_off)
|
||||||
{
|
{
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_btree_seekleaf()");
|
befs_debug(sb, "---> %s", __func__);
|
||||||
|
|
||||||
if (befs_bt_read_node(sb, ds, this_node, *node_off) != BEFS_OK) {
|
if (befs_bt_read_node(sb, ds, this_node, *node_off) != BEFS_OK) {
|
||||||
befs_error(sb, "befs_btree_seekleaf() failed to read "
|
befs_error(sb, "%s failed to read "
|
||||||
"node at %Lu", *node_off);
|
"node at %llu", __func__, *node_off);
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
befs_debug(sb, "Seekleaf to root node %Lu", *node_off);
|
befs_debug(sb, "Seekleaf to root node %llu", *node_off);
|
||||||
|
|
||||||
if (this_node->head.all_key_count == 0 && befs_leafnode(this_node)) {
|
if (this_node->head.all_key_count == 0 && befs_leafnode(this_node)) {
|
||||||
befs_debug(sb, "<--- befs_btree_seekleaf() Tree is EMPTY");
|
befs_debug(sb, "<--- %s Tree is EMPTY", __func__);
|
||||||
return BEFS_BT_EMPTY;
|
return BEFS_BT_EMPTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (!befs_leafnode(this_node)) {
|
while (!befs_leafnode(this_node)) {
|
||||||
|
|
||||||
if (this_node->head.all_key_count == 0) {
|
if (this_node->head.all_key_count == 0) {
|
||||||
befs_debug(sb, "befs_btree_seekleaf() encountered "
|
befs_debug(sb, "%s encountered "
|
||||||
"an empty interior node: %Lu. Using Overflow "
|
"an empty interior node: %llu. Using Overflow "
|
||||||
"node: %Lu", *node_off,
|
"node: %llu", __func__, *node_off,
|
||||||
this_node->head.overflow);
|
this_node->head.overflow);
|
||||||
*node_off = this_node->head.overflow;
|
*node_off = this_node->head.overflow;
|
||||||
} else {
|
} else {
|
||||||
|
@ -574,19 +577,19 @@ befs_btree_seekleaf(struct super_block *sb, befs_data_stream * ds,
|
||||||
*node_off = fs64_to_cpu(sb, valarray[0]);
|
*node_off = fs64_to_cpu(sb, valarray[0]);
|
||||||
}
|
}
|
||||||
if (befs_bt_read_node(sb, ds, this_node, *node_off) != BEFS_OK) {
|
if (befs_bt_read_node(sb, ds, this_node, *node_off) != BEFS_OK) {
|
||||||
befs_error(sb, "befs_btree_seekleaf() failed to read "
|
befs_error(sb, "%s failed to read "
|
||||||
"node at %Lu", *node_off);
|
"node at %llu", __func__, *node_off);
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
befs_debug(sb, "Seekleaf to child node %Lu", *node_off);
|
befs_debug(sb, "Seekleaf to child node %llu", *node_off);
|
||||||
}
|
}
|
||||||
befs_debug(sb, "Node %Lu is a leaf node", *node_off);
|
befs_debug(sb, "Node %llu is a leaf node", *node_off);
|
||||||
|
|
||||||
return BEFS_OK;
|
return BEFS_OK;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
befs_debug(sb, "<--- befs_btree_seekleaf() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -52,26 +52,25 @@ befs_read_datastream(struct super_block *sb, befs_data_stream * ds,
|
||||||
befs_block_run run;
|
befs_block_run run;
|
||||||
befs_blocknr_t block; /* block coresponding to pos */
|
befs_blocknr_t block; /* block coresponding to pos */
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_read_datastream() %Lu", pos);
|
befs_debug(sb, "---> %s %llu", __func__, pos);
|
||||||
block = pos >> BEFS_SB(sb)->block_shift;
|
block = pos >> BEFS_SB(sb)->block_shift;
|
||||||
if (off)
|
if (off)
|
||||||
*off = pos - (block << BEFS_SB(sb)->block_shift);
|
*off = pos - (block << BEFS_SB(sb)->block_shift);
|
||||||
|
|
||||||
if (befs_fblock2brun(sb, ds, block, &run) != BEFS_OK) {
|
if (befs_fblock2brun(sb, ds, block, &run) != BEFS_OK) {
|
||||||
befs_error(sb, "BeFS: Error finding disk addr of block %lu",
|
befs_error(sb, "BeFS: Error finding disk addr of block %lu",
|
||||||
block);
|
(unsigned long)block);
|
||||||
befs_debug(sb, "<--- befs_read_datastream() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
bh = befs_bread_iaddr(sb, run);
|
bh = befs_bread_iaddr(sb, run);
|
||||||
if (!bh) {
|
if (!bh) {
|
||||||
befs_error(sb, "BeFS: Error reading block %lu from datastream",
|
befs_error(sb, "BeFS: Error reading block %lu from datastream",
|
||||||
block);
|
(unsigned long)block);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_read_datastream() read data, starting at %Lu",
|
befs_debug(sb, "<--- %s read data, starting at %llu", __func__, pos);
|
||||||
pos);
|
|
||||||
|
|
||||||
return bh;
|
return bh;
|
||||||
}
|
}
|
||||||
|
@ -106,7 +105,8 @@ befs_fblock2brun(struct super_block *sb, befs_data_stream * data,
|
||||||
} else {
|
} else {
|
||||||
befs_error(sb,
|
befs_error(sb,
|
||||||
"befs_fblock2brun() was asked to find block %lu, "
|
"befs_fblock2brun() was asked to find block %lu, "
|
||||||
"which is not mapped by the datastream\n", fblock);
|
"which is not mapped by the datastream\n",
|
||||||
|
(unsigned long)fblock);
|
||||||
err = BEFS_ERR;
|
err = BEFS_ERR;
|
||||||
}
|
}
|
||||||
return err;
|
return err;
|
||||||
|
@ -128,14 +128,14 @@ befs_read_lsymlink(struct super_block * sb, befs_data_stream * ds, void *buff,
|
||||||
befs_off_t bytes_read = 0; /* bytes readed */
|
befs_off_t bytes_read = 0; /* bytes readed */
|
||||||
u16 plen;
|
u16 plen;
|
||||||
struct buffer_head *bh = NULL;
|
struct buffer_head *bh = NULL;
|
||||||
befs_debug(sb, "---> befs_read_lsymlink() length: %Lu", len);
|
befs_debug(sb, "---> %s length: %llu", __func__, len);
|
||||||
|
|
||||||
while (bytes_read < len) {
|
while (bytes_read < len) {
|
||||||
bh = befs_read_datastream(sb, ds, bytes_read, NULL);
|
bh = befs_read_datastream(sb, ds, bytes_read, NULL);
|
||||||
if (!bh) {
|
if (!bh) {
|
||||||
befs_error(sb, "BeFS: Error reading datastream block "
|
befs_error(sb, "BeFS: Error reading datastream block "
|
||||||
"starting from %Lu", bytes_read);
|
"starting from %llu", bytes_read);
|
||||||
befs_debug(sb, "<--- befs_read_lsymlink() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return bytes_read;
|
return bytes_read;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -146,7 +146,8 @@ befs_read_lsymlink(struct super_block * sb, befs_data_stream * ds, void *buff,
|
||||||
bytes_read += plen;
|
bytes_read += plen;
|
||||||
}
|
}
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_read_lsymlink() read %u bytes", bytes_read);
|
befs_debug(sb, "<--- %s read %u bytes", __func__, (unsigned int)
|
||||||
|
bytes_read);
|
||||||
return bytes_read;
|
return bytes_read;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -169,7 +170,7 @@ befs_count_blocks(struct super_block * sb, befs_data_stream * ds)
|
||||||
befs_blocknr_t metablocks; /* FS metadata blocks */
|
befs_blocknr_t metablocks; /* FS metadata blocks */
|
||||||
befs_sb_info *befs_sb = BEFS_SB(sb);
|
befs_sb_info *befs_sb = BEFS_SB(sb);
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_count_blocks()");
|
befs_debug(sb, "---> %s", __func__);
|
||||||
|
|
||||||
datablocks = ds->size >> befs_sb->block_shift;
|
datablocks = ds->size >> befs_sb->block_shift;
|
||||||
if (ds->size & (befs_sb->block_size - 1))
|
if (ds->size & (befs_sb->block_size - 1))
|
||||||
|
@ -206,7 +207,7 @@ befs_count_blocks(struct super_block * sb, befs_data_stream * ds)
|
||||||
}
|
}
|
||||||
|
|
||||||
blocks = datablocks + metablocks;
|
blocks = datablocks + metablocks;
|
||||||
befs_debug(sb, "<--- befs_count_blocks() %u blocks", blocks);
|
befs_debug(sb, "<--- %s %u blocks", __func__, (unsigned int)blocks);
|
||||||
|
|
||||||
return blocks;
|
return blocks;
|
||||||
}
|
}
|
||||||
|
@ -251,11 +252,11 @@ befs_find_brun_direct(struct super_block *sb, befs_data_stream * data,
|
||||||
befs_blocknr_t max_block =
|
befs_blocknr_t max_block =
|
||||||
data->max_direct_range >> BEFS_SB(sb)->block_shift;
|
data->max_direct_range >> BEFS_SB(sb)->block_shift;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_find_brun_direct(), find %lu", blockno);
|
befs_debug(sb, "---> %s, find %lu", __func__, (unsigned long)blockno);
|
||||||
|
|
||||||
if (blockno > max_block) {
|
if (blockno > max_block) {
|
||||||
befs_error(sb, "befs_find_brun_direct() passed block outside of"
|
befs_error(sb, "%s passed block outside of direct region",
|
||||||
"direct region");
|
__func__);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,13 +268,14 @@ befs_find_brun_direct(struct super_block *sb, befs_data_stream * data,
|
||||||
run->start = array[i].start + offset;
|
run->start = array[i].start + offset;
|
||||||
run->len = array[i].len - offset;
|
run->len = array[i].len - offset;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_find_brun_direct(), "
|
befs_debug(sb, "---> %s, "
|
||||||
"found %lu at direct[%d]", blockno, i);
|
"found %lu at direct[%d]", __func__,
|
||||||
|
(unsigned long)blockno, i);
|
||||||
return BEFS_OK;
|
return BEFS_OK;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_find_brun_direct() ERROR");
|
befs_debug(sb, "---> %s ERROR", __func__);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -316,7 +318,7 @@ befs_find_brun_indirect(struct super_block *sb,
|
||||||
befs_blocknr_t indirblockno = iaddr2blockno(sb, &indirect);
|
befs_blocknr_t indirblockno = iaddr2blockno(sb, &indirect);
|
||||||
int arraylen = befs_iaddrs_per_block(sb);
|
int arraylen = befs_iaddrs_per_block(sb);
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_find_brun_indirect(), find %lu", blockno);
|
befs_debug(sb, "---> %s, find %lu", __func__, (unsigned long)blockno);
|
||||||
|
|
||||||
indir_start_blk = data->max_direct_range >> BEFS_SB(sb)->block_shift;
|
indir_start_blk = data->max_direct_range >> BEFS_SB(sb)->block_shift;
|
||||||
search_blk = blockno - indir_start_blk;
|
search_blk = blockno - indir_start_blk;
|
||||||
|
@ -325,10 +327,9 @@ befs_find_brun_indirect(struct super_block *sb,
|
||||||
for (i = 0; i < indirect.len; i++) {
|
for (i = 0; i < indirect.len; i++) {
|
||||||
indirblock = befs_bread(sb, indirblockno + i);
|
indirblock = befs_bread(sb, indirblockno + i);
|
||||||
if (indirblock == NULL) {
|
if (indirblock == NULL) {
|
||||||
befs_debug(sb,
|
befs_debug(sb, "---> %s failed to read "
|
||||||
"---> befs_find_brun_indirect() failed to "
|
"disk block %lu from the indirect brun",
|
||||||
"read disk block %lu from the indirect brun",
|
__func__, (unsigned long)indirblockno + i);
|
||||||
indirblockno + i);
|
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -348,9 +349,10 @@ befs_find_brun_indirect(struct super_block *sb,
|
||||||
|
|
||||||
brelse(indirblock);
|
brelse(indirblock);
|
||||||
befs_debug(sb,
|
befs_debug(sb,
|
||||||
"<--- befs_find_brun_indirect() found "
|
"<--- %s found file block "
|
||||||
"file block %lu at indirect[%d]",
|
"%lu at indirect[%d]", __func__,
|
||||||
blockno, j + (i * arraylen));
|
(unsigned long)blockno,
|
||||||
|
j + (i * arraylen));
|
||||||
return BEFS_OK;
|
return BEFS_OK;
|
||||||
}
|
}
|
||||||
sum += len;
|
sum += len;
|
||||||
|
@ -360,10 +362,10 @@ befs_find_brun_indirect(struct super_block *sb,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Only fallthrough is an error */
|
/* Only fallthrough is an error */
|
||||||
befs_error(sb, "BeFS: befs_find_brun_indirect() failed to find "
|
befs_error(sb, "BeFS: %s failed to find "
|
||||||
"file block %lu", blockno);
|
"file block %lu", __func__, (unsigned long)blockno);
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_find_brun_indirect() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -444,7 +446,7 @@ befs_find_brun_dblindirect(struct super_block *sb,
|
||||||
size_t diblklen = iblklen * befs_iaddrs_per_block(sb)
|
size_t diblklen = iblklen * befs_iaddrs_per_block(sb)
|
||||||
* BEFS_DBLINDIR_BRUN_LEN;
|
* BEFS_DBLINDIR_BRUN_LEN;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_find_brun_dblindirect() find %lu", blockno);
|
befs_debug(sb, "---> %s find %lu", __func__, (unsigned long)blockno);
|
||||||
|
|
||||||
/* First, discover which of the double_indir->indir blocks
|
/* First, discover which of the double_indir->indir blocks
|
||||||
* contains pos. Then figure out how much of pos that
|
* contains pos. Then figure out how much of pos that
|
||||||
|
@ -460,8 +462,9 @@ befs_find_brun_dblindirect(struct super_block *sb,
|
||||||
dbl_which_block = dblindir_indx / befs_iaddrs_per_block(sb);
|
dbl_which_block = dblindir_indx / befs_iaddrs_per_block(sb);
|
||||||
if (dbl_which_block > data->double_indirect.len) {
|
if (dbl_which_block > data->double_indirect.len) {
|
||||||
befs_error(sb, "The double-indirect index calculated by "
|
befs_error(sb, "The double-indirect index calculated by "
|
||||||
"befs_read_brun_dblindirect(), %d, is outside the range "
|
"%s, %d, is outside the range "
|
||||||
"of the double-indirect block", dblindir_indx);
|
"of the double-indirect block", __func__,
|
||||||
|
dblindir_indx);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -469,10 +472,10 @@ befs_find_brun_dblindirect(struct super_block *sb,
|
||||||
befs_bread(sb, iaddr2blockno(sb, &data->double_indirect) +
|
befs_bread(sb, iaddr2blockno(sb, &data->double_indirect) +
|
||||||
dbl_which_block);
|
dbl_which_block);
|
||||||
if (dbl_indir_block == NULL) {
|
if (dbl_indir_block == NULL) {
|
||||||
befs_error(sb, "befs_read_brun_dblindirect() couldn't read the "
|
befs_error(sb, "%s couldn't read the "
|
||||||
"double-indirect block at blockno %lu",
|
"double-indirect block at blockno %lu", __func__,
|
||||||
iaddr2blockno(sb,
|
(unsigned long)
|
||||||
&data->double_indirect) +
|
iaddr2blockno(sb, &data->double_indirect) +
|
||||||
dbl_which_block);
|
dbl_which_block);
|
||||||
brelse(dbl_indir_block);
|
brelse(dbl_indir_block);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
|
@ -489,16 +492,16 @@ befs_find_brun_dblindirect(struct super_block *sb,
|
||||||
which_block = indir_indx / befs_iaddrs_per_block(sb);
|
which_block = indir_indx / befs_iaddrs_per_block(sb);
|
||||||
if (which_block > indir_run.len) {
|
if (which_block > indir_run.len) {
|
||||||
befs_error(sb, "The indirect index calculated by "
|
befs_error(sb, "The indirect index calculated by "
|
||||||
"befs_read_brun_dblindirect(), %d, is outside the range "
|
"%s, %d, is outside the range "
|
||||||
"of the indirect block", indir_indx);
|
"of the indirect block", __func__, indir_indx);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
indir_block =
|
indir_block =
|
||||||
befs_bread(sb, iaddr2blockno(sb, &indir_run) + which_block);
|
befs_bread(sb, iaddr2blockno(sb, &indir_run) + which_block);
|
||||||
if (indir_block == NULL) {
|
if (indir_block == NULL) {
|
||||||
befs_error(sb, "befs_read_brun_dblindirect() couldn't read the "
|
befs_error(sb, "%s couldn't read the indirect block "
|
||||||
"indirect block at blockno %lu",
|
"at blockno %lu", __func__, (unsigned long)
|
||||||
iaddr2blockno(sb, &indir_run) + which_block);
|
iaddr2blockno(sb, &indir_run) + which_block);
|
||||||
brelse(indir_block);
|
brelse(indir_block);
|
||||||
return BEFS_ERR;
|
return BEFS_ERR;
|
||||||
|
@ -519,7 +522,7 @@ befs_find_brun_dblindirect(struct super_block *sb,
|
||||||
run->len -= offset;
|
run->len -= offset;
|
||||||
|
|
||||||
befs_debug(sb, "Found file block %lu in double_indirect[%d][%d],"
|
befs_debug(sb, "Found file block %lu in double_indirect[%d][%d],"
|
||||||
" double_indirect_leftover = %lu",
|
" double_indirect_leftover = %lu", (unsigned long)
|
||||||
blockno, dblindir_indx, indir_indx, dblindir_leftover);
|
blockno, dblindir_indx, indir_indx, dblindir_leftover);
|
||||||
|
|
||||||
return BEFS_OK;
|
return BEFS_OK;
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
* debug functions
|
* debug functions
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
|
||||||
#ifdef __KERNEL__
|
#ifdef __KERNEL__
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
@ -23,43 +24,30 @@
|
||||||
|
|
||||||
#include "befs.h"
|
#include "befs.h"
|
||||||
|
|
||||||
#define ERRBUFSIZE 1024
|
|
||||||
|
|
||||||
void
|
void
|
||||||
befs_error(const struct super_block *sb, const char *fmt, ...)
|
befs_error(const struct super_block *sb, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
|
struct va_format vaf;
|
||||||
va_list args;
|
va_list args;
|
||||||
char *err_buf = kmalloc(ERRBUFSIZE, GFP_KERNEL);
|
|
||||||
if (err_buf == NULL) {
|
|
||||||
printk(KERN_ERR "could not allocate %d bytes\n", ERRBUFSIZE);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
vsnprintf(err_buf, ERRBUFSIZE, fmt, args);
|
vaf.fmt = fmt;
|
||||||
|
vaf.va = &args;
|
||||||
|
pr_err("(%s): %pV\n", sb->s_id, &vaf);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
|
|
||||||
printk(KERN_ERR "BeFS(%s): %s\n", sb->s_id, err_buf);
|
|
||||||
kfree(err_buf);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
befs_warning(const struct super_block *sb, const char *fmt, ...)
|
befs_warning(const struct super_block *sb, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
|
struct va_format vaf;
|
||||||
va_list args;
|
va_list args;
|
||||||
char *err_buf = kmalloc(ERRBUFSIZE, GFP_KERNEL);
|
|
||||||
if (err_buf == NULL) {
|
|
||||||
printk(KERN_ERR "could not allocate %d bytes\n", ERRBUFSIZE);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
vsnprintf(err_buf, ERRBUFSIZE, fmt, args);
|
vaf.fmt = fmt;
|
||||||
|
vaf.va = &args;
|
||||||
|
pr_warn("(%s): %pV\n", sb->s_id, &vaf);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
|
|
||||||
printk(KERN_WARNING "BeFS(%s): %s\n", sb->s_id, err_buf);
|
|
||||||
|
|
||||||
kfree(err_buf);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -67,25 +55,13 @@ befs_debug(const struct super_block *sb, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_BEFS_DEBUG
|
#ifdef CONFIG_BEFS_DEBUG
|
||||||
|
|
||||||
|
struct va_format vaf;
|
||||||
va_list args;
|
va_list args;
|
||||||
char *err_buf = NULL;
|
va_start(args, fmt);
|
||||||
|
vaf.fmt = fmt;
|
||||||
if (BEFS_SB(sb)->mount_opts.debug) {
|
vaf.va = &args;
|
||||||
err_buf = kmalloc(ERRBUFSIZE, GFP_KERNEL);
|
pr_debug("(%s): %pV\n", sb->s_id, &vaf);
|
||||||
if (err_buf == NULL) {
|
va_end(args);
|
||||||
printk(KERN_ERR "could not allocate %d bytes\n",
|
|
||||||
ERRBUFSIZE);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
va_start(args, fmt);
|
|
||||||
vsnprintf(err_buf, ERRBUFSIZE, fmt, args);
|
|
||||||
va_end(args);
|
|
||||||
|
|
||||||
printk(KERN_DEBUG "BeFS(%s): %s\n", sb->s_id, err_buf);
|
|
||||||
|
|
||||||
kfree(err_buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif //CONFIG_BEFS_DEBUG
|
#endif //CONFIG_BEFS_DEBUG
|
||||||
}
|
}
|
||||||
|
@ -109,9 +85,9 @@ befs_dump_inode(const struct super_block *sb, befs_inode * inode)
|
||||||
befs_debug(sb, " gid %u", fs32_to_cpu(sb, inode->gid));
|
befs_debug(sb, " gid %u", fs32_to_cpu(sb, inode->gid));
|
||||||
befs_debug(sb, " mode %08x", fs32_to_cpu(sb, inode->mode));
|
befs_debug(sb, " mode %08x", fs32_to_cpu(sb, inode->mode));
|
||||||
befs_debug(sb, " flags %08x", fs32_to_cpu(sb, inode->flags));
|
befs_debug(sb, " flags %08x", fs32_to_cpu(sb, inode->flags));
|
||||||
befs_debug(sb, " create_time %Lu",
|
befs_debug(sb, " create_time %llu",
|
||||||
fs64_to_cpu(sb, inode->create_time));
|
fs64_to_cpu(sb, inode->create_time));
|
||||||
befs_debug(sb, " last_modified_time %Lu",
|
befs_debug(sb, " last_modified_time %llu",
|
||||||
fs64_to_cpu(sb, inode->last_modified_time));
|
fs64_to_cpu(sb, inode->last_modified_time));
|
||||||
|
|
||||||
tmp_run = fsrun_to_cpu(sb, inode->parent);
|
tmp_run = fsrun_to_cpu(sb, inode->parent);
|
||||||
|
@ -137,7 +113,7 @@ befs_dump_inode(const struct super_block *sb, befs_inode * inode)
|
||||||
tmp_run.allocation_group, tmp_run.start,
|
tmp_run.allocation_group, tmp_run.start,
|
||||||
tmp_run.len);
|
tmp_run.len);
|
||||||
}
|
}
|
||||||
befs_debug(sb, " max_direct_range %Lu",
|
befs_debug(sb, " max_direct_range %llu",
|
||||||
fs64_to_cpu(sb,
|
fs64_to_cpu(sb,
|
||||||
inode->data.datastream.
|
inode->data.datastream.
|
||||||
max_direct_range));
|
max_direct_range));
|
||||||
|
@ -147,7 +123,7 @@ befs_dump_inode(const struct super_block *sb, befs_inode * inode)
|
||||||
tmp_run.allocation_group,
|
tmp_run.allocation_group,
|
||||||
tmp_run.start, tmp_run.len);
|
tmp_run.start, tmp_run.len);
|
||||||
|
|
||||||
befs_debug(sb, " max_indirect_range %Lu",
|
befs_debug(sb, " max_indirect_range %llu",
|
||||||
fs64_to_cpu(sb,
|
fs64_to_cpu(sb,
|
||||||
inode->data.datastream.
|
inode->data.datastream.
|
||||||
max_indirect_range));
|
max_indirect_range));
|
||||||
|
@ -158,12 +134,12 @@ befs_dump_inode(const struct super_block *sb, befs_inode * inode)
|
||||||
tmp_run.allocation_group, tmp_run.start,
|
tmp_run.allocation_group, tmp_run.start,
|
||||||
tmp_run.len);
|
tmp_run.len);
|
||||||
|
|
||||||
befs_debug(sb, " max_double_indirect_range %Lu",
|
befs_debug(sb, " max_double_indirect_range %llu",
|
||||||
fs64_to_cpu(sb,
|
fs64_to_cpu(sb,
|
||||||
inode->data.datastream.
|
inode->data.datastream.
|
||||||
max_double_indirect_range));
|
max_double_indirect_range));
|
||||||
|
|
||||||
befs_debug(sb, " size %Lu",
|
befs_debug(sb, " size %llu",
|
||||||
fs64_to_cpu(sb, inode->data.datastream.size));
|
fs64_to_cpu(sb, inode->data.datastream.size));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,8 +167,8 @@ befs_dump_super_block(const struct super_block *sb, befs_super_block * sup)
|
||||||
befs_debug(sb, " block_size %u", fs32_to_cpu(sb, sup->block_size));
|
befs_debug(sb, " block_size %u", fs32_to_cpu(sb, sup->block_size));
|
||||||
befs_debug(sb, " block_shift %u", fs32_to_cpu(sb, sup->block_shift));
|
befs_debug(sb, " block_shift %u", fs32_to_cpu(sb, sup->block_shift));
|
||||||
|
|
||||||
befs_debug(sb, " num_blocks %Lu", fs64_to_cpu(sb, sup->num_blocks));
|
befs_debug(sb, " num_blocks %llu", fs64_to_cpu(sb, sup->num_blocks));
|
||||||
befs_debug(sb, " used_blocks %Lu", fs64_to_cpu(sb, sup->used_blocks));
|
befs_debug(sb, " used_blocks %llu", fs64_to_cpu(sb, sup->used_blocks));
|
||||||
|
|
||||||
befs_debug(sb, " magic2 %08x", fs32_to_cpu(sb, sup->magic2));
|
befs_debug(sb, " magic2 %08x", fs32_to_cpu(sb, sup->magic2));
|
||||||
befs_debug(sb, " blocks_per_ag %u",
|
befs_debug(sb, " blocks_per_ag %u",
|
||||||
|
@ -206,8 +182,8 @@ befs_dump_super_block(const struct super_block *sb, befs_super_block * sup)
|
||||||
befs_debug(sb, " log_blocks %u, %hu, %hu",
|
befs_debug(sb, " log_blocks %u, %hu, %hu",
|
||||||
tmp_run.allocation_group, tmp_run.start, tmp_run.len);
|
tmp_run.allocation_group, tmp_run.start, tmp_run.len);
|
||||||
|
|
||||||
befs_debug(sb, " log_start %Ld", fs64_to_cpu(sb, sup->log_start));
|
befs_debug(sb, " log_start %lld", fs64_to_cpu(sb, sup->log_start));
|
||||||
befs_debug(sb, " log_end %Ld", fs64_to_cpu(sb, sup->log_end));
|
befs_debug(sb, " log_end %lld", fs64_to_cpu(sb, sup->log_end));
|
||||||
|
|
||||||
befs_debug(sb, " magic3 %08x", fs32_to_cpu(sb, sup->magic3));
|
befs_debug(sb, " magic3 %08x", fs32_to_cpu(sb, sup->magic3));
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,8 @@ befs_check_inode(struct super_block *sb, befs_inode * raw_inode,
|
||||||
/* check magic header. */
|
/* check magic header. */
|
||||||
if (magic1 != BEFS_INODE_MAGIC1) {
|
if (magic1 != BEFS_INODE_MAGIC1) {
|
||||||
befs_error(sb,
|
befs_error(sb,
|
||||||
"Inode has a bad magic header - inode = %lu", inode);
|
"Inode has a bad magic header - inode = %lu",
|
||||||
|
(unsigned long)inode);
|
||||||
return BEFS_BAD_INODE;
|
return BEFS_BAD_INODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,8 +35,8 @@ befs_check_inode(struct super_block *sb, befs_inode * raw_inode,
|
||||||
*/
|
*/
|
||||||
if (inode != iaddr2blockno(sb, &ino_num)) {
|
if (inode != iaddr2blockno(sb, &ino_num)) {
|
||||||
befs_error(sb, "inode blocknr field disagrees with vfs "
|
befs_error(sb, "inode blocknr field disagrees with vfs "
|
||||||
"VFS: %lu, Inode %lu",
|
"VFS: %lu, Inode %lu", (unsigned long)
|
||||||
inode, iaddr2blockno(sb, &ino_num));
|
inode, (unsigned long)iaddr2blockno(sb, &ino_num));
|
||||||
return BEFS_BAD_INODE;
|
return BEFS_BAD_INODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,7 +45,8 @@ befs_check_inode(struct super_block *sb, befs_inode * raw_inode,
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!(flags & BEFS_INODE_IN_USE)) {
|
if (!(flags & BEFS_INODE_IN_USE)) {
|
||||||
befs_error(sb, "inode is not used - inode = %lu", inode);
|
befs_error(sb, "inode is not used - inode = %lu",
|
||||||
|
(unsigned long)inode);
|
||||||
return BEFS_BAD_INODE;
|
return BEFS_BAD_INODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
24
fs/befs/io.c
24
fs/befs/io.c
|
@ -30,9 +30,9 @@ befs_bread_iaddr(struct super_block *sb, befs_inode_addr iaddr)
|
||||||
befs_blocknr_t block = 0;
|
befs_blocknr_t block = 0;
|
||||||
befs_sb_info *befs_sb = BEFS_SB(sb);
|
befs_sb_info *befs_sb = BEFS_SB(sb);
|
||||||
|
|
||||||
befs_debug(sb, "---> Enter befs_read_iaddr() "
|
befs_debug(sb, "---> Enter %s "
|
||||||
"[%u, %hu, %hu]",
|
"[%u, %hu, %hu]", __func__, iaddr.allocation_group,
|
||||||
iaddr.allocation_group, iaddr.start, iaddr.len);
|
iaddr.start, iaddr.len);
|
||||||
|
|
||||||
if (iaddr.allocation_group > befs_sb->num_ags) {
|
if (iaddr.allocation_group > befs_sb->num_ags) {
|
||||||
befs_error(sb, "BEFS: Invalid allocation group %u, max is %u",
|
befs_error(sb, "BEFS: Invalid allocation group %u, max is %u",
|
||||||
|
@ -42,20 +42,21 @@ befs_bread_iaddr(struct super_block *sb, befs_inode_addr iaddr)
|
||||||
|
|
||||||
block = iaddr2blockno(sb, &iaddr);
|
block = iaddr2blockno(sb, &iaddr);
|
||||||
|
|
||||||
befs_debug(sb, "befs_read_iaddr: offset = %lu", block);
|
befs_debug(sb, "%s: offset = %lu", __func__, (unsigned long)block);
|
||||||
|
|
||||||
bh = sb_bread(sb, block);
|
bh = sb_bread(sb, block);
|
||||||
|
|
||||||
if (bh == NULL) {
|
if (bh == NULL) {
|
||||||
befs_error(sb, "Failed to read block %lu", block);
|
befs_error(sb, "Failed to read block %lu",
|
||||||
|
(unsigned long)block);
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_read_iaddr()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
return bh;
|
return bh;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
befs_debug(sb, "<--- befs_read_iaddr() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,20 +65,21 @@ befs_bread(struct super_block *sb, befs_blocknr_t block)
|
||||||
{
|
{
|
||||||
struct buffer_head *bh = NULL;
|
struct buffer_head *bh = NULL;
|
||||||
|
|
||||||
befs_debug(sb, "---> Enter befs_read() %Lu", block);
|
befs_debug(sb, "---> Enter %s %lu", __func__, (unsigned long)block);
|
||||||
|
|
||||||
bh = sb_bread(sb, block);
|
bh = sb_bread(sb, block);
|
||||||
|
|
||||||
if (bh == NULL) {
|
if (bh == NULL) {
|
||||||
befs_error(sb, "Failed to read block %lu", block);
|
befs_error(sb, "Failed to read block %lu",
|
||||||
|
(unsigned long)block);
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_read()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
|
|
||||||
return bh;
|
return bh;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
befs_debug(sb, "<--- befs_read() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,8 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
|
||||||
|
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/fs.h>
|
#include <linux/fs.h>
|
||||||
|
@ -130,26 +132,28 @@ befs_get_block(struct inode *inode, sector_t block,
|
||||||
ulong disk_off;
|
ulong disk_off;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_get_block() for inode %lu, block %ld",
|
befs_debug(sb, "---> befs_get_block() for inode %lu, block %ld",
|
||||||
inode->i_ino, block);
|
(unsigned long)inode->i_ino, (long)block);
|
||||||
|
|
||||||
if (block < 0) {
|
if (block < 0) {
|
||||||
befs_error(sb, "befs_get_block() was asked for a block "
|
befs_error(sb, "befs_get_block() was asked for a block "
|
||||||
"number less than zero: block %ld in inode %lu",
|
"number less than zero: block %ld in inode %lu",
|
||||||
block, inode->i_ino);
|
(long)block, (unsigned long)inode->i_ino);
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (create) {
|
if (create) {
|
||||||
befs_error(sb, "befs_get_block() was asked to write to "
|
befs_error(sb, "befs_get_block() was asked to write to "
|
||||||
"block %ld in inode %lu", block, inode->i_ino);
|
"block %ld in inode %lu", (long)block,
|
||||||
|
(unsigned long)inode->i_ino);
|
||||||
return -EPERM;
|
return -EPERM;
|
||||||
}
|
}
|
||||||
|
|
||||||
res = befs_fblock2brun(sb, ds, block, &run);
|
res = befs_fblock2brun(sb, ds, block, &run);
|
||||||
if (res != BEFS_OK) {
|
if (res != BEFS_OK) {
|
||||||
befs_error(sb,
|
befs_error(sb,
|
||||||
"<--- befs_get_block() for inode %lu, block "
|
"<--- %s for inode %lu, block %ld ERROR",
|
||||||
"%ld ERROR", inode->i_ino, block);
|
__func__, (unsigned long)inode->i_ino,
|
||||||
|
(long)block);
|
||||||
return -EFBIG;
|
return -EFBIG;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -157,8 +161,9 @@ befs_get_block(struct inode *inode, sector_t block,
|
||||||
|
|
||||||
map_bh(bh_result, inode->i_sb, disk_off);
|
map_bh(bh_result, inode->i_sb, disk_off);
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_get_block() for inode %lu, block %ld, "
|
befs_debug(sb, "<--- %s for inode %lu, block %ld, disk address %lu",
|
||||||
"disk address %lu", inode->i_ino, block, disk_off);
|
__func__, (unsigned long)inode->i_ino, (long)block,
|
||||||
|
(unsigned long)disk_off);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -175,15 +180,15 @@ befs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
char *utfname;
|
char *utfname;
|
||||||
const char *name = dentry->d_name.name;
|
const char *name = dentry->d_name.name;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_lookup() "
|
befs_debug(sb, "---> %s name %s inode %ld", __func__,
|
||||||
"name %s inode %ld", dentry->d_name.name, dir->i_ino);
|
dentry->d_name.name, dir->i_ino);
|
||||||
|
|
||||||
/* Convert to UTF-8 */
|
/* Convert to UTF-8 */
|
||||||
if (BEFS_SB(sb)->nls) {
|
if (BEFS_SB(sb)->nls) {
|
||||||
ret =
|
ret =
|
||||||
befs_nls2utf(sb, name, strlen(name), &utfname, &utfnamelen);
|
befs_nls2utf(sb, name, strlen(name), &utfname, &utfnamelen);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
befs_debug(sb, "<--- befs_lookup() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return ERR_PTR(ret);
|
return ERR_PTR(ret);
|
||||||
}
|
}
|
||||||
ret = befs_btree_find(sb, ds, utfname, &offset);
|
ret = befs_btree_find(sb, ds, utfname, &offset);
|
||||||
|
@ -194,12 +199,12 @@ befs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ret == BEFS_BT_NOT_FOUND) {
|
if (ret == BEFS_BT_NOT_FOUND) {
|
||||||
befs_debug(sb, "<--- befs_lookup() %s not found",
|
befs_debug(sb, "<--- %s %s not found", __func__,
|
||||||
dentry->d_name.name);
|
dentry->d_name.name);
|
||||||
return ERR_PTR(-ENOENT);
|
return ERR_PTR(-ENOENT);
|
||||||
|
|
||||||
} else if (ret != BEFS_OK || offset == 0) {
|
} else if (ret != BEFS_OK || offset == 0) {
|
||||||
befs_warning(sb, "<--- befs_lookup() Error");
|
befs_warning(sb, "<--- %s Error", __func__);
|
||||||
return ERR_PTR(-ENODATA);
|
return ERR_PTR(-ENODATA);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,7 +214,7 @@ befs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
|
|
||||||
d_add(dentry, inode);
|
d_add(dentry, inode);
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_lookup()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -227,26 +232,25 @@ befs_readdir(struct file *file, struct dir_context *ctx)
|
||||||
char keybuf[BEFS_NAME_LEN + 1];
|
char keybuf[BEFS_NAME_LEN + 1];
|
||||||
const char *dirname = file->f_path.dentry->d_name.name;
|
const char *dirname = file->f_path.dentry->d_name.name;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_readdir() "
|
befs_debug(sb, "---> %s name %s, inode %ld, ctx->pos %lld",
|
||||||
"name %s, inode %ld, ctx->pos %Ld",
|
__func__, dirname, inode->i_ino, ctx->pos);
|
||||||
dirname, inode->i_ino, ctx->pos);
|
|
||||||
|
|
||||||
more:
|
more:
|
||||||
result = befs_btree_read(sb, ds, ctx->pos, BEFS_NAME_LEN + 1,
|
result = befs_btree_read(sb, ds, ctx->pos, BEFS_NAME_LEN + 1,
|
||||||
keybuf, &keysize, &value);
|
keybuf, &keysize, &value);
|
||||||
|
|
||||||
if (result == BEFS_ERR) {
|
if (result == BEFS_ERR) {
|
||||||
befs_debug(sb, "<--- befs_readdir() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
befs_error(sb, "IO error reading %s (inode %lu)",
|
befs_error(sb, "IO error reading %s (inode %lu)",
|
||||||
dirname, inode->i_ino);
|
dirname, inode->i_ino);
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
} else if (result == BEFS_BT_END) {
|
} else if (result == BEFS_BT_END) {
|
||||||
befs_debug(sb, "<--- befs_readdir() END");
|
befs_debug(sb, "<--- %s END", __func__);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
} else if (result == BEFS_BT_EMPTY) {
|
} else if (result == BEFS_BT_EMPTY) {
|
||||||
befs_debug(sb, "<--- befs_readdir() Empty directory");
|
befs_debug(sb, "<--- %s Empty directory", __func__);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -259,7 +263,7 @@ more:
|
||||||
result =
|
result =
|
||||||
befs_utf2nls(sb, keybuf, keysize, &nlsname, &nlsnamelen);
|
befs_utf2nls(sb, keybuf, keysize, &nlsname, &nlsnamelen);
|
||||||
if (result < 0) {
|
if (result < 0) {
|
||||||
befs_debug(sb, "<--- befs_readdir() ERROR");
|
befs_debug(sb, "<--- %s ERROR", __func__);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
if (!dir_emit(ctx, nlsname, nlsnamelen,
|
if (!dir_emit(ctx, nlsname, nlsnamelen,
|
||||||
|
@ -276,7 +280,7 @@ more:
|
||||||
ctx->pos++;
|
ctx->pos++;
|
||||||
goto more;
|
goto more;
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_readdir() pos %Ld", ctx->pos);
|
befs_debug(sb, "<--- %s pos %lld", __func__, ctx->pos);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -320,7 +324,7 @@ static struct inode *befs_iget(struct super_block *sb, unsigned long ino)
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
long ret = -EIO;
|
long ret = -EIO;
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_read_inode() " "inode = %lu", ino);
|
befs_debug(sb, "---> %s inode = %lu", __func__, ino);
|
||||||
|
|
||||||
inode = iget_locked(sb, ino);
|
inode = iget_locked(sb, ino);
|
||||||
if (!inode)
|
if (!inode)
|
||||||
|
@ -427,7 +431,7 @@ static struct inode *befs_iget(struct super_block *sb, unsigned long ino)
|
||||||
}
|
}
|
||||||
|
|
||||||
brelse(bh);
|
brelse(bh);
|
||||||
befs_debug(sb, "<--- befs_read_inode()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
unlock_new_inode(inode);
|
unlock_new_inode(inode);
|
||||||
return inode;
|
return inode;
|
||||||
|
|
||||||
|
@ -436,7 +440,7 @@ static struct inode *befs_iget(struct super_block *sb, unsigned long ino)
|
||||||
|
|
||||||
unacquire_none:
|
unacquire_none:
|
||||||
iget_failed(inode);
|
iget_failed(inode);
|
||||||
befs_debug(sb, "<--- befs_read_inode() - Bad inode");
|
befs_debug(sb, "<--- %s - Bad inode", __func__);
|
||||||
return ERR_PTR(ret);
|
return ERR_PTR(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -453,11 +457,9 @@ befs_init_inodecache(void)
|
||||||
SLAB_MEM_SPREAD),
|
SLAB_MEM_SPREAD),
|
||||||
init_once);
|
init_once);
|
||||||
if (befs_inode_cachep == NULL) {
|
if (befs_inode_cachep == NULL) {
|
||||||
printk(KERN_ERR "befs_init_inodecache: "
|
pr_err("%s: Couldn't initialize inode slabcache\n", __func__);
|
||||||
"Couldn't initialize inode slabcache\n");
|
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -543,16 +545,16 @@ befs_utf2nls(struct super_block *sb, const char *in,
|
||||||
*/
|
*/
|
||||||
int maxlen = in_len + 1;
|
int maxlen = in_len + 1;
|
||||||
|
|
||||||
befs_debug(sb, "---> utf2nls()");
|
befs_debug(sb, "---> %s", __func__);
|
||||||
|
|
||||||
if (!nls) {
|
if (!nls) {
|
||||||
befs_error(sb, "befs_utf2nls called with no NLS table loaded");
|
befs_error(sb, "%s called with no NLS table loaded", __func__);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
*out = result = kmalloc(maxlen, GFP_NOFS);
|
*out = result = kmalloc(maxlen, GFP_NOFS);
|
||||||
if (!*out) {
|
if (!*out) {
|
||||||
befs_error(sb, "befs_utf2nls() cannot allocate memory");
|
befs_error(sb, "%s cannot allocate memory", __func__);
|
||||||
*out_len = 0;
|
*out_len = 0;
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
@ -574,14 +576,14 @@ befs_utf2nls(struct super_block *sb, const char *in,
|
||||||
result[o] = '\0';
|
result[o] = '\0';
|
||||||
*out_len = o;
|
*out_len = o;
|
||||||
|
|
||||||
befs_debug(sb, "<--- utf2nls()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
|
|
||||||
return o;
|
return o;
|
||||||
|
|
||||||
conv_err:
|
conv_err:
|
||||||
befs_error(sb, "Name using character set %s contains a character that "
|
befs_error(sb, "Name using character set %s contains a character that "
|
||||||
"cannot be converted to unicode.", nls->charset);
|
"cannot be converted to unicode.", nls->charset);
|
||||||
befs_debug(sb, "<--- utf2nls()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
kfree(result);
|
kfree(result);
|
||||||
return -EILSEQ;
|
return -EILSEQ;
|
||||||
}
|
}
|
||||||
|
@ -622,16 +624,17 @@ befs_nls2utf(struct super_block *sb, const char *in,
|
||||||
* in special cases */
|
* in special cases */
|
||||||
int maxlen = (3 * in_len) + 1;
|
int maxlen = (3 * in_len) + 1;
|
||||||
|
|
||||||
befs_debug(sb, "---> nls2utf()\n");
|
befs_debug(sb, "---> %s\n", __func__);
|
||||||
|
|
||||||
if (!nls) {
|
if (!nls) {
|
||||||
befs_error(sb, "befs_nls2utf called with no NLS table loaded.");
|
befs_error(sb, "%s called with no NLS table loaded.",
|
||||||
|
__func__);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
*out = result = kmalloc(maxlen, GFP_NOFS);
|
*out = result = kmalloc(maxlen, GFP_NOFS);
|
||||||
if (!*out) {
|
if (!*out) {
|
||||||
befs_error(sb, "befs_nls2utf() cannot allocate memory");
|
befs_error(sb, "%s cannot allocate memory", __func__);
|
||||||
*out_len = 0;
|
*out_len = 0;
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
@ -652,14 +655,14 @@ befs_nls2utf(struct super_block *sb, const char *in,
|
||||||
result[o] = '\0';
|
result[o] = '\0';
|
||||||
*out_len = o;
|
*out_len = o;
|
||||||
|
|
||||||
befs_debug(sb, "<--- nls2utf()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
|
|
||||||
return i;
|
return i;
|
||||||
|
|
||||||
conv_err:
|
conv_err:
|
||||||
befs_error(sb, "Name using charecter set %s contains a charecter that "
|
befs_error(sb, "Name using charecter set %s contains a charecter that "
|
||||||
"cannot be converted to unicode.", nls->charset);
|
"cannot be converted to unicode.", nls->charset);
|
||||||
befs_debug(sb, "<--- nls2utf()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
kfree(result);
|
kfree(result);
|
||||||
return -EILSEQ;
|
return -EILSEQ;
|
||||||
}
|
}
|
||||||
|
@ -714,8 +717,8 @@ parse_options(char *options, befs_mount_options * opts)
|
||||||
if (option >= 0)
|
if (option >= 0)
|
||||||
uid = make_kuid(current_user_ns(), option);
|
uid = make_kuid(current_user_ns(), option);
|
||||||
if (!uid_valid(uid)) {
|
if (!uid_valid(uid)) {
|
||||||
printk(KERN_ERR "BeFS: Invalid uid %d, "
|
pr_err("Invalid uid %d, "
|
||||||
"using default\n", option);
|
"using default\n", option);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
opts->uid = uid;
|
opts->uid = uid;
|
||||||
|
@ -728,8 +731,8 @@ parse_options(char *options, befs_mount_options * opts)
|
||||||
if (option >= 0)
|
if (option >= 0)
|
||||||
gid = make_kgid(current_user_ns(), option);
|
gid = make_kgid(current_user_ns(), option);
|
||||||
if (!gid_valid(gid)) {
|
if (!gid_valid(gid)) {
|
||||||
printk(KERN_ERR "BeFS: Invalid gid %d, "
|
pr_err("Invalid gid %d, "
|
||||||
"using default\n", option);
|
"using default\n", option);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
opts->gid = gid;
|
opts->gid = gid;
|
||||||
|
@ -739,8 +742,8 @@ parse_options(char *options, befs_mount_options * opts)
|
||||||
kfree(opts->iocharset);
|
kfree(opts->iocharset);
|
||||||
opts->iocharset = match_strdup(&args[0]);
|
opts->iocharset = match_strdup(&args[0]);
|
||||||
if (!opts->iocharset) {
|
if (!opts->iocharset) {
|
||||||
printk(KERN_ERR "BeFS: allocation failure for "
|
pr_err("allocation failure for "
|
||||||
"iocharset string\n");
|
"iocharset string\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -748,8 +751,8 @@ parse_options(char *options, befs_mount_options * opts)
|
||||||
opts->debug = 1;
|
opts->debug = 1;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
printk(KERN_ERR "BeFS: Unrecognized mount option \"%s\" "
|
pr_err("Unrecognized mount option \"%s\" "
|
||||||
"or missing value\n", p);
|
"or missing value\n", p);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -792,8 +795,7 @@ befs_fill_super(struct super_block *sb, void *data, int silent)
|
||||||
|
|
||||||
sb->s_fs_info = kzalloc(sizeof(*befs_sb), GFP_KERNEL);
|
sb->s_fs_info = kzalloc(sizeof(*befs_sb), GFP_KERNEL);
|
||||||
if (sb->s_fs_info == NULL) {
|
if (sb->s_fs_info == NULL) {
|
||||||
printk(KERN_ERR
|
pr_err("(%s): Unable to allocate memory for private "
|
||||||
"BeFS(%s): Unable to allocate memory for private "
|
|
||||||
"portion of superblock. Bailing.\n", sb->s_id);
|
"portion of superblock. Bailing.\n", sb->s_id);
|
||||||
goto unacquire_none;
|
goto unacquire_none;
|
||||||
}
|
}
|
||||||
|
@ -804,7 +806,7 @@ befs_fill_super(struct super_block *sb, void *data, int silent)
|
||||||
goto unacquire_priv_sbp;
|
goto unacquire_priv_sbp;
|
||||||
}
|
}
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_fill_super()");
|
befs_debug(sb, "---> %s", __func__);
|
||||||
|
|
||||||
#ifndef CONFIG_BEFS_RW
|
#ifndef CONFIG_BEFS_RW
|
||||||
if (!(sb->s_flags & MS_RDONLY)) {
|
if (!(sb->s_flags & MS_RDONLY)) {
|
||||||
|
@ -852,7 +854,7 @@ befs_fill_super(struct super_block *sb, void *data, int silent)
|
||||||
goto unacquire_priv_sbp;
|
goto unacquire_priv_sbp;
|
||||||
|
|
||||||
if( befs_sb->num_blocks > ~((sector_t)0) ) {
|
if( befs_sb->num_blocks > ~((sector_t)0) ) {
|
||||||
befs_error(sb, "blocks count: %Lu "
|
befs_error(sb, "blocks count: %llu "
|
||||||
"is larger than the host can use",
|
"is larger than the host can use",
|
||||||
befs_sb->num_blocks);
|
befs_sb->num_blocks);
|
||||||
goto unacquire_priv_sbp;
|
goto unacquire_priv_sbp;
|
||||||
|
@ -922,7 +924,7 @@ befs_statfs(struct dentry *dentry, struct kstatfs *buf)
|
||||||
struct super_block *sb = dentry->d_sb;
|
struct super_block *sb = dentry->d_sb;
|
||||||
u64 id = huge_encode_dev(sb->s_bdev->bd_dev);
|
u64 id = huge_encode_dev(sb->s_bdev->bd_dev);
|
||||||
|
|
||||||
befs_debug(sb, "---> befs_statfs()");
|
befs_debug(sb, "---> %s", __func__);
|
||||||
|
|
||||||
buf->f_type = BEFS_SUPER_MAGIC;
|
buf->f_type = BEFS_SUPER_MAGIC;
|
||||||
buf->f_bsize = sb->s_blocksize;
|
buf->f_bsize = sb->s_blocksize;
|
||||||
|
@ -935,7 +937,7 @@ befs_statfs(struct dentry *dentry, struct kstatfs *buf)
|
||||||
buf->f_fsid.val[1] = (u32)(id >> 32);
|
buf->f_fsid.val[1] = (u32)(id >> 32);
|
||||||
buf->f_namelen = BEFS_NAME_LEN;
|
buf->f_namelen = BEFS_NAME_LEN;
|
||||||
|
|
||||||
befs_debug(sb, "<--- befs_statfs()");
|
befs_debug(sb, "<--- %s", __func__);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -961,7 +963,7 @@ init_befs_fs(void)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
printk(KERN_INFO "BeFS version: %s\n", BEFS_VERSION);
|
pr_info("version: %s\n", BEFS_VERSION);
|
||||||
|
|
||||||
err = befs_init_inodecache();
|
err = befs_init_inodecache();
|
||||||
if (err)
|
if (err)
|
||||||
|
|
Loading…
Reference in New Issue