--- linux/include/linux/reiserfs_fs.h.orig      Wed Jan 30 12:58:46 2002
+++ linux/include/linux/reiserfs_fs.h   Wed Jan 30 12:59:08 2002
@@ -1824,6 +1824,7 @@
void check_leaf (struct buffer_head * bh);
void check_internal (struct buffer_head * bh);
void print_statistics (struct super_block * s);
+char * reiserfs_hashname(int code);

/* lbalance.c */
int leaf_move_items (int shift_mode, struct tree_balance * tb, int mov_num, int mov_bytes, struct buffer_head * Snew);
--- linux/fs/reiserfs/super.c.orig      Wed Jan 30 12:04:54 2002
+++ linux/fs/reiserfs/super.c   Wed Jan 30 14:18:44 2002
@@ -756,7 +756,9 @@

    inode = s->s_root->d_inode;

-    while (1) {
+    do { // Some serious "goto"-hater was there ;)
+       u32 teahash, r5hash, yurahash;
+
       make_cpu_key (&key, inode, ~0, TYPE_DIRENTRY, 3);
       retval = search_by_entry_key (s, &key, &path, &de);
       if (retval == IO_ERROR) {
@@ -775,20 +777,30 @@
                            "is using the default hash\n");
           break;
       }
-       if (GET_HASH_VALUE(yura_hash (de.de_name, de.de_namelen)) ==
-           GET_HASH_VALUE(keyed_hash (de.de_name, de.de_namelen))) {
-           reiserfs_warning ("reiserfs: Could not detect hash function "
-                             "please mount with -o hash={tea,rupasov,r5}\n") ;
-           hash = UNSET_HASH ;
+       r5hash=GET_HASH_VALUE (r5_hash (de.de_name, de.de_namelen));
+       teahash=GET_HASH_VALUE (keyed_hash (de.de_name, de.de_namelen));
+       yurahash=GET_HASH_VALUE (yura_hash (de.de_name, de.de_namelen));
+       if ( ( (teahash == r5hash) && (GET_HASH_VALUE( deh_offset(&(de.de_deh[de.de_entry_num]))) == r5hash) ) ||
+            ( (teahash == yurahash) && (yurahash == GET_HASH_VALUE( deh_offset(&(de.de_deh[de.de_entry_num])))) ) ||
+            ( (r5hash == yurahash) && (yurahash == GET_HASH_VALUE( deh_offset(&(de.de_deh[de.de_entry_num])))) ) ) {
+           reiserfs_warning("reiserfs: Unable to automatically detect hash"
+               "function for device %s\n"
+               "please mount with -o hash={tea,rupasov,r5}\n", kdevname (s->s_dev));
+           hash = UNSET_HASH;
           break;
       }
-       if (GET_HASH_VALUE( deh_offset(&(de.de_deh[de.de_entry_num])) ) ==
-           GET_HASH_VALUE (yura_hash (de.de_name, de.de_namelen)))
+       if (GET_HASH_VALUE( deh_offset(&(de.de_deh[de.de_entry_num])) ) == yurahash)
           hash = YURA_HASH;
-       else
+       else if (GET_HASH_VALUE( deh_offset(&(de.de_deh[de.de_entry_num])) ) == teahash)
           hash = TEA_HASH;
-       break;
-    }
+       else if (GET_HASH_VALUE( deh_offset(&(de.de_deh[de.de_entry_num])) ) == r5hash)
+           hash = R5_HASH;
+       else {
+           reiserfs_warning("reiserfs: Unrecognised hash function for "
+                            "device %s\n", kdevname (s->s_dev));
+           hash = UNSET_HASH;
+       }
+    } while (0);

    pathrelse (&path);
    return hash;
@@ -813,16 +825,16 @@
       ** mount options
       */
       if (reiserfs_rupasov_hash(s) && code != YURA_HASH) {
-           printk("REISERFS: Error, tea hash detected, "
-                  "unable to force rupasov hash\n") ;
+           printk("REISERFS: Error, %s hash detected, "
+                  "unable to force rupasov hash\n", reiserfs_hashname(code)) ;
           code = UNSET_HASH ;
       } else if (reiserfs_tea_hash(s) && code != TEA_HASH) {
-           printk("REISERFS: Error, rupasov hash detected, "
-                  "unable to force tea hash\n") ;
+           printk("REISERFS: Error, %s hash detected, "
+                  "unable to force tea hash\n", reiserfs_hashname(code)) ;
           code = UNSET_HASH ;
       } else if (reiserfs_r5_hash(s) && code != R5_HASH) {
-           printk("REISERFS: Error, r5 hash detected, "
-                  "unable to force r5 hash %d\n", code) ;
+           printk("REISERFS: Error, %s hash detected, "
+                  "unable to force r5 hash\n", reiserfs_hashname(code)) ;
           code = UNSET_HASH ;
       }
    } else {
--- linux/fs/reiserfs/prints.c.orig     Wed Jan 30 12:54:54 2002
+++ linux/fs/reiserfs/prints.c  Wed Jan 30 12:58:29 2002
@@ -477,6 +477,17 @@
    return 0;
}

+char * reiserfs_hashname(int code)
+{
+    if ( code == YURA_HASH)
+       return "rupasov";
+    if ( code == TEA_HASH)
+       return "tea";
+    if ( code == R5_HASH)
+       return "r5";
+
+    return "unknown";
+}
/* return 1 if this is not super block */
static int print_super_block (struct buffer_head * bh)
{
@@ -519,8 +530,7 @@
    printk ("Filesystem state %s\n",
           (sb_state(rs) == REISERFS_VALID_FS) ? "VALID" : "ERROR");
    printk ("Hash function \"%s\"\n",
-            sb_hash_function_code(rs) == TEA_HASH ? "tea" :
-           ( sb_hash_function_code(rs) == YURA_HASH ? "rupasov" : (sb_hash_function_code(rs) == R5_HASH ? "r5" : "unknown")));
+            reiserfs_hashname(sb_hash_function_code(rs)));

    printk ("Tree height %d\n", sb_tree_height(rs));
    return 0;