diff options
-rw-r--r-- | extras/volume_id/libvolume_id/volume_id.c | 68 | ||||
-rw-r--r-- | extras/volume_id/libvolume_id/volume_id.h | 2 |
2 files changed, 36 insertions, 34 deletions
diff --git a/extras/volume_id/libvolume_id/volume_id.c b/extras/volume_id/libvolume_id/volume_id.c index 1daf1cbd74..6a900ab281 100644 --- a/extras/volume_id/libvolume_id/volume_id.c +++ b/extras/volume_id/libvolume_id/volume_id.c @@ -39,40 +39,42 @@ int volume_id_probe_raid(struct volume_id *id, uint64_t off, uint64_t size) /* probe for raid first, cause fs probes may be successful on raid members */ if (size) { if (volume_id_probe_linux_raid(id, off, size) == 0) - goto exit; + goto found; if (volume_id_probe_intel_software_raid(id, off, size) == 0) - goto exit; + goto found; if (volume_id_probe_lsi_mega_raid(id, off, size) == 0) - goto exit; + goto found; if (volume_id_probe_via_raid(id, off, size) == 0) - goto exit; + goto found; if (volume_id_probe_silicon_medley_raid(id, off, size) == 0) - goto exit; + goto found; if (volume_id_probe_nvidia_raid(id, off, size) == 0) - goto exit; + goto found; if (volume_id_probe_promise_fasttrack_raid(id, off, size) == 0) - goto exit; + goto found; if (volume_id_probe_highpoint_45x_raid(id, off, size) == 0) - goto exit; + goto found; } if (volume_id_probe_lvm1(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_lvm2(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_highpoint_37x_raid(id, off) == 0) - goto exit; + goto found; -exit: + return -1; + +found: /* If recognized, we free the allocated buffers */ volume_id_free_buffer(id); return 0; @@ -84,72 +86,72 @@ int volume_id_probe_filesystem(struct volume_id *id, uint64_t off, uint64_t size return -EINVAL; if (volume_id_probe_luks(id, off) == 0) - goto exit; + goto found; /* signature in the first block, only small buffer needed */ if (volume_id_probe_vfat(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_xfs(id, off) == 0) - goto exit; + goto found; /* fill buffer with maximum */ volume_id_get_buffer(id, 0, SB_BUFFER_SIZE); if (volume_id_probe_linux_swap(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_ext(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_reiserfs(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_jfs(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_udf(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_iso9660(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_hfs_hfsplus(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_ufs(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_ntfs(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_cramfs(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_romfs(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_hpfs(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_sysv(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_minix(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_ocfs1(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_ocfs2(id, off) == 0) - goto exit; + goto found; if (volume_id_probe_vxfs(id, off) == 0) - goto exit; + goto found; return -1; -exit: +found: /* If recognized, we free the allocated buffers */ volume_id_free_buffer(id); return 0; diff --git a/extras/volume_id/libvolume_id/volume_id.h b/extras/volume_id/libvolume_id/volume_id.h index 2caf75f532..78baf59820 100644 --- a/extras/volume_id/libvolume_id/volume_id.h +++ b/extras/volume_id/libvolume_id/volume_id.h @@ -14,7 +14,7 @@ #include <stdint.h> #include <stddef.h> -#define VOLUME_ID_VERSION 57 +#define VOLUME_ID_VERSION 58 #ifndef PACKED #define PACKED __attribute__((packed)) |