X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fgencgc-internal.h;h=bded273239f894b92af485683cb5f617ed33df7e;hb=9b1fade83db8453b75b8c7380eb12ce41b5b889c;hp=c7fb5c52538c3df4f978260681a2f0b45766e9e4;hpb=70769503c505c22bddef3bc7885b91b9d503607f;p=sbcl.git diff --git a/src/runtime/gencgc-internal.h b/src/runtime/gencgc-internal.h index c7fb5c5..bded273 100644 --- a/src/runtime/gencgc-internal.h +++ b/src/runtime/gencgc-internal.h @@ -24,16 +24,39 @@ #include "gencgc-alloc-region.h" #include "genesis/code.h" -#define PAGE_BYTES GENCGC_PAGE_SIZE - void gc_free_heap(void); inline page_index_t find_page_index(void *); inline void *page_address(page_index_t); int gencgc_handle_wp_violation(void *); + +/* Note that this structure is also used from Lisp-side in + * src/code/room.lisp, and the Lisp-side structure layout is currently + * not groveled from C code but hardcoded. Any changes to the + * structure layout need to be also made there. + * + * FIXME: We should probably just define this structure in Lisp, and + * output the C version in genesis. -- JES, 2006-12-30. + */ struct page { + /* The name of this field is not well-chosen for its actual use. + * This is the offset from the start of the page to the start + * of the alloc_region which contains/contained it. It's negative or 0 + */ + long first_object_offset; - unsigned int + /* the number of bytes of this page that are used. This may be less + * than the actual bytes used for pages within the current + * allocation regions. It should be 0 for all unallocated pages (not + * hard to achieve). + */ +#if PAGE_BYTES > USHRT_MAX + unsigned int bytes_used; +#else + unsigned short bytes_used; +#endif + + unsigned /* This is set when the page is write-protected. This should * always reflect the actual write_protect status of a page. * (If the page is written into, we catch the exception, make @@ -55,34 +78,23 @@ struct page { /* If the page is part of a large object then this flag is * set. No other objects should be allocated to these pages. * This is only valid when the page is allocated. */ - large_object :1; + large_object :1, + /* True if the page is known to contain only zeroes. */ + need_to_zero :1; /* the generation that this page belongs to. This should be valid * for all pages that may have objects allocated, even current * allocation region pages - this allows the space of an object to * be easily determined. */ generation_index_t gen; - - /* the number of bytes of this page that are used. This may be less - * than the actual bytes used for pages within the current - * allocation regions. It should be 0 for all unallocated pages (not - * hard to achieve). */ - int bytes_used; - - /* The name of this field is not well-chosen for its actual use. - * This is the offset from the start of the page to the start - * of the alloc_region which contains/contained it. It's negative or 0 - */ - long first_object_offset; }; + /* values for the page.allocated field */ -/* the number of pages needed for the dynamic space - rounding up */ -#define NUM_PAGES ((page_index_t) ((DYNAMIC_SPACE_SIZE+PAGE_BYTES-1)/PAGE_BYTES)) - -extern struct page page_table[NUM_PAGES]; +extern page_index_t page_table_pages; +extern struct page *page_table; /* forward declarations */ @@ -105,7 +117,7 @@ space_matches_p(lispobj obj, generation_index_t space) page_index_t page_index=(void*)obj - (void *)DYNAMIC_SPACE_START; return ((page_index >= 0) && ((page_index = - ((unsigned long)page_index)/PAGE_BYTES) < NUM_PAGES) + ((unsigned long)page_index)/PAGE_BYTES) < page_table_pages) && (page_table[page_index].gen == space)); }