Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932242AbVKUOxj (ORCPT ); Mon, 21 Nov 2005 09:53:39 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S932316AbVKUOxj (ORCPT ); Mon, 21 Nov 2005 09:53:39 -0500 Received: from ns.virtualhost.dk ([195.184.98.160]:5145 "EHLO virtualhost.dk") by vger.kernel.org with ESMTP id S932242AbVKUOxi (ORCPT ); Mon, 21 Nov 2005 09:53:38 -0500 Date: Mon, 21 Nov 2005 15:54:46 +0100 From: Jens Axboe To: Brice Goglin Cc: Linus Torvalds , LKML , Andrew Morton Subject: Re: Linux 2.6.14: Badness in as-iosched Message-ID: <20051121145446.GA15804@suse.de> References: <4373C042.3060901@ens-lyon.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <4373C042.3060901@ens-lyon.org> Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2401 Lines: 88 On Thu, Nov 10 2005, Brice Goglin wrote: > Hi Jens, > > I just hit a badness (actually, tons of badness like this) in as-iosched > while ripping > an audio CD with ripperX (with cdparanoia as a backend). > I was using 2.6.14 on an IBM Thinkpad R52. The kernel has been compiled with > gcc-4.0.2-2 (Debian testing). > > The first badness in dmesg is: > > cdrom: dropping to single frame dma > arq->state: 4 > Badness in as_insert_request at drivers/block/as-iosched.c:1519 > [] as_insert_request+0x70/0x1d0 > [] __elv_add_request+0xa5/0xe0 > [] elv_add_request+0x2b/0x40 > [] blk_execute_rq_nowait+0x46/0x60 > [] blk_execute_rq+0x7a/0xe0 > [] blk_end_sync_rq+0x0/0x30 > [] bio_phys_segments+0x27/0x30 > [] blk_rq_bio_prep+0x40/0xb0 > [] blk_rq_map_user+0xb7/0xf0 > [] cdrom_read_cdda_bpc+0x182/0x210 > [] cdrom_read_cdda+0x5b/0xc0 Similar case was posted yesterday (I realize yours is older, just missed it the first time around), see my explanation here: http://lkml.org/lkml/2005/11/20/119 And work-around below. diff --git a/drivers/cdrom/cdrom.c b/drivers/cdrom/cdrom.c index 1539603..7540d27 100644 --- a/drivers/cdrom/cdrom.c +++ b/drivers/cdrom/cdrom.c @@ -2089,7 +2089,7 @@ static int cdrom_read_cdda_bpc(struct cd int lba, int nframes) { request_queue_t *q = cdi->disk->queue; - struct request *rq; + struct request *rq = NULL; struct bio *bio; unsigned int len; int nr, ret = 0; @@ -2097,13 +2097,13 @@ static int cdrom_read_cdda_bpc(struct cd if (!q) return -ENXIO; - rq = blk_get_request(q, READ, GFP_KERNEL); - if (!rq) - return -ENOMEM; - cdi->last_sense = 0; while (nframes) { + rq = blk_get_request(q, READ, GFP_KERNEL); + if (!rq) + return -ENOMEM; + nr = nframes; if (cdi->cdda_method == CDDA_BPC_SINGLE) nr = 1; @@ -2151,9 +2151,13 @@ static int cdrom_read_cdda_bpc(struct cd nframes -= nr; lba += nr; ubuf += len; + blk_put_request(rq); + rq = NULL; } - blk_put_request(rq); + if (rq) + blk_put_request(rq); + return ret; } -- Jens Axboe - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/