From owner-freebsd-current Tue Nov 24 12:26:24 1998 Return-Path: Received: (from majordom@localhost) by hub.freebsd.org (8.8.8/8.8.8) id MAA02690 for freebsd-current-outgoing; Tue, 24 Nov 1998 12:26:24 -0800 (PST) (envelope-from owner-freebsd-current@FreeBSD.ORG) Received: from wall.polstra.com (rtrwan160.accessone.com [206.213.115.74]) by hub.freebsd.org (8.8.8/8.8.8) with ESMTP id MAA02685 for ; Tue, 24 Nov 1998 12:26:22 -0800 (PST) (envelope-from jdp@polstra.com) Received: from vashon.polstra.com (vashon.polstra.com [206.213.73.13]) by wall.polstra.com (8.9.1/8.9.1) with ESMTP id MAA02303; Tue, 24 Nov 1998 12:26:18 -0800 (PST) (envelope-from jdp@polstra.com) Received: (from jdp@localhost) by vashon.polstra.com (8.9.1/8.9.1) id MAA00962; Tue, 24 Nov 1998 12:26:16 -0800 (PST) (envelope-from jdp@polstra.com) Message-ID: X-Mailer: XFMail 1.3 [p0] on FreeBSD X-Priority: 3 (Normal) Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 8bit MIME-Version: 1.0 In-Reply-To: Date: Tue, 24 Nov 1998 12:26:16 -0800 (PST) Organization: Polstra & Co., Inc. From: John Polstra To: Julian Elischer Subject: Re: Elf linker question. Cc: current@FreeBSD.ORG Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG On 24-Nov-98 Julian Elischer wrote: > I'm not sure that it isn't following too many links.. > I had to add 100 libraries to our makefiles > (usually the same ones) > > Even if we were only using 1 function in a library, it required all the > rest of the libraries in that set, even if they were called from functions > other than the one we were calling. A shared library is fundamentally different from an archive library, in that a shared library is a monolithic object rather than a collection of separate object files. You either load the entire shared library or you don't load any of it. With archive libraries, only the component object files that actually satisfy external references are loaded. Also, the linker really doesn't understand the concept of "functions". It only knows about labels. It doesn't have any idea which function a call to another function appears in. > > I find it hard to believe that all out programs would have worked > > correctly if they were SO wrong! It worked just because none of the functions in the missing libraries were actually called. Maybe they can't possibly be called in your program. But the linker doesn't know that (because there are references to some of them even if those references aren't used). So it has to be safe and force you to satisfy all external references. The a.out linker didn't, and I think it was a bug. John --- John Polstra jdp@polstra.com John D. Polstra & Co., Inc. Seattle, Washington USA "Nobody ever went broke underestimating the taste of the American public." -- H. L. Mencken To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message