Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. Inconsistent behavior of QSerialPort on Debian
Forum Updated to NodeBB v4.3 + New Features

Inconsistent behavior of QSerialPort on Debian

Scheduled Pinned Locked Moved Unsolved General and Desktop
qtserialportlinuxescpos
23 Posts 3 Posters 8.1k 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.
  • S Offline
    S Offline
    SGaist
    Lifetime Qt Champion
    wrote on 3 Feb 2016, 22:05 last edited by
    #13

    All of them physical ports of your computer or converter like usb to serial ?

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

    H 1 Reply Last reply 4 Feb 2016, 12:50
    0
    • S SGaist
      3 Feb 2016, 22:05

      All of them physical ports of your computer or converter like usb to serial ?

      H Offline
      H Offline
      Hjunior
      wrote on 4 Feb 2016, 12:50 last edited by
      #14

      @SGaist Yes all of them are phsical ports of my computer. NO usb to serial.

      1 Reply Last reply
      0
      • S Offline
        S Offline
        SGaist
        Lifetime Qt Champion
        wrote on 4 Feb 2016, 20:29 last edited by
        #15

        Does it also happen if you change devices e.g. exchange the devices from ttyS1 and ttyS6.

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

        H 1 Reply Last reply 15 Feb 2016, 08:12
        0
        • S SGaist
          4 Feb 2016, 20:29

          Does it also happen if you change devices e.g. exchange the devices from ttyS1 and ttyS6.

          H Offline
          H Offline
          Hjunior
          wrote on 15 Feb 2016, 08:12 last edited by
          #16

          @SGaist No difference.

          1 Reply Last reply
          0
          • S Offline
            S Offline
            SGaist
            Lifetime Qt Champion
            wrote on 15 Feb 2016, 21:50 last edited by
            #17

            Does the devies need the DTR to be set ?

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

            H 1 Reply Last reply 21 Feb 2016, 14:05
            0
            • S SGaist
              15 Feb 2016, 21:50

              Does the devies need the DTR to be set ?

              H Offline
              H Offline
              Hjunior
              wrote on 21 Feb 2016, 14:05 last edited by
              #18

              @SGaist Yes the device uses Hardware flow control and in the technical manual says it uses DTR/DSR.

              1 Reply Last reply
              0
              • S Offline
                S Offline
                SGaist
                Lifetime Qt Champion
                wrote on 21 Feb 2016, 20:37 last edited by
                #19

                Silly question but, did you set DTR in your application ?

                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
                • H Offline
                  H Offline
                  Hjunior
                  wrote on 12 May 2016, 14:23 last edited by
                  #20

                  Hello again,

                  I finally figured out how this occurs.

                  BaseSerialDevice.cpp

                  class BaseSerialDevice : public QObject
                  {
                      Q_OBJECT
                  ....
                  protected:
                      QSerialPort *serial;
                  ....
                  

                  Problematic.cpp

                  class Problematic : public BaseSerialDevice
                  {
                      Q_OBJECT
                  ...
                  

                  MainWindow.h

                  ...
                  private:
                      Problematic worksLikeACharm;
                  

                  Everything works as expected if defined as a NON-POINTER but if;
                  MainWindow.h

                  ...
                  private:
                      Problematic* notWorksSo;
                  

                  then in MainWindow.cpp's constructor:

                  notWorksSo = new Problematic(parent()); 
                  or 
                  notWorksSo = new Problematic(NULL); 
                  or 
                  notWorksSo = new Problematic;
                  

                  the problem occurs as defined at the start of this topic. And same situation occurs if we use QSocket as same architecture.

                  I tested it from scratch at least 6 times. Im sure of that case.

                  And Cant believe and cant understand why?

                  1 Reply Last reply
                  0
                  • S Offline
                    S Offline
                    SGaist
                    Lifetime Qt Champion
                    wrote on 12 May 2016, 20:04 last edited by
                    #21

                    And if you build it with Problematic(this) ?

                    When you don't pass it a parent, do you delete it in the destructor of your MainWindow ?

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

                    H 1 Reply Last reply 13 May 2016, 06:34
                    0
                    • S SGaist
                      12 May 2016, 20:04

                      And if you build it with Problematic(this) ?

                      When you don't pass it a parent, do you delete it in the destructor of your MainWindow ?

                      H Offline
                      H Offline
                      Hjunior
                      wrote on 13 May 2016, 06:34 last edited by
                      #22

                      @SGaist Hi.

                      I am tried with Problematic(this) no change. In case of no parent arg i tried with delete, but nothing changed.

                      I tried making it static as
                      MainWindow.h

                      static Problematic* notWorksSo;
                      

                      MainWindow.cpp

                      Problematic* MainWindow::notWorksSo = 0;
                      

                      then in constructor

                      notWorksSo = new Problematic(this); 
                      

                      NOTHING CHANGED.

                      Any ideas?

                      1 Reply Last reply
                      0
                      • S Offline
                        S Offline
                        SGaist
                        Lifetime Qt Champion
                        wrote on 13 May 2016, 20:04 last edited by
                        #23

                        Without seeing the implementation of these classes I can't tell.

                        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