Annotation of OpenXM_contrib/gc/barrett_diagram, Revision 1.1
1.1 ! maekawa 1: This is an ASCII diagram of the data structure used to check pointer
! 2: validity. It was provided by Dave Barrett <barrett@asgard.cs.colorado.edu>,
! 3: and should be of use to others attempting to understand the code.
! 4: The data structure in GC4.X is essentially the same. -HB
! 5:
! 6:
! 7:
! 8:
! 9: Data Structure used by GC_base in gc3.7:
! 10: 21-Apr-94
! 11:
! 12:
! 13:
! 14:
! 15: 63 LOG_TOP_SZ[11] LOG_BOTTOM_SZ[10] LOG_HBLKSIZE[13]
! 16: +------------------+----------------+------------------+------------------+
! 17: p:| | TL_HASH(hi) | | HBLKDISPL(p) |
! 18: +------------------+----------------+------------------+------------------+
! 19: \-----------------------HBLKPTR(p)-------------------/
! 20: \------------hi-------------------/
! 21: \______ ________/ \________ _______/ \________ _______/
! 22: V V V
! 23: | | |
! 24: GC_top_index[] | | |
! 25: --- +--------------+ | | |
! 26: ^ | | | | |
! 27: | | | | | |
! 28: TOP +--------------+<--+ | |
! 29: _SZ +-<| [] | * | |
! 30: (items)| +--------------+ if 0 < bi< HBLKSIZE | |
! 31: | | | | then large object | |
! 32: | | | | starts at the bi'th | |
! 33: v | | | HBLK before p. | i |
! 34: --- | +--------------+ | (word- |
! 35: v | aligned) |
! 36: bi= |GET_BI(p){->hash_link}->key==hi | |
! 37: v | |
! 38: | (bottom_index) \ scratch_alloc'd | |
! 39: | ( struct bi ) / by get_index() | |
! 40: --- +->+--------------+ | |
! 41: ^ | | | |
! 42: ^ | | | |
! 43: BOTTOM | | ha=GET_HDR_ADDR(p) | |
! 44: _SZ(items)+--------------+<----------------------+ +-------+
! 45: | +--<| index[] | |
! 46: | | +--------------+ GC_obj_map: v
! 47: | | | | from / +-+-+-----+-+-+-+-+ ---
! 48: v | | | GC_add < 0| | | | | | | | ^
! 49: --- | +--------------+ _map_entry \ +-+-+-----+-+-+-+-+ |
! 50: | | asc_link | +-+-+-----+-+-+-+-+ MAXOBJSZ
! 51: | +--------------+ +-->| | | j | | | | | +1
! 52: | | key | | +-+-+-----+-+-+-+-+ |
! 53: | +--------------+ | +-+-+-----+-+-+-+-+ |
! 54: | | hash_link | | | | | | | | | | v
! 55: | +--------------+ | +-+-+-----+-+-+-+-+ ---
! 56: | | |<--MAX_OFFSET--->|
! 57: | | (bytes)
! 58: HDR(p)| GC_find_header(p) | |<--MAP_ENTRIES-->|
! 59: | \ from | =HBLKSIZE/WORDSZ
! 60: | (hdr) (struct hblkhdr) / alloc_hdr() | (1024 on Alpha)
! 61: +-->+----------------------+ | (8/16 bits each)
! 62: GET_HDR(p)| word hb_sz (words) | |
! 63: +----------------------+ |
! 64: | struct hblk *hb_next | |
! 65: +----------------------+ |
! 66: |mark_proc hb_mark_proc| |
! 67: +----------------------+ |
! 68: | char * hb_map |>-------------+
! 69: +----------------------+
! 70: | ushort hb_obj_kind |
! 71: +----------------------+
! 72: | hb_last_reclaimed |
! 73: --- +----------------------+
! 74: ^ | |
! 75: MARK_BITS| hb_marks[] | *if hdr is free, hb_sz + DISCARD_WORDS
! 76: _SZ(words)| | is the size of a heap chunk (struct hblk)
! 77: v | | of at least MININCR*HBLKSIZE bytes (below),
! 78: --- +----------------------+ otherwise, size of each object in chunk.
! 79:
! 80: Dynamic data structures above are interleaved throughout the heap in blocks of
! 81: size MININCR * HBLKSIZE bytes as done by gc_scratch_alloc which cannot be
! 82: freed; free lists are used (e.g. alloc_hdr). HBLKs's below are collected.
! 83:
! 84: (struct hblk)
! 85: --- +----------------------+ < HBLKSIZE --- --- DISCARD_
! 86: ^ |garbage[DISCARD_WORDS]| aligned ^ ^ HDR_BYTES WORDS
! 87: | | | | v (bytes) (words)
! 88: | +-----hb_body----------+ < WORDSZ | --- ---
! 89: | | | aligned | ^ ^
! 90: | | Object 0 | | hb_sz |
! 91: | | | i |(word- (words)|
! 92: | | | (bytes)|aligned) v |
! 93: | + - - - - - - - - - - -+ --- | --- |
! 94: | | | ^ | ^ |
! 95: n * | | j (words) | hb_sz BODY_SZ
! 96: HBLKSIZE | Object 1 | v v | (words)
! 97: (bytes) | |--------------- v MAX_OFFSET
! 98: | + - - - - - - - - - - -+ --- (bytes)
! 99: | | | !All_INTERIOR_PTRS ^ |
! 100: | | | sets j only for hb_sz |
! 101: | | Object N | valid object offsets. | |
! 102: v | | All objects WORDSZ v v
! 103: --- +----------------------+ aligned. --- ---
! 104:
! 105: DISCARD_WORDS is normally zero. Indeed the collector has not been tested
! 106: with another value in ages.
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>