diff options
Diffstat (limited to 'drivers/ide/ide-floppy.c')
-rw-r--r-- | drivers/ide/ide-floppy.c | 55 |
1 files changed, 6 insertions, 49 deletions
diff --git a/drivers/ide/ide-floppy.c b/drivers/ide/ide-floppy.c index 2860398b193c..13cb08f5eb92 100644 --- a/drivers/ide/ide-floppy.c +++ b/drivers/ide/ide-floppy.c | |||
@@ -120,44 +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 | * Removable Block Access Capabilities Page | ||
124 | */ | ||
125 | typedef struct { | ||
126 | #if defined(__LITTLE_ENDIAN_BITFIELD) | ||
127 | unsigned page_code :6; /* Page code - Should be 0x1b */ | ||
128 | unsigned reserved1_6 :1; /* Reserved */ | ||
129 | unsigned ps :1; /* Should be 0 */ | ||
130 | #elif defined(__BIG_ENDIAN_BITFIELD) | ||
131 | unsigned ps :1; /* Should be 0 */ | ||
132 | unsigned reserved1_6 :1; /* Reserved */ | ||
133 | unsigned page_code :6; /* Page code - Should be 0x1b */ | ||
134 | #else | ||
135 | #error "Bitfield endianness not defined! Check your byteorder.h" | ||
136 | #endif | ||
137 | u8 page_length; /* Page Length - Should be 0xa */ | ||
138 | #if defined(__LITTLE_ENDIAN_BITFIELD) | ||
139 | unsigned reserved2 :6; | ||
140 | unsigned srfp :1; /* Supports reporting progress of format */ | ||
141 | unsigned sflp :1; /* System floppy type device */ | ||
142 | unsigned tlun :3; /* Total logical units supported by the device */ | ||
143 | unsigned reserved3 :3; | ||
144 | unsigned sml :1; /* Single / Multiple lun supported */ | ||
145 | unsigned ncd :1; /* Non cd optical device */ | ||
146 | #elif defined(__BIG_ENDIAN_BITFIELD) | ||
147 | unsigned sflp :1; /* System floppy type device */ | ||
148 | unsigned srfp :1; /* Supports reporting progress of format */ | ||
149 | unsigned reserved2 :6; | ||
150 | unsigned ncd :1; /* Non cd optical device */ | ||
151 | unsigned sml :1; /* Single / Multiple lun supported */ | ||
152 | unsigned reserved3 :3; | ||
153 | unsigned tlun :3; /* Total logical units supported by the device */ | ||
154 | #else | ||
155 | #error "Bitfield endianness not defined! Check your byteorder.h" | ||
156 | #endif | ||
157 | u8 reserved[8]; | ||
158 | } idefloppy_capabilities_page_t; | ||
159 | |||
160 | /* | ||
161 | * Flexible disk page. | 123 | * Flexible disk page. |
162 | */ | 124 | */ |
163 | typedef struct { | 125 | typedef struct { |
@@ -397,7 +359,8 @@ typedef struct { | |||
397 | } idefloppy_request_sense_result_t; | 359 | } idefloppy_request_sense_result_t; |
398 | 360 | ||
399 | /* | 361 | /* |
400 | * Pages of the SELECT SENSE / MODE SENSE packet commands. | 362 | * Pages of the SELECT SENSE / MODE SENSE packet commands. |
363 | * See SFF-8070i spec. | ||
401 | */ | 364 | */ |
402 | #define IDEFLOPPY_CAPABILITIES_PAGE 0x1b | 365 | #define IDEFLOPPY_CAPABILITIES_PAGE 0x1b |
403 | #define IDEFLOPPY_FLEXIBLE_DISK_PAGE 0x05 | 366 | #define IDEFLOPPY_FLEXIBLE_DISK_PAGE 0x05 |
@@ -1273,25 +1236,20 @@ static int idefloppy_get_flexible_disk_page (ide_drive_t *drive) | |||
1273 | return 0; | 1236 | return 0; |
1274 | } | 1237 | } |
1275 | 1238 | ||
1276 | static int idefloppy_get_capability_page(ide_drive_t *drive) | 1239 | static int idefloppy_get_sfrp_bit(ide_drive_t *drive) |
1277 | { | 1240 | { |
1278 | idefloppy_floppy_t *floppy = drive->driver_data; | 1241 | idefloppy_floppy_t *floppy = drive->driver_data; |
1279 | idefloppy_pc_t pc; | 1242 | idefloppy_pc_t pc; |
1280 | idefloppy_mode_parameter_header_t *header; | ||
1281 | idefloppy_capabilities_page_t *page; | ||
1282 | 1243 | ||
1283 | floppy->srfp = 0; | 1244 | floppy->srfp = 0; |
1284 | idefloppy_create_mode_sense_cmd(&pc, IDEFLOPPY_CAPABILITIES_PAGE, | 1245 | idefloppy_create_mode_sense_cmd(&pc, IDEFLOPPY_CAPABILITIES_PAGE, |
1285 | MODE_SENSE_CURRENT); | 1246 | MODE_SENSE_CURRENT); |
1286 | 1247 | ||
1287 | set_bit(PC_SUPPRESS_ERROR, &pc.flags); | 1248 | set_bit(PC_SUPPRESS_ERROR, &pc.flags); |
1288 | if (idefloppy_queue_pc_tail(drive,&pc)) { | 1249 | if (idefloppy_queue_pc_tail(drive, &pc)) |
1289 | return 1; | 1250 | return 1; |
1290 | } | ||
1291 | 1251 | ||
1292 | header = (idefloppy_mode_parameter_header_t *) pc.buffer; | 1252 | floppy->srfp = pc.buffer[8 + 2] & 0x40; |
1293 | page= (idefloppy_capabilities_page_t *)(header+1); | ||
1294 | floppy->srfp = page->srfp; | ||
1295 | return (0); | 1253 | return (0); |
1296 | } | 1254 | } |
1297 | 1255 | ||
@@ -1497,8 +1455,7 @@ static int idefloppy_begin_format(ide_drive_t *drive, int __user *arg) | |||
1497 | return (-EFAULT); | 1455 | return (-EFAULT); |
1498 | } | 1456 | } |
1499 | 1457 | ||
1500 | /* Get the SFRP bit */ | 1458 | (void) idefloppy_get_sfrp_bit(drive); |
1501 | (void) idefloppy_get_capability_page(drive); | ||
1502 | idefloppy_create_format_unit_cmd(&pc, blocks, length, flags); | 1459 | idefloppy_create_format_unit_cmd(&pc, blocks, length, flags); |
1503 | if (idefloppy_queue_pc_tail(drive, &pc)) { | 1460 | if (idefloppy_queue_pc_tail(drive, &pc)) { |
1504 | return (-EIO); | 1461 | return (-EIO); |