Merge branch 'master' of github.com:erg/factor

db4
Doug Coleman 2010-06-17 13:27:44 -05:00
commit c53a11bef9
6 changed files with 20 additions and 13 deletions

View File

@ -5,7 +5,7 @@ BOOTIMAGE_VERSION = latest
!IF DEFINED(PLATFORM) !IF DEFINED(PLATFORM)
LINK_FLAGS = /nologo shell32.lib LINK_FLAGS = /nologo shell32.lib
CL_FLAGS = /nologo /O2 /W3 /D_CRT_SECURE_NO_WARNINGS CL_FLAGS = /nologo /O2 /WX /W3 /D_CRT_SECURE_NO_WARNINGS
!IF DEFINED(DEBUG) !IF DEFINED(DEBUG)
LINK_FLAGS = $(LINK_FLAGS) /DEBUG LINK_FLAGS = $(LINK_FLAGS) /DEBUG

View File

@ -2,7 +2,14 @@ IN: tools.disassembler.udis.tests
USING: tools.disassembler.udis tools.test alien.c-types system combinators kernel ; USING: tools.disassembler.udis tools.test alien.c-types system combinators kernel ;
{ {
{ [ cpu x86.32? ] [ [ 604 ] [ ud heap-size ] unit-test ] } {
[ cpu x86.32? ]
[
os windows?
[ [ 624 ] [ ud heap-size ] unit-test ]
[ [ 604 ] [ ud heap-size ] unit-test ] if
]
}
{ [ cpu x86.64? ] [ [ 672 ] [ ud heap-size ] unit-test ] } { [ cpu x86.64? ] [ [ 672 ] [ ud heap-size ] unit-test ] }
[ ] [ ]
} cond } cond

View File

@ -62,14 +62,14 @@ void context::scrub_stacks(gc_info *info, cell index)
{ {
cell base = info->scrub_d_base(index); cell base = info->scrub_d_base(index);
for(cell loc = 0; loc < info->scrub_d_count; loc++) for(int loc = 0; loc < info->scrub_d_count; loc++)
{ {
if(bitmap_p(bitmap,base + loc)) if(bitmap_p(bitmap,base + loc))
{ {
#ifdef DEBUG_GC_MAPS #ifdef DEBUG_GC_MAPS
std::cout << "scrubbing datastack location " << loc << std::endl; std::cout << "scrubbing datastack location " << loc << std::endl;
#endif #endif
((cell *)datastack)[-loc] = 0; *((cell *)datastack - loc) = 0;
} }
} }
} }
@ -77,14 +77,14 @@ void context::scrub_stacks(gc_info *info, cell index)
{ {
cell base = info->scrub_r_base(index); cell base = info->scrub_r_base(index);
for(cell loc = 0; loc < info->scrub_r_count; loc++) for(int loc = 0; loc < info->scrub_r_count; loc++)
{ {
if(bitmap_p(bitmap,base + loc)) if(bitmap_p(bitmap,base + loc))
{ {
#ifdef DEBUG_GC_MAPS #ifdef DEBUG_GC_MAPS
std::cout << "scrubbing retainstack location " << loc << std::endl; std::cout << "scrubbing retainstack location " << loc << std::endl;
#endif #endif
((cell *)retainstack)[-loc] = 0; *((cell *)retainstack - loc) = 0;
} }
} }
} }

View File

@ -7,7 +7,7 @@ int gc_info::return_address_index(cell return_address)
{ {
u32 *return_address_array = return_addresses(); u32 *return_address_array = return_addresses();
for(cell i = 0; i < return_address_count; i++) for(int i = 0; i < return_address_count; i++)
{ {
if(return_address == return_address_array[i]) if(return_address == return_address_array[i])
return i; return i;

View File

@ -2,10 +2,10 @@ namespace factor
{ {
struct gc_info { struct gc_info {
u32 scrub_d_count; int scrub_d_count;
u32 scrub_r_count; int scrub_r_count;
u32 gc_root_count; int gc_root_count;
u32 return_address_count; int return_address_count;
cell total_bitmap_size() cell total_bitmap_size()
{ {

4
vm/slot_visitor.hpp Normal file → Executable file
View File

@ -303,14 +303,14 @@ struct call_frame_slot_visitor {
cell base = info->spill_slot_base(index); cell base = info->spill_slot_base(index);
cell *stack_pointer = (cell *)(parent->frame_successor(frame) + 1); cell *stack_pointer = (cell *)(parent->frame_successor(frame) + 1);
for(cell spill_slot = 0; spill_slot < info->gc_root_count; spill_slot++) for(int spill_slot = 0; spill_slot < info->gc_root_count; spill_slot++)
{ {
if(bitmap_p(bitmap,base + spill_slot)) if(bitmap_p(bitmap,base + spill_slot))
{ {
#ifdef DEBUG_GC_MAPS #ifdef DEBUG_GC_MAPS
std::cout << "visiting spill slot " << spill_slot << std::endl; std::cout << "visiting spill slot " << spill_slot << std::endl;
#endif #endif
visitor->visit_handle(&stack_pointer[spill_slot]); visitor->visit_handle(stack_pointer + spill_slot);
} }
} }
} }