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. fatal assert: The application's primary screen should always be in sync with the main display
QtWS25 Last Chance

fatal assert: The application's primary screen should always be in sync with the main display

Scheduled Pinned Locked Moved Unsolved General and Desktop
20 Posts 5 Posters 1.1k Views
  • 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.
  • SGaistS Offline
    SGaistS Offline
    SGaist
    Lifetime Qt Champion
    wrote on last edited by
    #5

    Do you have several version of Qt installed ?
    Maybe a warning at startup telling that there's something fishy with regard to the frameworks loaded ?

    Interested in AI ? www.idiap.ch
    Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

    1 Reply Last reply
    0
    • D Offline
      D Offline
      davecotter
      wrote on last edited by
      #6

      Nope and nope

      1 Reply Last reply
      0
      • SGaistS Offline
        SGaistS Offline
        SGaist
        Lifetime Qt Champion
        wrote on last edited by
        #7

        What version of Qt ?

        Interested in AI ? www.idiap.ch
        Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

        1 Reply Last reply
        0
        • D Offline
          D Offline
          davecotter
          wrote on last edited by
          #8

          4.10.0, and i did do a full uninstall-reinstall of both the "macOS" kit and the sources, to no avail.

          J.HilkJ 1 Reply Last reply
          0
          • D davecotter

            4.10.0, and i did do a full uninstall-reinstall of both the "macOS" kit and the sources, to no avail.

            J.HilkJ Offline
            J.HilkJ Offline
            J.Hilk
            Moderators
            wrote on last edited by J.Hilk
            #9

            @davecotter said in fatal assert: The application's primary screen should always be in sync with the main display:

            4.10.0

            unlikely Qt 4 did not reach a 10s subversion 😉 What you likely told us, is is the QtCreator version. What @SGaist /we would like to know is the Qt Version used by your kit


            Be aware of the Qt Code of Conduct, when posting : https://forum.qt.io/topic/113070/qt-code-of-conduct


            Q: What's that?
            A: It's blue light.
            Q: What does it do?
            A: It turns blue.

            1 Reply Last reply
            1
            • D Offline
              D Offline
              davecotter
              wrote on last edited by
              #10

              oh sorry hah!

              5.13.1

              -dave

              1 Reply Last reply
              0
              • D Offline
                D Offline
                davecotter
                wrote on last edited by
                #11

                please, my project is dead in the water until i fix this. works fine on windows, just not on mac, where i do my dev work.

                is this just a bug in the binaries for the macOS kit?

                1 Reply Last reply
                0
                • D Offline
                  D Offline
                  davecotter
                  wrote on last edited by
                  #12

                  update:

                  this is a macbook pro, 2018 model, which has switchable graphics card.

                  the problem ONLY occurs when using the low-power graphics card, the Intel UHD 630.
                  when i manually switch to the Radeon Pro 560X, all is well. or if i attach an external monitor (forcing the use of the Radeon) all is well.

                  would you agree this is a bug i should file?

                  JKSHJ 1 Reply Last reply
                  0
                  • D davecotter

                    update:

                    this is a macbook pro, 2018 model, which has switchable graphics card.

                    the problem ONLY occurs when using the low-power graphics card, the Intel UHD 630.
                    when i manually switch to the Radeon Pro 560X, all is well. or if i attach an external monitor (forcing the use of the Radeon) all is well.

                    would you agree this is a bug i should file?

                    JKSHJ Offline
                    JKSHJ Offline
                    JKSH
                    Moderators
                    wrote on last edited by
                    #13

                    @davecotter said in fatal assert: The application's primary screen should always be in sync with the main display:

                    would you agree this is a bug i should file?

                    I agree that it would be great to find and fix the root cause of the crash.

                    You can certainly open a bug report. For it to be effective you need to help the Qt devs reproduce the issue reliably. Attach a minimal test case and provide clear and simple instructions to induce the crash.

                    please, my project is dead in the water until i fix this. works fine on windows, just not on mac, where i do my dev work.
                    In the meantime

                    Note that even if a Qt dev picks up your bug report and works on it, it will be a while before a fix is released.

                    In the meantime, you should apply a known workaround. It sounds like forcing the Radeon does the trick, yes?

                    Alternatively, what happens if you don't keep the QOpenGLWidget hidden in the beginning?

                    is this just a bug in the binaries for the macOS kit?

                    It's hard to say without a detailed investigation, I'm afraid.

                    Qt Doc Search for browsers: forum.qt.io/topic/35616/web-browser-extension-for-improved-doc-searches

                    1 Reply Last reply
                    3
                    • P Offline
                      P Offline
                      patrickkidd
                      wrote on last edited by
                      #14

                      I have had the same problem when not using my external monitor with my MacBook. Super frustrating.

                      I was able to solve it by:

                      1. Re-connecting my external monitor
                      2. changing the external monitor using the "Arrangement" tab in the display system preferences to drag the white top-bar indicating the "primary display" from the external monitor to the MacBook monitor
                      3. launched the app in the MacBook monitor
                      4. unplugged my external monitor, launched it again
                      5. re-connected the external monitor and set the primary display in system prefs back to the external monitor.
                      6. Launched it again in the external monitor as primary display.

                      ...or something like that. Not sure which step fixed it. Maybe there is some Qt pref that caches which monitor is primary for a certain combination of hardware the first time a Qt executable is executed, and maybe my workaround reset it. But now it works no matter how my system is set up.

                      Has to be a Qt bug, though primaryScreen() calls a macOS system call to get the primary display.

                      Cheers

                      https://alaskafamilysystems.com/

                      1 Reply Last reply
                      0
                      • P Offline
                        P Offline
                        patrickkidd
                        wrote on last edited by patrickkidd
                        #15

                        Looks like it has the potential to come back after my fix. The app fails on the following call after I have shown my main app window:

                        QCursor::pos()

                        Once removing that call from my code it crashes in another place, maybe more similar to what the first poster was seeing:

                        #0	0x0000000118075409 in QCocoaScreen::primaryScreen() at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/plugins/platforms/cocoa/qcocoascreen.mm:556
                        #1	0x000000011808d774 in QCocoaWindow::setCocoaGeometry(QRect const&) at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/plugins/platforms/cocoa/qcocoawindow.mm:293
                        #2	0x000000011808d281 in QCocoaWindow::setGeometry(QRect const&) at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/plugins/platforms/cocoa/qcocoawindow.mm:253
                        #3	0x000000010f324a07 in QWindow::resize(QSize const&) at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/gui/kernel/qwindow.cpp:1850
                        #4	0x00000001108d6456 in QWidgetPrivate::show_sys() at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/widgets/kernel/qwidget.cpp:8166
                        #5	0x00000001108d8b94 in QWidgetPrivate::show_helper() at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/widgets/kernel/qwidget.cpp:8096
                        #6	0x00000001108d9a3e in QWidgetPrivate::setVisible(bool) at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/widgets/kernel/qwidget.cpp:8398
                        #7	0x00000001108d964f in QWidget::setVisible(bool) at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/widgets/kernel/qwidget.cpp:8330
                        #8	0x00000001100a6702 in sipQMainWindow::setVisible(bool) at /Users/patrick/dev/vendor/sysroot-dev/build/PyQt5_gpl-5.12.2/QtWidgets/sipQtWidgetspart0.cpp:145076
                        #9	0x00000001108d887b in QWidget::show() at /Users/patrick/dev/vendor/sysroot-dev/build/qt-everywhere-src-5.13.1/qtbase/src/widgets/kernel/qwidget.cpp:7942
                        

                        https://alaskafamilysystems.com/

                        1 Reply Last reply
                        0
                        • P Offline
                          P Offline
                          patrickkidd
                          wrote on last edited by
                          #16

                          I commented out the assertion in qcocoascreen.mm and things seem to work OK for now. I have no idea what other problems this will cause however so we should still seek a solution.

                          https://alaskafamilysystems.com/

                          1 Reply Last reply
                          0
                          • D Offline
                            D Offline
                            davecotter
                            wrote on last edited by davecotter
                            #17

                            i'm having trouble creating a minimal repro project. my main app (which is huge) repro's 100% of the time, and fails to repro 100% of the time if i have "graphics switching" turned off, or an external monitor plugged in.

                            can someone else repro this with a simple project?

                            i've filed this bug:
                            https://bugreports.qt.io/browse/QTBUG-78707

                            but i do not think it's enough to go on without a solid repro case

                            -dave

                            JKSHJ 1 Reply Last reply
                            0
                            • D davecotter

                              i'm having trouble creating a minimal repro project. my main app (which is huge) repro's 100% of the time, and fails to repro 100% of the time if i have "graphics switching" turned off, or an external monitor plugged in.

                              can someone else repro this with a simple project?

                              i've filed this bug:
                              https://bugreports.qt.io/browse/QTBUG-78707

                              but i do not think it's enough to go on without a solid repro case

                              -dave

                              JKSHJ Offline
                              JKSHJ Offline
                              JKSH
                              Moderators
                              wrote on last edited by
                              #18

                              @davecotter said in fatal assert: The application's primary screen should always be in sync with the main display:

                              i'm having trouble creating a minimal repro project. my main app (which is huge) repro's 100% of the time

                              What if you clone your main app and start deleting huge chunks of it? How small can you go before the issue disappears?

                              can someone else repro this with a simple project?

                              I don't have a macOS machine, sorry.

                              i've filed this bug:
                              https://bugreports.qt.io/browse/QTBUG-78707

                              +1

                              but i do not think it's enough to go on without a solid repro case

                              I think so too.

                              Qt Doc Search for browsers: forum.qt.io/topic/35616/web-browser-extension-for-improved-doc-searches

                              1 Reply Last reply
                              0
                              • D Offline
                                D Offline
                                davecotter
                                wrote on last edited by davecotter
                                #19

                                What if you clone your main app and start deleting huge chunks of it?

                                my app is the size of photoshop†, it would take many weeks to do what you suggest.

                                perhaps @patrickkidd can repro?

                                -dave

                                † okay not LITERALLY the size of the PS code base, but there are dozens of dependencies, several dozen build scripts, hundreds of resources etc. there's just no practical way to take that route.

                                1 Reply Last reply
                                0
                                • D Offline
                                  D Offline
                                  davecotter
                                  wrote on last edited by
                                  #20

                                  i have filed this bug on it, if you care about this bug please "watch" it and/or vote for it

                                  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