[BACK]Return to pcr_interface.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / gc

Annotation of OpenXM_contrib2/asir2000/gc/pcr_interface.c, Revision 1.4

1.1       noro        1: /*
                      2:  * Copyright (c) 1991-1994 by Xerox Corporation.  All rights reserved.
                      3:  *
                      4:  * THIS MATERIAL IS PROVIDED AS IS, WITH ABSOLUTELY NO WARRANTY EXPRESSED
                      5:  * OR IMPLIED.  ANY USE IS AT YOUR OWN RISK.
                      6:  *
                      7:  * Permission is hereby granted to use or copy this program
                      8:  * for any purpose,  provided the above notices are retained on all copies.
                      9:  * Permission to modify the code and to distribute modified code is granted,
                     10:  * provided the above notices are retained, and a notice that the code was
                     11:  * modified is included with the above copyright notice.
                     12:  */
1.2       noro       13: # include "private/gc_priv.h"
1.1       noro       14:
                     15: # ifdef PCR
                     16: /*
                     17:  * Note that POSIX PCR requires an ANSI C compiler.  Hence we are allowed
                     18:  * to make the same assumption here.
                     19:  * We wrap all of the allocator functions to avoid questions of
                     20:  * compatibility between the prototyped and nonprototyped versions of the f
                     21:  */
                     22: # include "config/PCR_StdTypes.h"
                     23: # include "mm/PCR_MM.h"
                     24: # include <errno.h>
                     25:
                     26: # define MY_MAGIC 17L
                     27: # define MY_DEBUGMAGIC 42L
                     28:
                     29: void * GC_AllocProc(size_t size, PCR_Bool ptrFree, PCR_Bool clear )
                     30: {
                     31:     if (ptrFree) {
                     32:         void * result = (void *)GC_malloc_atomic(size);
                     33:         if (clear && result != 0) BZERO(result, size);
                     34:         return(result);
                     35:     } else {
                     36:         return((void *)GC_malloc(size));
                     37:     }
                     38: }
                     39:
                     40: void * GC_DebugAllocProc(size_t size, PCR_Bool ptrFree, PCR_Bool clear )
                     41: {
                     42:     if (ptrFree) {
                     43:         void * result = (void *)GC_debug_malloc_atomic(size, __FILE__,
                     44:                                                             __LINE__);
                     45:         if (clear && result != 0) BZERO(result, size);
                     46:         return(result);
                     47:     } else {
                     48:         return((void *)GC_debug_malloc(size, __FILE__, __LINE__));
                     49:     }
                     50: }
                     51:
                     52: # define GC_ReallocProc GC_realloc
                     53: void * GC_DebugReallocProc(void * old_object, size_t new_size_in_bytes)
                     54: {
                     55:     return(GC_debug_realloc(old_object, new_size_in_bytes, __FILE__, __LINE__));
                     56: }
                     57:
                     58: # define GC_FreeProc GC_free
                     59: # define GC_DebugFreeProc GC_debug_free
                     60:
                     61: typedef struct {
                     62:   PCR_ERes (*ed_proc)(void *p, size_t size, PCR_Any data);
                     63:   GC_bool ed_pointerfree;
                     64:   PCR_ERes ed_fail_code;
                     65:   PCR_Any ed_client_data;
                     66: } enumerate_data;
                     67:
                     68: void GC_enumerate_block(h, ed)
                     69: register struct hblk *h;
                     70: enumerate_data * ed;
                     71: {
                     72:     register hdr * hhdr;
                     73:     register int sz;
                     74:     word *p;
                     75:     word * lim;
                     76:
                     77:     hhdr = HDR(h);
                     78:     sz = hhdr -> hb_sz;
                     79:     if (sz >= 0 && ed -> ed_pointerfree
                     80:        || sz <= 0 && !(ed -> ed_pointerfree)) return;
                     81:     if (sz < 0) sz = -sz;
                     82:     lim = (word *)(h+1) - sz;
                     83:     p = (word *)h;
                     84:     do {
                     85:         if (PCR_ERes_IsErr(ed -> ed_fail_code)) return;
                     86:         ed -> ed_fail_code =
                     87:             (*(ed -> ed_proc))(p, WORDS_TO_BYTES(sz), ed -> ed_client_data);
                     88:         p+= sz;
                     89:     } while (p <= lim);
                     90: }
                     91:
                     92: struct PCR_MM_ProcsRep * GC_old_allocator = 0;
                     93:
                     94: PCR_ERes GC_EnumerateProc(
                     95:     PCR_Bool ptrFree,
                     96:     PCR_ERes (*proc)(void *p, size_t size, PCR_Any data),
                     97:     PCR_Any data
                     98: )
                     99: {
                    100:     enumerate_data ed;
                    101:
                    102:     ed.ed_proc = proc;
                    103:     ed.ed_pointerfree = ptrFree;
                    104:     ed.ed_fail_code = PCR_ERes_okay;
                    105:     ed.ed_client_data = data;
                    106:     GC_apply_to_all_blocks(GC_enumerate_block, &ed);
                    107:     if (ed.ed_fail_code != PCR_ERes_okay) {
                    108:         return(ed.ed_fail_code);
                    109:     } else {
                    110:        /* Also enumerate objects allocated by my predecessors */
                    111:        return((*(GC_old_allocator->mmp_enumerate))(ptrFree, proc, data));
                    112:     }
                    113: }
                    114:
                    115: void GC_DummyFreeProc(void *p) {}
                    116:
                    117: void GC_DummyShutdownProc(void) {}
                    118:
                    119: struct PCR_MM_ProcsRep GC_Rep = {
                    120:        MY_MAGIC,
                    121:        GC_AllocProc,
                    122:        GC_ReallocProc,
                    123:        GC_DummyFreeProc,       /* mmp_free */
                    124:        GC_FreeProc,            /* mmp_unsafeFree */
                    125:        GC_EnumerateProc,
                    126:        GC_DummyShutdownProc    /* mmp_shutdown */
                    127: };
                    128:
                    129: struct PCR_MM_ProcsRep GC_DebugRep = {
                    130:        MY_DEBUGMAGIC,
                    131:        GC_DebugAllocProc,
                    132:        GC_DebugReallocProc,
                    133:        GC_DummyFreeProc,       /* mmp_free */
                    134:        GC_DebugFreeProc,               /* mmp_unsafeFree */
                    135:        GC_EnumerateProc,
                    136:        GC_DummyShutdownProc    /* mmp_shutdown */
                    137: };
                    138:
                    139: GC_bool GC_use_debug = 0;
                    140:
                    141: void GC_pcr_install()
                    142: {
                    143:     PCR_MM_Install((GC_use_debug? &GC_DebugRep : &GC_Rep), &GC_old_allocator);
                    144: }
                    145:
                    146: PCR_ERes
                    147: PCR_GC_Setup(void)
                    148: {
                    149:     return PCR_ERes_okay;
                    150: }
                    151:
                    152: PCR_ERes
                    153: PCR_GC_Run(void)
                    154: {
                    155:
                    156:     if( !PCR_Base_TestPCRArg("-nogc") ) {
                    157:         GC_quiet = ( PCR_Base_TestPCRArg("-gctrace") ? 0 : 1 );
                    158:         GC_use_debug = (GC_bool)PCR_Base_TestPCRArg("-debug_alloc");
                    159:         GC_init();
                    160:         if( !PCR_Base_TestPCRArg("-nogc_incremental") ) {
                    161:             /*
                    162:              * awful hack to test whether VD is implemented ...
                    163:              */
                    164:             if( PCR_VD_Start( 0, NIL, 0) != PCR_ERes_FromErr(ENOSYS) ) {
                    165:                GC_enable_incremental();
                    166:            }
                    167:        }
                    168:     }
                    169:     return PCR_ERes_okay;
1.2       noro      170: }
                    171:
                    172: void GC_push_thread_structures(void)
                    173: {
                    174:     /* PCR doesn't work unless static roots are pushed.  Can't get here. */
                    175:     ABORT("In GC_push_thread_structures()");
1.1       noro      176: }
                    177:
                    178: # endif

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>