diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2010-07-19 16:18:05 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-07-19 16:18:05 -0400 |
| commit | 2decd5a7cea2c1dae6418fe778857d43680a91aa (patch) | |
| tree | 2ff5a57ef9db7a5fc000d323910b13ece778ab5b /fs | |
| parent | b4fd4f890bca2291a12bb0807027db40f929a82d (diff) | |
| parent | 878c495644be28cc881e7ee792f00fd879a1ebf9 (diff) | |
Merge branch 'for-linus' of git://git390.marist.edu/pub/scm/linux-2.6
* 'for-linus' of git://git390.marist.edu/pub/scm/linux-2.6:
[S390] cio: fix potential overflow in chpid descriptor
[S390] add missing device put
[S390] dasd: use correct label location for diag fba disks
Diffstat (limited to 'fs')
| -rw-r--r-- | fs/partitions/ibm.c | 14 |
1 files changed, 12 insertions, 2 deletions
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 | ||
