chiark / gitweb /
volume_id: set reiser instead of reiserfs for filesystem type
authorKay Sievers <kay.sievers@suse.de>
Sun, 18 Sep 2005 03:06:10 +0000 (05:06 +0200)
committerKay Sievers <kay.sievers@suse.de>
Sun, 18 Sep 2005 03:06:10 +0000 (05:06 +0200)
Thanks to Theodore Ts'o <tytso@mit.edu> for the hint and a test image.

Signed-off-by: Kay Sievers <kay.sievers@suse.de>
extras/volume_id/volume_id/reiserfs.c
extras/volume_id/volume_id/volume_id.h

index 75d1be05dc2c54dfaaf54a0a37852eca690028a6..6cffdce8d8b806eb2b997a1bebb0999155f11d59 100644 (file)
@@ -82,14 +82,17 @@ int volume_id_probe_reiserfs(struct volume_id *id, uint64_t off)
        rs = (struct reiserfs_super_block *) buf;;
        if (memcmp(rs->magic, "ReIsErFs", 8) == 0) {
                strcpy(id->type_version, "3.5");
+               id->type = "reiserfs";
                goto found;
        }
        if (memcmp(rs->magic, "ReIsEr2Fs", 9) == 0) {
                strcpy(id->type_version, "3.6");
+               id->type = "reiserfs";
                goto found_label;
        }
        if (memcmp(rs->magic, "ReIsEr3Fs", 9) == 0) {
                strcpy(id->type_version, "JR");
+               id->type = "reiserfs";
                goto found_label;
        }
 
@@ -99,15 +102,18 @@ int volume_id_probe_reiserfs(struct volume_id *id, uint64_t off)
                volume_id_set_label_raw(id, rs4->label, 16);
                volume_id_set_label_string(id, rs4->label, 16);
                volume_id_set_uuid(id, rs4->uuid, UUID_DCE);
+               id->type = "reiser4";
                goto found;
        }
 
-       rs = (struct reiserfs_super_block *) volume_id_get_buffer(id, off + REISERFS1_SUPERBLOCK_OFFSET, 0x200);
-       if (rs == NULL)
+       buf = volume_id_get_buffer(id, off + REISERFS1_SUPERBLOCK_OFFSET, 0x200);
+       if (buf == NULL)
                return -1;
 
+       rs = (struct reiserfs_super_block *) buf;
        if (memcmp(rs->magic, "ReIsErFs", 8) == 0) {
                strcpy(id->type_version, "3.5");
+               id->type = "reiserfs";
                goto found;
        }
 
@@ -120,7 +126,6 @@ found_label:
 
 found:
        volume_id_set_usage(id, VOLUME_ID_FILESYSTEM);
-       id->type = "reiserfs";
 
        return 0;
 }
index 84f8fb6740e7adb67fc580ec5bb174730a6d3289..0f5716b8939a70fc84240327601048a2fde7a897 100644 (file)
@@ -23,7 +23,7 @@
 
 #include <stdint.h>
 
-#define VOLUME_ID_VERSION              48
+#define VOLUME_ID_VERSION              49
 
 #define VOLUME_ID_LABEL_SIZE           64
 #define VOLUME_ID_UUID_SIZE            36