Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 03 Jan 2005 11:54:39 -0800
From:      Sean McNeil <sean@mcneil.com>
To:        =?ISO-8859-1?Q?S=F8ren?= Schmidt <sos@DeepCore.dk>
Cc:        Nate Lawson <nate@root.org>
Subject:   Re: ATA rman performance enhancement
Message-ID:  <1104782079.66465.3.camel@server.mcneil.com>
In-Reply-To: <41D99FBD.8070500@DeepCore.dk>
References:  <41D984A5.7010408@root.org>  <41D99FBD.8070500@DeepCore.dk>

next in thread | previous in thread | raw e-mail | index | archive | help

--=-mrEFAHAisOBjKry4LOtG
Content-Type: text/plain; charset=ISO-8859-1
Content-Transfer-Encoding: quoted-printable

On Mon, 2005-01-03 at 20:40 +0100, S=F8ren Schmidt wrote:
> Nate Lawson wrote:
> > While doing some benchmarking of other code, I noticed that there were =
a=20
> > lot of calls to rman_get_bustag/handle().  They weren't taking up much=20
> > actual time since they're pretty lightweight but seemed to be unnecessa=
ry.
> >=20
> > I worked up the attached diff and benchmarked it.  There are about 1000=
=20
> > calls a second to the rman routines without this patch and essentially=20
> > none with it.  It makes about a 1% difference in throughput under some=20
> > IO loads.  It is only for non-Promise or non-SII controllers right now=20
> > since I didn't extend the initialization step to more than ata-pci.c.=20
> > The same approach could be used for the other INW/OUTW calls as well bu=
t=20
> > they're not in the fast path.  I think it may make more of a difference=
=20
> > with small reads.
> >=20
> > Feel free to test, cleanup, and commit.
>=20
> I had something semilar to this once back when, but since HW got lots=20
> faster I couldn't measure it anymore, but maybe things has changed...
>=20
> Anyhow it needs to be applied to ata-isa.c ata-card.c ata-cbus.c etc to=20
> not break anything at least. I'll think about it and eventually do=20
> something about it in ATA-mkIII if it really is mesureable again..

I would suggest that it be done even if it isn't measurable.  If you do
not need to call a function all the time like that, then where is the
harm in doing it more efficiently?  The added memory storage for this is
more than made up by its usefulness.

Cheers,
Sean


--=-mrEFAHAisOBjKry4LOtG
Content-Type: application/pgp-signature; name=signature.asc
Content-Description: This is a digitally signed message part

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.0 (FreeBSD)

iD8DBQBB2aL/yQsGN30uGE4RAvl5AJ9+d/J1LciFXGXgxGbC2+MOx+vRpwCfUJUc
BS428I1NAjGVn06RVH3/MG0=
=WAOE
-----END PGP SIGNATURE-----

--=-mrEFAHAisOBjKry4LOtG--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?1104782079.66465.3.camel>