Commit 0571c7a4 authored by Borislav Petkov's avatar Borislav Petkov Committed by Bartlomiej Zolnierkiewicz

ide-floppy: fix most of the remaining checkpatch.pl issues

such as
ERROR: switch and case should be at the same indent
ERROR: need spaces around that '=' (ctx:VxV)
ERROR: trailing statements should be on next line
WARNING: no space between function name and open parenthesis '('
WARNING: printk() should include KERN_ facility level
ERROR: That open brace { should be on the previous line
ERROR: use tabs not spaces
ERROR: do not use assignment in if condition
WARNING: braces {} are not necessary for single statement blocks
ERROR: need space after that ',' (ctx:VxV)
WARNING: line over 80 characters
ERROR: do not use assignment in if condition
...
and so on.
Signed-off-by: default avatarBorislav Petkov <bbpetkov@yahoo.de>
Signed-off-by: default avatarBartlomiej Zolnierkiewicz <bzolnier@gmail.com>
parent 6e5fa7b8
...@@ -4,9 +4,7 @@ ...@@ -4,9 +4,7 @@
* Copyright (C) 1996-1999 Gadi Oxman <gadio@netvision.net.il> * Copyright (C) 1996-1999 Gadi Oxman <gadio@netvision.net.il>
* Copyright (C) 2000-2002 Paul Bristow <paul@paulbristow.net> * Copyright (C) 2000-2002 Paul Bristow <paul@paulbristow.net>
* Copyright (C) 2005 Bartlomiej Zolnierkiewicz * Copyright (C) 2005 Bartlomiej Zolnierkiewicz
*/ *
/*
* The driver currently doesn't have any fancy features, just the bare * The driver currently doesn't have any fancy features, just the bare
* minimum read/write support. * minimum read/write support.
* *
...@@ -51,57 +49,56 @@ ...@@ -51,57 +49,56 @@
#define IDEFLOPPY_DEBUG_LOG 0 #define IDEFLOPPY_DEBUG_LOG 0
/* #define IDEFLOPPY_DEBUG(fmt, args...) printk(KERN_INFO fmt, ## args) */ /* #define IDEFLOPPY_DEBUG(fmt, args...) printk(KERN_INFO fmt, ## args) */
#define IDEFLOPPY_DEBUG( fmt, args... ) #define IDEFLOPPY_DEBUG(fmt, args...)
#if IDEFLOPPY_DEBUG_LOG #if IDEFLOPPY_DEBUG_LOG
#define debug_log(fmt, args...) \ #define debug_log(fmt, args...) \
printk(KERN_INFO "ide-floppy: " fmt, ## args) printk(KERN_INFO "ide-floppy: " fmt, ## args)
#else #else
#define debug_log(fmt, args... ) do {} while(0) #define debug_log(fmt, args...) do {} while (0)
#endif #endif
/* /* Some drives require a longer irq timeout. */
* Some drives require a longer irq timeout.
*/
#define IDEFLOPPY_WAIT_CMD (5 * WAIT_CMD) #define IDEFLOPPY_WAIT_CMD (5 * WAIT_CMD)
/* /*
* After each failed packet command we issue a request sense command * After each failed packet command we issue a request sense command and retry
* and retry the packet command IDEFLOPPY_MAX_PC_RETRIES times. * the packet command IDEFLOPPY_MAX_PC_RETRIES times.
*/ */
#define IDEFLOPPY_MAX_PC_RETRIES 3 #define IDEFLOPPY_MAX_PC_RETRIES 3
/* /*
* With each packet command, we allocate a buffer of * With each packet command, we allocate a buffer of IDEFLOPPY_PC_BUFFER_SIZE
* IDEFLOPPY_PC_BUFFER_SIZE bytes. * bytes.
*/ */
#define IDEFLOPPY_PC_BUFFER_SIZE 256 #define IDEFLOPPY_PC_BUFFER_SIZE 256
/* /*
* In various places in the driver, we need to allocate storage * In various places in the driver, we need to allocate storage for packet
* for packet commands and requests, which will remain valid while * commands and requests, which will remain valid while we leave the driver to
* we leave the driver to wait for an interrupt or a timeout event. * wait for an interrupt or a timeout event.
*/ */
#define IDEFLOPPY_PC_STACK (10 + IDEFLOPPY_MAX_PC_RETRIES) #define IDEFLOPPY_PC_STACK (10 + IDEFLOPPY_MAX_PC_RETRIES)
/*
* Our view of a packet command.
*/
typedef struct idefloppy_packet_command_s { typedef struct idefloppy_packet_command_s {
u8 c[12]; /* Actual packet bytes */ u8 c[12]; /* Actual packet bytes */
int retries; /* On each retry, we increment retries */ int retries; /* On each retry, we increment
retries */
int error; /* Error code */ int error; /* Error code */
int request_transfer; /* Bytes to transfer */ int request_transfer; /* Bytes to transfer */
int actually_transferred; /* Bytes actually transferred */ int actually_transferred; /* Bytes actually transferred */
int buffer_size; /* Size of our data buffer */ int buffer_size; /* Size of our data buffer */
int b_count; /* Missing/Available data on the current buffer */ int b_count; /* Missing/Available data on
the current buffer */
struct request *rq; /* The corresponding request */ struct request *rq; /* The corresponding request */
u8 *buffer; /* Data buffer */ u8 *buffer; /* Data buffer */
u8 *current_position; /* Pointer into the above buffer */ u8 *current_position; /* Pointer into above buffer */
void (*callback) (ide_drive_t *); /* Called when this packet command is completed */ void (*callback) (ide_drive_t *); /* Called when this packet
command is completed */
u8 pc_buffer[IDEFLOPPY_PC_BUFFER_SIZE]; /* Temporary buffer */ u8 pc_buffer[IDEFLOPPY_PC_BUFFER_SIZE]; /* Temporary buffer */
unsigned long flags; /* Status/Action bit flags: long for set_bit */ unsigned long flags; /* Status/Action bit flags: long
for set_bit */
} idefloppy_pc_t; } idefloppy_pc_t;
/* Packet command flag bits. */ /* Packet command flag bits. */
...@@ -125,9 +122,9 @@ enum { ...@@ -125,9 +122,9 @@ enum {
#define CAPACITY_NO_CARTRIDGE 0x03 #define CAPACITY_NO_CARTRIDGE 0x03
/* /*
* Most of our global data which we need to save even as we leave the * Most of our global data which we need to save even as we leave the driver
* driver due to an interrupt or a timer event is stored in a variable * due to an interrupt or a timer event is stored in a variable of type
* of type idefloppy_floppy_t, defined below. * idefloppy_floppy_t, defined below.
*/ */
typedef struct ide_floppy_obj { typedef struct ide_floppy_obj {
ide_drive_t *drive; ide_drive_t *drive;
...@@ -148,17 +145,13 @@ typedef struct ide_floppy_obj { ...@@ -148,17 +145,13 @@ typedef struct ide_floppy_obj {
/* We implement a circular array */ /* We implement a circular array */
int rq_stack_index; int rq_stack_index;
/* /* Last error information */
* Last error information
*/
u8 sense_key, asc, ascq; u8 sense_key, asc, ascq;
/* delay this long before sending packet command */ /* delay this long before sending packet command */
u8 ticks; u8 ticks;
int progress_indication; int progress_indication;
/* /* Device information */
* Device information
*/
/* Current format */ /* Current format */
int blocks, block_size, bs_factor; int blocks, block_size, bs_factor;
/* Last format capacity descriptor */ /* Last format capacity descriptor */
...@@ -189,32 +182,24 @@ enum { ...@@ -189,32 +182,24 @@ enum {
IDEFLOPPY_FLAG_ZIP_DRIVE = (1 << 4), IDEFLOPPY_FLAG_ZIP_DRIVE = (1 << 4),
}; };
/* /* Defines for the MODE SENSE command */
* Defines for the mode sense command
*/
#define MODE_SENSE_CURRENT 0x00 #define MODE_SENSE_CURRENT 0x00
#define MODE_SENSE_CHANGEABLE 0x01 #define MODE_SENSE_CHANGEABLE 0x01
#define MODE_SENSE_DEFAULT 0x02 #define MODE_SENSE_DEFAULT 0x02
#define MODE_SENSE_SAVED 0x03 #define MODE_SENSE_SAVED 0x03
/* /* IOCTLs used in low-level formatting. */
* IOCTLs used in low-level formatting.
*/
#define IDEFLOPPY_IOCTL_FORMAT_SUPPORTED 0x4600 #define IDEFLOPPY_IOCTL_FORMAT_SUPPORTED 0x4600
#define IDEFLOPPY_IOCTL_FORMAT_GET_CAPACITY 0x4601 #define IDEFLOPPY_IOCTL_FORMAT_GET_CAPACITY 0x4601
#define IDEFLOPPY_IOCTL_FORMAT_START 0x4602 #define IDEFLOPPY_IOCTL_FORMAT_START 0x4602
#define IDEFLOPPY_IOCTL_FORMAT_GET_PROGRESS 0x4603 #define IDEFLOPPY_IOCTL_FORMAT_GET_PROGRESS 0x4603
/* /* Error code returned in rq->errors to the higher part of the driver. */
* Error codes which are returned in rq->errors to the higher part
* of the driver.
*/
#define IDEFLOPPY_ERROR_GENERAL 101 #define IDEFLOPPY_ERROR_GENERAL 101
/* /*
* The following is used to format the general configuration word of * The following is used to format the general configuration word of the
* the ATAPI IDENTIFY DEVICE command. * ATAPI IDENTIFY DEVICE command.
*/ */
struct idefloppy_id_gcw { struct idefloppy_id_gcw {
#if defined(__LITTLE_ENDIAN_BITFIELD) #if defined(__LITTLE_ENDIAN_BITFIELD)
...@@ -277,7 +262,7 @@ static void ide_floppy_put(struct ide_floppy_obj *floppy) ...@@ -277,7 +262,7 @@ static void ide_floppy_put(struct ide_floppy_obj *floppy)
* Too bad. The drive wants to send us data which we are not ready to accept. * Too bad. The drive wants to send us data which we are not ready to accept.
* Just throw it away. * Just throw it away.
*/ */
static void idefloppy_discard_data (ide_drive_t *drive, unsigned int bcount) static void idefloppy_discard_data(ide_drive_t *drive, unsigned int bcount)
{ {
while (bcount--) while (bcount--)
(void) HWIF(drive)->INB(IDE_DATA_REG); (void) HWIF(drive)->INB(IDE_DATA_REG);
...@@ -291,10 +276,8 @@ static void idefloppy_write_zeros(ide_drive_t *drive, unsigned int bcount) ...@@ -291,10 +276,8 @@ static void idefloppy_write_zeros(ide_drive_t *drive, unsigned int bcount)
/* /*
* idefloppy_do_end_request is used to finish servicing a request. * Used to finish servicing a request. For read/write requests, we will call
* * ide_end_request to pass to the next buffer.
* For read/write requests, we will call ide_end_request to pass to the
* next buffer.
*/ */
static int idefloppy_do_end_request(ide_drive_t *drive, int uptodate, int nsecs) static int idefloppy_do_end_request(ide_drive_t *drive, int uptodate, int nsecs)
{ {
...@@ -366,7 +349,7 @@ static void ide_floppy_io_buffers(ide_drive_t *drive, idefloppy_pc_t *pc, ...@@ -366,7 +349,7 @@ static void ide_floppy_io_buffers(ide_drive_t *drive, idefloppy_pc_t *pc,
} }
} }
static void idefloppy_update_buffers (ide_drive_t *drive, idefloppy_pc_t *pc) static void idefloppy_update_buffers(ide_drive_t *drive, idefloppy_pc_t *pc)
{ {
struct request *rq = pc->rq; struct request *rq = pc->rq;
struct bio *bio = rq->bio; struct bio *bio = rq->bio;
...@@ -376,11 +359,12 @@ static void idefloppy_update_buffers (ide_drive_t *drive, idefloppy_pc_t *pc) ...@@ -376,11 +359,12 @@ static void idefloppy_update_buffers (ide_drive_t *drive, idefloppy_pc_t *pc)
} }
/* /*
* idefloppy_queue_pc_head generates a new packet command request in front * Generate a new packet command request in front of the request queue, before
* of the request queue, before the current request, so that it will be * the current request so that it will be processed immediately, on the next
* processed immediately, on the next pass through the driver. * pass through the driver.
*/ */
static void idefloppy_queue_pc_head (ide_drive_t *drive,idefloppy_pc_t *pc,struct request *rq) static void idefloppy_queue_pc_head(ide_drive_t *drive, idefloppy_pc_t *pc,
struct request *rq)
{ {
struct ide_floppy_obj *floppy = drive->driver_data; struct ide_floppy_obj *floppy = drive->driver_data;
...@@ -391,16 +375,16 @@ static void idefloppy_queue_pc_head (ide_drive_t *drive,idefloppy_pc_t *pc,struc ...@@ -391,16 +375,16 @@ static void idefloppy_queue_pc_head (ide_drive_t *drive,idefloppy_pc_t *pc,struc
(void) ide_do_drive_cmd(drive, rq, ide_preempt); (void) ide_do_drive_cmd(drive, rq, ide_preempt);
} }
static idefloppy_pc_t *idefloppy_next_pc_storage (ide_drive_t *drive) static idefloppy_pc_t *idefloppy_next_pc_storage(ide_drive_t *drive)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
if (floppy->pc_stack_index == IDEFLOPPY_PC_STACK) if (floppy->pc_stack_index == IDEFLOPPY_PC_STACK)
floppy->pc_stack_index=0; floppy->pc_stack_index = 0;
return (&floppy->pc_stack[floppy->pc_stack_index++]); return (&floppy->pc_stack[floppy->pc_stack_index++]);
} }
static struct request *idefloppy_next_rq_storage (ide_drive_t *drive) static struct request *idefloppy_next_rq_storage(ide_drive_t *drive)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
...@@ -445,10 +429,8 @@ static void idefloppy_request_sense_callback(ide_drive_t *drive) ...@@ -445,10 +429,8 @@ static void idefloppy_request_sense_callback(ide_drive_t *drive)
} }
} }
/* /* General packet command callback function. */
* General packet command callback function. static void idefloppy_pc_callback(ide_drive_t *drive)
*/
static void idefloppy_pc_callback (ide_drive_t *drive)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
...@@ -457,10 +439,7 @@ static void idefloppy_pc_callback (ide_drive_t *drive) ...@@ -457,10 +439,7 @@ static void idefloppy_pc_callback (ide_drive_t *drive)
idefloppy_do_end_request(drive, floppy->pc->error ? 0 : 1, 0); idefloppy_do_end_request(drive, floppy->pc->error ? 0 : 1, 0);
} }
/* static void idefloppy_init_pc(idefloppy_pc_t *pc)
* idefloppy_init_pc initializes a packet command.
*/
static void idefloppy_init_pc (idefloppy_pc_t *pc)
{ {
memset(pc->c, 0, 12); memset(pc->c, 0, 12);
pc->retries = 0; pc->retries = 0;
...@@ -471,7 +450,7 @@ static void idefloppy_init_pc (idefloppy_pc_t *pc) ...@@ -471,7 +450,7 @@ static void idefloppy_init_pc (idefloppy_pc_t *pc)
pc->callback = &idefloppy_pc_callback; pc->callback = &idefloppy_pc_callback;
} }
static void idefloppy_create_request_sense_cmd (idefloppy_pc_t *pc) static void idefloppy_create_request_sense_cmd(idefloppy_pc_t *pc)
{ {
idefloppy_init_pc(pc); idefloppy_init_pc(pc);
pc->c[0] = GPCMD_REQUEST_SENSE; pc->c[0] = GPCMD_REQUEST_SENSE;
...@@ -481,11 +460,10 @@ static void idefloppy_create_request_sense_cmd (idefloppy_pc_t *pc) ...@@ -481,11 +460,10 @@ static void idefloppy_create_request_sense_cmd (idefloppy_pc_t *pc)
} }
/* /*
* idefloppy_retry_pc is called when an error was detected during the * Called when an error was detected during the last packet command. We queue a
* last packet command. We queue a request sense packet command in * request sense packet command in the head of the request list.
* the head of the request list.
*/ */
static void idefloppy_retry_pc (ide_drive_t *drive) static void idefloppy_retry_pc(ide_drive_t *drive)
{ {
idefloppy_pc_t *pc; idefloppy_pc_t *pc;
struct request *rq; struct request *rq;
...@@ -528,7 +506,8 @@ static ide_startstop_t idefloppy_pc_intr (ide_drive_t *drive) ...@@ -528,7 +506,8 @@ static ide_startstop_t idefloppy_pc_intr (ide_drive_t *drive)
/* Clear the interrupt */ /* Clear the interrupt */
stat = drive->hwif->INB(IDE_STATUS_REG); stat = drive->hwif->INB(IDE_STATUS_REG);
if ((stat & DRQ_STAT) == 0) { /* No more interrupts */ /* No more interrupts */
if ((stat & DRQ_STAT) == 0) {
debug_log("Packet command completed, %d bytes transferred\n", debug_log("Packet command completed, %d bytes transferred\n",
pc->actually_transferred); pc->actually_transferred);
pc->flags &= ~PC_FLAG_DMA_IN_PROGRESS; pc->flags &= ~PC_FLAG_DMA_IN_PROGRESS;
...@@ -628,7 +607,7 @@ static ide_startstop_t idefloppy_pc_intr (ide_drive_t *drive) ...@@ -628,7 +607,7 @@ static ide_startstop_t idefloppy_pc_intr (ide_drive_t *drive)
* It fails at high speeds on the Iomega ZIP drive, so there's a slower version * It fails at high speeds on the Iomega ZIP drive, so there's a slower version
* for that drive below. The algorithm is chosen based on drive type * for that drive below. The algorithm is chosen based on drive type
*/ */
static ide_startstop_t idefloppy_transfer_pc (ide_drive_t *drive) static ide_startstop_t idefloppy_transfer_pc(ide_drive_t *drive)
{ {
ide_startstop_t startstop; ide_startstop_t startstop;
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
...@@ -655,18 +634,16 @@ static ide_startstop_t idefloppy_transfer_pc (ide_drive_t *drive) ...@@ -655,18 +634,16 @@ static ide_startstop_t idefloppy_transfer_pc (ide_drive_t *drive)
/* /*
* What we have here is a classic case of a top half / bottom half * What we have here is a classic case of a top half / bottom half interrupt
* interrupt service routine. In interrupt mode, the device sends * service routine. In interrupt mode, the device sends an interrupt to signal
* an interrupt to signal it's ready to receive a packet. However, * that it is ready to receive a packet. However, we need to delay about 2-3
* we need to delay about 2-3 ticks before issuing the packet or we * ticks before issuing the packet or we gets in trouble.
* gets in trouble.
* *
* So, follow carefully. transfer_pc1 is called as an interrupt (or * So, follow carefully. transfer_pc1 is called as an interrupt (or directly).
* directly). In either case, when the device says it's ready for a * In either case, when the device says it's ready for a packet, we schedule
* packet, we schedule the packet transfer to occur about 2-3 ticks * the packet transfer to occur about 2-3 ticks later in transfer_pc2.
* later in transfer_pc2.
*/ */
static int idefloppy_transfer_pc2 (ide_drive_t *drive) static int idefloppy_transfer_pc2(ide_drive_t *drive)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
...@@ -676,7 +653,7 @@ static int idefloppy_transfer_pc2 (ide_drive_t *drive) ...@@ -676,7 +653,7 @@ static int idefloppy_transfer_pc2 (ide_drive_t *drive)
return IDEFLOPPY_WAIT_CMD; return IDEFLOPPY_WAIT_CMD;
} }
static ide_startstop_t idefloppy_transfer_pc1 (ide_drive_t *drive) static ide_startstop_t idefloppy_transfer_pc1(ide_drive_t *drive)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
ide_startstop_t startstop; ide_startstop_t startstop;
...@@ -702,10 +679,8 @@ static ide_startstop_t idefloppy_transfer_pc1 (ide_drive_t *drive) ...@@ -702,10 +679,8 @@ static ide_startstop_t idefloppy_transfer_pc1 (ide_drive_t *drive)
* used until after the packet is moved in about 50 msec. * used until after the packet is moved in about 50 msec.
*/ */
ide_set_handler(drive, ide_set_handler(drive, &idefloppy_pc_intr, floppy->ticks,
&idefloppy_pc_intr, /* service routine for packet command */ &idefloppy_transfer_pc2);
floppy->ticks, /* wait this long before "failing" */
&idefloppy_transfer_pc2); /* fail == transfer_pc2 */
return ide_started; return ide_started;
} }
...@@ -725,10 +700,8 @@ static void ide_floppy_report_error(idefloppy_floppy_t *floppy, ...@@ -725,10 +700,8 @@ static void ide_floppy_report_error(idefloppy_floppy_t *floppy,
} }
/* static ide_startstop_t idefloppy_issue_pc(ide_drive_t *drive,
* Issue a packet command idefloppy_pc_t *pc)
*/
static ide_startstop_t idefloppy_issue_pc (ide_drive_t *drive, idefloppy_pc_t *pc)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
ide_hwif_t *hwif = drive->hwif; ide_hwif_t *hwif = drive->hwif;
...@@ -773,7 +746,8 @@ static ide_startstop_t idefloppy_issue_pc (ide_drive_t *drive, idefloppy_pc_t *p ...@@ -773,7 +746,8 @@ static ide_startstop_t idefloppy_issue_pc (ide_drive_t *drive, idefloppy_pc_t *p
ide_pktcmd_tf_load(drive, IDE_TFLAG_NO_SELECT_MASK | ide_pktcmd_tf_load(drive, IDE_TFLAG_NO_SELECT_MASK |
IDE_TFLAG_OUT_DEVICE, bcount, dma); IDE_TFLAG_OUT_DEVICE, bcount, dma);
if (dma) { /* Begin DMA, if necessary */ if (dma) {
/* Begin DMA, if necessary */
pc->flags |= PC_FLAG_DMA_IN_PROGRESS; pc->flags |= PC_FLAG_DMA_IN_PROGRESS;
hwif->dma_start(drive); hwif->dma_start(drive);
} }
...@@ -801,7 +775,7 @@ static ide_startstop_t idefloppy_issue_pc (ide_drive_t *drive, idefloppy_pc_t *p ...@@ -801,7 +775,7 @@ static ide_startstop_t idefloppy_issue_pc (ide_drive_t *drive, idefloppy_pc_t *p
} }
} }
static void idefloppy_rw_callback (ide_drive_t *drive) static void idefloppy_rw_callback(ide_drive_t *drive)
{ {
debug_log("Reached %s\n", __func__); debug_log("Reached %s\n", __func__);
...@@ -809,7 +783,7 @@ static void idefloppy_rw_callback (ide_drive_t *drive) ...@@ -809,7 +783,7 @@ static void idefloppy_rw_callback (ide_drive_t *drive)
return; return;
} }
static void idefloppy_create_prevent_cmd (idefloppy_pc_t *pc, int prevent) static void idefloppy_create_prevent_cmd(idefloppy_pc_t *pc, int prevent)
{ {
debug_log("creating prevent removal command, prevent = %d\n", prevent); debug_log("creating prevent removal command, prevent = %d\n", prevent);
...@@ -818,7 +792,7 @@ static void idefloppy_create_prevent_cmd (idefloppy_pc_t *pc, int prevent) ...@@ -818,7 +792,7 @@ static void idefloppy_create_prevent_cmd (idefloppy_pc_t *pc, int prevent)
pc->c[4] = prevent; pc->c[4] = prevent;
} }
static void idefloppy_create_read_capacity_cmd (idefloppy_pc_t *pc) static void idefloppy_create_read_capacity_cmd(idefloppy_pc_t *pc)
{ {
idefloppy_init_pc(pc); idefloppy_init_pc(pc);
pc->c[0] = GPCMD_READ_FORMAT_CAPACITIES; pc->c[0] = GPCMD_READ_FORMAT_CAPACITIES;
...@@ -827,7 +801,7 @@ static void idefloppy_create_read_capacity_cmd (idefloppy_pc_t *pc) ...@@ -827,7 +801,7 @@ static void idefloppy_create_read_capacity_cmd (idefloppy_pc_t *pc)
pc->request_transfer = 255; pc->request_transfer = 255;
} }
static void idefloppy_create_format_unit_cmd (idefloppy_pc_t *pc, int b, int l, static void idefloppy_create_format_unit_cmd(idefloppy_pc_t *pc, int b, int l,
int flags) int flags)
{ {
idefloppy_init_pc(pc); idefloppy_init_pc(pc);
...@@ -844,14 +818,13 @@ static void idefloppy_create_format_unit_cmd (idefloppy_pc_t *pc, int b, int l, ...@@ -844,14 +818,13 @@ static void idefloppy_create_format_unit_cmd (idefloppy_pc_t *pc, int b, int l,
put_unaligned(cpu_to_be32(b), (unsigned int *)(&pc->buffer[4])); put_unaligned(cpu_to_be32(b), (unsigned int *)(&pc->buffer[4]));
put_unaligned(cpu_to_be32(l), (unsigned int *)(&pc->buffer[8])); put_unaligned(cpu_to_be32(l), (unsigned int *)(&pc->buffer[8]));
pc->buffer_size=12; pc->buffer_size = 12;
pc->flags |= PC_FLAG_WRITING; pc->flags |= PC_FLAG_WRITING;
} }
/* /* A mode sense command is used to "sense" floppy parameters. */
* A mode sense command is used to "sense" floppy parameters. static void idefloppy_create_mode_sense_cmd(idefloppy_pc_t *pc, u8 page_code,
*/ u8 type)
static void idefloppy_create_mode_sense_cmd (idefloppy_pc_t *pc, u8 page_code, u8 type)
{ {
u16 length = 8; /* sizeof(Mode Parameter Header) = 8 Bytes */ u16 length = 8; /* sizeof(Mode Parameter Header) = 8 Bytes */
...@@ -875,7 +848,7 @@ static void idefloppy_create_mode_sense_cmd (idefloppy_pc_t *pc, u8 page_code, u ...@@ -875,7 +848,7 @@ static void idefloppy_create_mode_sense_cmd (idefloppy_pc_t *pc, u8 page_code, u
pc->request_transfer = length; pc->request_transfer = length;
} }
static void idefloppy_create_start_stop_cmd (idefloppy_pc_t *pc, int start) static void idefloppy_create_start_stop_cmd(idefloppy_pc_t *pc, int start)
{ {
idefloppy_init_pc(pc); idefloppy_init_pc(pc);
pc->c[0] = GPCMD_START_STOP_UNIT; pc->c[0] = GPCMD_START_STOP_UNIT;
...@@ -914,8 +887,8 @@ static void idefloppy_create_rw_cmd(idefloppy_floppy_t *floppy, ...@@ -914,8 +887,8 @@ static void idefloppy_create_rw_cmd(idefloppy_floppy_t *floppy,
pc->flags |= PC_FLAG_DMA_RECOMMENDED; pc->flags |= PC_FLAG_DMA_RECOMMENDED;
} }
static void static void idefloppy_blockpc_cmd(idefloppy_floppy_t *floppy,
idefloppy_blockpc_cmd(idefloppy_floppy_t *floppy, idefloppy_pc_t *pc, struct request *rq) idefloppy_pc_t *pc, struct request *rq)
{ {
idefloppy_init_pc(pc); idefloppy_init_pc(pc);
pc->callback = &idefloppy_rw_callback; pc->callback = &idefloppy_rw_callback;
...@@ -934,10 +907,8 @@ idefloppy_blockpc_cmd(idefloppy_floppy_t *floppy, idefloppy_pc_t *pc, struct req ...@@ -934,10 +907,8 @@ idefloppy_blockpc_cmd(idefloppy_floppy_t *floppy, idefloppy_pc_t *pc, struct req
pc->request_transfer = pc->buffer_size = rq->data_len; pc->request_transfer = pc->buffer_size = rq->data_len;
} }
/* static ide_startstop_t idefloppy_do_request(ide_drive_t *drive,
* idefloppy_do_request is our request handling function. struct request *rq, sector_t block_s)
*/
static ide_startstop_t idefloppy_do_request (ide_drive_t *drive, struct request *rq, sector_t block_s)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
idefloppy_pc_t *pc; idefloppy_pc_t *pc;
...@@ -962,7 +933,7 @@ static ide_startstop_t idefloppy_do_request (ide_drive_t *drive, struct request ...@@ -962,7 +933,7 @@ static ide_startstop_t idefloppy_do_request (ide_drive_t *drive, struct request
if (blk_fs_request(rq)) { if (blk_fs_request(rq)) {
if (((long)rq->sector % floppy->bs_factor) || if (((long)rq->sector % floppy->bs_factor) ||
(rq->nr_sectors % floppy->bs_factor)) { (rq->nr_sectors % floppy->bs_factor)) {
printk("%s: unsupported r/w request size\n", printk(KERN_ERR "%s: unsupported r/w request size\n",
drive->name); drive->name);
idefloppy_do_end_request(drive, 0, 0); idefloppy_do_end_request(drive, 0, 0);
return ide_stopped; return ide_stopped;
...@@ -986,15 +957,15 @@ static ide_startstop_t idefloppy_do_request (ide_drive_t *drive, struct request ...@@ -986,15 +957,15 @@ static ide_startstop_t idefloppy_do_request (ide_drive_t *drive, struct request
} }
/* /*
* idefloppy_queue_pc_tail adds a special packet command request to the * Add a special packet command request to the tail of the request queue,
* tail of the request queue, and waits for it to be serviced. * and wait for it to be serviced.
*/ */
static int idefloppy_queue_pc_tail (ide_drive_t *drive,idefloppy_pc_t *pc) static int idefloppy_queue_pc_tail(ide_drive_t *drive, idefloppy_pc_t *pc)
{ {
struct ide_floppy_obj *floppy = drive->driver_data; struct ide_floppy_obj *floppy = drive->driver_data;
struct request rq; struct request rq;
ide_init_drive_cmd (&rq); ide_init_drive_cmd(&rq);
rq.buffer = (char *) pc; rq.buffer = (char *) pc;
rq.cmd_type = REQ_TYPE_SPECIAL; rq.cmd_type = REQ_TYPE_SPECIAL;
rq.rq_disk = floppy->disk; rq.rq_disk = floppy->disk;
...@@ -1247,14 +1218,14 @@ static int ide_floppy_get_format_capacities(ide_drive_t *drive, int __user *arg) ...@@ -1247,14 +1218,14 @@ static int ide_floppy_get_format_capacities(ide_drive_t *drive, int __user *arg)
} }
/* /*
** Get ATAPI_FORMAT_UNIT progress indication. * Get ATAPI_FORMAT_UNIT progress indication.
** *
** Userland gives a pointer to an int. The int is set to a progress * Userland gives a pointer to an int. The int is set to a progress
** indicator 0-65536, with 65536=100%. * indicator 0-65536, with 65536=100%.
** *
** If the drive does not support format progress indication, we just check * If the drive does not support format progress indication, we just check
** the dsc bit, and return either 0 or 65536. * the dsc bit, and return either 0 or 65536.
*/ */
static int idefloppy_get_format_progress(ide_drive_t *drive, int __user *arg) static int idefloppy_get_format_progress(ide_drive_t *drive, int __user *arg)
{ {
...@@ -1264,17 +1235,15 @@ static int idefloppy_get_format_progress(ide_drive_t *drive, int __user *arg) ...@@ -1264,17 +1235,15 @@ static int idefloppy_get_format_progress(ide_drive_t *drive, int __user *arg)
if (floppy->srfp) { if (floppy->srfp) {
idefloppy_create_request_sense_cmd(&pc); idefloppy_create_request_sense_cmd(&pc);
if (idefloppy_queue_pc_tail(drive, &pc)) { if (idefloppy_queue_pc_tail(drive, &pc))
return (-EIO); return (-EIO);
}
if (floppy->sense_key == 2 && if (floppy->sense_key == 2 &&
floppy->asc == 4 && floppy->asc == 4 &&
floppy->ascq == 4) { floppy->ascq == 4)
progress_indication = floppy->progress_indication; progress_indication = floppy->progress_indication;
}
/* Else assume format_unit has finished, and we're /* Else assume format_unit has finished, and we're at 0x10000 */
** at 0x10000 */
} else { } else {
unsigned long flags; unsigned long flags;
u8 stat; u8 stat;
...@@ -1291,10 +1260,7 @@ static int idefloppy_get_format_progress(ide_drive_t *drive, int __user *arg) ...@@ -1291,10 +1260,7 @@ static int idefloppy_get_format_progress(ide_drive_t *drive, int __user *arg)
return (0); return (0);
} }
/* static sector_t idefloppy_capacity(ide_drive_t *drive)
* Return the current floppy capacity.
*/
static sector_t idefloppy_capacity (ide_drive_t *drive)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
unsigned long capacity = floppy->blocks * floppy->bs_factor; unsigned long capacity = floppy->blocks * floppy->bs_factor;
...@@ -1344,22 +1310,20 @@ static void idefloppy_add_settings(ide_drive_t *drive) ...@@ -1344,22 +1310,20 @@ static void idefloppy_add_settings(ide_drive_t *drive)
{ {
idefloppy_floppy_t *floppy = drive->driver_data; idefloppy_floppy_t *floppy = drive->driver_data;
/* ide_add_setting(drive, "bios_cyl", SETTING_RW, TYPE_INT, 0, 1023, 1, 1,
* drive setting name read/write data type min max mul_factor div_factor data pointer set function &drive->bios_cyl, NULL);
*/ ide_add_setting(drive, "bios_head", SETTING_RW, TYPE_BYTE, 0, 255, 1, 1,
ide_add_setting(drive, "bios_cyl", SETTING_RW, TYPE_INT, 0, 1023, 1, 1, &drive->bios_cyl, NULL); &drive->bios_head, NULL);
ide_add_setting(drive, "bios_head", SETTING_RW, TYPE_BYTE, 0, 255, 1, 1, &drive->bios_head, NULL); ide_add_setting(drive, "bios_sect", SETTING_RW, TYPE_BYTE, 0, 63, 1, 1,
ide_add_setting(drive, "bios_sect", SETTING_RW, TYPE_BYTE, 0, 63, 1, 1, &drive->bios_sect, NULL); &drive->bios_sect, NULL);
ide_add_setting(drive, "ticks", SETTING_RW, TYPE_BYTE, 0, 255, 1, 1, &floppy->ticks, NULL); ide_add_setting(drive, "ticks", SETTING_RW, TYPE_BYTE, 0, 255, 1, 1,
&floppy->ticks, NULL);
} }
#else #else
static inline void idefloppy_add_settings(ide_drive_t *drive) { ; } static inline void idefloppy_add_settings(ide_drive_t *drive) { ; }
#endif #endif
/* static void idefloppy_setup(ide_drive_t *drive, idefloppy_floppy_t *floppy)
* Driver initialization.
*/
static void idefloppy_setup (ide_drive_t *drive, idefloppy_floppy_t *floppy)
{ {
struct idefloppy_id_gcw gcw; struct idefloppy_id_gcw gcw;
...@@ -1368,16 +1332,14 @@ static void idefloppy_setup (ide_drive_t *drive, idefloppy_floppy_t *floppy) ...@@ -1368,16 +1332,14 @@ static void idefloppy_setup (ide_drive_t *drive, idefloppy_floppy_t *floppy)
if (gcw.drq_type == 1) if (gcw.drq_type == 1)
floppy->flags |= IDEFLOPPY_FLAG_DRQ_INTERRUPT; floppy->flags |= IDEFLOPPY_FLAG_DRQ_INTERRUPT;
/* /*
* We used to check revisions here. At this point however * We used to check revisions here. At this point however I'm giving up.
* I'm giving up. Just assume they are all broken, its easier. * Just assume they are all broken, its easier.
* *
* The actual reason for the workarounds was likely * The actual reason for the workarounds was likely a driver bug after
* a driver bug after all rather than a firmware bug, * all rather than a firmware bug, and the workaround below used to hide
* and the workaround below used to hide it. It should * it. It should be fixed as of version 1.9, but to be on the safe side
* be fixed as of version 1.9, but to be on the safe side
* we'll leave the limitation below for the 2.2.x tree. * we'll leave the limitation below for the 2.2.x tree.
*/ */
if (!strncmp(drive->id->model, "IOMEGA ZIP 100 ATAPI", 20)) { if (!strncmp(drive->id->model, "IOMEGA ZIP 100 ATAPI", 20)) {
floppy->flags |= IDEFLOPPY_FLAG_ZIP_DRIVE; floppy->flags |= IDEFLOPPY_FLAG_ZIP_DRIVE;
/* This value will be visible in the /proc/ide/hdx/settings */ /* This value will be visible in the /proc/ide/hdx/settings */
...@@ -1386,16 +1348,14 @@ static void idefloppy_setup (ide_drive_t *drive, idefloppy_floppy_t *floppy) ...@@ -1386,16 +1348,14 @@ static void idefloppy_setup (ide_drive_t *drive, idefloppy_floppy_t *floppy)
} }
/* /*
* Guess what? The IOMEGA Clik! drive also needs the * Guess what? The IOMEGA Clik! drive also needs the above fix. It makes
* above fix. It makes nasty clicking noises without * nasty clicking noises without it, so please don't remove this.
* it, so please don't remove this.
*/ */
if (strncmp(drive->id->model, "IOMEGA Clik!", 11) == 0) { if (strncmp(drive->id->model, "IOMEGA Clik!", 11) == 0) {
blk_queue_max_sectors(drive->queue, 64); blk_queue_max_sectors(drive->queue, 64);
floppy->flags |= IDEFLOPPY_FLAG_CLIK_DRIVE; floppy->flags |= IDEFLOPPY_FLAG_CLIK_DRIVE;
} }
(void) ide_floppy_get_capacity(drive); (void) ide_floppy_get_capacity(drive);
idefloppy_add_settings(drive); idefloppy_add_settings(drive);
} }
...@@ -1425,14 +1385,14 @@ static void idefloppy_cleanup_obj(struct kref *kref) ...@@ -1425,14 +1385,14 @@ static void idefloppy_cleanup_obj(struct kref *kref)
} }
#ifdef CONFIG_IDE_PROC_FS #ifdef CONFIG_IDE_PROC_FS
static int proc_idefloppy_read_capacity static int proc_idefloppy_read_capacity(char *page, char **start, off_t off,
(char *page, char **start, off_t off, int count, int *eof, void *data) int count, int *eof, void *data)
{ {
ide_drive_t*drive = (ide_drive_t *)data; ide_drive_t*drive = (ide_drive_t *)data;
int len; int len;
len = sprintf(page,"%llu\n", (long long)idefloppy_capacity(drive)); len = sprintf(page, "%llu\n", (long long)idefloppy_capacity(drive));
PROC_IDE_READ_RETURN(page,start,off,count,eof,len); PROC_IDE_READ_RETURN(page, start, off, count, eof, len);
} }
static ide_proc_entry_t idefloppy_proc[] = { static ide_proc_entry_t idefloppy_proc[] = {
...@@ -1474,7 +1434,8 @@ static int idefloppy_open(struct inode *inode, struct file *filp) ...@@ -1474,7 +1434,8 @@ static int idefloppy_open(struct inode *inode, struct file *filp)
debug_log("Reached %s\n", __func__); debug_log("Reached %s\n", __func__);
if (!(floppy = ide_floppy_get(disk))) floppy = ide_floppy_get(disk);
if (!floppy)
return -ENXIO; return -ENXIO;
drive = floppy->drive; drive = floppy->drive;
...@@ -1494,9 +1455,9 @@ static int idefloppy_open(struct inode *inode, struct file *filp) ...@@ -1494,9 +1455,9 @@ static int idefloppy_open(struct inode *inode, struct file *filp)
if (ide_floppy_get_capacity(drive) if (ide_floppy_get_capacity(drive)
&& (filp->f_flags & O_NDELAY) == 0 && (filp->f_flags & O_NDELAY) == 0
/* /*
** Allow O_NDELAY to open a drive without a disk, or with * Allow O_NDELAY to open a drive without a disk, or with an
** an unreadable disk, so that we can get the format * unreadable disk, so that we can get the format capacity
** capacity of the drive or begin the format - Sam * of the drive or begin the format - Sam
*/ */
) { ) {
ret = -EIO; ret = -EIO;
...@@ -1726,16 +1687,20 @@ static int ide_floppy_probe(ide_drive_t *drive) ...@@ -1726,16 +1687,20 @@ static int ide_floppy_probe(ide_drive_t *drive)
goto failed; goto failed;
if (drive->media != ide_floppy) if (drive->media != ide_floppy)
goto failed; goto failed;
if (!idefloppy_identify_device (drive, drive->id)) { if (!idefloppy_identify_device(drive, drive->id)) {
printk (KERN_ERR "ide-floppy: %s: not supported by this version of ide-floppy\n", drive->name); printk(KERN_ERR "ide-floppy: %s: not supported by this version"
" of ide-floppy\n", drive->name);
goto failed; goto failed;
} }
if (drive->scsi) { if (drive->scsi) {
printk("ide-floppy: passing drive %s to ide-scsi emulation.\n", drive->name); printk(KERN_INFO "ide-floppy: passing drive %s to ide-scsi"
" emulation.\n", drive->name);
goto failed; goto failed;
} }
if ((floppy = kzalloc(sizeof (idefloppy_floppy_t), GFP_KERNEL)) == NULL) { floppy = kzalloc(sizeof(idefloppy_floppy_t), GFP_KERNEL);
printk (KERN_ERR "ide-floppy: %s: Can't allocate a floppy structure\n", drive->name); if (!floppy) {
printk(KERN_ERR "ide-floppy: %s: Can't allocate a floppy"
" structure\n", drive->name);
goto failed; goto failed;
} }
...@@ -1757,7 +1722,7 @@ static int ide_floppy_probe(ide_drive_t *drive) ...@@ -1757,7 +1722,7 @@ static int ide_floppy_probe(ide_drive_t *drive)
drive->driver_data = floppy; drive->driver_data = floppy;
idefloppy_setup (drive, floppy); idefloppy_setup(drive, floppy);
g->minors = 1 << PARTN_BITS; g->minors = 1 << PARTN_BITS;
g->driverfs_dev = &drive->gendev; g->driverfs_dev = &drive->gendev;
...@@ -1773,9 +1738,7 @@ static int ide_floppy_probe(ide_drive_t *drive) ...@@ -1773,9 +1738,7 @@ static int ide_floppy_probe(ide_drive_t *drive)
return -ENODEV; return -ENODEV;
} }
MODULE_DESCRIPTION("ATAPI FLOPPY Driver"); static void __exit idefloppy_exit(void)
static void __exit idefloppy_exit (void)
{ {
driver_unregister(&idefloppy_driver.gen_driver); driver_unregister(&idefloppy_driver.gen_driver);
} }
...@@ -1790,3 +1753,5 @@ MODULE_ALIAS("ide:*m-floppy*"); ...@@ -1790,3 +1753,5 @@ MODULE_ALIAS("ide:*m-floppy*");
module_init(idefloppy_init); module_init(idefloppy_init);
module_exit(idefloppy_exit); module_exit(idefloppy_exit);
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
MODULE_DESCRIPTION("ATAPI FLOPPY Driver");
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment