Re: -mm -> 2.6.13 merge status

From: Pekka Enberg
Date: Thu Jun 23 2005 - 03:12:23 EST


Hi Hans,

On 6/22/05, Hans Reiser <reiser@xxxxxxxxxxx> wrote:
> I would in particular love to have you Andi Kleen do a full review of V4
> if you could be that generous with your time, as I liked much of the
> advice you gave us on V3.

Well, I am not Andi Kleen and this is not even in the ballpark of a full
review but here goes...

P.S. Would it be possible to have a version without the plugin stuff
submitted (and perhaps file as directory)? It would make much more
sense for the rest of us to review reiser4 without the most controversial
bits and get the bits that people agree on merged.

Pekka

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/pool.c 2005-06-03 17:49:38.668204642 +0400
> +/* initialise new pool */
> +reiser4_internal void
> +reiser4_init_pool(reiser4_pool * pool /* pool to initialise */ ,
> + size_t obj_size /* size of objects in @pool */ ,
> + int num_of_objs /* number of preallocated objects */ ,
> + char *data /* area for preallocated objects */ )
> +{
> + reiser4_pool_header *h;
> + int i;
> +
> + assert("nikita-955", pool != NULL);

These assertion codes are meaningless to the rest of us so please drop
them.

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/type_safe_hash.h 2005-06-03 17:49:38.751209197 +0400
> @@ -0,0 +1,320 @@
> +/* Copyright 2001, 2002, 2003 by Hans Reiser, licensing governed by
> + * reiser4/README */
> +
> +/* A hash table class that uses hash chains (singly-linked) and is
> + parametrized to provide type safety. */

This belongs to include/linux, not reiser4.

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/type_safe_list.h 2005-06-03 17:49:38.755209417 +0400
> @@ -0,0 +1,436 @@
> +/* Copyright 2001, 2002, 2003 by Hans Reiser, licensing governed by reiser4/README */
> +
> +#ifndef __REISER4_TYPE_SAFE_LIST_H__
> +#define __REISER4_TYPE_SAFE_LIST_H__
> +
> +#include "debug.h"
> +/* A circular doubly linked list that differs from the previous
> + <linux/list.h> implementation because it is parametrized to provide
> + type safety. This data structure is also useful as a queue or stack.

This belongs to include/linux, not reiser4.

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/vfs_ops.c 2005-06-03 17:51:28.110210237 +0400
> +/* ->get_sb() method of file_system operations. */
> +static struct super_block *
> +reiser4_get_sb(struct file_system_type *fs_type /* file
> + * system
> + * type */ ,
> + int flags /* flags */ ,
> + const char *dev_name /* device name */ ,
> + void *data /* mount options */ )

Please drop the useless parameter comments.

> +/*
> + * Initialization stages for reiser4.
> + *
> + * These enumerate various things that have to be done during reiser4
> + * startup. Initialization code (init_reiser4()) keeps track of what stage was
> + * reached, so that proper undo can be done if error occurs during
> + * initialization.
> + */
> +typedef enum {
> + INIT_NONE, /* nothing is initialized yet */
> + INIT_INODECACHE, /* inode cache created */
> + INIT_CONTEXT_MGR, /* list of active contexts created */
> + INIT_ZNODES, /* znode slab created */
> + INIT_PLUGINS, /* plugins initialized */
> + INIT_PLUGIN_SET, /* psets initialized */
> + INIT_TXN, /* transaction manager initialized */
> + INIT_FAKES, /* fake inode initialized */
> + INIT_JNODES, /* jnode slab initialized */
> + INIT_EFLUSH, /* emergency flush initialized */
> + INIT_FQS, /* flush queues initialized */
> + INIT_DENTRY_FSDATA, /* dentry_fsdata slab initialized */
> + INIT_FILE_FSDATA, /* file_fsdata slab initialized */
> + INIT_D_CURSOR, /* d_cursor suport initialized */
> + INIT_FS_REGISTERED, /* reiser4 file system type registered */
> +} reiser4_init_stage;

Please use regular gotos instead. This is a silly hack especially since you
don't have release function for all of the stages.

> +reiser4_internal void reiser4_handle_error(void)
> +{
> + struct super_block *sb = reiser4_get_current_sb();
> +
> + if ( !sb )
> + return;
> + reiser4_status_write(REISER4_STATUS_DAMAGED, 0, "Filesystem error occured");
> + switch ( get_super_private(sb)->onerror ) {
> + case 0:
> + reiser4_panic("foobar-42", "Filesystem error occured\n");
> + case 1:
> + if ( sb->s_flags & MS_RDONLY )
> + return;
> + sb->s_flags |= MS_RDONLY;
> + break;
> + case 2:
> + machine_restart(NULL);

Probably not something you should do at fs level.

> +/* free this znode */
> +reiser4_internal void
> +zfree(znode * node /* znode to free */ )
> +{
> + assert("nikita-465", node != NULL);
> + assert("nikita-2120", znode_page(node) == NULL);
> + assert("nikita-2301", owners_list_empty(&node->lock.owners));
> + assert("nikita-2302", requestors_list_empty(&node->lock.requestors));
> + assert("nikita-2663", capture_list_is_clean(ZJNODE(node)) && NODE_LIST(ZJNODE(node)) == NOT_CAPTURED);
> + assert("nikita-2773", !JF_ISSET(ZJNODE(node), JNODE_EFLUSH));
> + assert("nikita-3220", list_empty(&ZJNODE(node)->jnodes));
> + assert("nikita-3293", !znode_is_right_connected(node));
> + assert("nikita-3294", !znode_is_left_connected(node));
> + assert("nikita-3295", node->left == NULL);
> + assert("nikita-3296", node->right == NULL);

Are all these still required? Seems bit too defensive for the kernel.

> +
> +
> + /* not yet phash_jnode_destroy(ZJNODE(node)); */
> +
> + /* poison memory. */
> + ON_DEBUG(memset(node, 0xde, sizeof *node));

Poisoning belongs to slab, not fs.

> +/* allocate fresh znode */
> +reiser4_internal znode *
> +zalloc(int gfp_flag /* allocation flag */ )
> +{
> + znode *node;
> +
> + node = kmem_cache_alloc(znode_slab, gfp_flag);
> + return node;
> +}

Please drop this useless wrapper.

> +reiser4_internal void
> +znode_remove(znode * node /* znode to remove */ , reiser4_tree * tree)
> +{
> + assert("nikita-2108", node != NULL);
> + assert("nikita-470", node->c_count == 0);
> + assert("zam-879", rw_tree_is_write_locked(tree));
> +
> + /* remove reference to this znode from cbk cache */
> + cbk_cache_invalidate(node, tree);
> +
> + /* update c_count of parent */
> + if (znode_parent(node) != NULL) {
> + assert("nikita-472", znode_parent(node)->c_count > 0);
> + /* father, onto your hands I forward my spirit... */
> + znode_parent(node)->c_count --;
> + node->in_parent.node = NULL;
> + } else {
> + /* orphaned znode?! Root? */

Drop the useless else branch.

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/debug.c 2005-06-03 17:49:38.293184063 +0400
> @@ -0,0 +1,447 @@
> +/* Copyright 2001, 2002, 2003 by Hans Reiser, licensing governed by
> + * reiser4/README */
> +
> +/* Debugging facilities. */
> +
> +/*
> + * This file contains generic debugging functions used by reiser4. Roughly
> + * following:
> + *
> + * panicking: reiser4_do_panic(), reiser4_print_prefix().
> + *
> + * locking: schedulable(), lock_counters(), print_lock_counters(),
> + * no_counters_are_held(), commit_check_locks()
> + *
> + * {debug,trace,log}_flags: reiser4_are_all_debugged(),
> + * reiser4_is_debugged(), get_current_trace_flags(),
> + * get_current_log_flags().
> + *
> + * kmalloc/kfree leak detection: reiser4_kmalloc(), reiser4_kfree(),
> + * reiser4_kfree_in_sb().

Please don't do this! We've had enough trouble trying to get the
current subsystem specific allocators out, so do not introduce a new one. If
you need memory leak detection, make it generic and submit that. Reiser4, like
all other subsystems, should use kmalloc() and friends directly.

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/debug.h 2005-06-03 17:49:38.297184283 +0400
> +
> +/*
> + * Error code tracing facility. (Idea is borrowed from XFS code.)

Could this be turned into a generic facility?

> + *
> + * Suppose some strange and/or unexpected code is returned from some function
> + * (for example, write(2) returns -EEXIST). It is possible to place a
> + * breakpoint in the reiser4_write(), but it is too late here. How to find out
--
> +#define RETERR(code) \
> +({ \
> + typeof(code) __code; \
> + \
> + __code = (code); \
> + return_err(__code, __FILE__, __LINE__); \
> + __code; \
> +})

> +#define reiser4_internal

Please drop the above useless #define.

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/emergency_flush.c 2005-06-03 17:51:59.000905353 +0400
> @@ -0,0 +1,913 @@
> +/* Copyright 2002, 2003 by Hans Reiser, licensing governed by reiser4/README */
> +
> +/* This file exists only until VM gets fixed to reserve pages properly, which
> + * might or might not be very political. */

Please fix vm instead of working around it in fs.

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/init_super.c 2005-06-03 17:51:27.959201950 +0400
> +
> +#define _INIT_PARAM_LIST (struct super_block * s, reiser4_context * ctx, void * data, int silent)
> +#define _DONE_PARAM_LIST (struct super_block * s)
> +
> +#define _INIT_(subsys) static int _init_##subsys _INIT_PARAM_LIST
> +#define _DONE_(subsys) static void _done_##subsys _DONE_PARAM_LIST

Please remove this macro obfuscation.

> +
> +_DONE_EMPTY(exit_context)
> +
> +struct reiser4_subsys {
> + int (*init) _INIT_PARAM_LIST;
> + void (*done) _DONE_PARAM_LIST;
> +};
> +
> +#define _SUBSYS(subsys) {.init = &_init_##subsys, .done = &_done_##subsys}
> +static struct reiser4_subsys subsys_array[] = {
> + _SUBSYS(mount_flags_check),
> + _SUBSYS(sinfo),
> + _SUBSYS(context),
> + _SUBSYS(parse_options),
> + _SUBSYS(object_ops),
> + _SUBSYS(read_super),
> + _SUBSYS(tree0),
> + _SUBSYS(txnmgr),
> + _SUBSYS(ktxnmgrd_context),
> + _SUBSYS(ktxnmgrd),
> + _SUBSYS(entd),
> + _SUBSYS(formatted_fake),
> + _SUBSYS(disk_format),
> + _SUBSYS(sb_counters),
> + _SUBSYS(d_cursor),
> + _SUBSYS(fs_root),
> + _SUBSYS(safelink),
> + _SUBSYS(exit_context)
> +};

The above is overkill and silly. parse_options and read_super, for
example, are _not_ a subsystem inits but regular fs ops. Please consider
dropping this altogether but at least trim it down to something sane.

> --- /dev/null 2003-09-23 21:59:22.000000000 +0400
> +++ linux-2.6.11-vs/fs/reiser4/page_cache.c 2005-06-03 17:51:59.003905518 +0400
> +/* one-time initialization of fake inodes handling functions. */
> +reiser4_internal int
> +init_fakes()
> +{
> + return 0;
> +}

Please drop this empty function.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/