Summary: | Valgrind crash when check Marmalade app | ||
---|---|---|---|
Product: | [Developer tools] valgrind | Reporter: | kalibannez <kalibannez> |
Component: | memcheck | Assignee: | Rhys Kidd <rhyskidd> |
Status: | RESOLVED INTENTIONAL | ||
Severity: | wishlist | CC: | kalibannez, lou.salkind, rhyskidd |
Priority: | NOR | ||
Version: | 3.10 SVN | ||
Target Milestone: | --- | ||
Platform: | Compiled Sources | ||
OS: | macOS | ||
See Also: |
https://bugs.kde.org/show_bug.cgi?id=346023 https://bugs.kde.org/show_bug.cgi?id=344337 |
||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: | |||
Attachments: |
Simple cocoa app, invokes Valgrind crash
Proposed patch (partial, still needs to be tested on OS X 10.10) |
Description
kalibannez
2014-10-07 10:56:58 UTC
Note: This has been reported with Firefox on Mac OS X (10.8) as well and may be duplicate of https://bugs.kde.org/show_bug.cgi?id=322368 and https://bugs.kde.org/show_bug.cgi?id=216837 Can you post the output of 'uname -msr'? > Can you post the output of 'uname -msr'?
kalibannez$uname -msr
Darwin 13.3.0 x86_64
Note: i'm using Valgrind, compiled for i386 arch, and i testing application, compiled for i386. Not for x86_64 like kernel os OS X.
Created attachment 89103 [details]
Simple cocoa app, invokes Valgrind crash
For make test just compile this Xcode project and execute:
valgrind ./VGTest.app
Please not that both valgrind and test app must be compiled for i386 architecture. For test it run: lipo -info ./VGTest.app/Contents/MacOS/VGTest Output must be: Non-fat file: VGTest.app/Contents/MacOS/VGTest is architecture: i386 Please not that both valgrind and test app must be compiled for i386 architecture. For test it run: lipo -info ./VGTest.app/Contents/MacOS/VGTest Output must be: Non-fat file: VGTest.app/Contents/MacOS/VGTest is architecture: i386 To build/run: cd VGTest/ xcodebuild ./vg-in-place ./build/Release/VGTest.app/Contents/MacOS/VGTest This might be a problem with the computation of "magic_delta" for the target (32 bit 10.9) and therefore very easy to fix. Julian, is there any external commentary on the calculation of "magic_delta" beyond the source code which you could point me towards? Created attachment 90661 [details]
Proposed patch (partial, still needs to be tested on OS X 10.10)
kalibannez, Can you please apply the proposed patch to your local copy of Valgrind and rebuild? Based on my testing here, the newly added 'magic_delta' for OS X 10.9 (32 bit) works to resolve the crash as found within your provided VGTest. I am hopeful this fix will also resolve the crash in your Marmalade app. Please let us know either way. TODO before being ready for commit: 1. Check the magic constants against OS X 10.10 Please note there is a further, unrelated crash report in VGTest after passing the 'magic_delta' check, due to "unhandled syscall: mach:41". It will be addressed in a separate bugzilla report. OS X 10.10 uses the same magic constants. c.f. http://www.opensource.apple.com/source/libpthread/libpthread-105.1.4/kern/workqueue_internal.h for WQ_FLAG_THREAD_REUSE 0x00020000. Partial fix in r14888. Refer related bug: https://bugs.kde.org/show_bug.cgi?id=344337 ("unhandled syscall: mach:41") Refer related bug: https://bugs.kde.org/show_bug.cgi?id=346023 ("vex x86->IR: unhandled instruction bytes: 0x66 0xF 0x3A 0xB (roundsd)") Unfortunately, given Valgrind does not plan to support SSE4 instructions on 32 bit (which Marmalade uses) it looks unlikely that Marmalade will be supported on Valgrind until they transition to 64 bit on OS X. I've noticed that they are already supporting 64 bit on iOS, to meet the Apple Store requirements from 1 February 2015, so hopefully shouldn't be too long. If there is some way that you can compile your Marmalade app for 64 bit, it should start working correctly on Valgrind. See https://bugs.kde.org/show_bug.cgi?id=332917 and http://www.valgrind.org/docs/manual/manual-core.html#manual-core.limits |