1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-27 16:39:08 +00:00

Correct calculation of RAID0 sizes on VIA RAID arrays.

This commit is contained in:
Søren Schmidt 2005-12-14 12:11:51 +00:00
parent 54ccb3ac94
commit c6c6c58a89
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=153414
2 changed files with 9 additions and 7 deletions

View File

@ -3396,19 +3396,21 @@ ata_raid_via_read_meta(device_t dev, struct ar_softc **raidp)
case VIA_T_RAID0: case VIA_T_RAID0:
raid->type = AR_T_RAID0; raid->type = AR_T_RAID0;
raid->width = meta->stripe_layout & VIA_L_MASK; raid->width = meta->stripe_layout & VIA_L_MASK;
raid->total_sectors = meta->total_sectors; if (!raid->total_sectors ||
(raid->total_sectors > (raid->width * meta->disk_sectors)))
raid->total_sectors = raid->width * meta->disk_sectors;
break; break;
case VIA_T_RAID1: case VIA_T_RAID1:
raid->type = AR_T_RAID1; raid->type = AR_T_RAID1;
raid->width = 1; raid->width = 1;
raid->total_sectors = meta->total_sectors; raid->total_sectors = meta->disk_sectors;
break; break;
case VIA_T_SPAN: case VIA_T_SPAN:
raid->type = AR_T_SPAN; raid->type = AR_T_SPAN;
raid->width = 1; raid->width = 1;
raid->total_sectors += meta->total_sectors; raid->total_sectors += meta->disk_sectors;
break; break;
default: default:
@ -3433,7 +3435,7 @@ ata_raid_via_read_meta(device_t dev, struct ar_softc **raidp)
if ((meta->disks[disk] == meta->disk_id) && if ((meta->disks[disk] == meta->disk_id) &&
((disk * sizeof(int32_t)) == (meta->disk_index & VIA_D_MASK))) { ((disk * sizeof(int32_t)) == (meta->disk_index & VIA_D_MASK))) {
raid->disks[disk].dev = parent; raid->disks[disk].dev = parent;
raid->disks[disk].sectors = meta->total_sectors / raid->width; raid->disks[disk].sectors = meta->disk_sectors;
raid->disks[disk].flags = raid->disks[disk].flags =
(AR_DF_ONLINE | AR_DF_PRESENT | AR_DF_ASSIGNED); (AR_DF_ONLINE | AR_DF_PRESENT | AR_DF_ASSIGNED);
ars->raid[raid->volume] = raid; ars->raid[raid->volume] = raid;
@ -4409,8 +4411,8 @@ ata_raid_via_print_meta(struct via_raid_conf *meta)
printf("stripe_disks %d\n", meta->stripe_layout & VIA_L_MASK); printf("stripe_disks %d\n", meta->stripe_layout & VIA_L_MASK);
printf("stripe_sectors %d\n", printf("stripe_sectors %d\n",
0x08 << (meta->stripe_layout >> VIA_L_SHIFT)); 0x08 << (meta->stripe_layout >> VIA_L_SHIFT));
printf("total_sectors %llu\n", printf("disk_sectors %llu\n",
(unsigned long long)meta->total_sectors); (unsigned long long)meta->disk_sectors);
printf("disk_id 0x%08x\n", meta->disk_id); printf("disk_id 0x%08x\n", meta->disk_id);
printf("DISK# disk_id\n"); printf("DISK# disk_id\n");
for (i = 0; i < 8; i++) { for (i = 0; i < 8; i++) {

View File

@ -757,7 +757,7 @@ struct via_raid_conf {
#define VIA_L_MASK 0x07 #define VIA_L_MASK 0x07
#define VIA_L_SHIFT 4 #define VIA_L_SHIFT 4
u_int64_t total_sectors; u_int64_t disk_sectors;
u_int32_t disk_id; u_int32_t disk_id;
u_int32_t disks[8]; u_int32_t disks[8];
u_int8_t checksum; u_int8_t checksum;