mirror of
https://github.com/Zenithsiz/ftmemsim-valgrind.git
synced 2026-02-03 18:13:01 +00:00
500 lines
19 KiB
Plaintext
500 lines
19 KiB
Plaintext
|
|
Unstable (cvs head) release 2.1.1 (12 March 2004)
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
2.1.1 contains some internal structure changes needed for V's
|
|
long-term future. These don't affect end-users. Most notable
|
|
user-visible changes are:
|
|
|
|
* Greater isolation between Valgrind and the program being run, so
|
|
the program is less likely to inadvertently kill Valgrind by
|
|
doing wild writes.
|
|
|
|
* Massif: a new space profiling tool. Try it! It's cool, and it'll
|
|
tell you in detail where and when your C/C++ code is allocating heap.
|
|
Draws pretty .ps pictures of memory use against time. A potentially
|
|
powerful tool for making sense of your program's space use.
|
|
|
|
* Fixes for many bugs, including support for more SSE2/SSE3 instructions,
|
|
various signal/syscall things, and various problems with debug
|
|
info readers.
|
|
|
|
* Support for glibc-2.3.3 based systems.
|
|
|
|
We are now doing automatic overnight build-and-test runs on a variety
|
|
of distros. As a result, we believe 2.1.1 builds and runs on:
|
|
Red Hat 7.2, 7.3, 8.0, 9, Fedora Core 1, SuSE 8.2, SuSE 9.
|
|
|
|
|
|
The following bugs, and probably many more, have been fixed. These
|
|
are listed at http://bugs.kde.org. Reporting a bug for valgrind in
|
|
the http://bugs.kde.org is much more likely to get you a fix than
|
|
mailing developers directly, so please continue to keep sending bugs
|
|
there.
|
|
|
|
69616 glibc 2.3.2 w/NPTL is massively different than what valgrind expects
|
|
69856 I don't know how to instrument MMXish stuff (Helgrind)
|
|
73892 valgrind segfaults starting with Objective-C debug info
|
|
(fix for S-type stabs)
|
|
73145 Valgrind complains too much about close(<reserved fd>)
|
|
73902 Shadow memory allocation seems to fail on RedHat 8.0
|
|
68633 VG_N_SEMAPHORES too low (V itself was leaking semaphores)
|
|
75099 impossible to trace multiprocess programs
|
|
76839 the `impossible' happened: disInstr: INT but not 0x80 !
|
|
76762 vg_to_ucode.c:3748 (dis_push_segreg): Assertion `sz == 4' failed.
|
|
76747 cannot include valgrind.h in c++ program
|
|
76223 parsing B(3,10) gave NULL type => impossible happens
|
|
75604 shmdt handling problem
|
|
76416 Problems with gcc 3.4 snap 20040225
|
|
75614 using -gstabs when building your programs the `impossible' happened
|
|
75787 Patch for some CDROM ioctls CDORM_GET_MCN, CDROM_SEND_PACKET,
|
|
75294 gcc 3.4 snapshot's libstdc++ have unsupported instructions.
|
|
(REP RET)
|
|
73326 vg_symtab2.c:272 (addScopeRange): Assertion `range->size > 0' failed.
|
|
72596 not recognizing __libc_malloc
|
|
69489 Would like to attach ddd to running program
|
|
72781 Cachegrind crashes with kde programs
|
|
73055 Illegal operand at DXTCV11CompressBlockSSE2 (more SSE opcodes)
|
|
73026 Descriptor leak check reports port numbers wrongly
|
|
71705 README_MISSING_SYSCALL_OR_IOCTL out of date
|
|
72643 Improve support for SSE/SSE2 instructions
|
|
72484 valgrind leaves it's own signal mask in place when execing
|
|
72650 Signal Handling always seems to restart system calls
|
|
72006 The mmap system call turns all errors in ENOMEM
|
|
71781 gdb attach is pretty useless
|
|
71180 unhandled instruction bytes: 0xF 0xAE 0x85 0xE8
|
|
69886 writes to zero page cause valgrind to assert on exit
|
|
71791 crash when valgrinding gimp 1.3 (stabs reader problem)
|
|
69783 unhandled syscall: 218
|
|
69782 unhandled instruction bytes: 0x66 0xF 0x2B 0x80
|
|
70385 valgrind fails if the soft file descriptor limit is less
|
|
than about 828
|
|
69529 "rep; nop" should do a yield
|
|
70827 programs with lots of shared libraries report "mmap failed"
|
|
for some of them when reading symbols
|
|
71028 glibc's strnlen is optimised enough to confuse valgrind
|
|
|
|
|
|
|
|
|
|
Unstable (cvs head) release 2.1.0 (15 December 2003)
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
For whatever it's worth, 2.1.0 actually seems pretty darn stable to me
|
|
(Julian). It looks eminently usable, and given that it fixes some
|
|
significant bugs, may well be worth using on a day-to-day basis.
|
|
2.1.0 is known to build and pass regression tests on: SuSE 9, SuSE
|
|
8.2, RedHat 8.
|
|
|
|
2.1.0 most notably includes Jeremy Fitzhardinge's complete overhaul of
|
|
handling of system calls and signals, and their interaction with
|
|
threads. In general, the accuracy of the system call, thread and
|
|
signal simulations is much improved. Specifically:
|
|
|
|
- Blocking system calls behave exactly as they do when running
|
|
natively (not on valgrind). That is, if a syscall blocks only the
|
|
calling thread when running natively, than it behaves the same on
|
|
valgrind. No more mysterious hangs because V doesn't know that some
|
|
syscall or other, should block only the calling thread.
|
|
|
|
- Interrupted syscalls should now give more faithful results.
|
|
|
|
- Finally, signal contexts in signal handlers are supported. As a
|
|
result, konqueror on SuSE 9 no longer segfaults when notified of
|
|
file changes in directories it is watching.
|
|
|
|
Other changes:
|
|
|
|
- Robert Walsh's file descriptor leakage checks. When enabled,
|
|
Valgrind will print out a list of open file descriptors on
|
|
exit. Along with each file descriptor, Valgrind prints out a stack
|
|
backtrace of where the file was opened and any details relating to the
|
|
file descriptor such as the file name or socket details.
|
|
To use, give: --track-fds=yes
|
|
|
|
- Implemented a few more SSE/SSE2 instructions.
|
|
|
|
- Less crud on the stack when you do 'where' inside a GDB attach.
|
|
|
|
- Fixed the following bugs:
|
|
68360: Valgrind does not compile against 2.6.0-testX kernels
|
|
68525: CVS head doesn't compile on C90 compilers
|
|
68566: pkgconfig support (wishlist)
|
|
68588: Assertion `sz == 4' failed in vg_to_ucode.c (disInstr)
|
|
69140: valgrind not able to explicitly specify a path to a binary.
|
|
69432: helgrind asserts encountering a MutexErr when there are
|
|
EraserErr suppressions
|
|
|
|
- Increase the max size of the translation cache from 200k average bbs
|
|
to 300k average bbs. Programs on the size of OOo (680m17) are
|
|
thrashing the cache at the smaller size, creating large numbers of
|
|
retranslations and wasting significant time as a result.
|
|
|
|
|
|
|
|
Stable release 2.0.0 (5 Nov 2003)
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
2.0.0 improves SSE/SSE2 support, fixes some minor bugs, and
|
|
improves support for SuSE 9 and the Red Hat "Severn" beta.
|
|
|
|
- Further improvements to SSE/SSE2 support. The entire test suite of
|
|
the GNU Scientific Library (gsl-1.4) compiled with Intel Icc 7.1
|
|
20030307Z '-g -O -xW' now works. I think this gives pretty good
|
|
coverage of SSE/SSE2 floating point instructions, or at least the
|
|
subset emitted by Icc.
|
|
|
|
- Also added support for the following instructions:
|
|
MOVNTDQ UCOMISD UNPCKLPS UNPCKHPS SQRTSS
|
|
PUSH/POP %{FS,GS}, and PUSH %CS (Nb: there is no POP %CS).
|
|
|
|
- CFI support for GDB version 6. Needed to enable newer GDBs
|
|
to figure out where they are when using --gdb-attach=yes.
|
|
|
|
- Fix this:
|
|
mc_translate.c:1091 (memcheck_instrument): Assertion
|
|
`u_in->size == 4 || u_in->size == 16' failed.
|
|
|
|
- Return an error rather than panicing when given a bad socketcall.
|
|
|
|
- Fix checking of syscall rt_sigtimedwait().
|
|
|
|
- Implement __NR_clock_gettime (syscall 265). Needed on Red Hat Severn.
|
|
|
|
- Fixed bug in overlap check in strncpy() -- it was assuming the src was 'n'
|
|
bytes long, when it could be shorter, which could cause false
|
|
positives.
|
|
|
|
- Support use of select() for very large numbers of file descriptors.
|
|
|
|
- Don't fail silently if the executable is statically linked, or is
|
|
setuid/setgid. Print an error message instead.
|
|
|
|
- Support for old DWARF-1 format line number info.
|
|
|
|
|
|
|
|
Snapshot 20031012 (12 October 2003)
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Three months worth of bug fixes, roughly. Most significant single
|
|
change is improved SSE/SSE2 support, mostly thanks to Dirk Mueller.
|
|
|
|
20031012 builds on Red Hat Fedora ("Severn") but doesn't really work
|
|
(curiosly, mozilla runs OK, but a modest "ls -l" bombs). I hope to
|
|
get a working version out soon. It may or may not work ok on the
|
|
forthcoming SuSE 9; I hear positive noises about it but haven't been
|
|
able to verify this myself (not until I get hold of a copy of 9).
|
|
|
|
A detailed list of changes, in no particular order:
|
|
|
|
- Describe --gen-suppressions in the FAQ.
|
|
|
|
- Syscall __NR_waitpid supported.
|
|
|
|
- Minor MMX bug fix.
|
|
|
|
- -v prints program's argv[] at startup.
|
|
|
|
- More glibc-2.3 suppressions.
|
|
|
|
- Suppressions for stack underrun bug(s) in the c++ support library
|
|
distributed with Intel Icc 7.0.
|
|
|
|
- Fix problems reading /proc/self/maps.
|
|
|
|
- Fix a couple of messages that should have been suppressed by -q,
|
|
but weren't.
|
|
|
|
- Make Addrcheck understand "Overlap" suppressions.
|
|
|
|
- At startup, check if program is statically linked and bail out if so.
|
|
|
|
- Cachegrind: Auto-detect Intel Pentium-M, also VIA Nehemiah
|
|
|
|
- Memcheck/addrcheck: minor speed optimisations
|
|
|
|
- Handle syscall __NR_brk more correctly than before.
|
|
|
|
- Fixed incorrect allocate/free mismatch errors when using
|
|
operator new(unsigned, std::nothrow_t const&)
|
|
operator new[](unsigned, std::nothrow_t const&)
|
|
|
|
- Support POSIX pthread spinlocks.
|
|
|
|
- Fixups for clean compilation with gcc-3.3.1.
|
|
|
|
- Implemented more opcodes:
|
|
- push %es
|
|
- push %ds
|
|
- pop %es
|
|
- pop %ds
|
|
- movntq
|
|
- sfence
|
|
- pshufw
|
|
- pavgb
|
|
- ucomiss
|
|
- enter
|
|
- mov imm32, %esp
|
|
- all "in" and "out" opcodes
|
|
- inc/dec %esp
|
|
- A whole bunch of SSE/SSE2 instructions
|
|
|
|
- Memcheck: don't bomb on SSE/SSE2 code.
|
|
|
|
|
|
Snapshot 20030725 (25 July 2003)
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Fixes some minor problems in 20030716.
|
|
|
|
- Fix bugs in overlap checking for strcpy/memcpy etc.
|
|
|
|
- Do overlap checking with Addrcheck as well as Memcheck.
|
|
|
|
- Fix this:
|
|
Memcheck: the `impossible' happened:
|
|
get_error_name: unexpected type
|
|
|
|
- Install headers needed to compile new skins.
|
|
|
|
- Remove leading spaces and colon in the LD_LIBRARY_PATH / LD_PRELOAD
|
|
passed to non-traced children.
|
|
|
|
- Fix file descriptor leak in valgrind-listener.
|
|
|
|
- Fix longstanding bug in which the allocation point of a
|
|
block resized by realloc was not correctly set. This may
|
|
have caused confusing error messages.
|
|
|
|
|
|
Snapshot 20030716 (16 July 2003)
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
20030716 is a snapshot of our current CVS head (development) branch.
|
|
This is the branch which will become valgrind-2.0. It contains
|
|
significant enhancements over the 1.9.X branch.
|
|
|
|
Despite this being a snapshot of the CVS head, it is believed to be
|
|
quite stable -- at least as stable as 1.9.6 or 1.0.4, if not more so
|
|
-- and therefore suitable for widespread use. Please let us know asap
|
|
if it causes problems for you.
|
|
|
|
Two reasons for releasing a snapshot now are:
|
|
|
|
- It's been a while since 1.9.6, and this snapshot fixes
|
|
various problems that 1.9.6 has with threaded programs
|
|
on glibc-2.3.X based systems.
|
|
|
|
- So as to make available improvements in the 2.0 line.
|
|
|
|
Major changes in 20030716, as compared to 1.9.6:
|
|
|
|
- More fixes to threading support on glibc-2.3.1 and 2.3.2-based
|
|
systems (SuSE 8.2, Red Hat 9). If you have had problems
|
|
with inconsistent/illogical behaviour of errno, h_errno or the DNS
|
|
resolver functions in threaded programs, 20030716 should improve
|
|
matters. This snapshot seems stable enough to run OpenOffice.org
|
|
1.1rc on Red Hat 7.3, SuSE 8.2 and Red Hat 9, and that's a big
|
|
threaded app if ever I saw one.
|
|
|
|
- Automatic generation of suppression records; you no longer
|
|
need to write them by hand. Use --gen-suppressions=yes.
|
|
|
|
- strcpy/memcpy/etc check their arguments for overlaps, when
|
|
running with the Memcheck or Addrcheck skins.
|
|
|
|
- malloc_usable_size() is now supported.
|
|
|
|
- new client requests:
|
|
- VALGRIND_COUNT_ERRORS, VALGRIND_COUNT_LEAKS:
|
|
useful with regression testing
|
|
- VALGRIND_NON_SIMD_CALL[0123]: for running arbitrary functions
|
|
on real CPU (use with caution!)
|
|
|
|
- The GDB attach mechanism is more flexible. Allow the GDB to
|
|
be run to be specified by --gdb-path=/path/to/gdb, and specify
|
|
which file descriptor V will read its input from with
|
|
--input-fd=<number>.
|
|
|
|
- Cachegrind gives more accurate results (wasn't tracking instructions in
|
|
malloc() and friends previously, is now).
|
|
|
|
- Complete support for the MMX instruction set.
|
|
|
|
- Partial support for the SSE and SSE2 instruction sets. Work for this
|
|
is ongoing. About half the SSE/SSE2 instructions are done, so
|
|
some SSE based programs may work. Currently you need to specify
|
|
--skin=addrcheck. Basically not suitable for real use yet.
|
|
|
|
- Significant speedups (10%-20%) for standard memory checking.
|
|
|
|
- Fix assertion failure in pthread_once().
|
|
|
|
- Fix this:
|
|
valgrind: vg_intercept.c:598 (vgAllRoadsLeadToRome_select):
|
|
Assertion `ms_end >= ms_now' failed.
|
|
|
|
- Implement pthread_mutexattr_setpshared.
|
|
|
|
- Understand Pentium 4 branch hints. Also implemented a couple more
|
|
obscure x86 instructions.
|
|
|
|
- Lots of other minor bug fixes.
|
|
|
|
- We have a decent regression test system, for the first time.
|
|
This doesn't help you directly, but it does make it a lot easier
|
|
for us to track the quality of the system, especially across
|
|
multiple linux distributions.
|
|
|
|
You can run the regression tests with 'make regtest' after 'make
|
|
install' completes. On SuSE 8.2 and Red Hat 9 I get this:
|
|
|
|
== 84 tests, 0 stderr failures, 0 stdout failures ==
|
|
|
|
On Red Hat 8, I get this:
|
|
|
|
== 84 tests, 2 stderr failures, 1 stdout failure ==
|
|
corecheck/tests/res_search (stdout)
|
|
memcheck/tests/sigaltstack (stderr)
|
|
|
|
sigaltstack is probably harmless. res_search doesn't work
|
|
on R H 8 even running natively, so I'm not too worried.
|
|
|
|
On Red Hat 7.3, a glibc-2.2.5 system, I get these harmless failures:
|
|
|
|
== 84 tests, 2 stderr failures, 1 stdout failure ==
|
|
corecheck/tests/pth_atfork1 (stdout)
|
|
corecheck/tests/pth_atfork1 (stderr)
|
|
memcheck/tests/sigaltstack (stderr)
|
|
|
|
You need to run on a PII system, at least, since some tests
|
|
contain P6-specific instructions, and the test machine needs
|
|
access to the internet so that corecheck/tests/res_search
|
|
(a test that the DNS resolver works) can function.
|
|
|
|
As ever, thanks for the vast amount of feedback :) and bug reports :(
|
|
We may not answer all messages, but we do at least look at all of
|
|
them, and tend to fix the most frequently reported bugs.
|
|
|
|
|
|
|
|
Version 1.9.6 (7 May 2003 or thereabouts)
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Major changes in 1.9.6:
|
|
|
|
- Improved threading support for glibc >= 2.3.2 (SuSE 8.2,
|
|
RedHat 9, to name but two ...) It turned out that 1.9.5
|
|
had problems with threading support on glibc >= 2.3.2,
|
|
usually manifested by threaded programs deadlocking in system calls,
|
|
or running unbelievably slowly. Hopefully these are fixed now. 1.9.6
|
|
is the first valgrind which gives reasonable support for
|
|
glibc-2.3.2. Also fixed a 2.3.2 problem with pthread_atfork().
|
|
|
|
- Majorly expanded FAQ.txt. We've added workarounds for all
|
|
common problems for which a workaround is known.
|
|
|
|
Minor changes in 1.9.6:
|
|
|
|
- Fix identification of the main thread's stack. Incorrect
|
|
identification of it was causing some on-stack addresses to not get
|
|
identified as such. This only affected the usefulness of some error
|
|
messages; the correctness of the checks made is unchanged.
|
|
|
|
- Support for kernels >= 2.5.68.
|
|
|
|
- Dummy implementations of __libc_current_sigrtmin,
|
|
__libc_current_sigrtmax and __libc_allocate_rtsig, hopefully
|
|
good enough to keep alive programs which previously died for lack of
|
|
them.
|
|
|
|
- Fix bug in the VALGRIND_DISCARD_TRANSLATIONS client request.
|
|
|
|
- Fix bug in the DWARF2 debug line info loader, when instructions
|
|
following each other have source lines far from each other
|
|
(e.g. with inlined functions).
|
|
|
|
- Debug info reading: read symbols from both "symtab" and "dynsym"
|
|
sections, rather than merely from the one that comes last in the
|
|
file.
|
|
|
|
- New syscall support: prctl(), creat(), lookup_dcookie().
|
|
|
|
- When checking calls to accept(), recvfrom(), getsocketopt(),
|
|
don't complain if buffer values are NULL.
|
|
|
|
- Try and avoid assertion failures in
|
|
mash_LD_PRELOAD_and_LD_LIBRARY_PATH.
|
|
|
|
- Minor bug fixes in cg_annotate.
|
|
|
|
|
|
|
|
Version 1.9.5 (7 April 2003)
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
It occurs to me that it would be helpful for valgrind users to record
|
|
in the source distribution the changes in each release. So I now
|
|
attempt to mend my errant ways :-) Changes in this and future releases
|
|
will be documented in the NEWS file in the source distribution.
|
|
|
|
Major changes in 1.9.5:
|
|
|
|
- (Critical bug fix): Fix a bug in the FPU simulation. This was
|
|
causing some floating point conditional tests not to work right.
|
|
Several people reported this. If you had floating point code which
|
|
didn't work right on 1.9.1 to 1.9.4, it's worth trying 1.9.5.
|
|
|
|
- Partial support for Red Hat 9. RH9 uses the new Native Posix
|
|
Threads Library (NPTL), instead of the older LinuxThreads.
|
|
This potentially causes problems with V which will take some
|
|
time to correct. In the meantime we have partially worked around
|
|
this, and so 1.9.5 works on RH9. Threaded programs still work,
|
|
but they may deadlock, because some system calls (accept, read,
|
|
write, etc) which should be nonblocking, in fact do block. This
|
|
is a known bug which we are looking into.
|
|
|
|
If you can, your best bet (unfortunately) is to avoid using
|
|
1.9.5 on a Red Hat 9 system, or on any NPTL-based distribution.
|
|
If your glibc is 2.3.1 or earlier, you're almost certainly OK.
|
|
|
|
Minor changes in 1.9.5:
|
|
|
|
- Added some #errors to valgrind.h to ensure people don't include
|
|
it accidentally in their sources. This is a change from 1.0.X
|
|
which was never properly documented. The right thing to include
|
|
is now memcheck.h. Some people reported problems and strange
|
|
behaviour when (incorrectly) including valgrind.h in code with
|
|
1.9.1 -- 1.9.4. This is no longer possible.
|
|
|
|
- Add some __extension__ bits and pieces so that gcc configured
|
|
for valgrind-checking compiles even with -Werror. If you
|
|
don't understand this, ignore it. Of interest to gcc developers
|
|
only.
|
|
|
|
- Removed a pointless check which caused problems interworking
|
|
with Clearcase. V would complain about shared objects whose
|
|
names did not end ".so", and refuse to run. This is now fixed.
|
|
In fact it was fixed in 1.9.4 but not documented.
|
|
|
|
- Fixed a bug causing an assertion failure of "waiters == 1"
|
|
somewhere in vg_scheduler.c, when running large threaded apps,
|
|
notably MySQL.
|
|
|
|
- Add support for the munlock system call (124).
|
|
|
|
Some comments about future releases:
|
|
|
|
1.9.5 is, we hope, the most stable Valgrind so far. It pretty much
|
|
supersedes the 1.0.X branch. If you are a valgrind packager, please
|
|
consider making 1.9.5 available to your users. You can regard the
|
|
1.0.X branch as obsolete: 1.9.5 is stable and vastly superior. There
|
|
are no plans at all for further releases of the 1.0.X branch.
|
|
|
|
If you want a leading-edge valgrind, consider building the cvs head
|
|
(from SourceForge), or getting a snapshot of it. Current cool stuff
|
|
going in includes MMX support (done); SSE/SSE2 support (in progress),
|
|
a significant (10-20%) performance improvement (done), and the usual
|
|
large collection of minor changes. Hopefully we will be able to
|
|
improve our NPTL support, but no promises.
|
|
|