diff options
Diffstat (limited to 'drivers/ide/ide-floppy.c')
-rw-r--r-- | drivers/ide/ide-floppy.c | 90 |
1 files changed, 36 insertions, 54 deletions
diff --git a/drivers/ide/ide-floppy.c b/drivers/ide/ide-floppy.c index e9d11faec9bd..5d84fa5f3dc6 100644 --- a/drivers/ide/ide-floppy.c +++ b/drivers/ide/ide-floppy.c | |||
@@ -120,33 +120,6 @@ typedef struct idefloppy_packet_command_s { | |||
120 | #define PC_SUPPRESS_ERROR 6 /* Suppress error reporting */ | 120 | #define PC_SUPPRESS_ERROR 6 /* Suppress error reporting */ |
121 | 121 | ||
122 | /* | 122 | /* |
123 | * Flexible disk page. | ||
124 | */ | ||
125 | typedef struct { | ||
126 | #if defined(__LITTLE_ENDIAN_BITFIELD) | ||
127 | unsigned page_code :6; /* Page code - Should be 0x5 */ | ||
128 | unsigned reserved1_6 :1; /* Reserved */ | ||
129 | unsigned ps :1; /* The device is capable of saving the page */ | ||
130 | #elif defined(__BIG_ENDIAN_BITFIELD) | ||
131 | unsigned ps :1; /* The device is capable of saving the page */ | ||
132 | unsigned reserved1_6 :1; /* Reserved */ | ||
133 | unsigned page_code :6; /* Page code - Should be 0x5 */ | ||
134 | #else | ||
135 | #error "Bitfield endianness not defined! Check your byteorder.h" | ||
136 | #endif | ||
137 | u8 page_length; /* Page Length - Should be 0x1e */ | ||
138 | u16 transfer_rate; /* In kilobits per second */ | ||
139 | u8 heads, sectors; /* Number of heads, Number of sectors per track */ | ||
140 | u16 sector_size; /* Byes per sector */ | ||
141 | u16 cyls; /* Number of cylinders */ | ||
142 | u8 reserved10[10]; | ||
143 | u8 motor_delay; /* Motor off delay */ | ||
144 | u8 reserved21[7]; | ||
145 | u16 rpm; /* Rotations per minute */ | ||
146 | u8 reserved30[2]; | ||
147 | } idefloppy_flexible_disk_page_t; | ||
148 | |||
149 | /* | ||
150 | * Format capacity | 123 | * Format capacity |
151 | */ | 124 | */ |
152 | typedef struct { | 125 | typedef struct { |
@@ -214,7 +187,7 @@ typedef struct ide_floppy_obj { | |||
214 | /* Last format capacity */ | 187 | /* Last format capacity */ |
215 | idefloppy_capacity_descriptor_t capacity; | 188 | idefloppy_capacity_descriptor_t capacity; |
216 | /* Copy of the flexible disk page */ | 189 | /* Copy of the flexible disk page */ |
217 | idefloppy_flexible_disk_page_t flexible_disk_page; | 190 | u8 flexible_disk_page[32]; |
218 | /* Write protect */ | 191 | /* Write protect */ |
219 | int wp; | 192 | int wp; |
220 | /* Supports format progress report */ | 193 | /* Supports format progress report */ |
@@ -1095,48 +1068,57 @@ static int idefloppy_queue_pc_tail (ide_drive_t *drive,idefloppy_pc_t *pc) | |||
1095 | } | 1068 | } |
1096 | 1069 | ||
1097 | /* | 1070 | /* |
1098 | * Look at the flexible disk page parameters. We will ignore the CHS | 1071 | * Look at the flexible disk page parameters. We ignore the CHS capacity |
1099 | * capacity parameters and use the LBA parameters instead. | 1072 | * parameters and use the LBA parameters instead. |
1100 | */ | 1073 | */ |
1101 | static int idefloppy_get_flexible_disk_page (ide_drive_t *drive) | 1074 | static int ide_floppy_get_flexible_disk_page(ide_drive_t *drive) |
1102 | { | 1075 | { |
1103 | idefloppy_floppy_t *floppy = drive->driver_data; | 1076 | idefloppy_floppy_t *floppy = drive->driver_data; |
1104 | idefloppy_pc_t pc; | 1077 | idefloppy_pc_t pc; |
1105 | idefloppy_flexible_disk_page_t *page; | 1078 | u8 *page; |
1106 | int capacity, lba_capacity; | 1079 | int capacity, lba_capacity; |
1080 | u16 transfer_rate, sector_size, cyls, rpm; | ||
1081 | u8 heads, sectors; | ||
1107 | 1082 | ||
1108 | idefloppy_create_mode_sense_cmd(&pc, IDEFLOPPY_FLEXIBLE_DISK_PAGE, MODE_SENSE_CURRENT); | 1083 | idefloppy_create_mode_sense_cmd(&pc, IDEFLOPPY_FLEXIBLE_DISK_PAGE, |
1109 | if (idefloppy_queue_pc_tail(drive,&pc)) { | 1084 | MODE_SENSE_CURRENT); |
1110 | printk(KERN_ERR "ide-floppy: Can't get flexible disk " | 1085 | |
1111 | "page parameters\n"); | 1086 | if (idefloppy_queue_pc_tail(drive, &pc)) { |
1087 | printk(KERN_ERR "ide-floppy: Can't get flexible disk page" | ||
1088 | " parameters\n"); | ||
1112 | return 1; | 1089 | return 1; |
1113 | } | 1090 | } |
1114 | floppy->wp = !!(pc.buffer[3] & 0x80); | 1091 | floppy->wp = !!(pc.buffer[3] & 0x80); |
1115 | set_disk_ro(floppy->disk, floppy->wp); | 1092 | set_disk_ro(floppy->disk, floppy->wp); |
1116 | page = (idefloppy_flexible_disk_page_t *) &pc.buffer[8]; | 1093 | page = &pc.buffer[8]; |
1117 | 1094 | ||
1118 | page->transfer_rate = be16_to_cpu(page->transfer_rate); | 1095 | transfer_rate = be16_to_cpu(*(u16 *)&pc.buffer[8 + 2]); |
1119 | page->sector_size = be16_to_cpu(page->sector_size); | 1096 | sector_size = be16_to_cpu(*(u16 *)&pc.buffer[8 + 6]); |
1120 | page->cyls = be16_to_cpu(page->cyls); | 1097 | cyls = be16_to_cpu(*(u16 *)&pc.buffer[8 + 8]); |
1121 | page->rpm = be16_to_cpu(page->rpm); | 1098 | rpm = be16_to_cpu(*(u16 *)&pc.buffer[8 + 28]); |
1122 | capacity = page->cyls * page->heads * page->sectors * page->sector_size; | 1099 | heads = pc.buffer[8 + 4]; |
1123 | if (memcmp (page, &floppy->flexible_disk_page, sizeof (idefloppy_flexible_disk_page_t))) | 1100 | sectors = pc.buffer[8 + 5]; |
1101 | |||
1102 | capacity = cyls * heads * sectors * sector_size; | ||
1103 | |||
1104 | if (memcmp(page, &floppy->flexible_disk_page, 32)) | ||
1124 | printk(KERN_INFO "%s: %dkB, %d/%d/%d CHS, %d kBps, " | 1105 | printk(KERN_INFO "%s: %dkB, %d/%d/%d CHS, %d kBps, " |
1125 | "%d sector size, %d rpm\n", | 1106 | "%d sector size, %d rpm\n", |
1126 | drive->name, capacity / 1024, page->cyls, | 1107 | drive->name, capacity / 1024, cyls, heads, |
1127 | page->heads, page->sectors, | 1108 | sectors, transfer_rate / 8, sector_size, rpm); |
1128 | page->transfer_rate / 8, page->sector_size, page->rpm); | 1109 | |
1129 | 1110 | memcpy(&floppy->flexible_disk_page, page, 32); | |
1130 | floppy->flexible_disk_page = *page; | 1111 | drive->bios_cyl = cyls; |
1131 | drive->bios_cyl = page->cyls; | 1112 | drive->bios_head = heads; |
1132 | drive->bios_head = page->heads; | 1113 | drive->bios_sect = sectors; |
1133 | drive->bios_sect = page->sectors; | ||
1134 | lba_capacity = floppy->blocks * floppy->block_size; | 1114 | lba_capacity = floppy->blocks * floppy->block_size; |
1115 | |||
1135 | if (capacity < lba_capacity) { | 1116 | if (capacity < lba_capacity) { |
1136 | printk(KERN_NOTICE "%s: The disk reports a capacity of %d " | 1117 | printk(KERN_NOTICE "%s: The disk reports a capacity of %d " |
1137 | "bytes, but the drive only handles %d\n", | 1118 | "bytes, but the drive only handles %d\n", |
1138 | drive->name, lba_capacity, capacity); | 1119 | drive->name, lba_capacity, capacity); |
1139 | floppy->blocks = floppy->block_size ? capacity / floppy->block_size : 0; | 1120 | floppy->blocks = floppy->block_size ? |
1121 | capacity / floppy->block_size : 0; | ||
1140 | } | 1122 | } |
1141 | return 0; | 1123 | return 0; |
1142 | } | 1124 | } |
@@ -1243,7 +1225,7 @@ static int idefloppy_get_capacity (ide_drive_t *drive) | |||
1243 | 1225 | ||
1244 | /* Clik! disk does not support get_flexible_disk_page */ | 1226 | /* Clik! disk does not support get_flexible_disk_page */ |
1245 | if (!test_bit(IDEFLOPPY_CLIK_DRIVE, &floppy->flags)) { | 1227 | if (!test_bit(IDEFLOPPY_CLIK_DRIVE, &floppy->flags)) { |
1246 | (void) idefloppy_get_flexible_disk_page(drive); | 1228 | (void) ide_floppy_get_flexible_disk_page(drive); |
1247 | } | 1229 | } |
1248 | 1230 | ||
1249 | set_capacity(floppy->disk, floppy->blocks * floppy->bs_factor); | 1231 | set_capacity(floppy->disk, floppy->blocks * floppy->bs_factor); |