diff options
| -rw-r--r-- | drivers/s390/block/dasd_devmap.c | 4 | ||||
| -rw-r--r-- | drivers/s390/cio/chsc.c | 2 | ||||
| -rw-r--r-- | fs/partitions/ibm.c | 14 |
3 files changed, 16 insertions, 4 deletions
diff --git a/drivers/s390/block/dasd_devmap.c b/drivers/s390/block/dasd_devmap.c index 34d51dd4c539..bed7b4634ccd 100644 --- a/drivers/s390/block/dasd_devmap.c +++ b/drivers/s390/block/dasd_devmap.c | |||
| @@ -948,8 +948,10 @@ static ssize_t dasd_alias_show(struct device *dev, | |||
| 948 | if (device->discipline && device->discipline->get_uid && | 948 | if (device->discipline && device->discipline->get_uid && |
| 949 | !device->discipline->get_uid(device, &uid)) { | 949 | !device->discipline->get_uid(device, &uid)) { |
| 950 | if (uid.type == UA_BASE_PAV_ALIAS || | 950 | if (uid.type == UA_BASE_PAV_ALIAS || |
| 951 | uid.type == UA_HYPER_PAV_ALIAS) | 951 | uid.type == UA_HYPER_PAV_ALIAS) { |
| 952 | dasd_put_device(device); | ||
| 952 | return sprintf(buf, "1\n"); | 953 | return sprintf(buf, "1\n"); |
| 954 | } | ||
| 953 | } | 955 | } |
| 954 | dasd_put_device(device); | 956 | dasd_put_device(device); |
| 955 | 957 | ||
diff --git a/drivers/s390/cio/chsc.c b/drivers/s390/cio/chsc.c index ce7cb87479fe..407d0e9adfaf 100644 --- a/drivers/s390/cio/chsc.c +++ b/drivers/s390/cio/chsc.c | |||
| @@ -713,7 +713,7 @@ int chsc_determine_base_channel_path_desc(struct chp_id chpid, | |||
| 713 | ret = chsc_determine_channel_path_desc(chpid, 0, 0, 0, 0, chsc_resp); | 713 | ret = chsc_determine_channel_path_desc(chpid, 0, 0, 0, 0, chsc_resp); |
| 714 | if (ret) | 714 | if (ret) |
| 715 | goto out_free; | 715 | goto out_free; |
| 716 | memcpy(desc, &chsc_resp->data, chsc_resp->length); | 716 | memcpy(desc, &chsc_resp->data, sizeof(*desc)); |
| 717 | out_free: | 717 | out_free: |
| 718 | kfree(chsc_resp); | 718 | kfree(chsc_resp); |
| 719 | return ret; | 719 | return ret; |
diff --git a/fs/partitions/ibm.c b/fs/partitions/ibm.c index 3e73de5967ff..fc8497643fd0 100644 --- a/fs/partitions/ibm.c +++ b/fs/partitions/ibm.c | |||
| @@ -74,6 +74,7 @@ int ibm_partition(struct parsed_partitions *state) | |||
| 74 | } *label; | 74 | } *label; |
| 75 | unsigned char *data; | 75 | unsigned char *data; |
| 76 | Sector sect; | 76 | Sector sect; |
| 77 | sector_t labelsect; | ||
| 77 | 78 | ||
| 78 | res = 0; | 79 | res = 0; |
| 79 | blocksize = bdev_logical_block_size(bdev); | 80 | blocksize = bdev_logical_block_size(bdev); |
| @@ -98,10 +99,19 @@ int ibm_partition(struct parsed_partitions *state) | |||
| 98 | goto out_freeall; | 99 | goto out_freeall; |
| 99 | 100 | ||
| 100 | /* | 101 | /* |
| 102 | * Special case for FBA disks: label sector does not depend on | ||
| 103 | * blocksize. | ||
| 104 | */ | ||
| 105 | if ((info->cu_type == 0x6310 && info->dev_type == 0x9336) || | ||
| 106 | (info->cu_type == 0x3880 && info->dev_type == 0x3370)) | ||
| 107 | labelsect = info->label_block; | ||
| 108 | else | ||
| 109 | labelsect = info->label_block * (blocksize >> 9); | ||
| 110 | |||
| 111 | /* | ||
| 101 | * Get volume label, extract name and type. | 112 | * Get volume label, extract name and type. |
| 102 | */ | 113 | */ |
| 103 | data = read_part_sector(state, info->label_block*(blocksize/512), | 114 | data = read_part_sector(state, labelsect, §); |
| 104 | §); | ||
| 105 | if (data == NULL) | 115 | if (data == NULL) |
| 106 | goto out_readerr; | 116 | goto out_readerr; |
| 107 | 117 | ||
