Ignore:
Timestamp:
Dec 18, 2011, 10:28:22 PM (14 years ago)
Author:
dmik
Message:

Merge branch gcc-kmk to trunk.

Location:
trunk
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk

    • Property svn:ignore
      •  

        old new  
        1 bin
        2 Makefile.inc
         1env.cmd
         2LocalConfig.kmk
    • Property svn:mergeinfo set to
      /branches/gcc-kmkmergedeligible
  • trunk/src/imagehlp/initterm.cpp

    r6646 r21916  
    11/* $Id: initterm.cpp,v 1.7 2001-09-05 12:55:49 bird Exp $
    22 *
    3  * DLL entry point
     3 * IMAGEHLP DLL entry point
    44 *
    55 * Copyright 1998 Sander van Leeuwen
    66 * Copyright 1998 Peter Fitzsimmons
    77 *
    8  *
    98 * Project Odin Software License can be found in LICENSE.TXT
    10  *
    119 */
    1210
    13 /*-------------------------------------------------------------*/
    14 /* INITERM.C -- Source for a custom dynamic link library       */
    15 /*              initialization and termination (_DLL_InitTerm) */
    16 /*              function.                                      */
    17 /*                                                             */
    18 /* When called to perform initialization, this sample function */
    19 /* gets storage for an array of integers, and initializes its  */
    20 /* elements with random integers.  At termination time, it     */
    21 /* frees the array.  Substitute your own special processing.   */
    22 /*-------------------------------------------------------------*/
    23 
    24 
    25 /* Include files */
    2611#define  INCL_DOSMODULEMGR
    2712#define  INCL_DOSPROCESS
     
    3722#include <initdll.h>
    3823
    39 extern "C" {
    40  //Win32 resource table (produced by wrc)
    41  extern DWORD _Resource_PEResTab;
    42 }
     24// Win32 resource table (produced by wrc)
     25extern DWORD imagehlp_PEResTab;
     26
    4327static HMODULE dllHandle = 0;
    4428
    4529BOOL WINAPI IMAGEHLP_LibMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved);
    4630
    47 //******************************************************************************
    48 //******************************************************************************
    4931BOOL WINAPI LibMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID fImpLoad)
    5032{
    51    switch (fdwReason)
    52    {
    53    case DLL_PROCESS_ATTACH:
    54    case DLL_THREAD_ATTACH:
    55    case DLL_THREAD_DETACH:
    56     return IMAGEHLP_LibMain(hinstDLL, fdwReason, fImpLoad);
     33    switch (fdwReason)
     34    {
     35    case DLL_PROCESS_ATTACH:
     36    case DLL_THREAD_ATTACH:
     37    case DLL_THREAD_DETACH:
     38        return IMAGEHLP_LibMain(hinstDLL, fdwReason, fImpLoad);
    5739
    58    case DLL_PROCESS_DETACH:
    59     IMAGEHLP_LibMain(hinstDLL, fdwReason, fImpLoad);
    60     ctordtorTerm();
    61     return TRUE;
    62    }
    63    return FALSE;
     40    case DLL_PROCESS_DETACH:
     41        IMAGEHLP_LibMain(hinstDLL, fdwReason, fImpLoad);
     42#ifdef __IBMC__
     43        ctordtorTerm();
     44#endif
     45        return TRUE;
     46    }
     47    return FALSE;
    6448}
    65 /****************************************************************************/
    66 /* _DLL_InitTerm is the function that gets called by the operating system   */
    67 /* loader when it loads and frees this DLL for each process that accesses   */
    68 /* this DLL.  However, it only gets called the first time the DLL is loaded */
    69 /* and the last time it is freed for a particular process.  The system      */
    70 /* linkage convention MUST be used because the operating system loader is   */
    71 /* calling this function.                                                   */
    72 /****************************************************************************/
    73 unsigned long SYSTEM _DLL_InitTerm(unsigned long hModule, unsigned long
    74                                    ulFlag)
     49
     50ULONG SYSTEM DLL_InitImageHlp(ULONG hModule)
    7551{
    76    size_t i;
    77    APIRET rc;
     52    CheckVersionFromHMOD(PE2LX_VERSION, hModule); /*PLF Wed  98-03-18 05:28:48*/
    7853
    79    /*-------------------------------------------------------------------------*/
    80    /* If ulFlag is zero then the DLL is being loaded so initialization should */
    81    /* be performed.  If ulFlag is 1 then the DLL is being freed so            */
    82    /* termination should be performed.                                        */
    83    /*-------------------------------------------------------------------------*/
     54    dllHandle = RegisterLxDll(hModule, LibMain, (PVOID)&imagehlp_PEResTab);
     55    if(dllHandle == 0)
     56        return -1;
    8457
    85    switch (ulFlag) {
    86       case 0 :
    87          ctordtorInit();
     58    return 0;
     59}
    8860
    89          CheckVersionFromHMOD(PE2LX_VERSION, hModule); /*PLF Wed  98-03-18 05:28:48*/
     61void SYSTEM DLL_TermImageHlp(ULONG hModule)
     62{
     63    if (dllHandle)
     64       UnregisterLxDll(dllHandle);
     65}
    9066
    91      dllHandle = RegisterLxDll(hModule, LibMain, (PVOID)&_Resource_PEResTab);
    92          if(dllHandle == 0)
    93         return 0UL;
     67ULONG SYSTEM DLL_Init(ULONG hModule)
     68{
     69    if (DLL_InitDefault(hModule) == -1)
     70        return -1;
     71    return DLL_InitImageHlp(hModule);
     72}
    9473
    95          break;
    96       case 1 :
    97          if(dllHandle) {
    98         UnregisterLxDll(dllHandle);
    99          }
    100          break;
    101 
    102       default  :
    103          return 0UL;
    104    }
    105 
    106    /***********************************************************/
    107    /* A non-zero value must be returned to indicate success.  */
    108    /***********************************************************/
    109    return 1UL;
     74void SYSTEM DLL_Term(ULONG hModule)
     75{
     76    DLL_TermImageHlp(hModule);
     77    DLL_TermDefault(hModule);
    11078}
    111 //******************************************************************************
    112 //******************************************************************************
Note: See TracChangeset for help on using the changeset viewer.