* [PATCH] ide-cd: remove obsolete seek optimization
@ 2008-10-15 19:47 Bartlomiej Zolnierkiewicz
2008-10-16 5:42 ` Borislav Petkov
0 siblings, 1 reply; 3+ messages in thread
From: Bartlomiej Zolnierkiewicz @ 2008-10-15 19:47 UTC (permalink / raw)
To: linux-ide; +Cc: linux-kernel, Borislav Petkov
It doesn't make much sense nowadays and is problematic on some drives.
Cc: Borislav Petkov <petkovbb@googlemail.com>
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
---
against pata tree
drivers/ide/ide-cd.c | 89 +++------------------------------------------------
drivers/ide/ide-cd.h | 2 -
include/linux/ide.h | 4 --
3 files changed, 6 insertions(+), 89 deletions(-)
Index: b/drivers/ide/ide-cd.c
===================================================================
--- a/drivers/ide/ide-cd.c
+++ b/drivers/ide/ide-cd.c
@@ -774,52 +774,6 @@ static ide_startstop_t cdrom_start_rw_co
return cdrom_transfer_packet_command(drive, rq, cdrom_newpc_intr);
}
-#define IDECD_SEEK_THRESHOLD (1000) /* 1000 blocks */
-#define IDECD_SEEK_TIMER (5 * WAIT_MIN_SLEEP) /* 100 ms */
-#define IDECD_SEEK_TIMEOUT (2 * WAIT_CMD) /* 20 sec */
-
-static ide_startstop_t cdrom_seek_intr(ide_drive_t *drive)
-{
- struct cdrom_info *info = drive->driver_data;
- int stat;
- static int retry = 10;
-
- ide_debug_log(IDE_DBG_FUNC, "Call %s\n", __func__);
-
- if (cdrom_decode_status(drive, 0, &stat))
- return ide_stopped;
-
- drive->atapi_flags |= IDE_AFLAG_SEEKING;
-
- if (retry && time_after(jiffies, info->start_seek + IDECD_SEEK_TIMER)) {
- if (--retry == 0)
- drive->dev_flags &= ~IDE_DFLAG_DSC_OVERLAP;
- }
- return ide_stopped;
-}
-
-static void ide_cd_prepare_seek_request(ide_drive_t *drive, struct request *rq)
-{
- sector_t frame = rq->sector;
-
- ide_debug_log(IDE_DBG_FUNC, "Call %s\n", __func__);
-
- sector_div(frame, queue_hardsect_size(drive->queue) >> SECTOR_BITS);
-
- memset(rq->cmd, 0, BLK_MAX_CDB);
- rq->cmd[0] = GPCMD_SEEK;
- put_unaligned(cpu_to_be32(frame), (unsigned int *) &rq->cmd[2]);
-
- rq->timeout = ATAPI_WAIT_PC;
-}
-
-static ide_startstop_t cdrom_start_seek_continuation(ide_drive_t *drive)
-{
- struct request *rq = drive->hwif->hwgroup->rq;
-
- return cdrom_transfer_packet_command(drive, rq, &cdrom_seek_intr);
-}
-
/*
* Fix up a possibly partially-processed request so that we can start it over
* entirely, or even put it back on the request queue.
@@ -1259,7 +1213,6 @@ static void cdrom_do_block_pc(ide_drive_
static ide_startstop_t ide_cd_do_request(ide_drive_t *drive, struct request *rq,
sector_t block)
{
- struct cdrom_info *info = drive->driver_data;
ide_handler_t *fn;
int xferlen;
@@ -1269,44 +1222,14 @@ static ide_startstop_t ide_cd_do_request
(unsigned long long)block);
if (blk_fs_request(rq)) {
- if (drive->atapi_flags & IDE_AFLAG_SEEKING) {
- ide_hwif_t *hwif = drive->hwif;
- unsigned long elapsed = jiffies - info->start_seek;
- int stat = hwif->tp_ops->read_status(hwif);
-
- if ((stat & ATA_DSC) != ATA_DSC) {
- if (elapsed < IDECD_SEEK_TIMEOUT) {
- ide_stall_queue(drive,
- IDECD_SEEK_TIMER);
- return ide_stopped;
- }
- printk(KERN_ERR PFX "%s: DSC timeout\n",
- drive->name);
- }
- drive->atapi_flags &= ~IDE_AFLAG_SEEKING;
- }
- if (rq_data_dir(rq) == READ &&
- IDE_LARGE_SEEK(info->last_block, block,
- IDECD_SEEK_THRESHOLD) &&
- (drive->dev_flags & IDE_DFLAG_DSC_OVERLAP)) {
- xferlen = 0;
- fn = cdrom_start_seek_continuation;
-
- drive->dma = 0;
- info->start_seek = jiffies;
-
- ide_cd_prepare_seek_request(drive, rq);
- } else {
- xferlen = 32768;
- fn = cdrom_start_rw_cont;
+ xferlen = 32768;
+ fn = cdrom_start_rw_cont;
- if (cdrom_start_rw(drive, rq) == ide_stopped)
- return ide_stopped;
+ if (cdrom_start_rw(drive, rq) == ide_stopped)
+ return ide_stopped;
- if (ide_cd_prepare_rw_request(drive, rq) == ide_stopped)
- return ide_stopped;
- }
- info->last_block = block;
+ if (ide_cd_prepare_rw_request(drive, rq) == ide_stopped)
+ return ide_stopped;
} else if (blk_sense_request(rq) || blk_pc_request(rq) ||
rq->cmd_type == REQ_TYPE_ATA_PC) {
xferlen = rq->data_len;
Index: b/drivers/ide/ide-cd.h
===================================================================
--- a/drivers/ide/ide-cd.h
+++ b/drivers/ide/ide-cd.h
@@ -88,8 +88,6 @@ struct cdrom_info {
struct request_sense sense_data;
struct request request_sense_request;
- unsigned long last_block;
- unsigned long start_seek;
u8 max_speed; /* Max speed of the drive. */
u8 current_speed; /* Current speed of the drive. */
Index: b/include/linux/ide.h
===================================================================
--- a/include/linux/ide.h
+++ b/include/linux/ide.h
@@ -122,8 +122,6 @@ struct ide_io_ports {
#define MAX_DRIVES 2 /* per interface; 2 assumed by lots of code */
#define SECTOR_SIZE 512
-#define IDE_LARGE_SEEK(b1,b2,t) (((b1) > (b2) + (t)) || ((b2) > (b1) + (t)))
-
/*
* Timeouts for various operations:
*/
@@ -496,8 +494,6 @@ enum {
* when more than one interrupt is needed.
*/
IDE_AFLAG_LIMIT_NFRAMES = (1 << 7),
- /* Seeking in progress. */
- IDE_AFLAG_SEEKING = (1 << 8),
/* Saved TOC information is current. */
IDE_AFLAG_TOC_VALID = (1 << 9),
/* We think that the drive door is locked. */
^ permalink raw reply [flat|nested] 3+ messages in thread* Re: [PATCH] ide-cd: remove obsolete seek optimization
2008-10-15 19:47 [PATCH] ide-cd: remove obsolete seek optimization Bartlomiej Zolnierkiewicz
@ 2008-10-16 5:42 ` Borislav Petkov
2008-10-16 19:41 ` Bartlomiej Zolnierkiewicz
0 siblings, 1 reply; 3+ messages in thread
From: Borislav Petkov @ 2008-10-16 5:42 UTC (permalink / raw)
To: Bartlomiej Zolnierkiewicz; +Cc: linux-ide, linux-kernel
On Wed, Oct 15, 2008 at 09:47:47PM +0200, Bartlomiej Zolnierkiewicz wrote:
> It doesn't make much sense nowadays and is problematic on some drives.
This is a big chunk, after all. We should do more hammering on it though, just
to be sure.
> Cc: Borislav Petkov <petkovbb@googlemail.com>
> Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
> ---
> against pata tree
>
> drivers/ide/ide-cd.c | 89 +++------------------------------------------------
> drivers/ide/ide-cd.h | 2 -
> include/linux/ide.h | 4 --
> 3 files changed, 6 insertions(+), 89 deletions(-)
>
> Index: b/drivers/ide/ide-cd.c
> ===================================================================
> --- a/drivers/ide/ide-cd.c
> +++ b/drivers/ide/ide-cd.c
> @@ -774,52 +774,6 @@ static ide_startstop_t cdrom_start_rw_co
> return cdrom_transfer_packet_command(drive, rq, cdrom_newpc_intr);
> }
>
> -#define IDECD_SEEK_THRESHOLD (1000) /* 1000 blocks */
> -#define IDECD_SEEK_TIMER (5 * WAIT_MIN_SLEEP) /* 100 ms */
> -#define IDECD_SEEK_TIMEOUT (2 * WAIT_CMD) /* 20 sec */
> -
> -static ide_startstop_t cdrom_seek_intr(ide_drive_t *drive)
> -{
> - struct cdrom_info *info = drive->driver_data;
> - int stat;
> - static int retry = 10;
> -
> - ide_debug_log(IDE_DBG_FUNC, "Call %s\n", __func__);
> -
> - if (cdrom_decode_status(drive, 0, &stat))
> - return ide_stopped;
> -
> - drive->atapi_flags |= IDE_AFLAG_SEEKING;
> -
> - if (retry && time_after(jiffies, info->start_seek + IDECD_SEEK_TIMER)) {
> - if (--retry == 0)
> - drive->dev_flags &= ~IDE_DFLAG_DSC_OVERLAP;
> - }
> - return ide_stopped;
> -}
> -
> -static void ide_cd_prepare_seek_request(ide_drive_t *drive, struct request *rq)
> -{
> - sector_t frame = rq->sector;
> -
> - ide_debug_log(IDE_DBG_FUNC, "Call %s\n", __func__);
> -
> - sector_div(frame, queue_hardsect_size(drive->queue) >> SECTOR_BITS);
> -
> - memset(rq->cmd, 0, BLK_MAX_CDB);
> - rq->cmd[0] = GPCMD_SEEK;
> - put_unaligned(cpu_to_be32(frame), (unsigned int *) &rq->cmd[2]);
> -
> - rq->timeout = ATAPI_WAIT_PC;
> -}
> -
> -static ide_startstop_t cdrom_start_seek_continuation(ide_drive_t *drive)
> -{
> - struct request *rq = drive->hwif->hwgroup->rq;
> -
> - return cdrom_transfer_packet_command(drive, rq, &cdrom_seek_intr);
> -}
> -
> /*
> * Fix up a possibly partially-processed request so that we can start it over
> * entirely, or even put it back on the request queue.
> @@ -1259,7 +1213,6 @@ static void cdrom_do_block_pc(ide_drive_
> static ide_startstop_t ide_cd_do_request(ide_drive_t *drive, struct request *rq,
> sector_t block)
> {
> - struct cdrom_info *info = drive->driver_data;
> ide_handler_t *fn;
> int xferlen;
>
> @@ -1269,44 +1222,14 @@ static ide_startstop_t ide_cd_do_request
> (unsigned long long)block);
>
> if (blk_fs_request(rq)) {
> - if (drive->atapi_flags & IDE_AFLAG_SEEKING) {
> - ide_hwif_t *hwif = drive->hwif;
> - unsigned long elapsed = jiffies - info->start_seek;
> - int stat = hwif->tp_ops->read_status(hwif);
> -
> - if ((stat & ATA_DSC) != ATA_DSC) {
> - if (elapsed < IDECD_SEEK_TIMEOUT) {
> - ide_stall_queue(drive,
> - IDECD_SEEK_TIMER);
> - return ide_stopped;
> - }
> - printk(KERN_ERR PFX "%s: DSC timeout\n",
> - drive->name);
> - }
> - drive->atapi_flags &= ~IDE_AFLAG_SEEKING;
> - }
> - if (rq_data_dir(rq) == READ &&
> - IDE_LARGE_SEEK(info->last_block, block,
> - IDECD_SEEK_THRESHOLD) &&
> - (drive->dev_flags & IDE_DFLAG_DSC_OVERLAP)) {
> - xferlen = 0;
> - fn = cdrom_start_seek_continuation;
> -
> - drive->dma = 0;
> - info->start_seek = jiffies;
> -
> - ide_cd_prepare_seek_request(drive, rq);
> - } else {
> - xferlen = 32768;
> - fn = cdrom_start_rw_cont;
> + xferlen = 32768;
> + fn = cdrom_start_rw_cont;
>
> - if (cdrom_start_rw(drive, rq) == ide_stopped)
> - return ide_stopped;
> + if (cdrom_start_rw(drive, rq) == ide_stopped)
> + return ide_stopped;
>
> - if (ide_cd_prepare_rw_request(drive, rq) == ide_stopped)
> - return ide_stopped;
> - }
> - info->last_block = block;
> + if (ide_cd_prepare_rw_request(drive, rq) == ide_stopped)
> + return ide_stopped;
> } else if (blk_sense_request(rq) || blk_pc_request(rq) ||
> rq->cmd_type == REQ_TYPE_ATA_PC) {
> xferlen = rq->data_len;
> Index: b/drivers/ide/ide-cd.h
> ===================================================================
> --- a/drivers/ide/ide-cd.h
> +++ b/drivers/ide/ide-cd.h
> @@ -88,8 +88,6 @@ struct cdrom_info {
> struct request_sense sense_data;
>
> struct request request_sense_request;
> - unsigned long last_block;
> - unsigned long start_seek;
>
> u8 max_speed; /* Max speed of the drive. */
> u8 current_speed; /* Current speed of the drive. */
> Index: b/include/linux/ide.h
> ===================================================================
> --- a/include/linux/ide.h
> +++ b/include/linux/ide.h
> @@ -122,8 +122,6 @@ struct ide_io_ports {
> #define MAX_DRIVES 2 /* per interface; 2 assumed by lots of code */
> #define SECTOR_SIZE 512
>
> -#define IDE_LARGE_SEEK(b1,b2,t) (((b1) > (b2) + (t)) || ((b2) > (b1) + (t)))
> -
> /*
> * Timeouts for various operations:
> */
> @@ -496,8 +494,6 @@ enum {
> * when more than one interrupt is needed.
> */
> IDE_AFLAG_LIMIT_NFRAMES = (1 << 7),
> - /* Seeking in progress. */
> - IDE_AFLAG_SEEKING = (1 << 8),
> /* Saved TOC information is current. */
> IDE_AFLAG_TOC_VALID = (1 << 9),
> /* We think that the drive door is locked. */
maybe: = (1 << 8),
--
Regards/Gruss,
Boris.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2008-10-16 19:52 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-10-15 19:47 [PATCH] ide-cd: remove obsolete seek optimization Bartlomiej Zolnierkiewicz
2008-10-16 5:42 ` Borislav Petkov
2008-10-16 19:41 ` Bartlomiej Zolnierkiewicz
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).