From 49c810b2c86be0780d2f88bfc2d81f85b4624681 Mon Sep 17 00:00:00 2001 From: pk Date: Mon, 29 Dec 1997 15:36:50 +0000 Subject: [PATCH] Avoid spurious calls to foreign constructors/destructors in case the shared library we link with does not have any of its own. Note: this only works for a.out(5). --- lib/csu/c++/c++rt0.c | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/lib/csu/c++/c++rt0.c b/lib/csu/c++/c++rt0.c index 49e90b5b1e0f..0d6a4df4e2d4 100644 --- a/lib/csu/c++/c++rt0.c +++ b/lib/csu/c++/c++rt0.c @@ -1,4 +1,4 @@ -/* $NetBSD: c++rt0.c,v 1.5 1996/10/18 05:36:49 thorpej Exp $ */ +/* $NetBSD: c++rt0.c,v 1.6 1997/12/29 15:36:50 pk Exp $ */ /* * Copyright (c) 1993 Paul Kranenburg @@ -40,6 +40,18 @@ */ #include + +/* + * We make the __{C,D}TOR_LIST__ symbols appear as type `SETD' and + * include a dummy local function in the set. This keeps references + * to these symbols local to the shared object this module is linked to. + */ +static void dummy __P((void)) { return; } + +/* Note: this is "a.out" dependent. */ +__asm(".stabs \"___CTOR_LIST__\",22,0,0,_dummy"); +__asm(".stabs \"___DTOR_LIST__\",22,0,0,_dummy"); + void (*__CTOR_LIST__[0]) __P((void)); void (*__DTOR_LIST__[0]) __P((void));