threaded ls?


From slashdot: Funny. My /bin/ls (Debian unstable) is nearly 60k, yet is dynamically linked, and is even stripped.

% ls -l /bin/ls -rwxr-xr-x 1 root root 59592 Oct 8 20:17 /bin/ls*

% ldd /bin/ls => /lib/ (0x40022000) => /lib/ (0x40034000) => /lib/ (0x40147000) /lib/ => /lib/ (0x40000000)

% file /bin/ls /bin/ls: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), for GNU/Linux 2.2.0, dynamically linked (uses shared libs), stripped

At first glance seeing that ls is linked to libthread brought beads of cold sweat to my brow. After all, ls JUST ISN’T FAST ENOUGH. Clearly, it requires a multithreaded solution. By applying a little more thought to this puzzle, I now believe the one of the other shared libraries (I’m looking at you libc) probably uses it. Any system hackers here care to comment?

[Original post and comments.]