struct sysfs_class_device *class_dev_parent = NULL;
struct volume_id *vid = NULL;
char *devpath;
- char probe = 'p';
+ char probe_disk_label = 0;
char print = 'a';
static char name[VOLUME_ID_LABEL_SIZE];
int len, i, j;
print = 'u';
continue;
case 'd':
- probe = 'd';
+ probe_disk_label = 1;
continue;
case 'h':
case '?':
goto exit;
}
- switch(probe) {
- case 'p' :
- /* open block device */
+ if (probe_disk_label == 0) {
vid = open_classdev(class_dev);
if (vid == NULL)
goto exit;
if (volume_id_probe_all(vid, 0, size) == 0)
goto print;
- break;
- case 'd' :
+ } else {
/* if we are on a partition, open main block device instead */
class_dev_parent = sysfs_get_classdev_parent(class_dev);
if (class_dev_parent != NULL)
if (vid == NULL)
goto exit;
- if (probe_ibm_partition(vid) == 0)
+ if (volume_id_probe_dasd_partition(vid) == 0)
goto print;
- break;
}
printf("unknown volume type\n");
printf("%s\n", vid->type);
break;
case 'l':
- if (name[0] == '\0' || vid->usage_id != VOLUME_ID_FILESYSTEM) {
+ if (name[0] == '\0' ||
+ (vid->usage_id != VOLUME_ID_FILESYSTEM && vid->usage_id != VOLUME_ID_DISKLABEL)) {
rc = 2;
goto exit;
}