3 // gc_info should be kept in sync with:
7 uint32_t scrub_d_count;
8 uint32_t scrub_r_count;
9 uint32_t check_d_count;
10 uint32_t check_r_count;
11 uint32_t gc_root_count;
12 uint32_t derived_root_count;
13 uint32_t return_address_count;
15 cell callsite_bitmap_size() {
24 cell total_bitmap_size() {
25 return return_address_count * callsite_bitmap_size();
28 cell total_bitmap_bytes() { return ((total_bitmap_size() + 7) / 8); }
30 uint32_t* return_addresses() {
31 return (uint32_t*)this - return_address_count;
34 uint32_t* base_pointer_map() {
35 return return_addresses() - return_address_count * derived_root_count;
38 uint8_t* gc_info_bitmap() {
39 return (uint8_t*)base_pointer_map() - total_bitmap_bytes();
42 cell callsite_scrub_d(cell index) {
44 return base + index * scrub_d_count;
47 cell callsite_scrub_r(cell index) {
48 cell base = return_address_count * scrub_d_count;
49 return base + index * scrub_r_count;
52 cell callsite_check_d(cell index) {
54 return_address_count * scrub_d_count +
55 return_address_count * scrub_r_count;
56 return base + index * check_d_count;
59 cell callsite_check_r(cell index) {
61 return_address_count * scrub_d_count +
62 return_address_count * scrub_r_count +
63 return_address_count * check_d_count;
64 return base + index + check_r_count;
67 cell callsite_gc_roots(cell index) {
69 return_address_count * scrub_d_count +
70 return_address_count * scrub_r_count +
71 return_address_count * check_d_count +
72 return_address_count * check_r_count;
73 return base + index * gc_root_count;
76 uint32_t lookup_base_pointer(cell index, cell derived_root) {
77 return base_pointer_map()[index * derived_root_count + derived_root];
80 cell return_address_index(cell return_address);