Skip to content

Known Issues

Volker Krause edited this page Jan 17, 2014 · 26 revisions

Known Issues

All Platforms

Injection does not work with static linking

The way GammaRay injects itself into the analyzed application requires dynamic linking to Qt at the moment. Neither statically linked applications nor a statically linked GammaRay will work.

The solution would be "static injection", similar to what QtCreator does with the QML debugger, statically linking GammaRay in to the application. This has not been implemented yet. Also note that this will not work with GammaRay plug-ins, those would need to be linked statically as well.

QtQuick 2 key event handling misbehaves (Qt5 <= 5.2.1)

The key event handling code in Qt Quick 2 changes behavior depending on whether its signals are connected or not. However, Qt also considers all signal to be connected if a signal spy callback (not to be confused with QSignalSpy) is registered. This is done by the GammaRay timer plug-in.

A fix for this has been integrated upstream (https://codereview.qt-project.org/#change,75530), for Qt 5.2.2 or later.

As a workaround, remove the timer plug-in (gammaray_timertop_plugin.so/dll) from your GammaRay installation.

Linux

Preloading fails with -Bsymbolic-function

If your Qt is linked with "-Bsymbolic-function", preloading wont work. If used, references to global functions are bind to the shared object internally. The definition of the function is now fixed and cant be overwritten by preloading. Note that this is different from using -reduce-relocations from Qt's configure command, this will add exceptions for the preloading hooks we (and also e.g. Squish) need.

Be sure that your distro provided packages or your self-compiled packages are not linked with this flag (check with echo $LDFLAGS before compiling) without including the exception from src/corelib/QtCore.dynlist. For more info see: "man ld; search for "-Bsymbolic-function".

Affected distros:

If you are affected by this, try the gdb or style injectors instead, using the "-i" command line option.

Preloading fails with -reduce-relocations and the gold linker

Similar issue as the one above, but here also the -reduce-relocations flag of Qt's configure is affected. The gold linker does not seem to support adding exceptions to the -Bsymbolic-functions option yet, so the hooks we need in QtCore wont work. (Issue is tracked here: http://sourceware.org/bugzilla/show_bug.cgi?id=13577)

Note that -reduce-relocations is enabled by default in Qt5.

Workarounds are either not using -no-reduce-relocations in combination with gold when compiling Qt or using a differerent GammaRay injection method. Both the gdb and style injectors still work in this case.

GDB method fails to attach to running process

First, note that you do not need to run gammaray as root to attach to user-space processes. It's fine to run gammaray as user, as long as the following conditions are met.

Ubuntu (and probably other distros) have a kernel security feature that disallows attaching to other processes. The message you'll get when trying to do so looks like this:

Could not attach to process.
If your uid matches the uid of the target process, check the setting of /proc/sys/kernel/yama/ptrace_scope, or try again as the root user.
For more details, see /etc/sysctl.d/10-ptrace.conf
ptrace: Operation not permitted.

In case that happens please read the following resources:

Mac

Undefined behavior when using app bundles containing Qt

When attaching GammaRay to an app bundle that contains its own Qt version, GammaRay may additionally load the Qt libraries it has been linked against. This will cause undefined behavior even if these are exactly the same Qt versions as static variables are overwritten in the process.

So far, the only workaround is adding GammaRay to the same app bundle.

GammaRay fails when build for 32bit

GammaRay fails to work when build for 32bit systems on Mac. No workaround is currently known.

Windows

Attaching not always working

GammaRay fails to attach to some applications. We are investigating in this issue. Please try the startup method, with passing the application to GammaRay in command line.

Fixed in version 1.1.

MSVC 64bit release mode not supported by DLL injector

Release builds with MSVC on 64bit Windows will fail to attach or start with the DLL injector (not implemented/tested yet). The style injector should work though (start with "-i style" command line option).

Fixed in version 1.1.

Clone this wiki locally