Summary: | Valgrind should warn the user that SSE4 is not supported in the 32-bit mode | ||
---|---|---|---|
Product: | [Developer tools] valgrind | Reporter: | Sofia Rodina <rodinasophie> |
Component: | vex | Assignee: | Julian Seward <jseward> |
Status: | REPORTED --- | ||
Severity: | crash | CC: | alexanderm.08, austinenglish, eugeni.stepanov, glider, philippe.waroquiers, rhyskidd, timurrrr |
Priority: | NOR | ||
Version: | 3.9.0 | ||
Target Milestone: | --- | ||
Platform: | Ubuntu | ||
OS: | Linux | ||
See Also: |
https://bugs.kde.org/show_bug.cgi?id=296577 https://bugs.kde.org/show_bug.cgi?id=346023 https://bugs.kde.org/show_bug.cgi?id=303804 https://bugs.kde.org/show_bug.cgi?id=347198 https://bugs.kde.org/show_bug.cgi?id=291924 https://bugs.kde.org/show_bug.cgi?id=254616 |
||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: |
Description
Sofia Rodina
2014-04-01 16:53:26 UTC
(In reply to comment #0) > So, don't you think that it's a good idea to warn the user that such > instructions are not handled in 32-bit mode or just specify this information > on official valgrind site? Some people would be grateful for such > notifications :) Yes, that looks a good idea. Where could we put that, so that it is (likely to be) found by people needing this info ? From what I can see, the fact that SSE4 is not (fully) supported on 32 bits is *already* in the user manual (and so, also on the valgrind website, which has a copy of the manual) : The 32 bits limited to SSE3 is in the first paragraph of the 'Limitations' section: http://www.valgrind.org/docs/manual/manual-core.html#manual-core.limits It is also somewhat documented in the NEWS file (search for SSE4). Maybe we could put a reference to the FAQ and the user manual limitation in the error msg: #define M(a) VG_(umsg)(a "\n"); M("Your program just tried to execute an instruction that Valgrind" ); M("did not recognise. There are two possible reasons for this." ); M("1. Your program has a bug and erroneously jumped to a non-code" ); M(" location. If you are running Memcheck and you just saw a" ); M(" warning about a bad jump, it's probably your program's fault."); M("2. The instruction is legitimate but Valgrind doesn't handle it,"); M(" i.e. it's Valgrind's fault. If you think this is the case or"); M(" you are not sure, please let us know and we'll try to fix it."); M("Either way, Valgrind will now raise a SIGILL signal which will" ); M("probably kill your program." ); #undef M I like the idea of adding a FAQ link into the message. Another related idea: Whenever Valgrind says something like vex x86->IR: unhandled instruction bytes: 0x66 0xF 0x38 0x20 I do ------------------- $ cat >foo.c void foo() { asm(".byte 0x66, 0xf, 0x38, 0x20, 0x0"); } ^D $ gcc -c -O2 foo.c && objdump -d foo.o 66 0f 38 20 00 pmovsxbw (%rax),%xmm0 ------------------- /* Please note Valgrind only prints out the first 4 bytes of the unhandled instruction, looks like this number should be raised to the maximum instruction length? */ I wonder if it's possible to automatically invoke something like objdump when an unhandled instruction happens? Then Valgrind can just say "hey, pmovsxbw is not handled, sorry". Otherwise, the FAQ entry should mention the above method. [adding my colleagues who fought similar problems before] Yeah. I also like the idea to put FAQ link to error message. Btw, if it's possible to invoke objdump or something similar when "unhandled instructions" happen, it would be very helpful. Have closed as wontfix two reports from OS X of unhandled SSE4.1 instructions in 32 bit. At the same time, referenced them here as am sure we will continue to get reports notwithstanding the tangential limitation expressed in the V manual. |