Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. Language Bindings
  4. Code suddenly stops at self.cam = QCamera() , PyQt5.9.2, Qt5.9.3, Python3.5
Forum Update on Monday, May 27th 2025

Code suddenly stops at self.cam = QCamera() , PyQt5.9.2, Qt5.9.3, Python3.5

Scheduled Pinned Locked Moved Unsolved Language Bindings
pyqtpython
55 Posts 4 Posters 19.3k 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.
  • X Xenoshell
    7 Dec 2017, 09:18

    Ok, somehow when i use sudo python3 qt5.py instead of python3 qt5.py the program doesnt stop at self.cam = QCamera(). I suspect this is just something with ubuntu mate.
    The bad part about this is that the camera window opens for a second and then my whole screen goes black. On the top left side is a underscore that blinks, then my raspberry is locked and i need to type in my password again.
    It almost looks like the terminal is going fullscreen but thats just my guess.
    Also the output for qcamerainfo.availablecameras() is PyQt5.QtMultimedia.QCameraInfo object at 0x72dbe3b0 so i guess i could write QCamera(0x72dbe3b0)?

    Greets,
    Xenoshell

    J Offline
    J Offline
    jsulm
    Lifetime Qt Champion
    wrote on 7 Dec 2017, 09:24 last edited by
    #8

    @Xenoshell I guess the user you're using on your Ubuntu system does not have access rights to the camera device. You need to check the group of the camera device and add your user to that group.

    https://forum.qt.io/topic/113070/qt-code-of-conduct

    J 1 Reply Last reply 7 Dec 2017, 14:34
    1
    • X Offline
      X Offline
      Xenoshell
      wrote on 7 Dec 2017, 09:37 last edited by Xenoshell 12 Jul 2017, 12:47
      #9

      Is that really the problem if i can just use sudo? I am more worried about the screen just going blank. Can you maybe recommend a good debuggin program? I use geany but it doesnt even has a step option and eclipse is very complicated to set up with python or i just didnt managed to link all the libraries

      Oh i just ran gdb python3 just to see the error and if it would give more informations. This was the output:

      Program received signal SIGSEGV, Segmentation fault.
      0x76fd9dde in ?? () from /lib/ld-linux-armhf.so.3
      
      
      (gdb) bt
      #0  0x76fd9dde in ?? () from /lib/ld-linux-armhf.so.3
      #1  0x76fd9df6 in ?? () from /lib/ld-linux-armhf.so.3
      Backtrace stopped: previous frame identical to this frame (corrupt stack?)
      

      So it seems like i have also a segmentation fault with ubuntu mate. I also tried the same program with raspbian and i also got a segmentation fault. The only difference is that it is now another file that gets called.

      J 1 Reply Last reply 7 Dec 2017, 10:14
      0
      • X Xenoshell
        7 Dec 2017, 09:37

        Is that really the problem if i can just use sudo? I am more worried about the screen just going blank. Can you maybe recommend a good debuggin program? I use geany but it doesnt even has a step option and eclipse is very complicated to set up with python or i just didnt managed to link all the libraries

        Oh i just ran gdb python3 just to see the error and if it would give more informations. This was the output:

        Program received signal SIGSEGV, Segmentation fault.
        0x76fd9dde in ?? () from /lib/ld-linux-armhf.so.3
        
        
        (gdb) bt
        #0  0x76fd9dde in ?? () from /lib/ld-linux-armhf.so.3
        #1  0x76fd9df6 in ?? () from /lib/ld-linux-armhf.so.3
        Backtrace stopped: previous frame identical to this frame (corrupt stack?)
        

        So it seems like i have also a segmentation fault with ubuntu mate. I also tried the same program with raspbian and i also got a segmentation fault. The only difference is that it is now another file that gets called.

        J Offline
        J Offline
        JonB
        wrote on 7 Dec 2017, 10:14 last edited by JonB 12 Jul 2017, 10:14
        #10

        @Xenoshell

        Is that really the problem if i can just use sudo?

        You really should not run your application as root just to get around this issue! If you expect non-root users to access your camera, you need to set whatever Linux permissions are necessary to allow them access to it.

        gdb python

        But you run your application via python3, so there's no point trying to debug python, which under Linux is Python 2.... You need to run gdb python3, and then type run qt5.py....

        1 Reply Last reply
        0
        • X Offline
          X Offline
          Xenoshell
          wrote on 7 Dec 2017, 12:34 last edited by
          #11

          The issue with python or python3 was a typo on my part so all the outputs are with python3. If my code is finished i actually planned to put it on autostart so the raspberry pi can only be used as a camera with also some other functions. What should i do if i wanna fix this issue with sudo?

          1 Reply Last reply
          0
          • J jsulm
            7 Dec 2017, 09:24

            @Xenoshell I guess the user you're using on your Ubuntu system does not have access rights to the camera device. You need to check the group of the camera device and add your user to that group.

            J Offline
            J Offline
            JonB
            wrote on 7 Dec 2017, 14:34 last edited by
            #12

            @Xenoshell

            @jsulm said in Code suddenly stops at self.cam = QCamera() , PyQt5.9.2, Qt5.9.3, Python3.5:

            @Xenoshell I guess the user you're using on your Ubuntu system does not have access rights to the camera device. You need to check the group of the camera device and add your user to that group.

            What have you done about about what @jsulm suggested?

            X 1 Reply Last reply 7 Dec 2017, 14:47
            0
            • J JonB
              7 Dec 2017, 14:34

              @Xenoshell

              @jsulm said in Code suddenly stops at self.cam = QCamera() , PyQt5.9.2, Qt5.9.3, Python3.5:

              @Xenoshell I guess the user you're using on your Ubuntu system does not have access rights to the camera device. You need to check the group of the camera device and add your user to that group.

              What have you done about about what @jsulm suggested?

              X Offline
              X Offline
              Xenoshell
              wrote on 7 Dec 2017, 14:47 last edited by
              #13

              @JNBarchan What group are you talking about? I am pretty new in python programming or general speaking ubuntu so i dont know how to check the group of the camera device and add me to that group. I set up this Ubuntu Mate myself and i am the only user on the Raspberry Pi besides root

              J J 2 Replies Last reply 7 Dec 2017, 15:36
              0
              • X Xenoshell
                7 Dec 2017, 14:47

                @JNBarchan What group are you talking about? I am pretty new in python programming or general speaking ubuntu so i dont know how to check the group of the camera device and add me to that group. I set up this Ubuntu Mate myself and i am the only user on the Raspberry Pi besides root

                J Offline
                J Offline
                JonB
                wrote on 7 Dec 2017, 15:36 last edited by JonB 12 Jul 2017, 15:39
                #14

                @Xenoshell
                Sorry, I know nothing about "camera device access/groups under Ubuntu" other than what @jsulm wrote. (I use Ubuntu, but not Mate/Pi, and I don't have a camera.) He may return to offer more information, or he may just be giving you a hint as to what you need to look for.

                If you're new to Ubuntu/Linux, here's just a word about sudo/root user.

                • Linux (like Windows) has users & groups, who have different permissions. Files and devices have permissions, and if your user/groups doesn't have permission to access something you'll be blocked from it.
                • Ubuntu doesn't really have a root user that you can log in as, per se, but you can use the sudo command to gain root privileges.
                • You are saying that if you run your code normally as you, it "hangs" at QCamera().
                • But if you run it as root via sudo it does not hang.
                • That would imply you as you lack permission to access the camera (perhaps a device), while root does not have that problem.
                • Therefore we are thinking there might be a "group" who have access to the camera, and you need to be a member of that group.
                • You can list all groups with cat /etc/groups. You'd have to look through yours to see if there looks like anything "likely". You add users to groups via adduser user group.
                • You can run sudo python3 qt5.py if you really want. But it's a really bad idea (haven't got time to list myriad reasons), and I think you'll really regret it as you try to do other stuff in your app.

                BTW, did you have to install your "camera device/software"? If so did it come with any instructions about this?

                Your Python code looks OK, and I doubt it will have anything to do with Python/PyQt.

                I am a little surprised that just plain QCamera() hangs/requires permissions, because you're not even naming a device there, but it might do, or it might try to access the "default" camera device, i don't know. @jsulm / @SGaist know more than me.

                Try @SGaist's suggestion of just enumerating the available cameras. You're going to need to learn soon how to turn his bit of Qt C++ code into Python to get anywhere much with Qt.... (Not meaning to be rude or disheartening, just a heads-up, but if you think you could just write code QCamera(0x72dbe3b0) in Python or C++ you have quite a bit still to learn before you'll be able to do stuff.)

                Finally, I don't like the look of gdb python3 itself generating a SIGSEGV, but I don't know exactly what you did, could be a red-herring.

                Your "screen going black and locking up" might be to do with it requesting a password to access, I really don't know. I assume you've got your camera all working and you can play with it OK outside of your application?

                X 1 Reply Last reply 11 Dec 2017, 09:45
                2
                • X Xenoshell
                  7 Dec 2017, 14:47

                  @JNBarchan What group are you talking about? I am pretty new in python programming or general speaking ubuntu so i dont know how to check the group of the camera device and add me to that group. I set up this Ubuntu Mate myself and i am the only user on the Raspberry Pi besides root

                  J Offline
                  J Offline
                  jsulm
                  Lifetime Qt Champion
                  wrote on 11 Dec 2017, 05:31 last edited by
                  #15

                  @Xenoshell Please take a look at https://www.tutorialspoint.com/unix/unix-file-permission.htm
                  Each device is represented by a device file which. To read from such a device you read from the device file to write to the device you write into this file. UNIX/Linux access rights apply to device files as well. So, you have user, user groups and others. You have read/write and execute rights. My guess is that the user you are using on your machine does not have access rights to the camera device file. Usually to solve this you just need to add this user to the correct user group (probably this group is called "video"). To see in which groups your user is member execute the command "groups" in a terminal. To add a user to a group see https://askubuntu.com/questions/79565/how-to-add-existing-user-to-an-existing-group

                  https://forum.qt.io/topic/113070/qt-code-of-conduct

                  1 Reply Last reply
                  1
                  • J JonB
                    7 Dec 2017, 15:36

                    @Xenoshell
                    Sorry, I know nothing about "camera device access/groups under Ubuntu" other than what @jsulm wrote. (I use Ubuntu, but not Mate/Pi, and I don't have a camera.) He may return to offer more information, or he may just be giving you a hint as to what you need to look for.

                    If you're new to Ubuntu/Linux, here's just a word about sudo/root user.

                    • Linux (like Windows) has users & groups, who have different permissions. Files and devices have permissions, and if your user/groups doesn't have permission to access something you'll be blocked from it.
                    • Ubuntu doesn't really have a root user that you can log in as, per se, but you can use the sudo command to gain root privileges.
                    • You are saying that if you run your code normally as you, it "hangs" at QCamera().
                    • But if you run it as root via sudo it does not hang.
                    • That would imply you as you lack permission to access the camera (perhaps a device), while root does not have that problem.
                    • Therefore we are thinking there might be a "group" who have access to the camera, and you need to be a member of that group.
                    • You can list all groups with cat /etc/groups. You'd have to look through yours to see if there looks like anything "likely". You add users to groups via adduser user group.
                    • You can run sudo python3 qt5.py if you really want. But it's a really bad idea (haven't got time to list myriad reasons), and I think you'll really regret it as you try to do other stuff in your app.

                    BTW, did you have to install your "camera device/software"? If so did it come with any instructions about this?

                    Your Python code looks OK, and I doubt it will have anything to do with Python/PyQt.

                    I am a little surprised that just plain QCamera() hangs/requires permissions, because you're not even naming a device there, but it might do, or it might try to access the "default" camera device, i don't know. @jsulm / @SGaist know more than me.

                    Try @SGaist's suggestion of just enumerating the available cameras. You're going to need to learn soon how to turn his bit of Qt C++ code into Python to get anywhere much with Qt.... (Not meaning to be rude or disheartening, just a heads-up, but if you think you could just write code QCamera(0x72dbe3b0) in Python or C++ you have quite a bit still to learn before you'll be able to do stuff.)

                    Finally, I don't like the look of gdb python3 itself generating a SIGSEGV, but I don't know exactly what you did, could be a red-herring.

                    Your "screen going black and locking up" might be to do with it requesting a password to access, I really don't know. I assume you've got your camera all working and you can play with it OK outside of your application?

                    X Offline
                    X Offline
                    Xenoshell
                    wrote on 11 Dec 2017, 09:45 last edited by Xenoshell 12 Nov 2017, 09:53
                    #16

                    @JNBarchan

                    1. input: cat /etc/group -> output (i am in the group video)
                      I just post this if i dont see a group i should be in:
                    root:x:0:
                    daemon:x:1:
                    bin:x:2:
                    sys:x:3:
                    adm:x:4:syslog,blz
                    tty:x:5:
                    disk:x:6:
                    lp:x:7:
                    mail:x:8:
                    news:x:9:
                    uucp:x:10:
                    man:x:12:
                    proxy:x:13:
                    kmem:x:15:
                    dialout:x:20:
                    fax:x:21:
                    voice:x:22:
                    cdrom:x:24:blz
                    floppy:x:25:
                    tape:x:26:
                    sudo:x:27:blz
                    audio:x:29:pulse,blz
                    dip:x:30:blz
                    www-data:x:33:
                    backup:x:34:
                    operator:x:37:
                    list:x:38:
                    irc:x:39:
                    src:x:40:
                    gnats:x:41:
                    shadow:x:42:
                    utmp:x:43:
                    video:x:44:blz
                    sasl:x:45:
                    plugdev:x:46:blz
                    staff:x:50:
                    games:x:60:
                    users:x:100:
                    nogroup:x:65534:
                    systemd-journal:x:101:
                    systemd-timesync:x:102:
                    systemd-network:x:103:
                    systemd-resolve:x:104:
                    systemd-bus-proxy:x:105:
                    input:x:106:blz
                    crontab:x:107:
                    syslog:x:108:
                    netdev:x:109:
                    messagebus:x:110:
                    uuidd:x:111:
                    mlocate:x:112:
                    ssh:x:113:
                    ssl-cert:x:114:
                    lpadmin:x:115:blz
                    lightdm:x:116:
                    nopasswdlogin:x:117:
                    ntp:x:118:
                    avahi-autoipd:x:119:
                    avahi:x:120:
                    bluetooth:x:121:
                    scanner:x:122:saned
                    colord:x:123:
                    pulse:x:124:
                    pulse-access:x:125:
                    rtkit:x:126:
                    saned:x:127:
                    whoopsie:x:128:
                    gpio:x:999:blz
                    i2c:x:998:blz
                    spi:x:997:blz
                    blz:x:1000:
                    sambashare:x:129:blz
                    
                    
                    QCamera(0x72dbe3b0)
                    

                    From the QCamera documentation: "QCamera::QCamera(const QByteArray &deviceName, QObject *parent = Q_NULLPTR) Construct a QCamera from deviceName and parent."
                    Correct me if i'm wrong but that means if i know the deviceName that i can just initialize the Camera with QCamera(0x72dbe3b0).
                    3)
                    gdb is a debug program which can be used for segmentation fault errors.

                    @jsulm
                    4)
                    Input:

                    ls -l /home/blz/Schreibtisch/qt5.py
                    

                    Output:
                    -rwxrwxrwx 1 blz blz 1537 Dez 7 10:33 /home/blz/Schreibtisch/qt5.py
                    I guess that means that i have full accessibility to qt5.py

                    Thanks for your help. I appreciate your feedback.

                    Greets

                    J J 2 Replies Last reply 11 Dec 2017, 09:57
                    0
                    • X Xenoshell
                      11 Dec 2017, 09:45

                      @JNBarchan

                      1. input: cat /etc/group -> output (i am in the group video)
                        I just post this if i dont see a group i should be in:
                      root:x:0:
                      daemon:x:1:
                      bin:x:2:
                      sys:x:3:
                      adm:x:4:syslog,blz
                      tty:x:5:
                      disk:x:6:
                      lp:x:7:
                      mail:x:8:
                      news:x:9:
                      uucp:x:10:
                      man:x:12:
                      proxy:x:13:
                      kmem:x:15:
                      dialout:x:20:
                      fax:x:21:
                      voice:x:22:
                      cdrom:x:24:blz
                      floppy:x:25:
                      tape:x:26:
                      sudo:x:27:blz
                      audio:x:29:pulse,blz
                      dip:x:30:blz
                      www-data:x:33:
                      backup:x:34:
                      operator:x:37:
                      list:x:38:
                      irc:x:39:
                      src:x:40:
                      gnats:x:41:
                      shadow:x:42:
                      utmp:x:43:
                      video:x:44:blz
                      sasl:x:45:
                      plugdev:x:46:blz
                      staff:x:50:
                      games:x:60:
                      users:x:100:
                      nogroup:x:65534:
                      systemd-journal:x:101:
                      systemd-timesync:x:102:
                      systemd-network:x:103:
                      systemd-resolve:x:104:
                      systemd-bus-proxy:x:105:
                      input:x:106:blz
                      crontab:x:107:
                      syslog:x:108:
                      netdev:x:109:
                      messagebus:x:110:
                      uuidd:x:111:
                      mlocate:x:112:
                      ssh:x:113:
                      ssl-cert:x:114:
                      lpadmin:x:115:blz
                      lightdm:x:116:
                      nopasswdlogin:x:117:
                      ntp:x:118:
                      avahi-autoipd:x:119:
                      avahi:x:120:
                      bluetooth:x:121:
                      scanner:x:122:saned
                      colord:x:123:
                      pulse:x:124:
                      pulse-access:x:125:
                      rtkit:x:126:
                      saned:x:127:
                      whoopsie:x:128:
                      gpio:x:999:blz
                      i2c:x:998:blz
                      spi:x:997:blz
                      blz:x:1000:
                      sambashare:x:129:blz
                      
                      
                      QCamera(0x72dbe3b0)
                      

                      From the QCamera documentation: "QCamera::QCamera(const QByteArray &deviceName, QObject *parent = Q_NULLPTR) Construct a QCamera from deviceName and parent."
                      Correct me if i'm wrong but that means if i know the deviceName that i can just initialize the Camera with QCamera(0x72dbe3b0).
                      3)
                      gdb is a debug program which can be used for segmentation fault errors.

                      @jsulm
                      4)
                      Input:

                      ls -l /home/blz/Schreibtisch/qt5.py
                      

                      Output:
                      -rwxrwxrwx 1 blz blz 1537 Dez 7 10:33 /home/blz/Schreibtisch/qt5.py
                      I guess that means that i have full accessibility to qt5.py

                      Thanks for your help. I appreciate your feedback.

                      Greets

                      J Offline
                      J Offline
                      jsulm
                      Lifetime Qt Champion
                      wrote on 11 Dec 2017, 09:57 last edited by jsulm 12 Nov 2017, 09:59
                      #17

                      @Xenoshell 1. Well, the question is: what is the group of the camera device file?
                      2. You can use this code to see all the camera device names (http://doc.qt.io/qt-5/qcamera.html):

                      QList<QCameraInfo> cameras = QCameraInfo::availableCameras();
                      foreach (const QCameraInfo &cameraInfo, cameras) {
                          qDebug() << cameraInfo.deviceName();
                      }
                      
                      1. Yes, you can use GDB to get more information if your app crashes
                      2. Everyone has full access to Schreibtisch/qt5.py. Not sure how is this related?

                      https://forum.qt.io/topic/113070/qt-code-of-conduct

                      1 Reply Last reply
                      0
                      • X Xenoshell
                        11 Dec 2017, 09:45

                        @JNBarchan

                        1. input: cat /etc/group -> output (i am in the group video)
                          I just post this if i dont see a group i should be in:
                        root:x:0:
                        daemon:x:1:
                        bin:x:2:
                        sys:x:3:
                        adm:x:4:syslog,blz
                        tty:x:5:
                        disk:x:6:
                        lp:x:7:
                        mail:x:8:
                        news:x:9:
                        uucp:x:10:
                        man:x:12:
                        proxy:x:13:
                        kmem:x:15:
                        dialout:x:20:
                        fax:x:21:
                        voice:x:22:
                        cdrom:x:24:blz
                        floppy:x:25:
                        tape:x:26:
                        sudo:x:27:blz
                        audio:x:29:pulse,blz
                        dip:x:30:blz
                        www-data:x:33:
                        backup:x:34:
                        operator:x:37:
                        list:x:38:
                        irc:x:39:
                        src:x:40:
                        gnats:x:41:
                        shadow:x:42:
                        utmp:x:43:
                        video:x:44:blz
                        sasl:x:45:
                        plugdev:x:46:blz
                        staff:x:50:
                        games:x:60:
                        users:x:100:
                        nogroup:x:65534:
                        systemd-journal:x:101:
                        systemd-timesync:x:102:
                        systemd-network:x:103:
                        systemd-resolve:x:104:
                        systemd-bus-proxy:x:105:
                        input:x:106:blz
                        crontab:x:107:
                        syslog:x:108:
                        netdev:x:109:
                        messagebus:x:110:
                        uuidd:x:111:
                        mlocate:x:112:
                        ssh:x:113:
                        ssl-cert:x:114:
                        lpadmin:x:115:blz
                        lightdm:x:116:
                        nopasswdlogin:x:117:
                        ntp:x:118:
                        avahi-autoipd:x:119:
                        avahi:x:120:
                        bluetooth:x:121:
                        scanner:x:122:saned
                        colord:x:123:
                        pulse:x:124:
                        pulse-access:x:125:
                        rtkit:x:126:
                        saned:x:127:
                        whoopsie:x:128:
                        gpio:x:999:blz
                        i2c:x:998:blz
                        spi:x:997:blz
                        blz:x:1000:
                        sambashare:x:129:blz
                        
                        
                        QCamera(0x72dbe3b0)
                        

                        From the QCamera documentation: "QCamera::QCamera(const QByteArray &deviceName, QObject *parent = Q_NULLPTR) Construct a QCamera from deviceName and parent."
                        Correct me if i'm wrong but that means if i know the deviceName that i can just initialize the Camera with QCamera(0x72dbe3b0).
                        3)
                        gdb is a debug program which can be used for segmentation fault errors.

                        @jsulm
                        4)
                        Input:

                        ls -l /home/blz/Schreibtisch/qt5.py
                        

                        Output:
                        -rwxrwxrwx 1 blz blz 1537 Dez 7 10:33 /home/blz/Schreibtisch/qt5.py
                        I guess that means that i have full accessibility to qt5.py

                        Thanks for your help. I appreciate your feedback.

                        Greets

                        J Offline
                        J Offline
                        JonB
                        wrote on 11 Dec 2017, 10:37 last edited by
                        #18

                        @Xenoshell

                        Nothing looks interesting in your groups. Never mind, it was only an idea of @jsulm's, maybe or maybe not relevant.

                        Correct me if i'm wrong but that means if i know the deviceName that i can just initialize the Camera with QCamera(0x72dbe3b0).

                        It's so wrong. Fortunately in C++ it won't compile, in Python I hope it will spit it back at you. You really need to understand why this is plain wrong in any language/circumstance, if you're new to programming. You must pass a string which has the value of a device name to QCamera(), e.g. QCamera("camera-device-name"), or a device name picked up from a QCameraInfo.deviceName() (which itself is a string).

                        Please try @jsulm's suggestion of enumerating the available cameras you have. In Python it'll be like:

                        for cameraInfo in QCameraInfo.availableCameras():
                            print(cameraInfo.deviceName())
                        

                        QString QCameraInfo::deviceName() const
                        Returns the device name of the camera
                        This is a unique ID to identify the camera and may not be human-readable.

                        So a device name might come out like abc1234 (I don't know 'coz I haven't got one to test). Then the actual Linux device will be /dev/abc1234, or something like that. We want you to ls -l that, and look at its owner & group permissions, and see if you have access to it under your own user, not sudo. This is what we mean about "permissions", not the permissions you list for /home/blz/Schreibtisch/qt5.py.

                        X 1 Reply Last reply 11 Dec 2017, 11:32
                        0
                        • J JonB
                          11 Dec 2017, 10:37

                          @Xenoshell

                          Nothing looks interesting in your groups. Never mind, it was only an idea of @jsulm's, maybe or maybe not relevant.

                          Correct me if i'm wrong but that means if i know the deviceName that i can just initialize the Camera with QCamera(0x72dbe3b0).

                          It's so wrong. Fortunately in C++ it won't compile, in Python I hope it will spit it back at you. You really need to understand why this is plain wrong in any language/circumstance, if you're new to programming. You must pass a string which has the value of a device name to QCamera(), e.g. QCamera("camera-device-name"), or a device name picked up from a QCameraInfo.deviceName() (which itself is a string).

                          Please try @jsulm's suggestion of enumerating the available cameras you have. In Python it'll be like:

                          for cameraInfo in QCameraInfo.availableCameras():
                              print(cameraInfo.deviceName())
                          

                          QString QCameraInfo::deviceName() const
                          Returns the device name of the camera
                          This is a unique ID to identify the camera and may not be human-readable.

                          So a device name might come out like abc1234 (I don't know 'coz I haven't got one to test). Then the actual Linux device will be /dev/abc1234, or something like that. We want you to ls -l that, and look at its owner & group permissions, and see if you have access to it under your own user, not sudo. This is what we mean about "permissions", not the permissions you list for /home/blz/Schreibtisch/qt5.py.

                          X Offline
                          X Offline
                          Xenoshell
                          wrote on 11 Dec 2017, 11:32 last edited by Xenoshell 12 Nov 2017, 11:33
                          #19

                          @JNBarchan, @jsulm
                          The output for the for-loop is:

                          /dev/video0
                          

                          Here the output is:

                          blz@blz-desktop:~$ ls -l /dev/video0
                          crw-rw----+ 1 root video 81, 0 Dez 11 10:55 /dev/video0
                          
                          

                          To me it looks like i dont have the permission to everything.

                          J J 2 Replies Last reply 11 Dec 2017, 11:35
                          0
                          • X Xenoshell
                            11 Dec 2017, 11:32

                            @JNBarchan, @jsulm
                            The output for the for-loop is:

                            /dev/video0
                            

                            Here the output is:

                            blz@blz-desktop:~$ ls -l /dev/video0
                            crw-rw----+ 1 root video 81, 0 Dez 11 10:55 /dev/video0
                            
                            

                            To me it looks like i dont have the permission to everything.

                            J Offline
                            J Offline
                            jsulm
                            Lifetime Qt Champion
                            wrote on 11 Dec 2017, 11:35 last edited by
                            #20

                            @Xenoshell Add yourself to the video group if it's not already the case

                            https://forum.qt.io/topic/113070/qt-code-of-conduct

                            X 1 Reply Last reply 11 Dec 2017, 11:59
                            2
                            • X Xenoshell
                              11 Dec 2017, 11:32

                              @JNBarchan, @jsulm
                              The output for the for-loop is:

                              /dev/video0
                              

                              Here the output is:

                              blz@blz-desktop:~$ ls -l /dev/video0
                              crw-rw----+ 1 root video 81, 0 Dez 11 10:55 /dev/video0
                              
                              

                              To me it looks like i dont have the permission to everything.

                              J Offline
                              J Offline
                              JonB
                              wrote on 11 Dec 2017, 11:47 last edited by JonB 12 Nov 2017, 11:48
                              #21

                              @Xenoshell
                              You can see if you're already a member of video group via executing command groups.

                              If your username is blz, I think you already are....

                              If you are a member, it would then look like: as yourself, not root, you do have access to the camera device, hence you say it seems to "initially open", but then something else is happening which works as root but not as you.... You could temporarily sudo chmod 666 /dev/video0, see if that helps, then revert to sudo chmod 660 /dev/video0.

                              1 Reply Last reply
                              0
                              • J jsulm
                                11 Dec 2017, 11:35

                                @Xenoshell Add yourself to the video group if it's not already the case

                                X Offline
                                X Offline
                                Xenoshell
                                wrote on 11 Dec 2017, 11:59 last edited by
                                #22

                                @jsulm @JNBarchan ,
                                i am already member of the video group.
                                The camera device only opens if i use sudo. If i dont it just gets stuck at self.cam = QCamera().
                                After the command sudo chmod 666 /dev/video0 i tried using qt5.py without sudo but it just got stuck.
                                So there has to be a group which i am not a member of that uses QCamera(). Am i at least right with this assumption?

                                1 Reply Last reply
                                0
                                • X Offline
                                  X Offline
                                  Xenoshell
                                  wrote on 11 Dec 2017, 15:37 last edited by
                                  #23

                                  Ok i cant reproduce the gdb output anymore. It just stops at 1 and then somehow locks up and i have to relog again.
                                  I somehow have this feeling that the code/the usb-camera use audio or at least try to use it. When i want to turn off the pi i always get the message that "Pulse Audio Sound System" is currently running and if i want to terminate it.
                                  Tomorrow i will sit down and try to get the gdb output without sudo /with sudo and look what is possible.
                                  Debugging can really be stressful...

                                  1 Reply Last reply
                                  0
                                  • X Offline
                                    X Offline
                                    Xenoshell
                                    wrote on 12 Dec 2017, 09:35 last edited by Xenoshell 12 Dec 2017, 09:39
                                    #24

                                    @jsulm, @JNBarchan
                                    Here i am again, this is the new gdb output:

                                    (gdb) run qt5.py
                                    Starting program: /usr/bin/python3 qt5.py
                                    Cannot parse expression `.L1185 4@r4'.
                                    warning: Probes-based dynamic linker interface failed.
                                    Reverting to original interface.
                                    
                                    [Thread debugging using libthread_db enabled]
                                    Using host libthread_db library "/lib/arm-linux-gnueabihf/libthread_db.so.1".
                                    1
                                    [New Thread 0x72b39470 (LWP 4134)]
                                    2
                                    3
                                    [New Thread 0x6de10470 (LWP 4139)]
                                    [Thread 0x6de10470 (LWP 4139) exited]
                                    [New Thread 0x6de10470 (LWP 4140)]
                                    [Thread 0x6de10470 (LWP 4140) exited]
                                    

                                    At this output is libpulse.so and also libasound.so.2 i talked about in my post above. It could actually be that QCamera() tries to also initalise Audio but obviously i dont have any audiooutput plugged in and thats why it stops at QCamera

                                    (gdb) bt
                                    #0  __libc_do_syscall () at ../sysdeps/unix/sysv/linux/arm/libc-do-syscall.S:46
                                    #1  0x76f21c0a in __GI_ppoll (fds=0x7001a8, nfds=1, timeout=<optimized out>, 
                                        sigmask=0x0) at ../sysdeps/unix/sysv/linux/ppoll.c:50
                                    #2  0x73389e12 in pa_mainloop_poll ()
                                       from /usr/lib/arm-linux-gnueabihf/libpulse.so.0
                                    #3  0x7338a290 in pa_mainloop_iterate ()
                                       from /usr/lib/arm-linux-gnueabihf/libpulse.so.0
                                    #4  0x6de2888c in conf_pulse_hook_load_if_running ()
                                       from /usr/lib/arm-linux-gnueabihf/alsa-lib/libasound_module_conf_pulse.so
                                    #5  0x6e01c9f2 in ?? () from /usr/lib/arm-linux-gnueabihf/libasound.so.2
                                    Backtrace stopped: previous frame identical to this frame (corrupt stack?)
                                    

                                    Here the info threads:

                                    (gdb) info threads
                                      Id   Target Id         Frame 
                                    * 1    Thread 0x76ff6300 (LWP 4204) "python3" __libc_do_syscall ()
                                        at ../sysdeps/unix/sysv/linux/arm/libc-do-syscall.S:46
                                      2    Thread 0x72b39470 (LWP 4206) "QXcbEventReader" 0x76f21b90 in poll ()
                                        at ../sysdeps/unix/syscall-template.S:84
                                    

                                    Can anyone tell me whats going on in those gdb outputs? Are they even important or are they just there and we cant really do anything with them?

                                    J 1 Reply Last reply 12 Dec 2017, 10:20
                                    0
                                    • X Xenoshell
                                      12 Dec 2017, 09:35

                                      @jsulm, @JNBarchan
                                      Here i am again, this is the new gdb output:

                                      (gdb) run qt5.py
                                      Starting program: /usr/bin/python3 qt5.py
                                      Cannot parse expression `.L1185 4@r4'.
                                      warning: Probes-based dynamic linker interface failed.
                                      Reverting to original interface.
                                      
                                      [Thread debugging using libthread_db enabled]
                                      Using host libthread_db library "/lib/arm-linux-gnueabihf/libthread_db.so.1".
                                      1
                                      [New Thread 0x72b39470 (LWP 4134)]
                                      2
                                      3
                                      [New Thread 0x6de10470 (LWP 4139)]
                                      [Thread 0x6de10470 (LWP 4139) exited]
                                      [New Thread 0x6de10470 (LWP 4140)]
                                      [Thread 0x6de10470 (LWP 4140) exited]
                                      

                                      At this output is libpulse.so and also libasound.so.2 i talked about in my post above. It could actually be that QCamera() tries to also initalise Audio but obviously i dont have any audiooutput plugged in and thats why it stops at QCamera

                                      (gdb) bt
                                      #0  __libc_do_syscall () at ../sysdeps/unix/sysv/linux/arm/libc-do-syscall.S:46
                                      #1  0x76f21c0a in __GI_ppoll (fds=0x7001a8, nfds=1, timeout=<optimized out>, 
                                          sigmask=0x0) at ../sysdeps/unix/sysv/linux/ppoll.c:50
                                      #2  0x73389e12 in pa_mainloop_poll ()
                                         from /usr/lib/arm-linux-gnueabihf/libpulse.so.0
                                      #3  0x7338a290 in pa_mainloop_iterate ()
                                         from /usr/lib/arm-linux-gnueabihf/libpulse.so.0
                                      #4  0x6de2888c in conf_pulse_hook_load_if_running ()
                                         from /usr/lib/arm-linux-gnueabihf/alsa-lib/libasound_module_conf_pulse.so
                                      #5  0x6e01c9f2 in ?? () from /usr/lib/arm-linux-gnueabihf/libasound.so.2
                                      Backtrace stopped: previous frame identical to this frame (corrupt stack?)
                                      

                                      Here the info threads:

                                      (gdb) info threads
                                        Id   Target Id         Frame 
                                      * 1    Thread 0x76ff6300 (LWP 4204) "python3" __libc_do_syscall ()
                                          at ../sysdeps/unix/sysv/linux/arm/libc-do-syscall.S:46
                                        2    Thread 0x72b39470 (LWP 4206) "QXcbEventReader" 0x76f21b90 in poll ()
                                          at ../sysdeps/unix/syscall-template.S:84
                                      

                                      Can anyone tell me whats going on in those gdb outputs? Are they even important or are they just there and we cant really do anything with them?

                                      J Offline
                                      J Offline
                                      JonB
                                      wrote on 12 Dec 2017, 10:20 last edited by
                                      #25

                                      @Xenoshell
                                      Because you are using Python, not a standalone executable of your program compiled from C++, if you use gdb you have to gdb the Python executable, not your app running as a Python script. This means gdb probably is not of any interest to you, per se, for general debugging of your app; though it may give us some clues in this particular case.

                                      To clarify, for your app script completely. Just run gdb against Python without any mention of your qt5.py script. For the record, here is my output under Ubuntu not Pi:

                                      jon@ubuntu:~$ gdb python3
                                      Reading symbols from python3...(no debugging symbols found)...done.
                                      (gdb) run
                                      Starting program: /usr/bin/python3 
                                      [Thread debugging using libthread_db enabled]
                                      Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
                                      Python 3.5.3 (default, Nov 23 2017, 11:34:05) 
                                      [GCC 6.3.0 20170406] on linux
                                      Type "help", "copyright", "credits" or "license" for more information.
                                      >>> 
                                      
                                      

                                      Does yours produce much the same? Does it only give the libpulse/libasound if a certain line is in your Python script, and not if it is removed, then you'd have an idea what is related to what? I wish you'd show what that line is now, because we no longer know whether you are enumerating available cameras or opening a camera?

                                      X 1 Reply Last reply 12 Dec 2017, 10:51
                                      0
                                      • J JonB
                                        12 Dec 2017, 10:20

                                        @Xenoshell
                                        Because you are using Python, not a standalone executable of your program compiled from C++, if you use gdb you have to gdb the Python executable, not your app running as a Python script. This means gdb probably is not of any interest to you, per se, for general debugging of your app; though it may give us some clues in this particular case.

                                        To clarify, for your app script completely. Just run gdb against Python without any mention of your qt5.py script. For the record, here is my output under Ubuntu not Pi:

                                        jon@ubuntu:~$ gdb python3
                                        Reading symbols from python3...(no debugging symbols found)...done.
                                        (gdb) run
                                        Starting program: /usr/bin/python3 
                                        [Thread debugging using libthread_db enabled]
                                        Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
                                        Python 3.5.3 (default, Nov 23 2017, 11:34:05) 
                                        [GCC 6.3.0 20170406] on linux
                                        Type "help", "copyright", "credits" or "license" for more information.
                                        >>> 
                                        
                                        

                                        Does yours produce much the same? Does it only give the libpulse/libasound if a certain line is in your Python script, and not if it is removed, then you'd have an idea what is related to what? I wish you'd show what that line is now, because we no longer know whether you are enumerating available cameras or opening a camera?

                                        X Offline
                                        X Offline
                                        Xenoshell
                                        wrote on 12 Dec 2017, 10:51 last edited by Xenoshell 12 Dec 2017, 10:52
                                        #26

                                        @JNBarchan
                                        This is the whole output:

                                        blz@blz-desktop:~$ gdb python3
                                        GNU gdb (Ubuntu 7.11.1-0ubuntu1~16.5) 7.11.1
                                        Copyright (C) 2016 Free Software Foundation, Inc.
                                        License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
                                        This is free software: you are free to change and redistribute it.
                                        There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
                                        and "show warranty" for details.
                                        This GDB was configured as "arm-linux-gnueabihf".
                                        Type "show configuration" for configuration details.
                                        For bug reporting instructions, please see:
                                        <http://www.gnu.org/software/gdb/bugs/>.
                                        Find the GDB manual and other documentation resources online at:
                                        <http://www.gnu.org/software/gdb/documentation/>.
                                        For help, type "help".
                                        Type "apropos word" to search for commands related to "word"...
                                        Reading symbols from python3...Reading symbols from /usr/lib/debug/.build-id/d7/14ad8d8b52ca34a8a81f10b4917027977b05ca.debug...done.
                                        done.
                                        (gdb) run
                                        Starting program: /usr/bin/python3 
                                        Cannot parse expression `.L1185 4@r4'.
                                        warning: Probes-based dynamic linker interface failed.
                                        Reverting to original interface.
                                        
                                        [Thread debugging using libthread_db enabled]
                                        Using host libthread_db library "/lib/arm-linux-gnueabihf/libthread_db.so.1".
                                        Python 3.5.2 (default, Nov 23 2017, 16:37:01) 
                                        [GCC 5.4.0 20160609] on linux
                                        Type "help", "copyright", "credits" or "license" for more information.
                                        >>> 
                                        
                                        

                                        My code always stops at self.cam = QCamera() otherwise it would also print 4 and not suddenly stop
                                        As a reminder, here is my code:

                                        import sys
                                        from PyQt5 import QtCore , QtWidgets, QtGui, QtMultimedia, QtMultimediaWidgets
                                        from PyQt5.QtCore import QObject, pyqtSignal, pyqtSlot
                                        from PyQt5.QtWidgets import QApplication, QPushButton, QMainWindow
                                        from PyQt5.QtMultimedia import QCamera, QCameraInfo, QMediaObject, QCameraViewfinderSettings, QCameraImageCapture
                                        from PyQt5.QtMultimediaWidgets import QCameraViewfinder
                                        
                                        
                                        class Camera(QObject):
                                            def __init__(self, parent = QObject()):
                                                super(Camera, self).__init__(parent)
                                                print("3")
                                                self.cam = QCamera()
                                                print("4")
                                                self.caminfo = QCameraInfo(self.cam)
                                                self.camvfind = QCameraViewfinder()
                                                self.camvfindset = QCameraViewfinderSettings()
                                                self.cammode = self.cam.CaptureMode(2)
                                                self.camimgcap = QCameraImageCapture(self.cam)
                                        
                                            def iniCamera(self):
                                                #print(self.caminfo.description())
                                                #print(self.caminfo.availableCameras())
                                                
                                                for caminfo in QCameraInfo.availableCameras():
                                                    print(caminfo.deviceName())
                                                
                                                
                                                if self.cam.isCaptureModeSupported(self.cammode):
                                                    print("Capturemode supported")
                                            
                                            def startVid(self):
                                                self.camimgcap.CaptureDestination(2)
                                                
                                                self.camvfind.show()
                                                
                                                self.cam.setViewfinder(self.camvfind)
                                                
                                                self.cam.setCaptureMode(self.cammode)
                                                
                                                self.cam.start()
                                                
                                                
                                        
                                        if __name__ == '__main__':
                                            print("1")
                                            app = QtWidgets.QApplication(sys.argv)
                                            print("2")
                                            cam = Camera()
                                            print("4")
                                            cam.iniCamera()
                                            
                                            cam.startVid()
                                            
                                            sys.exit(app.exec_())
                                        
                                        
                                        J 1 Reply Last reply 12 Dec 2017, 12:10
                                        0
                                        • X Xenoshell
                                          12 Dec 2017, 10:51

                                          @JNBarchan
                                          This is the whole output:

                                          blz@blz-desktop:~$ gdb python3
                                          GNU gdb (Ubuntu 7.11.1-0ubuntu1~16.5) 7.11.1
                                          Copyright (C) 2016 Free Software Foundation, Inc.
                                          License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
                                          This is free software: you are free to change and redistribute it.
                                          There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
                                          and "show warranty" for details.
                                          This GDB was configured as "arm-linux-gnueabihf".
                                          Type "show configuration" for configuration details.
                                          For bug reporting instructions, please see:
                                          <http://www.gnu.org/software/gdb/bugs/>.
                                          Find the GDB manual and other documentation resources online at:
                                          <http://www.gnu.org/software/gdb/documentation/>.
                                          For help, type "help".
                                          Type "apropos word" to search for commands related to "word"...
                                          Reading symbols from python3...Reading symbols from /usr/lib/debug/.build-id/d7/14ad8d8b52ca34a8a81f10b4917027977b05ca.debug...done.
                                          done.
                                          (gdb) run
                                          Starting program: /usr/bin/python3 
                                          Cannot parse expression `.L1185 4@r4'.
                                          warning: Probes-based dynamic linker interface failed.
                                          Reverting to original interface.
                                          
                                          [Thread debugging using libthread_db enabled]
                                          Using host libthread_db library "/lib/arm-linux-gnueabihf/libthread_db.so.1".
                                          Python 3.5.2 (default, Nov 23 2017, 16:37:01) 
                                          [GCC 5.4.0 20160609] on linux
                                          Type "help", "copyright", "credits" or "license" for more information.
                                          >>> 
                                          
                                          

                                          My code always stops at self.cam = QCamera() otherwise it would also print 4 and not suddenly stop
                                          As a reminder, here is my code:

                                          import sys
                                          from PyQt5 import QtCore , QtWidgets, QtGui, QtMultimedia, QtMultimediaWidgets
                                          from PyQt5.QtCore import QObject, pyqtSignal, pyqtSlot
                                          from PyQt5.QtWidgets import QApplication, QPushButton, QMainWindow
                                          from PyQt5.QtMultimedia import QCamera, QCameraInfo, QMediaObject, QCameraViewfinderSettings, QCameraImageCapture
                                          from PyQt5.QtMultimediaWidgets import QCameraViewfinder
                                          
                                          
                                          class Camera(QObject):
                                              def __init__(self, parent = QObject()):
                                                  super(Camera, self).__init__(parent)
                                                  print("3")
                                                  self.cam = QCamera()
                                                  print("4")
                                                  self.caminfo = QCameraInfo(self.cam)
                                                  self.camvfind = QCameraViewfinder()
                                                  self.camvfindset = QCameraViewfinderSettings()
                                                  self.cammode = self.cam.CaptureMode(2)
                                                  self.camimgcap = QCameraImageCapture(self.cam)
                                          
                                              def iniCamera(self):
                                                  #print(self.caminfo.description())
                                                  #print(self.caminfo.availableCameras())
                                                  
                                                  for caminfo in QCameraInfo.availableCameras():
                                                      print(caminfo.deviceName())
                                                  
                                                  
                                                  if self.cam.isCaptureModeSupported(self.cammode):
                                                      print("Capturemode supported")
                                              
                                              def startVid(self):
                                                  self.camimgcap.CaptureDestination(2)
                                                  
                                                  self.camvfind.show()
                                                  
                                                  self.cam.setViewfinder(self.camvfind)
                                                  
                                                  self.cam.setCaptureMode(self.cammode)
                                                  
                                                  self.cam.start()
                                                  
                                                  
                                          
                                          if __name__ == '__main__':
                                              print("1")
                                              app = QtWidgets.QApplication(sys.argv)
                                              print("2")
                                              cam = Camera()
                                              print("4")
                                              cam.iniCamera()
                                              
                                              cam.startVid()
                                              
                                              sys.exit(app.exec_())
                                          
                                          
                                          J Offline
                                          J Offline
                                          JonB
                                          wrote on 12 Dec 2017, 12:10 last edited by JonB 12 Dec 2017, 12:11
                                          #27

                                          @Xenoshell
                                          I asked earlier:

                                          Does it only give the libpulse/libasound if a certain line is in your Python script, and not if it is removed, then you'd have an idea what is related to what?

                                          So, if I were you, under gdb, I'd try commenting in & commenting out the QCamera() line, and report whether your debugger only shows the libpulse error if & only if you have that line in there. then you'd know for sure whether QCamera() has anything to do with libpulse....

                                          I'd also try QCamera("video0") or QCamera("/dev/video0") or whatever it is, instead of plain QCamera(). I'd probably also try QCamera("rubbish"). These are all things for you to play with to try to understand just what causes the problem/hang, it's up to you....

                                          X 1 Reply Last reply 12 Dec 2017, 13:05
                                          0

                                          17/55

                                          11 Dec 2017, 09:57

                                          topic:navigator.unread, 38
                                          • Login

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