diff options
author | Jim Meyering <meyering@redhat.com> | 2010-08-28 17:45:29 +0200 |
---|---|---|
committer | Jim Meyering <meyering@redhat.com> | 2010-08-28 19:28:20 +0200 |
commit | 777024889c0043004962834f4d9353cfa6847dd6 (patch) | |
tree | ab597978663b93ef1134cdcaa57ab921dd1d21f0 /tests/misc | |
parent | c984948ff5db81b760a8a1d9d5d9512754fc30c2 (diff) | |
download | coreutils-777024889c0043004962834f4d9353cfa6847dd6.tar.xz |
tac: avoid double free
* src/tac.c (main): Reading a line longer than 16KiB would cause
tac to realloc its primary buffer. Then, just before exit, tac
would mistakenly free the original (now free'd) buffer.
This bug was introduced by commit be6c13e7, "maint: always free a
buffer, to avoid even semblance of a leak".
* NEWS (Bug fixes): Mention it.
* tests/misc/tac (double-free): New test, to exercise this.
Reported by Salvo Tomaselli in <http://bugs.debian.org/594666>.
Diffstat (limited to 'tests/misc')
-rwxr-xr-x | tests/misc/tac | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/tests/misc/tac b/tests/misc/tac index 763104993..4130c004d 100755 --- a/tests/misc/tac +++ b/tests/misc/tac @@ -24,6 +24,9 @@ my $prog = 'tac'; my $bad_dir = 'no/such/dir'; +# This must be longer than 16KiB to trigger the double free in coreutils-8.5. +my $long_line = 'o' x (16 * 1024 + 1); + my @Tests = ( ['segfault', '-r', {IN=>"a\n"}, {IN=>"b\n"}, {OUT=>"a\nb\n"}], @@ -67,6 +70,9 @@ my @Tests = {ERR_SUBST => "s,`$bad_dir': .*,...,"}, {ERR => "$prog: cannot create temporary file in ...\n"}, {EXIT => 1}], + + # coreutils-8.5's tac would double-free its primary buffer. + ['double-free', {IN=>$long_line}, {OUT=>$long_line}], ); @Tests = triple_test \@Tests; |