2015-12-10 Richard Biener <rguenther@suse.de>
[official-gcc.git] / boehm-gc / doc / barrett_diagram
blob27e80dc15cd103b5c3ad02a2cc60972370bd2842
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
9                 Data Structure used by GC_base in gc3.7:
10                               21-Apr-94
11                          
12                         
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.
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.
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.               ---   ---
105 DISCARD_WORDS is normally zero.  Indeed the collector has not been tested
106 with another value in ages.