Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. XCB Error when using X-forwarding
Forum Updated to NodeBB v4.3 + New Features

XCB Error when using X-forwarding

Scheduled Pinned Locked Moved General and Desktop
xcbx11
4 Posts 4 Posters 19.2k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • N Offline
    N Offline
    nakedmind
    wrote on last edited by
    #1

    Greetings,

    I'm developing a Qt5-based application for data analysis on a remote RHEL7 machine, and I'm having problems with XCB not properly detecting the screen, resulting in crashes and odd window/widget behavior. I'm connecting via PuTTY from a Windows 7 machine using Xming, however I've confirmed this problem also exists when remoting from a Ubuntu 14.04 machine. When I run my application (compiled with cmake), these messages come up just before the window appears:

    When connecting from Windows 7:
    failed to get the current screen resources
    QXcbConnection: XCB error: 170 (Unknown), sequence: 161, resource id: 90, major code: 146 (Unknown), minor code: 20

    When connecting from Ubuntu 14.04:
    libGL error: failed to open drm device: Permission denied
    libGL error: failed to load driver: i965

    In both cases, the application runs and I can interact with the window, but it occasionally crashes - seems random when interacting with combo boxes, input fields, etc - and it also doesn't update/repaint properly, so sometimes I resize the window and it doesn't draw portions of it. I believe this has something to do with the configuration of the RHEL7 server rather than a bug in Qt itself, but it's hard for me to pinpoint.

    Some background: I'm using the Qt5.5 libraries, which I installed via the instructions here: https://wiki.qt.io/Building_Qt_5_from_Git#Getting_updates
    I did this about a week ago (June 2, 2015) so I should be using the newest, or close to the newest, version of the source.

    I found this related bug, which almost exactly describes the behavior I'm seeing: https://bugreports.qt.io/browse/QTBUG-31389
    However, this was resolved a few months ago and should no longer be an issue in Qt5.5.0.

    I confirmed that I'm actually using the Qt5.5 libraries - when I run make, this is shown in the output:
    /usr/bin/c++ -W -Wall -pedantic -fPIC -pthread -m64 -std=c++11 CMakeFiles/GIAnalysis.dir/bin_src/GIAnalysis.cc.o CMakeFiles/GIAnalysis.dir/GIAnalysis_automoc.cpp.o -o GIAnalysis -rdynamic lib/libgialib.so lib/libanalib.so -L/da ta/nmdc/gammaImaging/root/lib -lGui -lCore -lRIO -lNet -lHist -lGraf -lGraf3d -lGpad -lTree -lRint -lPostscript -lMatrix -lPhysics -lMathCore -lThread -pthread -lm -ldl -rdynamic /data/nmdc/gammaImaging/qt5/qtbase/lib/libQt5Core.so.5.5.0 /data/nmdc/gammaImaging/qt5/qtbase/lib/libQt5Widgets.so.5.5.0 /data/nmdc/gammaImaging/qt5/qtbase/lib/libQt5Gui.so.5.5.0 /data/nmdc/gammaImaging/qt5/qtbase/lib/libQt5Core.so.5.5.0 -m64 -Wl,-rpath,/data/nmdc/gammaImaging/analib-bu ild/lib:/data/nmdc/gammaImaging/qt5/qtbase/lib

    I'm not really sure where to go from here. Other applications (ie. ROOT, the libraries of which I'm compiling against above) work fine over the X-forwarding. This seems to be specifically a problem with Qt/XCB and the way it's handling the screens. Obviously, my $DISPLAY is set properly because other applications work:

    $ echo $DISPLAY
    localhost:10.0

    Maybe it's a settings problem? Here's the output of xrandr:

    $ xrandr
    xrandr: Failed to get size of gamma for output default
    Screen 0: minimum 3840 x 1080, current 3840 x 1080, maximum 3840 x 1080
    default connected 3840x1080+0+0 0mm x 0mm
    3840x1080 0.0*

    I've looked around quite a bit online but haven't been able to find anything on this specific issue. If anyone has any ideas for troubleshooting steps I can take, please help! Thanks for your time, your assistance is appreciated.

    1 Reply Last reply
    0
    • M Offline
      M Offline
      Mike A
      wrote on last edited by
      #2

      Hello:

      I'm having a similar problem, but not exactly the same. I'm using FastX 1.0.39 to connect remotely to a linux machine with Red Hat 7.1 that has Qt 5.5 on it. Qt works fine when I am using the Linux machine in person, but when I'm connected remotely I get the following error when a program opens:

      QXcbConnection: XCB error: 146 (Unknown), sequence: 163, resource id: 0, major code: 139 (Unknown), minor code: 20

      The initial window in my program opens, but the when the program tries to open a second window, the program freezes. I found a bug report that was closed in March also concerns remote connections, xcb errors, and screen problems:

      https://bugreports.qt.io/browse/QTBUG-31389

      Did you solve your problem, nakedmind? Has anyone else found a fix to a similar bug? I just installed 5.5 last week: would that include the bug fix listed in the link above (which refers to 5.5.0 Beta)? If not, how would I install the Beta version to see if that addressed my problem?

      Thanks,

      Mike

      PS. I'm new on this forum, so please let me know if I should be addressing this elsewhere, or if I need to make a bug report of some kind.

      1 Reply Last reply
      0
      • Q Offline
        Q Offline
        qt_practice
        wrote on last edited by
        #3

        Any one knows how to fix that? I have the same problem with Qt5.8.

        1 Reply Last reply
        0
        • B Offline
          B Offline
          borkowsk
          wrote on last edited by
          #4

          I have similar problem with running Wireshark GUI on Centos7 using XMing on Windows 10.

          I was trying to debug this issue, but it seems to be inside Qt libraries. The QtApplication constructor print "failed to get the current screen resources", and after quite a lot of code application finished at this line:

          main_window->show()

          with message:
          The X11 connection broke: I/O error (code 1)
          XIO: fatal IO error 2 (No such file or directory) on X server "localhost:14.0"
          after 363 requests (363 known processed) with 0 events remaining.

          1 Reply Last reply
          0

          • Login

          • Login or register to search.
          • First post
            Last post
          0
          • Categories
          • Recent
          • Tags
          • Popular
          • Users
          • Groups
          • Search
          • Get Qt Extensions
          • Unsolved