Annotation of objc/cplus_init.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
        !             3:  *
        !             4:  * @APPLE_LICENSE_HEADER_START@
        !             5:  * 
        !             6:  * "Portions Copyright (c) 1999 Apple Computer, Inc.  All Rights
        !             7:  * Reserved.  This file contains Original Code and/or Modifications of
        !             8:  * Original Code as defined in and that are subject to the Apple Public
        !             9:  * Source License Version 1.0 (the 'License').  You may not use this file
        !            10:  * except in compliance with the License.  Please obtain a copy of the
        !            11:  * License at http://www.apple.com/publicsource and read it before using
        !            12:  * this file.
        !            13:  * 
        !            14:  * The Original Code and all software distributed under the License are
        !            15:  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
        !            16:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
        !            17:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
        !            18:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
        !            19:  * License for the specific language governing rights and limitations
        !            20:  * under the License."
        !            21:  * 
        !            22:  * @APPLE_LICENSE_HEADER_END@
        !            23:  */
        !            24: 
        !            25: #ifndef KERNEL
        !            26: #ifdef SHLIB
        !            27: #include "shlib.h"
        !            28: #endif
        !            29: 
        !            30: #include <libc.h>
        !            31: #include <stdlib.h>
        !            32: #include <mach-o/loader.h>
        !            33: 
        !            34: static void call_constructors (void);
        !            35: static void call_destructors (void);
        !            36: static void call_routines_for_section (const struct mach_header **headers,
        !            37:                                       const char *segment_name,
        !            38:                                       const char *section_name);
        !            39: 
        !            40: /* Perform C++ initialization.  This only works for the MH_EXECUTE and
        !            41:    MH_FVMLIB formats, since the headers must be mapped.
        !            42:    
        !            43:    crt0.o uses the trick of declaring a common symbol with the same name
        !            44:    as this function to call this routine if it is linked in for some other
        !            45:    reason, but without forcing it to be linked in itself. */
        !            46: 
        !            47: void _cplus_init (void)
        !            48: {
        !            49:   /* Each module which contains constructors or destructors should
        !            50:      contain an undefined reference to these symbols to ensure that
        !            51:      this initialization routine is linked in. */
        !            52:   asm (".globl .constructors_used");
        !            53:   asm (".constructors_used = 0");
        !            54:   asm (".globl .destructors_used");
        !            55:   asm (".destructors_used = 0");
        !            56:   
        !            57:   atexit (&call_destructors);
        !            58:   call_constructors ();
        !            59: }
        !            60: 
        !            61: 
        !            62: /* Call the appropriate contructor for each static object in the program. */
        !            63: 
        !            64: static void call_constructors (void)
        !            65: {
        !            66:   const struct mach_header **headers = getmachheaders ();
        !            67: 
        !            68:   call_routines_for_section (headers, "__TEXT", "__constructor");
        !            69:   free (headers);
        !            70: }
        !            71: 
        !            72: 
        !            73: /* Call the appropriate destructor for each static object in the program. */
        !            74: 
        !            75: static void call_destructors (void)
        !            76: {
        !            77:   const struct mach_header **headers = getmachheaders ();
        !            78: 
        !            79:   call_routines_for_section (getmachheaders (), "__TEXT", "__destructor");
        !            80:   free (headers);
        !            81: }
        !            82: 
        !            83: 
        !            84: /* Call the init functions in the specified section of each header.
        !            85:    The section is assumed to contain a sequential list of function pointers.
        !            86:    The functions are called with no arguments, and no return value is
        !            87:    expected. */
        !            88: 
        !            89: static void call_routines_for_section (const struct mach_header **headers,
        !            90:                                       const char *segment_name,
        !            91:                                       const char *section_name)
        !            92: {
        !            93:   unsigned int i;
        !            94:   
        !            95:   if (headers == NULL)
        !            96:     return;
        !            97:   
        !            98:   for (i = 0; headers[i] != NULL; i++)
        !            99:     {
        !           100:       const struct section *section;
        !           101:       void (**init_routines) (void);
        !           102:       unsigned int n, j;
        !           103:       
        !           104:       section = getsectbynamefromheader (headers[i],
        !           105:                                         segment_name,
        !           106:                                         section_name);
        !           107:       
        !           108:       if (section == NULL)
        !           109:         continue;
        !           110:       
        !           111:       init_routines = (void (**) (void)) section->addr;
        !           112:       n = section->size / sizeof (init_routines[0]);
        !           113:       
        !           114:       for (j = 0; j < n; j++)
        !           115:        (*init_routines[j]) ();
        !           116:     }
        !           117: }
        !           118: 
        !           119: #endif /* KERNEL */

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.