* gc.c (rb_objspace_free): With our "lazy-sweep" GC engine, it is
possible for an object to survive until its surrounding object space is about to be freed. Those objects, if any, remains not leaked for the rest of a process life. This is problematic because for instance a T_DATA object may have its own destructor to terminate something. * vm.c (ruby_vm_destruct): ruby_current_vm termination should be somewhere after rb_objspace_free for above reason. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@30065 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
adc978adc3
commit
9d3ba342c9
12
ChangeLog
12
ChangeLog
@ -1,3 +1,15 @@
|
|||||||
|
Fri Dec 3 12:41:52 2010 URABE Shyouhei <shyouhei@ruby-lang.org>
|
||||||
|
|
||||||
|
* gc.c (rb_objspace_free): With our "lazy-sweep" GC engine, it is
|
||||||
|
possible for an object to survive until its surrounding object
|
||||||
|
space is about to be freed. Those objects, if any, remains not
|
||||||
|
leaked for the rest of a process life. This is problematic
|
||||||
|
because for instance a T_DATA object may have its own destructor
|
||||||
|
to terminate something.
|
||||||
|
|
||||||
|
* vm.c (ruby_vm_destruct): ruby_current_vm termination should be
|
||||||
|
somewhere after rb_objspace_free for above reason.
|
||||||
|
|
||||||
Fri Dec 3 12:17:19 2010 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
Fri Dec 3 12:17:19 2010 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
* vm_insnhelper.c (vm_call_method): protected singleton methods should
|
* vm_insnhelper.c (vm_call_method): protected singleton methods should
|
||||||
|
6
gc.c
6
gc.c
@ -400,9 +400,15 @@ rb_objspace_alloc(void)
|
|||||||
return objspace;
|
return objspace;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void gc_sweep(rb_objspace_t *);
|
||||||
|
static void slot_sweep(rb_objspace_t *, struct heaps_slot *);
|
||||||
|
static void gc_clear_mark_on_sweep_slots(rb_objspace_t *);
|
||||||
|
|
||||||
void
|
void
|
||||||
rb_objspace_free(rb_objspace_t *objspace)
|
rb_objspace_free(rb_objspace_t *objspace)
|
||||||
{
|
{
|
||||||
|
gc_clear_mark_on_sweep_slots(objspace);
|
||||||
|
gc_sweep(objspace);
|
||||||
if (objspace->profile.record) {
|
if (objspace->profile.record) {
|
||||||
free(objspace->profile.record);
|
free(objspace->profile.record);
|
||||||
objspace->profile.record = 0;
|
objspace->profile.record = 0;
|
||||||
|
6
vm.c
6
vm.c
@ -1545,14 +1545,14 @@ ruby_vm_destruct(rb_vm_t *vm)
|
|||||||
st_free_table(vm->living_threads);
|
st_free_table(vm->living_threads);
|
||||||
vm->living_threads = 0;
|
vm->living_threads = 0;
|
||||||
}
|
}
|
||||||
rb_vm_gvl_destroy(vm);
|
|
||||||
ruby_xfree(vm);
|
|
||||||
ruby_current_vm = 0;
|
|
||||||
#if defined(ENABLE_VM_OBJSPACE) && ENABLE_VM_OBJSPACE
|
#if defined(ENABLE_VM_OBJSPACE) && ENABLE_VM_OBJSPACE
|
||||||
if (objspace) {
|
if (objspace) {
|
||||||
rb_objspace_free(objspace);
|
rb_objspace_free(objspace);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
rb_vm_gvl_destroy(vm);
|
||||||
|
ruby_xfree(vm);
|
||||||
|
ruby_current_vm = 0;
|
||||||
}
|
}
|
||||||
RUBY_FREE_LEAVE("vm");
|
RUBY_FREE_LEAVE("vm");
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user