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. Modbus TCP Client write holding registers
Forum Updated to NodeBB v4.3 + New Features

Modbus TCP Client write holding registers

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

    Look..
    I wold like call wr_ready when QbyteArray (m_holdRegArray) was changed, so I created code like below:

    
    void ClientMachine1::run()
    {
       ///my Modbus TCP Client code 
       ///........  
       how connect wr_redy  with  signal   holdRegArrayChanged 	
       
    }
    
    QByteArray ClientMachine1::holdRegArray() const
    {
        return m_holdRegArray;
    }
    
    void ClientMachine1::setHoldRegArray(const QByteArray &newHoldRegArray)
    {
        if (m_holdRegArray == newHoldRegArray)
            return;
        m_holdRegArray = newHoldRegArray;
        emit holdRegArrayChanged();
    }
    

    How connect holdRegArrayChanged with wr_ready inside run() thread ?

    jsulmJ 1 Reply Last reply
    0
    • D Damian7546

      Look..
      I wold like call wr_ready when QbyteArray (m_holdRegArray) was changed, so I created code like below:

      
      void ClientMachine1::run()
      {
         ///my Modbus TCP Client code 
         ///........  
         how connect wr_redy  with  signal   holdRegArrayChanged 	
         
      }
      
      QByteArray ClientMachine1::holdRegArray() const
      {
          return m_holdRegArray;
      }
      
      void ClientMachine1::setHoldRegArray(const QByteArray &newHoldRegArray)
      {
          if (m_holdRegArray == newHoldRegArray)
              return;
          m_holdRegArray = newHoldRegArray;
          emit holdRegArrayChanged();
      }
      

      How connect holdRegArrayChanged with wr_ready inside run() thread ?

      jsulmJ Offline
      jsulmJ Offline
      jsulm
      Lifetime Qt Champion
      wrote on last edited by
      #5

      @Damian7546 I still don't understand the problem. If wr_ready is a slot and holdRegArrayChanged a signal then simply connect them like any other signal/slot. Can you explain what exactly is not clear?

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

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

        Because wr_ready is not visible in the constructor:

        ClientMachine1::ClientMachine1(QObject *parent)
            : QThread{parent}
        {
        
            connect(this, ClientMachine1::holdRegArrayChanged, this, ClientMachine1::wr_ready);
        }
        

        In othe hand, the holdRegArrayChanged I can not connect inside run() because I have errors:

        Reference to non-static member function must be called; did you mean to call it with no arguments? (fix available)
        insert '()'
        
        No member named 'wr_redy' in 'ClientMachine1'
        
        jsulmJ 1 Reply Last reply
        0
        • D Damian7546

          Because wr_ready is not visible in the constructor:

          ClientMachine1::ClientMachine1(QObject *parent)
              : QThread{parent}
          {
          
              connect(this, ClientMachine1::holdRegArrayChanged, this, ClientMachine1::wr_ready);
          }
          

          In othe hand, the holdRegArrayChanged I can not connect inside run() because I have errors:

          Reference to non-static member function must be called; did you mean to call it with no arguments? (fix available)
          insert '()'
          
          No member named 'wr_redy' in 'ClientMachine1'
          
          jsulmJ Offline
          jsulmJ Offline
          jsulm
          Lifetime Qt Champion
          wrote on last edited by
          #7

          @Damian7546 said in Modbus TCP Client write holding registers:

          Because wr_ready is not visible in the constructor

          Of course it's not, because you defined it inside run().
          Simply define it as normal member of ClientMachine1...

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

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

            Can you tell me how create definition in *.h file to my wr_redy lambda contruction and auto type ?

            jsulmJ 2 Replies Last reply
            0
            • D Damian7546

              Can you tell me how create definition in *.h file to my wr_redy lambda contruction and auto type ?

              jsulmJ Offline
              jsulmJ Offline
              jsulm
              Lifetime Qt Champion
              wrote on last edited by
              #9

              @Damian7546 said in Modbus TCP Client write holding registers:

              Can you tell me how create definition in *.h file to my wr_redy lambda contruction and auto type ?

              Why does it have to be a lambda?

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

              D 1 Reply Last reply
              0
              • D Damian7546

                Can you tell me how create definition in *.h file to my wr_redy lambda contruction and auto type ?

                jsulmJ Offline
                jsulmJ Offline
                jsulm
                Lifetime Qt Champion
                wrote on last edited by
                #10

                @Damian7546 I'm also wondering why you use threads at all?
                If you need to do something periodically then simply use QTimer.

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

                D 1 Reply Last reply
                0
                • jsulmJ jsulm

                  @Damian7546 said in Modbus TCP Client write holding registers:

                  Can you tell me how create definition in *.h file to my wr_redy lambda contruction and auto type ?

                  Why does it have to be a lambda?

                  D Offline
                  D Offline
                  Damian7546
                  wrote on last edited by Damian7546
                  #11

                  @jsulm said in Modbus TCP Client write holding registers:

                  @Damian7546 said in Modbus TCP Client write holding registers:

                  Can you tell me how create definition in *.h file to my wr_redy lambda contruction and auto type ?

                  Why does it have to be a lambda?

                  I just want to know how to do it - for my own knowledge

                  1 Reply Last reply
                  0
                  • jsulmJ jsulm

                    @Damian7546 I'm also wondering why you use threads at all?
                    If you need to do something periodically then simply use QTimer.

                    D Offline
                    D Offline
                    Damian7546
                    wrote on last edited by Damian7546
                    #12

                    @jsulm said in Modbus TCP Client write holding registers:

                    @Damian7546 I'm also wondering why you use threads at all?
                    If you need to do something periodically then simply use QTimer.

                    I would like to run Client on thread and test with several clients(threads) ... how will it be with stability and read/write speed,
                    So how define wr_redy in *.h file ?

                    jsulmJ 1 Reply Last reply
                    0
                    • D Damian7546

                      @jsulm said in Modbus TCP Client write holding registers:

                      @Damian7546 I'm also wondering why you use threads at all?
                      If you need to do something periodically then simply use QTimer.

                      I would like to run Client on thread and test with several clients(threads) ... how will it be with stability and read/write speed,
                      So how define wr_redy in *.h file ?

                      jsulmJ Offline
                      jsulmJ Offline
                      jsulm
                      Lifetime Qt Champion
                      wrote on last edited by
                      #13

                      @Damian7546 said in Modbus TCP Client write holding registers:

                      So how define wr_redy in *.h file ?

                      Don't define it as lambda, but a normal method.

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

                      D 1 Reply Last reply
                      0
                      • jsulmJ jsulm

                        @Damian7546 said in Modbus TCP Client write holding registers:

                        So how define wr_redy in *.h file ?

                        Don't define it as lambda, but a normal method.

                        D Offline
                        D Offline
                        Damian7546
                        wrote on last edited by Damian7546
                        #14

                        @jsulm How do I do that?
                        When I declare my function in *.h file :
                        void wr_redy();

                        And I will create definition this function outside my run() function , I do not have acces to variables defined in run()...

                        jsulmJ 1 Reply Last reply
                        0
                        • D Damian7546

                          @jsulm How do I do that?
                          When I declare my function in *.h file :
                          void wr_redy();

                          And I will create definition this function outside my run() function , I do not have acces to variables defined in run()...

                          jsulmJ Offline
                          jsulmJ Offline
                          jsulm
                          Lifetime Qt Champion
                          wrote on last edited by
                          #15

                          @Damian7546 If you want to connect a lambda to a signal then do it properly:

                          connect(this, ClientMachine1::holdRegArrayChanged, this, wr_redy);
                          

                          wr_redy is NOT a member of your class, so simply do not prefix it with your class name.

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

                          D 1 Reply Last reply
                          0
                          • jsulmJ jsulm

                            @Damian7546 If you want to connect a lambda to a signal then do it properly:

                            connect(this, ClientMachine1::holdRegArrayChanged, this, wr_redy);
                            

                            wr_redy is NOT a member of your class, so simply do not prefix it with your class name.

                            D Offline
                            D Offline
                            Damian7546
                            wrote on last edited by
                            #16

                            @jsulm said in Modbus TCP Client write holding registers:

                            @Damian7546 If you want to connect a lambda to a signal then do it properly:

                            connect(this, ClientMachine1::holdRegArrayChanged, this, wr_redy);
                            

                            wr_redy is NOT a member of your class, so simply do not prefix it with your class name.

                            Right

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

                              @jsulm Unfortunetly my write function still doesn't work:/

                              auto wr_redy = [&](){
                                          for(int i=0; i < m_holdRegArray.count(); i++){
                                              qDebug() << "count: " << i;
                                              wr.setValue(i, m_holdRegArray[i]);
                                          }
                                  };
                              

                              The application was crash when it wr.setValue(i, m_holdRegArray[i]); is called...

                              jsulmJ 1 Reply Last reply
                              0
                              • D Damian7546

                                @jsulm Unfortunetly my write function still doesn't work:/

                                auto wr_redy = [&](){
                                            for(int i=0; i < m_holdRegArray.count(); i++){
                                                qDebug() << "count: " << i;
                                                wr.setValue(i, m_holdRegArray[i]);
                                            }
                                    };
                                

                                The application was crash when it wr.setValue(i, m_holdRegArray[i]); is called...

                                jsulmJ Offline
                                jsulmJ Offline
                                jsulm
                                Lifetime Qt Champion
                                wrote on last edited by
                                #18

                                @Damian7546 said in Modbus TCP Client write holding registers:

                                The application was crash when

                                So, did you use debugger to see why it crashes?
                                What is wr?

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

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

                                  @jsulm When I have status: "ModbusTCPClient is disconnected" my app crash when I try write registers..

                                  jsulmJ 1 Reply Last reply
                                  0
                                  • D Damian7546

                                    @jsulm When I have status: "ModbusTCPClient is disconnected" my app crash when I try write registers..

                                    jsulmJ Offline
                                    jsulmJ Offline
                                    jsulm
                                    Lifetime Qt Champion
                                    wrote on last edited by
                                    #20

                                    @Damian7546 Then don't write registers if there is no connection...

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

                                    D 1 Reply Last reply
                                    0
                                    • jsulmJ jsulm

                                      @Damian7546 Then don't write registers if there is no connection...

                                      D Offline
                                      D Offline
                                      Damian7546
                                      wrote on last edited by
                                      #21

                                      @jsulm I was wrong, sometimes app was crash when I try write value. I get message like below :

                                      QSocketNotifier: Socket notifiers cannot be enabled or disabled from another thread
                                      QObject: Cannot create children for a parent that is in a different thread.
                                      (Parent is QModbusTcpClient(0x504f8fc), parent's thread is ClientTicketMach(0x1215a30), current thread is QThread(0x11c0b28)
                                      QObject::startTimer: Timers cannot be started from another thread
                                      Error Modbus TCP CLient read:  QModbusDevice::TimeoutError
                                      QObject::killTimer: Timers cannot be stopped from another thread
                                      
                                      jsulmJ 1 Reply Last reply
                                      0
                                      • D Damian7546

                                        @jsulm I was wrong, sometimes app was crash when I try write value. I get message like below :

                                        QSocketNotifier: Socket notifiers cannot be enabled or disabled from another thread
                                        QObject: Cannot create children for a parent that is in a different thread.
                                        (Parent is QModbusTcpClient(0x504f8fc), parent's thread is ClientTicketMach(0x1215a30), current thread is QThread(0x11c0b28)
                                        QObject::startTimer: Timers cannot be started from another thread
                                        Error Modbus TCP CLient read:  QModbusDevice::TimeoutError
                                        QObject::killTimer: Timers cannot be stopped from another thread
                                        
                                        jsulmJ Offline
                                        jsulmJ Offline
                                        jsulm
                                        Lifetime Qt Champion
                                        wrote on last edited by
                                        #22

                                        @Damian7546 As all these errors tell you: do the threading properly!

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

                                        D 1 Reply Last reply
                                        0
                                        • D Offline
                                          D Offline
                                          Damian7546
                                          wrote on last edited by Damian7546
                                          #23
                                          This post is deleted!
                                          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