[BACK]Return to new_hblk.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib / gc

Annotation of OpenXM_contrib/gc/new_hblk.c, Revision 1.1.1.2

1.1       maekawa     1: /*
                      2:  * Copyright 1988, 1989 Hans-J. Boehm, Alan J. Demers
                      3:  * Copyright (c) 1991-1994 by Xerox Corporation.  All rights reserved.
                      4:  *
                      5:  * THIS MATERIAL IS PROVIDED AS IS, WITH ABSOLUTELY NO WARRANTY EXPRESSED
                      6:  * OR IMPLIED.  ANY USE IS AT YOUR OWN RISK.
                      7:  *
                      8:  * Permission is hereby granted to use or copy this program
                      9:  * for any purpose,  provided the above notices are retained on all copies.
                     10:  * Permission to modify the code and to distribute modified code is granted,
                     11:  * provided the above notices are retained, and a notice that the code was
                     12:  * modified is included with the above copyright notice.
                     13:  *
                     14:  * This file contains the functions:
                     15:  *     ptr_t GC_build_flXXX(h, old_fl)
                     16:  *     void GC_new_hblk(n)
                     17:  */
                     18: /* Boehm, May 19, 1994 2:09 pm PDT */
                     19:
                     20:
                     21: # include <stdio.h>
                     22: # include "gc_priv.h"
                     23:
                     24: #ifndef SMALL_CONFIG
                     25: /*
                     26:  * Build a free list for size 1 objects inside hblk h.  Set the last link to
                     27:  * be ofl.  Return a pointer tpo the first free list entry.
                     28:  */
                     29: ptr_t GC_build_fl1(h, ofl)
                     30: struct hblk *h;
                     31: ptr_t ofl;
                     32: {
                     33:     register word * p = (word *)h;
                     34:     register word * lim = (word *)(h + 1);
                     35:
                     36:     p[0] = (word)ofl;
                     37:     p[1] = (word)(p);
                     38:     p[2] = (word)(p+1);
                     39:     p[3] = (word)(p+2);
                     40:     p += 4;
                     41:     for (; p < lim; p += 4) {
                     42:         p[0] = (word)(p-1);
                     43:         p[1] = (word)(p);
                     44:         p[2] = (word)(p+1);
                     45:         p[3] = (word)(p+2);
                     46:     };
                     47:     return((ptr_t)(p-1));
                     48: }
                     49:
                     50: /* The same for size 2 cleared objects */
                     51: ptr_t GC_build_fl_clear2(h, ofl)
                     52: struct hblk *h;
                     53: ptr_t ofl;
                     54: {
                     55:     register word * p = (word *)h;
                     56:     register word * lim = (word *)(h + 1);
                     57:
                     58:     p[0] = (word)ofl;
                     59:     p[1] = 0;
                     60:     p[2] = (word)p;
                     61:     p[3] = 0;
                     62:     p += 4;
                     63:     for (; p < lim; p += 4) {
                     64:         p[0] = (word)(p-2);
                     65:         p[1] = 0;
                     66:         p[2] = (word)p;
                     67:         p[3] = 0;
                     68:     };
                     69:     return((ptr_t)(p-2));
                     70: }
                     71:
                     72: /* The same for size 3 cleared objects */
                     73: ptr_t GC_build_fl_clear3(h, ofl)
                     74: struct hblk *h;
                     75: ptr_t ofl;
                     76: {
                     77:     register word * p = (word *)h;
                     78:     register word * lim = (word *)(h + 1) - 2;
                     79:
                     80:     p[0] = (word)ofl;
                     81:     p[1] = 0;
                     82:     p[2] = 0;
                     83:     p += 3;
                     84:     for (; p < lim; p += 3) {
                     85:         p[0] = (word)(p-3);
                     86:         p[1] = 0;
                     87:         p[2] = 0;
                     88:     };
                     89:     return((ptr_t)(p-3));
                     90: }
                     91:
                     92: /* The same for size 4 cleared objects */
                     93: ptr_t GC_build_fl_clear4(h, ofl)
                     94: struct hblk *h;
                     95: ptr_t ofl;
                     96: {
                     97:     register word * p = (word *)h;
                     98:     register word * lim = (word *)(h + 1);
                     99:
                    100:     p[0] = (word)ofl;
                    101:     p[1] = 0;
                    102:     p[2] = 0;
                    103:     p[3] = 0;
                    104:     p += 4;
                    105:     for (; p < lim; p += 4) {
1.1.1.2 ! maekawa   106:        PREFETCH_FOR_WRITE(p+64);
1.1       maekawa   107:         p[0] = (word)(p-4);
                    108:         p[1] = 0;
1.1.1.2 ! maekawa   109:        CLEAR_DOUBLE(p+2);
1.1       maekawa   110:     };
                    111:     return((ptr_t)(p-4));
                    112: }
                    113:
                    114: /* The same for size 2 uncleared objects */
                    115: ptr_t GC_build_fl2(h, ofl)
                    116: struct hblk *h;
                    117: ptr_t ofl;
                    118: {
                    119:     register word * p = (word *)h;
                    120:     register word * lim = (word *)(h + 1);
                    121:
                    122:     p[0] = (word)ofl;
                    123:     p[2] = (word)p;
                    124:     p += 4;
                    125:     for (; p < lim; p += 4) {
                    126:         p[0] = (word)(p-2);
                    127:         p[2] = (word)p;
                    128:     };
                    129:     return((ptr_t)(p-2));
                    130: }
                    131:
                    132: /* The same for size 4 uncleared objects */
                    133: ptr_t GC_build_fl4(h, ofl)
                    134: struct hblk *h;
                    135: ptr_t ofl;
                    136: {
                    137:     register word * p = (word *)h;
                    138:     register word * lim = (word *)(h + 1);
                    139:
                    140:     p[0] = (word)ofl;
                    141:     p[4] = (word)p;
                    142:     p += 8;
                    143:     for (; p < lim; p += 8) {
1.1.1.2 ! maekawa   144:        PREFETCH_FOR_WRITE(p+64);
1.1       maekawa   145:         p[0] = (word)(p-4);
                    146:         p[4] = (word)p;
                    147:     };
                    148:     return((ptr_t)(p-4));
                    149: }
                    150:
                    151: #endif /* !SMALL_CONFIG */
                    152:
                    153: /*
                    154:  * Allocate a new heapblock for small objects of size n.
                    155:  * Add all of the heapblock's objects to the free list for objects
                    156:  * of that size.
                    157:  * Set all mark bits if objects are uncollectable.
                    158:  * Will fail to do anything if we are out of memory.
                    159:  */
                    160: void GC_new_hblk(sz, kind)
                    161: register word sz;
                    162: int kind;
                    163: {
                    164:     register word *p,
                    165:                  *prev;
                    166:     word *last_object;         /* points to last object in new hblk    */
                    167:     register struct hblk *h;   /* the new heap block                   */
                    168:     register GC_bool clear = GC_obj_kinds[kind].ok_init;
                    169:
                    170: #   ifdef PRINTSTATS
                    171:        if ((sizeof (struct hblk)) > HBLKSIZE) {
                    172:            ABORT("HBLK SZ inconsistency");
                    173:         }
                    174: #   endif
                    175:
                    176:   /* Allocate a new heap block */
                    177:     h = GC_allochblk(sz, kind, 0);
                    178:     if (h == 0) return;
                    179:
                    180:   /* Mark all objects if appropriate. */
                    181:       if (IS_UNCOLLECTABLE(kind)) GC_set_hdr_marks(HDR(h));
                    182:
1.1.1.2 ! maekawa   183:   PREFETCH_FOR_WRITE((char *)h);
        !           184:   PREFETCH_FOR_WRITE((char *)h + 128);
        !           185:   PREFETCH_FOR_WRITE((char *)h + 256);
        !           186:   PREFETCH_FOR_WRITE((char *)h + 378);
1.1       maekawa   187:   /* Handle small objects sizes more efficiently.  For larger objects  */
                    188:   /* the difference is less significant.                               */
                    189: #  ifndef SMALL_CONFIG
                    190:     switch (sz) {
                    191:         case 1: GC_obj_kinds[kind].ok_freelist[1] =
                    192:                  GC_build_fl1(h, GC_obj_kinds[kind].ok_freelist[1]);
                    193:                return;
                    194:         case 2: if (clear) {
                    195:                    GC_obj_kinds[kind].ok_freelist[2] =
                    196:                      GC_build_fl_clear2(h, GC_obj_kinds[kind].ok_freelist[2]);
                    197:                } else {
                    198:                    GC_obj_kinds[kind].ok_freelist[2] =
                    199:                      GC_build_fl2(h, GC_obj_kinds[kind].ok_freelist[2]);
                    200:                }
                    201:                return;
                    202:         case 3: if (clear) {
                    203:                    GC_obj_kinds[kind].ok_freelist[3] =
                    204:                      GC_build_fl_clear3(h, GC_obj_kinds[kind].ok_freelist[3]);
                    205:                    return;
                    206:                } else {
                    207:                    /* It's messy to do better than the default here. */
                    208:                    break;
                    209:                }
                    210:         case 4: if (clear) {
                    211:                    GC_obj_kinds[kind].ok_freelist[4] =
                    212:                      GC_build_fl_clear4(h, GC_obj_kinds[kind].ok_freelist[4]);
                    213:                } else {
                    214:                    GC_obj_kinds[kind].ok_freelist[4] =
                    215:                      GC_build_fl4(h, GC_obj_kinds[kind].ok_freelist[4]);
                    216:                }
                    217:                return;
                    218:         default:
                    219:                break;
                    220:     }
                    221: #  endif /* !SMALL_CONFIG */
                    222:
                    223:   /* Clear the page if necessary. */
                    224:     if (clear) BZERO(h, HBLKSIZE);
                    225:
                    226:   /* Add objects to free list */
                    227:     p = &(h -> hb_body[sz]);   /* second object in *h  */
                    228:     prev = &(h -> hb_body[0]);         /* One object behind p  */
                    229:     last_object = (word *)((char *)h + HBLKSIZE);
                    230:     last_object -= sz;
                    231:                            /* Last place for last object to start */
                    232:
                    233:   /* make a list of all objects in *h with head as last object */
                    234:     while (p <= last_object) {
                    235:       /* current object's link points to last object */
                    236:         obj_link(p) = (ptr_t)prev;
                    237:        prev = p;
                    238:        p += sz;
                    239:     }
                    240:     p -= sz;                   /* p now points to last object */
                    241:
                    242:   /*
                    243:    * put p (which is now head of list of objects in *h) as first
                    244:    * pointer in the appropriate free list for this size.
                    245:    */
                    246:       obj_link(h -> hb_body) = GC_obj_kinds[kind].ok_freelist[sz];
                    247:       GC_obj_kinds[kind].ok_freelist[sz] = ((ptr_t)p);
                    248: }
                    249:

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