From: David Mansfield <lkml@dm.ultramaster.com>
To: Jens Axboe <axboe@suse.de>
Cc: lkml <linux-kernel@vger.kernel.org>
Subject: Re: cdrom changes in test13-pre2 slow down cdrom access by 70%
Date: Tue, 26 Dec 2000 15:51:22 -0500 [thread overview]
Message-ID: <3A4904CA.EA1062AF@dm.ultramaster.com> (raw)
In-Reply-To: <3A43D48D.B1825354@dm.ultramaster.com> <20001223133737.D300@suse.de>
Jens Axboe wrote:
>
> On Fri, Dec 22 2000, David Mansfield wrote:
> > Jens,
> >
> > The cdrom changes that went into test13-pre2 really kill the performance
> > of my cdrom. I'm using cdparanoia to read audio data, and it normally
> > reads at 2-3x. Since test13-pre2 it's down to .6 - .7x. I've reverted
> > the following files to the ones from test13-pre1 and it's back to
> > normal:
>
> Humm, interesting.
>
> > This is a huge patch, is there some way I could break it apart to see
> > what the relevant changes are?
>
> The change affecting you is most likely the CDROMREADAUDIO change,
> where we now just read a single cdda frame at the time. This gives
> us less data per interrupt, and apparently this is more than a
> theoretical slowdown for you. Please try with attached patch. If
> this solves it (as it should), then we should probably try and do
> persistent allocation of a bigger buffer for things like this.
> Grabbing > 1 frame was disabled because multi-page allocation is not
> reliable.
>
> --- drivers/cdrom/cdrom.c~ Sat Dec 23 13:27:33 2000
> +++ drivers/cdrom/cdrom.c Sat Dec 23 13:30:39 2000
> @@ -1985,7 +1985,7 @@
> }
> case CDROMREADAUDIO: {
> struct cdrom_read_audio ra;
> - int lba;
> + int lba, frames;
>
> IOCTL_IN(arg, struct cdrom_read_audio, ra);
>
> @@ -2002,7 +2002,9 @@
> if (lba < 0 || ra.nframes <= 0)
> return -EINVAL;
>
> - if ((cgc.buffer = (char *) kmalloc(CD_FRAMESIZE_RAW, GFP_KERNEL)) == NULL)
> + frames = ra.nframes > 8 ? 8 : ra.nframes;
> +
> + if ((cgc.buffer = (char *) kmalloc(CD_FRAMESIZE_RAW * frames, GFP_KERNEL)) == NULL)
> return -ENOMEM;
>
> if (!access_ok(VERIFY_WRITE, ra.buf, ra.nframes*CD_FRAMESIZE_RAW)) {
> @@ -2011,12 +2013,14 @@
> }
> cgc.data_direction = CGC_DATA_READ;
> while (ra.nframes > 0) {
> - ret = cdrom_read_block(cdi, &cgc, lba, 1, 1, CD_FRAMESIZE_RAW);
> - if (ret) break;
> - __copy_to_user(ra.buf, cgc.buffer, CD_FRAMESIZE_RAW);
> - ra.buf += CD_FRAMESIZE_RAW;
> - ra.nframes--;
> - lba++;
> + ret = cdrom_read_block(cdi, &cgc, lba, frames, 1, CD_FRAMESIZE_RAW);
> + if (ret)
> + break;
> + __copy_to_user(ra.buf, cgc.buffer,
> + CD_FRAMESIZE_RAW * frames);
> + ra.buf += (CD_FRAMESIZE_RAW * frames);
> + ra.nframes -= frames;
> + lba += frames;
> }
> kfree(cgc.buffer);
> return ret;
>
Yes. test13-pre4 + the above patch is back to normal speed. I had
spotted that too as a likely candidate, especially because when the
accesses were slow, the light on the cdrom was blinking at a much higher
rate than before (I suppose it was processing 8x the number of commands,
right?).
Anyway, do you think a 'try to allocate 8, if that fails, try to
allocate 1' solution would be a simple compromise? That should be easy
to do, based on the above code (if kmalloc returns NULL && frames > 1,
frames = 1, retry...).
David
--
David Mansfield (718) 963-2020
david@ultramaster.com
Ultramaster Group, LLC www.ultramaster.com
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
Please read the FAQ at http://www.tux.org/lkml/
next prev parent reply other threads:[~2000-12-26 21:22 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2000-12-22 22:24 cdrom changes in test13-pre2 slow down cdrom access by 70% David Mansfield
2000-12-23 12:37 ` Jens Axboe
2000-12-26 20:51 ` David Mansfield [this message]
2000-12-26 21:47 ` David Mansfield
2000-12-27 5:38 ` Jens Axboe
2000-12-27 16:06 ` David Mansfield
2000-12-27 16:14 ` 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=3A4904CA.EA1062AF@dm.ultramaster.com \
--to=lkml@dm.ultramaster.com \
--cc=axboe@suse.de \
--cc=linux-kernel@vger.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox