Date: Sun, 25 May 2003 09:03:24 -0400 (EDT) From: "Matthew N. Dodd" <mdodd@FreeBSD.ORG> To: Dag-Erling Smorgrav <des@ofug.org> Cc: current@FreeBSD.ORG Subject: Re: Preliminary ELF prebinding patches available. Message-ID: <20030525084629.R30007@sasami.jurai.net> In-Reply-To: <xzpaddb8ab8.fsf@flood.ping.uio.no> References: <20030525061524.H30007@sasami.jurai.net> <xzpaddb8ab8.fsf@flood.ping.uio.no>
next in thread | previous in thread | raw e-mail | index | archive | help
On Sun, 25 May 2003, Dag-Erling Smorgrav wrote: > "Matthew N. Dodd" <mdodd@FreeBSD.ORG> writes: > > I've implemented per-executable ELF prebinding: > > Could you explain briefly what prebinding does? (This isn't as brief as you or I hoped I suspect.) Relocatable objects (executables and libraries) contain elements that require relocation before the are usable. In some cases this relocation requires symbols to be located and resolved. Resolving these symbols and performing the lookups imposes some execution overhead. By 'prebinding' we can do as much of this work beforehand and speed up the actual relocation process. The short answer is that things like KDE and other library happy executables take a little less time to load. Consider this program: # cat test.c int main (int argc, char *argv[]) { return (0); } # cc -o test test.c # ldd test test: libc.so.5 => /usr/lib/libc.so.5 (0x28076000) ... Using a simple execloop (1000 iterations) and time(1): normal: 0.734u 4.395s 0:07.55 67.8% 13+163k 0+0io 0pf+0w prebind: 0.396u 3.777s 0:05.26 79.0% 16+173k 0+0io 0pf+0w static: 0.000u 0.663s 0:01.06 62.2% 56+186k 0+0io 0pf+0w Now lets link test.c with lots of useless libraries: # cc -Wall -o test test.c -lalias -lasn1 -latm -lbsdxml -lbz2 -lc -lc_r -lcalendar -lcam -lcom_err -lcrypt -lcrypto -ldevinfo -ldevstat -ldialog -ledit -lfetch -lform -lftpio -lg2c -lgeom -lgnuregex -lhistory -lipsec -lipx -lisc -lm -lmd -lmenu -lmilter -lmp -lncp -lncurses -lnetgraph -lopie -lpam -lpanel -lpcap -lradius -lreadline -lroken -lrpcsvc -lsbuf -lsmb -lssh -lssl -lstdc++ -ltacplus -lufs -lugidfw -lusbhid -lutil -lvgl -lwrap -lxpg4 -lypclnt -lz -lkvm (We'll run execloop with only 100 iterations) normal: 14.003u 4.263s 0:23.14 78.9% 5+174k 0+0io 0pf+0w prebind: 1.108u 3.231s 0:05.46 79.3% 6+182k 0+0io 0pf+0w static: 0.000u 0.062s 0:00.15 40.0% 66+229k 0+0io 0pf+0w This is just a quick and dirty example mind you; I should really run things with 10000 iterations and make execloop do its own timing statistics etc. -- | Matthew N. Dodd | '78 Datsun 280Z | '75 Volvo 164E | FreeBSD/NetBSD | | winter@jurai.net | 2 x '84 Volvo 245DL | ix86,sparc,pmax | | http://www.jurai.net/~winter | For Great Justice! | ISO8802.5 4ever |
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20030525084629.R30007>