public inbox for gcc-cvs@sourceware.org
help / color / mirror / Atom feed
* [gcc r12-5908] libgcc: vxcrtstuff.c: make ctor/dtor functions static
@ 2021-12-11 13:34 Rasmus Villemoes
  0 siblings, 0 replies; only message in thread
From: Rasmus Villemoes @ 2021-12-11 13:34 UTC (permalink / raw)
  To: gcc-cvs

https://gcc.gnu.org/g:365c7c6ac5400d88816e602f7f9aa12268ba53e3

commit r12-5908-g365c7c6ac5400d88816e602f7f9aa12268ba53e3
Author: Rasmus Villemoes <rasmus.villemoes@prevas.dk>
Date:   Wed Oct 27 12:21:49 2021 +0200

    libgcc: vxcrtstuff.c: make ctor/dtor functions static
    
    When the translation unit itself creates pointers to the ctors/dtors
    in a specific section handled by the linker (whether .init_array or
    .ctors.*), there's no reason for the functions to have external
    linkage. That ends up polluting the symbol table in the running
    kernel.
    
    This makes vxcrtstuff.c on par with the generic crtstuff.c which also
    defines e.g. frame_dummy and __do_global_dtors_aux static.
    
    libgcc/
            * config/vxcrtstuff.c: Make constructor and destructor
            functions static when possible.

Diff:
---
 libgcc/config/vxcrtstuff.c | 10 +++++++---
 1 file changed, 7 insertions(+), 3 deletions(-)

diff --git a/libgcc/config/vxcrtstuff.c b/libgcc/config/vxcrtstuff.c
index 908146d6c99..c15e15e54e9 100644
--- a/libgcc/config/vxcrtstuff.c
+++ b/libgcc/config/vxcrtstuff.c
@@ -66,14 +66,18 @@ __attribute__((section(__LIBGCC_EH_FRAME_SECTION_NAME__), aligned(4)))
 
 #define EH_CTOR_NAME _crtbe_register_frame
 #define EH_DTOR_NAME _ctrbe_deregister_frame
+#define EH_LINKAGE static
 
 #else
 
 /* No specific sections for constructors or destructors: we thus use a
    symbol naming convention so that the constructors are then recognized
-   by munch or whatever tool is used for the final link phase.  */
+   by munch or whatever tool is used for the final link phase.  Since the
+   pointers to the constructor/destructor functions are not created in this
+   translation unit, they must have external linkage.  */
 #define EH_CTOR_NAME _GLOBAL__I_00101_0__crtbe_register_frame
 #define EH_DTOR_NAME _GLOBAL__D_00101_1__crtbe_deregister_frame
+#define EH_LINKAGE
 
 #endif
 
@@ -96,13 +100,13 @@ __attribute__((section(__LIBGCC_EH_FRAME_SECTION_NAME__), aligned(4)))
 
 #endif /* USE_INITFINI_ARRAY  */
 
-EH_CTOR_ATTRIBUTE void EH_CTOR_NAME (void)
+EH_LINKAGE EH_CTOR_ATTRIBUTE void EH_CTOR_NAME (void)
 {
   static struct object object;
   __register_frame_info (__EH_FRAME_BEGIN__, &object);
 }
 
-EH_DTOR_ATTRIBUTE void EH_DTOR_NAME (void)
+EH_LINKAGE EH_DTOR_ATTRIBUTE void EH_DTOR_NAME (void)
 {
   __deregister_frame_info (__EH_FRAME_BEGIN__);
 }


^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2021-12-11 13:34 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-12-11 13:34 [gcc r12-5908] libgcc: vxcrtstuff.c: make ctor/dtor functions static Rasmus Villemoes

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).