Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. Mobile and Embedded
  4. Google Pixel C Tablet again , Black screen on OpenGL apps?
Forum Updated to NodeBB v4.3 + New Features

Google Pixel C Tablet again , Black screen on OpenGL apps?

Scheduled Pinned Locked Moved Unsolved Mobile and Embedded
16 Posts 2 Posters 5.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.
  • SGaistS Offline
    SGaistS Offline
    SGaist
    Lifetime Qt Champion
    wrote on last edited by
    #2

    Hi and welcome to devnet,

    Since 5.6.0 just got out, can you test against it ?

    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
    • servantiS Offline
      servantiS Offline
      servanti
      wrote on last edited by
      #3

      Hi, thank you for your response. Sure I will do that today and report back. I have managed to cross compile Qt 5.5 for nVidia X1 development kit , DRIVEC X (which is the processor used in Pixel C) with nVidia provided 64bit toolchain running on Ubuntu and it is all good. It is only the Android builds that have the issue. I am wondering if this has to do with 64bit architecture! I will try this today on my Mac . Thanks again.

      1 Reply Last reply
      0
      • servantiS Offline
        servantiS Offline
        servanti
        wrote on last edited by
        #4

        Hi,
        Just uninstalled previous (5.5) version of Qt for iOS and Android and installed the 5.6. The same thing. I am trying the QtBase qopenglwindow example which is one of the simplest ones. BTW I cannot do debugging on the device as connection is refused. The helloGL2 sample in Android runs fine through Android Studio but even there I am not able to launch the debugger wither.
        Also when I run the Qt sample in Qt Creator I see this on application out put pane:

        Starting remote process.I art : Late-enabling -Xcheck:jni
        W System : ClassLoader referenced unknown path:
        W linker : /data/app/org.qtproject.example.qopenglwindow-1/lib/arm/libQt5Gui.so: unused DT entry: type 0xf arg 0x5042f
        W linker : /data/app/org.qtproject.example.qopenglwindow-1/lib/arm/libQt5Gui.so: unsupported flags DT_FLAGS_1=0x81
        W linker : /data/data/org.qtproject.example.qopenglwindow/qt-reserved-files/plugins/platforms/android/libqtforandroid.so: unused DT entry: type 0xf arg 0x9260
        W linker : /data/data/org.qtproject.example.qopenglwindow/qt-reserved-files/plugins/platforms/android/libqtforandroid.so: unsupported flags DT_FLAGS_1=0x81
        W linker : /data/data/org.qtproject.example.qopenglwindow/qt-reserved-files/plugins/platforms/android/libqtforandroid.so: is missing DT_SONAME will use basename as a replacement: "libqtforandroid.so"
        I Qt : qt start
        W linker : /data/app/org.qtproject.example.qopenglwindow-1/lib/arm/libqopenglwindow.so: unused DT entry: type 0x1d arg 0x3a56
        D OpenGLRenderer: Use EGL_SWAP_BEHAVIOR_PRESERVED: true
        D NvOsDebugPrintf: NvRmPrivGetChipPlatform: Could not read platform information
        D NvOsDebugPrintf: Expected on kernels without fuse support, using silicon
        I OpenGLRenderer: Initialized EGL, version 1.4
        D libphs : cannot connect to power hinting service: service not available

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

          Just to be sure we're on the same track. You used the stock version of Qt or did you cross-compile it ?

          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
          • servantiS Offline
            servantiS Offline
            servanti
            wrote on last edited by
            #6

            It is stock out of the box on my Mac, Qt 5.6 downloaded this morning. On Ubuntu I have cross compiled Qt from source (5.5) for DRIVECX (Tegra X1) but even there the Qt Android builds are all stock. I just have a separate Qt libs that I have cross compiled for our development for my DRIVECX and that all work fine.

            I am now trying to compile a 64 bit Qt app on my Mac by messing with Android-g++ config and it seems that a QtGui and and Qt5Core lib is missing according to the linker. This makes sense if the pre build libs are all 32 bit. I wonder is this is the issue. Maybe I need a set of 64bit Qt libs for android. This is the only difference I can think of , I also noticed that Android NDK platform 21 has 64 bit libs so I changed that in the projects ANDROID_MDH_PLATFORM build Environment variables as the default I think was 9. Do you think this is a 32 v. 64 issue or am I barking up a wrong tree here :)

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

              That would make sense indeed.

              AFAIK to you should only need to setup ANDROID_TARGET_ARCH in order to have 64 bit build of Qt for Android.

              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
              • servantiS Offline
                servantiS Offline
                servanti
                wrote on last edited by
                #8

                Yes After trying a few things and looking in the qmake.conf I did realize that I only had to set that one env variable to do a 64bit build and when I do trying to build the app I get this , do you know of anyone anyone who has ran a Qt OpenGL app on Pixel C ?

                In file included from /home/allen/Android/Sdk/ndk-bundle/platforms/android-24/arch-arm64/usr/include/signal.h:37:0,
                from /home/allen/Android/Sdk/ndk-bundle/platforms/android-24/arch-arm64/usr/include/pthread.h:33,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/libs/arm64-v8a/include/bits/gthr-default.h:35,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/libs/arm64-v8a/include/bits/gthr.h:148,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/ext/atomicity.h:35,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/bits/basic_string.h:39,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/string:52,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/random:40,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/bits/stl_algo.h:66,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/algorithm:62,
                from /home/allen/QtAndroid/5.5/android_armv7/include/QtCore/qglobal.h:85,
                from /home/allen/QtAndroid/5.5/android_armv7/include/QtGui/qopenglwindow.h:37,
                from /home/allen/QtAndroid/5.5/android_armv7/include/QtGui/QOpenGLWindow:1,
                from ../qopenglwindow/main.cpp:41:
                /home/allen/Android/Sdk/ndk-bundle/platforms/android-24/arch-arm64/usr/include/asm/sigcontext.h:44:2: error: '__uint128_t' does not name a type
                __uint128_t vregs[32];
                ^
                In file included from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/random:49:0,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/bits/stl_algo.h:66,
                from /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/algorithm:62,
                from /home/allen/QtAndroid/5.5/android_armv7/include/QtCore/qglobal.h:85,
                from /home/allen/QtAndroid/5.5/android_armv7/include/QtGui/qopenglwindow.h:37,
                from /home/allen/QtAndroid/5.5/android_armv7/include/QtGui/QOpenGLWindow:1,
                from ../qopenglwindow/main.cpp:41:
                /home/allen/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/include/bits/random.h:106:26: error: expected unqualified-id before '__int128'
                { typedef unsigned __int128 type; };
                ^
                make: *** [.obj/main.o] Error 1
                14:31:02: The process "/usr/bin/make" exited with code 2.
                Error while building/deploying project qopenglwindow (kit: Android for armeabi-v7a (GCC 4.9, Qt 5.5.1))
                When executing step "Make"

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

                  Sorry, I'm not aware of somebody owning a Pixel C around me.

                  Did you rebuild Qt for 64 bit ?

                  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
                  • servantiS Offline
                    servantiS Offline
                    servanti
                    wrote on last edited by
                    #10

                    noticed that I had to set a few other Env variables

                    ANDROID_NDK_TOOLCHAIN_PREFIX=aarch64-linux-android
                    ANDROID_NDK_TOOLS_PREFIX=aarch64-linux-android

                    No, I am looking in to building Qt from source with the NDK 64bit toolchain, but what is puzzling is why non-opengl apps run?

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

                      Do you mean widget based app ?

                      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
                      • servantiS Offline
                        servantiS Offline
                        servanti
                        wrote on last edited by
                        #12

                        Yes, so far any non-OGL app works. I am trying to cross compile with Android 64bit toolchain but in the configure command I seem not to be able to tell it to go to the aarch64 architecture. the qdevice.pri that is generated keeps listing
                        DEFAULT_ANDROID_TARGET_ARCH = armeabi-v7a

                        So I am not using the correct compilers. I have exported all the environment variable (BTW I am on Ubuntu) bit it seems that these environment variables are not set in the qmake.conf. What is the configure option to set these?

                        Thanks

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

                          Can you show your environment setup and configure call ?

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

                          servantiS 1 Reply Last reply
                          0
                          • servantiS Offline
                            servantiS Offline
                            servanti
                            wrote on last edited by
                            #14

                            Sorry for the delay , This website was flaky yesterday. I have it all building. I managed (and it took a bit ) to cross compile Qt for 64 bit android using the android-24 NDK platform and toolchains. No luck , but I see a more meaningful message now. The activity fails to start on the device and here is the message
                            W ActivityThread: Application org.qtproject.example.qopenglwindow can be debugged on port 8100...
                            E Qt : Can't create main activity
                            E Qt : java.io.FileNotFoundException: /data/user/0/org.qtproject.example.qopenglwindow/lib/libplugins_platforms_android_libqtforandroid.so: open failed: ENOENT (No such file or directory)

                            I do have the ibplugins_platforms_android_libqtforandroid.so in the folder where the app is built. I saw some Qt bug report yesterday and some one mentioned they had the black screen and it was due to third party libs. I tried in the configuration to turn all third party libs disabled or use the Qt Bundle , Here is "final Qt Config report at the end of cross compiling. Is there something I am missing? Any ideas about third part libs or why I get this error on Activity start? Thanks

                            Final config for Android 64 bit

                            Running configure tests...

                            Checking for fontconfig... no
                            Checking for gccdepends... yes
                            Checking for glx... no
                            Checking for gnuld... yes
                            Checking for icu... no
                            Checking for leveldb... no
                            Checking for libwebp... no
                            Checking for libXcomposite... no
                            Checking for libxml2... no
                            Checking for libXrender... no
                            Checking for libxslt... no
                            Checking for libzlib... yes

                            Final configuration:

                            Build ......................... webkit1 webkit2
                            Configuration ................. debug
                            All-in-one files .............. no
                            GNUmake ....................... yes
                            Static libs as shared ......... no
                            Static libs as thin archives .. yes
                            Production build .............. yes

                            Have .......................... qtquick qtprintsupport qstyle qttestlib qtpositioning qtsensors
                            Use ........................... tiled_backing_store cross_platform_context_menus zlib 3d_graphics gstreamer native_fullscreen_video leveldb wchar_unicode glib
                            Features ...................... fast_mobile_scrolling gesture_events inspector_server legacy_viewport_adaption smooth_scrolling subpixel_layout touch_adjustment view_mode_css_media plugin_architecture_unsupported

                            3D Rendering .................. yes
                            Accelerated 2D Canvas ......... yes
                            Battery Status ................ no
                            Blob .......................... yes
                            Canvas Path ................... yes
                            CanvasProxy ................... no
                            Channel Messaging ............. yes
                            Content Security Policy 1.1 ... no
                            CSS Device Adaptation ......... no
                            CSS Exclusions ................ yes
                            CSS Shapes .................... yes
                            CSS Filters ................... yes
                            CSS3 Conditional Rules support (i.e. @supports) no
                            CSS3 Text ..................... no
                            CSS3 Text Line Break .......... no
                            CSS box-decoration-break ...... yes
                            CSS image-orientation ......... no
                            CSS image-resolution .......... no
                            CSS image-set ................. yes
                            CSS Regions ................... yes
                            CSS Shaders ................... no
                            CSS sticky position ........... yes
                            CSS Compositing ............... yes
                            Support for unprefixed CSS animations and transforms yes
                            CSS Variable .................. no
                            Custom Scheme Handler ......... no
                            Datalist Element .............. yes
                            Data Transfer Items ........... no
                            Details Element ............... yes
                            Device Orientation ............ yes
                            Dialog Element ................ no
                            Directory Upload .............. no
                            Expose DOM4 Events constructors no
                            Download Attribute ............ yes
                            File System ................... no
                            Filters ....................... yes
                            Font Load Events .............. no
                            FTP Directory ................. yes
                            Fullscreen API ................ yes
                            Gamepad ....................... no
                            Geolocation ................... yes
                            High DPI Canvas ............... no
                            Icondatabase .................. yes
                            Iframe seamless attribute ..... yes
                            Indexed Database .............. yes
                            Input Speech .................. no
                            Input Type Color .............. yes
                            Input Type Date ............... no
                            Broken Input Type Datetime .... no
                            Input Type Datetimelocal ...... no
                            Input Type Month .............. no
                            Input Type Time ............... no
                            Input Type Week ............... no
                            Inspector ..................... yes
                            JavaScript Debugger ........... yes
                            Legacy Notifications .......... yes
                            Legacy Vendor Prefix .......... yes
                            Legacy Web Audio .............. yes
                            Link Prefetch ................. yes
                            MathML ........................ no
                            Media Capture ................. no
                            Media Source .................. no
                            Media Statistics .............. no
                            Media Stream .................. no
                            Meter Element ................. yes
                            MHTML ......................... yes
                            Microdata ..................... no
                            Scaled mouse cursor ........... no
                            Navigator Content Utils ....... no
                            Netscape Plugin API ........... no
                            Network Info .................. no
                            Support for 'X-Content-Type-Options: nosniff' no
                            Notifications ................. yes
                            Orientation Events ............ yes
                            Page Visibility API ........... yes
                            Performance Timeline .......... no
                            Progress Element .............. yes
                            Proximity Events .............. no
                            Quota ......................... no
                            Resolution media query ........ yes
                            Resource Timing ............... no
                            Request Animation Frame ....... yes
                            Seccomp Filter sandbox ........ no
                            Scripted Speech ............... no
                            Shadow DOM .................... no
                            Shared Workers ................ yes
                            SQL Database .................. yes
                            Style Scoped .................. no
                            Suid sandbox for linux ........ no
                            SVG ........................... yes
                            SVG Fonts ..................... yes
                            HTMLTemplateElement ........... no
                            Text Autosizing ............... no
                            Tiled Backing Store ........... no
                            Threaded HTML parser .......... no
                            Touch Events .................. yes
                            Touch Slider .................. yes
                            Touch Icon Loading Support .... no
                            User Timing ................... no
                            Vibration ..................... no
                            Video ......................... yes
                            Video Track ................... yes
                            WebGL ......................... yes
                            Web Audio ..................... no
                            Web Sockets ................... yes
                            Web Timing .................... yes
                            Workers ....................... yes
                            XHR Timeout ................... yes
                            XSLT .......................... no

                            Encountered 2 configuration warning(s):

                            ! Qt not configured to use system libjpeg, QImageDecoder will decode JPEG images
                            ! Qt not configured to use system libpng, QImageDecoder will decode PNG images

                            1 Reply Last reply
                            0
                            • SGaistS SGaist

                              Can you show your environment setup and configure call ?

                              servantiS Offline
                              servantiS Offline
                              servanti
                              wrote on last edited by
                              #15

                              @SGaist So I did some more looking around and saw a blog post that explained how to use Android Studio to source level debug the Java Activity part of a Qt app. It seem that in createBundeleBinary methot in QtActivity.java
                              it looks for libqtforandroid.so in /data/usr/0/org.qtproject.example/q-reserved-files/plugins/platforms/android and it does not find it there, there is a msg in the code that I never see on the application window

                              "This application requires Ministro service. Would you like to install it"
                              which makes sense if it does not find the .so . I never specified using Ministro in the kit. Also /data folder is protected and I
                              cannot look in it in the adb shell, I suppose unless I root the device which since it is not mine I do not want to do.
                              Do you have any idea why this so is not installed even though it is in the Android folder when I build, is this
                              a bug in androiddeplyqt? I have the code but was wondering if you know anything about this. I read in some other
                              bug reports or discussions that there maybe a bug. Again this happen ONLY on Pixel C , we run fine on other android devices.

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

                                That might be something specific to the Pixel C OS setup.

                                One thing to check is the properties of your project. IIRC you can select whether you want to use Ministro or embed Qt with your application when deploying.

                                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

                                • Login

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