From: Benjamin Herrenschmidt <benh@kernel.crashing.org>
To: Tejun Heo <tj@kernel.org>
Cc: axboe@kernel.dk, linux-kernel@vger.kernel.org,
donari75@gmail.com, bzolnier@gmail.com, joerg@dorchain.net,
geert@linux-m68k.org, davem@davemloft.net, jdike@linux.intel.com,
Laurent@lvivier.info
Subject: Re: [PATCH 09/14] swim3: clean up request completion paths
Date: Tue, 28 Apr 2009 16:44:50 +1000 [thread overview]
Message-ID: <1240901090.9924.2.camel@pasglop> (raw)
In-Reply-To: <1240891577-4813-10-git-send-email-tj@kernel.org>
On Tue, 2009-04-28 at 13:06 +0900, Tejun Heo wrote:
> swim3 curiously tries to update request parameters before calling
> __blk_end_request() when __blk_end_request() will do it anyway, and it
> updates request for partial completion manually instead of using
> blk_update_request(). Also, it does some spurious checks on rq such
> as testing whether rq->sector is negative or current_nr_sectors is
> zero right after fetching.
>
> Drop unnecessary stuff and use standard block layer mechanisms.
That smells like historical stuff from floppy.c :-)
I'll try to dig a mac with a floppy drive to test that.
Cheers,
Ben.
> [ Impact: cleanup ]
>
> Signed-off-by: Tejun Heo <tj@kernel.org>
> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
> ---
> drivers/block/swim3.c | 31 +++++--------------------------
> 1 files changed, 5 insertions(+), 26 deletions(-)
>
> diff --git a/drivers/block/swim3.c b/drivers/block/swim3.c
> index 5904f7b..4248559 100644
> --- a/drivers/block/swim3.c
> +++ b/drivers/block/swim3.c
> @@ -319,14 +319,10 @@ static void start_request(struct floppy_state *fs)
> req->errors, req->current_nr_sectors);
> #endif
>
> - if (req->sector < 0 || req->sector >= fs->total_secs) {
> + if (req->sector >= fs->total_secs) {
> __blk_end_request_cur(req, -EIO);
> continue;
> }
> - if (req->current_nr_sectors == 0) {
> - __blk_end_request_cur(req, 0);
> - continue;
> - }
> if (fs->ejected) {
> __blk_end_request_cur(req, -EIO);
> continue;
> @@ -593,8 +589,6 @@ static void xfer_timeout(unsigned long data)
> struct floppy_state *fs = (struct floppy_state *) data;
> struct swim3 __iomem *sw = fs->swim3;
> struct dbdma_regs __iomem *dr = fs->dma;
> - struct dbdma_cmd *cp = fs->dma_cmd;
> - unsigned long s;
> int n;
>
> fs->timeout_pending = 0;
> @@ -605,14 +599,6 @@ static void xfer_timeout(unsigned long data)
> out_8(&sw->intr_enable, 0);
> out_8(&sw->control_bic, WRITE_SECTORS | DO_ACTION);
> out_8(&sw->select, RELAX);
> - if (rq_data_dir(fd_req) == WRITE)
> - ++cp;
> - if (ld_le16(&cp->xfer_status) != 0)
> - s = fs->scount - ((ld_le16(&cp->res_count) + 511) >> 9);
> - else
> - s = 0;
> - fd_req->sector += s;
> - fd_req->current_nr_sectors -= s;
> printk(KERN_ERR "swim3: timeout %sing sector %ld\n",
> (rq_data_dir(fd_req)==WRITE? "writ": "read"), (long)fd_req->sector);
> __blk_end_request_cur(fd_req, -EIO);
> @@ -719,9 +705,7 @@ static irqreturn_t swim3_interrupt(int irq, void *dev_id)
> if (intr & ERROR_INTR) {
> n = fs->scount - 1 - resid / 512;
> if (n > 0) {
> - fd_req->sector += n;
> - fd_req->current_nr_sectors -= n;
> - fd_req->buffer += n * 512;
> + blk_update_request(fd_req, 0, n << 9);
> fs->req_sector += n;
> }
> if (fs->retries < 5) {
> @@ -745,13 +729,7 @@ static irqreturn_t swim3_interrupt(int irq, void *dev_id)
> start_request(fs);
> break;
> }
> - fd_req->sector += fs->scount;
> - fd_req->current_nr_sectors -= fs->scount;
> - fd_req->buffer += fs->scount * 512;
> - if (fd_req->current_nr_sectors <= 0) {
> - __blk_end_request_cur(fd_req, 0);
> - fs->state = idle;
> - } else {
> + if (__blk_end_request(fd_req, 0, fs->scount << 9)) {
> fs->req_sector += fs->scount;
> if (fs->req_sector > fs->secpertrack) {
> fs->req_sector -= fs->secpertrack;
> @@ -761,7 +739,8 @@ static irqreturn_t swim3_interrupt(int irq, void *dev_id)
> }
> }
> act(fs);
> - }
> + } else
> + fs->state = idle;
> }
> if (fs->state == idle)
> start_request(fs);
next prev parent reply other threads:[~2009-04-28 6:46 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-04-28 4:06 [GIT PATCH linux-2.6-block#for-2.6.31] block: lld cleanup patches, take#2 Tejun Heo
2009-04-28 4:06 ` [PATCH 01/14] block: make blk_end_request_cur() return bool Tejun Heo
2009-04-28 4:06 ` [PATCH 02/14] block: don't init rq fields unnecessarily Tejun Heo
2009-04-28 4:06 ` [PATCH 03/14] amiflop,ataflop,xd,mg_disk: clean up unnecessary stuff from block drivers Tejun Heo
2009-04-28 4:06 ` [PATCH 04/14] ps3disk: simplify request completion Tejun Heo
2009-04-28 4:06 ` [PATCH 05/14] sunvdc: kill vdc_end_request() Tejun Heo
2009-04-28 4:06 ` [PATCH 06/14] ubd: cleanup completion path Tejun Heo
2009-04-28 4:06 ` [PATCH 07/14] ubd: drop unnecessary rq->sector manipulation Tejun Heo
2009-04-28 4:06 ` [PATCH 08/14] hd: clean up request completion paths Tejun Heo
2009-04-28 4:06 ` [PATCH 09/14] swim3: " Tejun Heo
2009-04-28 6:44 ` Benjamin Herrenschmidt [this message]
2009-04-28 4:06 ` [PATCH 10/14] swim: " Tejun Heo
2009-04-28 4:06 ` [PATCH 11/14] mg_disk: fold mg_disk.h into mg_disk.c Tejun Heo
2009-04-28 4:06 ` [PATCH 12/14] mg_disk: clean up request completion paths Tejun Heo
2009-04-28 4:06 ` [PATCH 13/14] mg_disk: fix dependency on libata Tejun Heo
2009-04-28 4:06 ` [PATCH 14/14] mg_disk: use defines from <linux/ata.h> Tejun Heo
2009-04-28 6:15 ` [GIT PATCH linux-2.6-block#for-2.6.31] block: lld cleanup patches, take#2 Jens Axboe
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1240901090.9924.2.camel@pasglop \
--to=benh@kernel.crashing.org \
--cc=Laurent@lvivier.info \
--cc=axboe@kernel.dk \
--cc=bzolnier@gmail.com \
--cc=davem@davemloft.net \
--cc=donari75@gmail.com \
--cc=geert@linux-m68k.org \
--cc=jdike@linux.intel.com \
--cc=joerg@dorchain.net \
--cc=linux-kernel@vger.kernel.org \
--cc=tj@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.