aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/ide-floppy.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ide/ide-floppy.c')
-rw-r--r--drivers/ide/ide-floppy.c63
1 files changed, 13 insertions, 50 deletions
diff --git a/drivers/ide/ide-floppy.c b/drivers/ide/ide-floppy.c
index 1a28b2e7bbb1..b56e37d01593 100644
--- a/drivers/ide/ide-floppy.c
+++ b/drivers/ide/ide-floppy.c
@@ -47,11 +47,8 @@
47#include <linux/io.h> 47#include <linux/io.h>
48#include <asm/unaligned.h> 48#include <asm/unaligned.h>
49 49
50/* 50/* define to see debug info */
51 * The following are used to debug the driver.
52 */
53#define IDEFLOPPY_DEBUG_LOG 0 51#define IDEFLOPPY_DEBUG_LOG 0
54#define IDEFLOPPY_DEBUG_INFO 0
55 52
56/* #define IDEFLOPPY_DEBUG(fmt, args...) printk(KERN_INFO fmt, ## args) */ 53/* #define IDEFLOPPY_DEBUG(fmt, args...) printk(KERN_INFO fmt, ## args) */
57#define IDEFLOPPY_DEBUG( fmt, args... ) 54#define IDEFLOPPY_DEBUG( fmt, args... )
@@ -1303,15 +1300,12 @@ static sector_t idefloppy_capacity (ide_drive_t *drive)
1303} 1300}
1304 1301
1305/* 1302/*
1306 * idefloppy_identify_device checks if we can support a drive, 1303 * Check whether we can support a drive, based on the ATAPI IDENTIFY command
1307 * based on the ATAPI IDENTIFY command results. 1304 * results.
1308 */ 1305 */
1309static int idefloppy_identify_device (ide_drive_t *drive,struct hd_driveid *id) 1306static int idefloppy_identify_device(ide_drive_t *drive, struct hd_driveid *id)
1310{ 1307{
1311 struct idefloppy_id_gcw gcw; 1308 struct idefloppy_id_gcw gcw;
1312#if IDEFLOPPY_DEBUG_INFO
1313 char buffer[80];
1314#endif /* IDEFLOPPY_DEBUG_INFO */
1315 1309
1316 *((u16 *) &gcw) = id->config; 1310 *((u16 *) &gcw) = id->config;
1317 1311
@@ -1320,54 +1314,23 @@ static int idefloppy_identify_device (ide_drive_t *drive,struct hd_driveid *id)
1320 if ((gcw.device_type == 5) && 1314 if ((gcw.device_type == 5) &&
1321 !strstr(id->model, "CD-ROM") && 1315 !strstr(id->model, "CD-ROM") &&
1322 strstr(id->model, "ZIP")) 1316 strstr(id->model, "ZIP"))
1323 gcw.device_type = 0; 1317 gcw.device_type = 0;
1324#endif 1318#endif
1325 1319
1326#if IDEFLOPPY_DEBUG_INFO
1327 printk(KERN_INFO "Dumping ATAPI Identify Device floppy parameters\n");
1328 switch (gcw.protocol) {
1329 case 0: case 1: sprintf(buffer, "ATA");break;
1330 case 2: sprintf(buffer, "ATAPI");break;
1331 case 3: sprintf(buffer, "Reserved (Unknown to ide-floppy)");break;
1332 }
1333 printk(KERN_INFO "Protocol Type: %s\n", buffer);
1334 switch (gcw.device_type) {
1335 case 0: sprintf(buffer, "Direct-access Device");break;
1336 case 1: sprintf(buffer, "Streaming Tape Device");break;
1337 case 2: case 3: case 4: sprintf (buffer, "Reserved");break;
1338 case 5: sprintf(buffer, "CD-ROM Device");break;
1339 case 6: sprintf(buffer, "Reserved");
1340 case 7: sprintf(buffer, "Optical memory Device");break;
1341 case 0x1f: sprintf(buffer, "Unknown or no Device type");break;
1342 default: sprintf(buffer, "Reserved");
1343 }
1344 printk(KERN_INFO "Device Type: %x - %s\n", gcw.device_type, buffer);
1345 printk(KERN_INFO "Removable: %s\n",gcw.removable ? "Yes":"No");
1346 switch (gcw.drq_type) {
1347 case 0: sprintf(buffer, "Microprocessor DRQ");break;
1348 case 1: sprintf(buffer, "Interrupt DRQ");break;
1349 case 2: sprintf(buffer, "Accelerated DRQ");break;
1350 case 3: sprintf(buffer, "Reserved");break;
1351 }
1352 printk(KERN_INFO "Command Packet DRQ Type: %s\n", buffer);
1353 switch (gcw.packet_size) {
1354 case 0: sprintf(buffer, "12 bytes");break;
1355 case 1: sprintf(buffer, "16 bytes");break;
1356 default: sprintf(buffer, "Reserved");break;
1357 }
1358 printk(KERN_INFO "Command Packet Size: %s\n", buffer);
1359#endif /* IDEFLOPPY_DEBUG_INFO */
1360
1361 if (gcw.protocol != 2) 1320 if (gcw.protocol != 2)
1362 printk(KERN_ERR "ide-floppy: Protocol is not ATAPI\n"); 1321 printk(KERN_ERR "ide-floppy: Protocol (0x%02x) is not ATAPI\n",
1322 gcw.protocol);
1363 else if (gcw.device_type != 0) 1323 else if (gcw.device_type != 0)
1364 printk(KERN_ERR "ide-floppy: Device type is not set to floppy\n"); 1324 printk(KERN_ERR "ide-floppy: Device type (0x%02x) is not set "
1325 "to floppy\n", gcw.device_type);
1365 else if (!gcw.removable) 1326 else if (!gcw.removable)
1366 printk(KERN_ERR "ide-floppy: The removable flag is not set\n"); 1327 printk(KERN_ERR "ide-floppy: The removable flag is not set\n");
1367 else if (gcw.drq_type == 3) { 1328 else if (gcw.drq_type == 3) {
1368 printk(KERN_ERR "ide-floppy: Sorry, DRQ type %d not supported\n", gcw.drq_type); 1329 printk(KERN_ERR "ide-floppy: Sorry, DRQ type (0x%02x) not "
1330 "supported\n", gcw.drq_type);
1369 } else if (gcw.packet_size != 0) { 1331 } else if (gcw.packet_size != 0) {
1370 printk(KERN_ERR "ide-floppy: Packet size is not 12 bytes long\n"); 1332 printk(KERN_ERR "ide-floppy: Packet size (0x%02x) is not 12 "
1333 "bytes long\n", gcw.packet_size);
1371 } else 1334 } else
1372 return 1; 1335 return 1;
1373 return 0; 1336 return 0;