mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
merge revision(s) r45291,r45299,r45314,r45325: [Backport #9518]
* ext/dl/cptr.c (dlptr_free), ext/dl/handle.c (dlhandle_free), ext/fiddle/handle.c (fiddle_handle_free), ext/fiddle/pointer.c (fiddle_ptr_free): fix memory leak. based on the patch Heesob Park at [ruby-dev:48021] [Bug #9599]. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_1@45820 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
647b55f64a
commit
acd893d175
11 changed files with 33 additions and 3 deletions
|
@ -1,3 +1,10 @@
|
|||
Mon May 5 02:21:48 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* ext/dl/cptr.c (dlptr_free), ext/dl/handle.c (dlhandle_free),
|
||||
ext/fiddle/handle.c (fiddle_handle_free),
|
||||
ext/fiddle/pointer.c (fiddle_ptr_free): fix memory leak.
|
||||
based on the patch Heesob Park at [ruby-dev:48021] [Bug #9599].
|
||||
|
||||
Mon May 5 01:20:27 2014 Eric Wong <e@80x24.org>
|
||||
|
||||
* gc.c (rb_gc_writebarrier): drop special case for big hash/array
|
||||
|
|
|
@ -49,6 +49,7 @@ dlptr_free(void *ptr)
|
|||
(*(data->free))(data->ptr);
|
||||
}
|
||||
}
|
||||
xfree(ptr);
|
||||
}
|
||||
|
||||
static size_t
|
||||
|
|
|
@ -38,6 +38,7 @@ dlhandle_free(void *ptr)
|
|||
if( dlhandle->ptr && dlhandle->open && dlhandle->enable_close ){
|
||||
dlclose(dlhandle->ptr);
|
||||
}
|
||||
xfree(ptr);
|
||||
}
|
||||
|
||||
static size_t
|
||||
|
|
|
@ -40,6 +40,7 @@ fiddle_handle_free(void *ptr)
|
|||
if( fiddle_handle->ptr && fiddle_handle->open && fiddle_handle->enable_close ){
|
||||
dlclose(fiddle_handle->ptr);
|
||||
}
|
||||
xfree(ptr);
|
||||
}
|
||||
|
||||
static size_t
|
||||
|
|
|
@ -56,6 +56,7 @@ fiddle_ptr_free(void *ptr)
|
|||
(*(data->free))(data->ptr);
|
||||
}
|
||||
}
|
||||
xfree(ptr);
|
||||
}
|
||||
|
||||
static size_t
|
||||
|
|
|
@ -219,4 +219,8 @@ module DL
|
|||
assert_raise(DLError) {nullpo[0] = 1}
|
||||
end
|
||||
end
|
||||
|
||||
def test_no_memory_leak
|
||||
assert_no_memory_leak(%w[-W0 -rdl.so], '', '100_000.times {DL::CPtr.allocate}', rss: true)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -184,4 +184,8 @@ module DL
|
|||
DL.dlopen("/lib/libc.so.7").sym('strcpy')
|
||||
end if /freebsd/=~ RUBY_PLATFORM
|
||||
end
|
||||
|
||||
def test_no_memory_leak
|
||||
assert_no_memory_leak(%w[-W0 -rdl.so], '', '100_000.times {DL::Handle.allocate}; GC.start', rss: true)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
begin
|
||||
require_relative 'helper'
|
||||
require_relative '../ruby/envutil'
|
||||
rescue LoadError
|
||||
end
|
||||
|
||||
|
@ -7,6 +8,8 @@ module Fiddle
|
|||
class TestHandle < TestCase
|
||||
include Fiddle
|
||||
|
||||
include Test::Unit::Assertions
|
||||
|
||||
def test_to_i
|
||||
handle = Fiddle::Handle.new(LIBC_SO)
|
||||
assert_kind_of Integer, handle.to_i
|
||||
|
@ -185,5 +188,9 @@ module Fiddle
|
|||
Socket.gethostbyname("localhost")
|
||||
Fiddle.dlopen("/lib/libc.so.7").sym('strcpy')
|
||||
end if /freebsd/=~ RUBY_PLATFORM
|
||||
|
||||
def test_no_memory_leak
|
||||
assert_no_memory_leak(%w[-W0 -rfiddle.so], '', '100_000.times {Fiddle::Handle.allocate}; GC.start', rss: true)
|
||||
end
|
||||
end
|
||||
end if defined?(Fiddle)
|
||||
|
|
|
@ -230,5 +230,9 @@ module Fiddle
|
|||
assert_raise(DLError) {nullpo[0]}
|
||||
assert_raise(DLError) {nullpo[0] = 1}
|
||||
end
|
||||
|
||||
def test_no_memory_leak
|
||||
assert_no_memory_leak(%w[-W0 -rfiddle.so], '', '100_000.times {Fiddle::Pointer.allocate}', rss: true)
|
||||
end
|
||||
end
|
||||
end if defined?(Fiddle)
|
||||
|
|
|
@ -372,7 +372,7 @@ eom
|
|||
assert_warning(*args) {$VERBOSE = false; yield}
|
||||
end
|
||||
|
||||
def assert_no_memory_leak(args, prepare, code, message=nil, limit: 1.5, **opt)
|
||||
def assert_no_memory_leak(args, prepare, code, message=nil, limit: 1.5, rss: false, **opt)
|
||||
require_relative 'memory_status'
|
||||
token = "\e[7;1m#{$$.to_s}:#{Time.now.strftime('%s.%L')}:#{rand(0x10000).to_s(16)}:\e[m"
|
||||
token_dump = token.dump
|
||||
|
@ -397,7 +397,7 @@ eom
|
|||
before = err.sub!(/^#{token_re}START=(\{.*\})\n/, '') && Memory::Status.parse($1)
|
||||
after = err.sub!(/^#{token_re}FINAL=(\{.*\})\n/, '') && Memory::Status.parse($1)
|
||||
assert_equal([true, ""], [status.success?, err], message)
|
||||
([:size, :rss] & after.members).each do |n|
|
||||
([:size, (rss && :rss)] & after.members).each do |n|
|
||||
b = before[n]
|
||||
a = after[n]
|
||||
next unless a > 0 and b > 0
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
#define RUBY_VERSION "2.1.2"
|
||||
#define RUBY_RELEASE_DATE "2014-05-05"
|
||||
#define RUBY_PATCHLEVEL 90
|
||||
#define RUBY_PATCHLEVEL 91
|
||||
|
||||
#define RUBY_RELEASE_YEAR 2014
|
||||
#define RUBY_RELEASE_MONTH 5
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue