Duet3D Logo Duet3D
    • Tags
    • Documentation
    • Order
    • Register
    • Login

    Duet sometimes really slow? - I2C error or?

    Scheduled Pinned Locked Moved
    Other control boards
    13
    147
    17.5k
    Loading More Posts
    • 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.
    • TBSundefined
      TBS
      last edited by

      Here is my short update:
      I have updated to 2.02. The error has recurred. This time again at the start of printing.

      dc42undefined 1 Reply Last reply Reply Quote 0
      • dc42undefined
        dc42 administrators @TBS
        last edited by

        @tbs said in Duet sometimes really slow? - I2C error or?:

        Here is my short update:
        I have updated to 2.02. The error has recurred. This time again at the start of printing.

        Thanks, please see my post addressed to @GizmotronX5000 for useful (to me) tests you can do when this problem occurs.

        Duet WiFi hardware designer and firmware engineer
        Please do not ask me for Duet support via PM or email, use the forum
        http://www.escher3d.com, https://miscsolutions.wordpress.com

        1 Reply Last reply Reply Quote 0
        • deckingmanundefined
          deckingman
          last edited by

          I've just had this slow down happen mid print - first time for me - it's only ever happened at first boot until now,. The only thing I have not yet done is DC42s suggestion of fitting resistors which was mentioned in another thread.

          The manifestation is that the printer carries out one or 2 moves, then pauses for several seconds before continuing. M122 shows I2C nak errors 0, send timeouts 34803, receive timeouts 0, finish timeouts 34803. Also reported were:

          "Warning: motor phase A may be disconnected reported by driver(s) 5 7" (Never seen that before).

          I have the full M122 report if there is any other info that might be needed.

          I've sent M106 Pn H-1 to a few of the fans connected to the Duex5 then tried a few M106 Pnn Snnn commands with no reaction on the fans themselves. So, I guess that means a total breakdown in I2C comms?

          I've taken a video of what happens with the printer. I've cancelled the print but I'll leave it in this state for a few hours in case anyone wants me to do any tests or provide any more information.

          Ian
          https://somei3deas.wordpress.com/
          https://www.youtube.com/@deckingman

          dc42undefined 1 Reply Last reply Reply Quote 0
          • dc42undefined
            dc42 administrators @deckingman
            last edited by

            @deckingman, thanks for keeping your machine on. Please see my response to @GizmotronX500 a few posts back and run the tests there.

            Duet WiFi hardware designer and firmware engineer
            Please do not ask me for Duet support via PM or email, use the forum
            http://www.escher3d.com, https://miscsolutions.wordpress.com

            deckingmanundefined 1 Reply Last reply Reply Quote 0
            • deckingmanundefined
              deckingman @dc42
              last edited by

              @dc42 said in Duet sometimes really slow? - I2C error or?:

              @deckingman, thanks for keeping your machine on. Please see my response to @GizmotronX500 a few posts back and run the tests there.

              Yes tried that. As I said, the fans are all configured as thermostatic so I tried sending M106 Pn H-1 first, then a few M106 Pnn Snnn commands and nothing happened as far as the fans were concerned.

              I don't have any Duex end stops configured so I can't test them. That's not strictly true. I do have micro switches connected to E2 and E3 but no axes configured to use those switches....... Just tried toggling those switches but the status on machine properties page remains unchanged.

              So I'm guess that I2C comms have completely stopped in my case. M122 now reports I2C send and finish timeouts as 1861859.

              I'll leave the printer powered up for a while yet.

              Ian
              https://somei3deas.wordpress.com/
              https://www.youtube.com/@deckingman

              dc42undefined 1 Reply Last reply Reply Quote 0
              • dc42undefined
                dc42 administrators @deckingman
                last edited by

                @deckingman, thanks. What were the results of #3 and #6? I'd like to know whether the I2C error count increases (a) continuously, (b) [if not continuously] when you try to change the speed of a DueX fan, (c) [if not continuously] when you toggle the state of a DueX endstop switch.

                Duet WiFi hardware designer and firmware engineer
                Please do not ask me for Duet support via PM or email, use the forum
                http://www.escher3d.com, https://miscsolutions.wordpress.com

                deckingmanundefined 1 Reply Last reply Reply Quote 0
                • deckingmanundefined
                  deckingman @dc42
                  last edited by

                  @dc42 said in Duet sometimes really slow? - I2C error or?:

                  @deckingman, thanks. What were the results of #3 and #6? I'd like to know whether the I2C error count increases (a) continuously, (b) [if not continuously] when you try to change the speed of a DueX fan, (c) [if not continuously] when you toggle the state of a DueX endstop switch.

                  Damm. Sorry I didn't pay enough attention to what you were asking. The only info I have is that when I did the first M122 during the print, the send timeouts were 34803 and some time later, they were 1861859 which isn't much use to you. I turned the printer off before I went to bed last night and of course, the bloody thing is behaving itself again now.

                  I'll pay more attention next time it happens.

                  Ian
                  https://somei3deas.wordpress.com/
                  https://www.youtube.com/@deckingman

                  dc42undefined 1 Reply Last reply Reply Quote 0
                  • dc42undefined
                    dc42 administrators @deckingman
                    last edited by

                    @deckingman, if they went up that much then I suspect they were continuously incrementing.

                    What I suspect happened is that the interrupt signal from the SX1509B on the DueX went high, indicating a change in an endstop input signal (real or imagined). That causes the Duet main processor to try to read the SX1509B input registers, which will also make the interrupt signal go away. But if I2C communication with the SX1509B has broken down, the interrupt won't go away and the Duet will keep trying to read it - which accounts for the slowdown.

                    Duet WiFi hardware designer and firmware engineer
                    Please do not ask me for Duet support via PM or email, use the forum
                    http://www.escher3d.com, https://miscsolutions.wordpress.com

                    deckingmanundefined 1 Reply Last reply Reply Quote 0
                    • deckingmanundefined
                      deckingman @dc42
                      last edited by

                      @dc42 Cheers. I'm just in the process of making up a plug with the resistors you mentioned elsewhere. I'll try that and I'll replace the ribbon cable between the Duet and Duex5 as well. Open to any other suggestions.

                      Ian
                      https://somei3deas.wordpress.com/
                      https://www.youtube.com/@deckingman

                      dc42undefined 1 Reply Last reply Reply Quote 0
                      • dc42undefined
                        dc42 administrators @deckingman
                        last edited by dc42

                        @deckingman said in Duet sometimes really slow? - I2C error or?:

                        @dc42 Cheers. I'm just in the process of making up a plug with the resistors you mentioned elsewhere. I'll try that and I'll replace the ribbon cable between the Duet and Duex5 as well. Open to any other suggestions.

                        Please try just the resistors. The ribbon cable is unlikely to be the problem, and I'd like to know whether the resistors fix it.

                        Duet WiFi hardware designer and firmware engineer
                        Please do not ask me for Duet support via PM or email, use the forum
                        http://www.escher3d.com, https://miscsolutions.wordpress.com

                        deckingmanundefined 3 Replies Last reply Reply Quote 0
                        • deckingmanundefined
                          deckingman @dc42
                          last edited by

                          @dc42 said in Duet sometimes really slow? - I2C error or?:

                          @deckingman said in Duet sometimes really slow? - I2C error or?:

                          @dc42 Cheers. I'm just in the process of making up a plug with the resistors you mentioned elsewhere. I'll try that and I'll replace the ribbon cable between the Duet and Duex5 as well. Open to any other suggestions.

                          Please try just the resistors. The ribbon cable is unlikey to be the problem, and I'd like to know whether the resistors fix it.

                          Sure thing - will do.

                          Ian
                          https://somei3deas.wordpress.com/
                          https://www.youtube.com/@deckingman

                          1 Reply Last reply Reply Quote 0
                          • Martin1454undefined
                            Martin1454
                            last edited by

                            I will try the next time it occurs to plug on my logic analyzer and see what I can see.

                            1 Reply Last reply Reply Quote 0
                            • deckingmanundefined
                              deckingman @dc42
                              last edited by

                              @dc42 0_1548254302186_resistors2.JPG

                              Had to improvise a bit (as well as make allowances for my failing eye site and shaky hands ☺ ) but it'll do the job. The resistors are 1.8K so pretty much in the middle of the range you specified. We'll see what happens....

                              Interestingly enough, now that the machine is not in an error state, those switches that are connected to the Duex End stops do now respond, even though the axes they were originally assigned to are no longer configured - (I guess you knew that though).

                              Ian
                              https://somei3deas.wordpress.com/
                              https://www.youtube.com/@deckingman

                              1 Reply Last reply Reply Quote 0
                              • deckingmanundefined
                                deckingman @dc42
                                last edited by

                                @dc42,

                                David. As I'm waiting for some filament to arrive, the machine is just sitting here idle. Is there anything I can do to attempt to provoke the misbehaviour? I was thinking along the lines of writing a little script that would generate a gcode file that simply toggled one of the duex5 fans on and off. Or may send multiple M260 commands. Is there any point in me doing that?

                                Ian
                                https://somei3deas.wordpress.com/
                                https://www.youtube.com/@deckingman

                                dc42undefined 1 Reply Last reply Reply Quote 0
                                • dc42undefined
                                  dc42 administrators @deckingman
                                  last edited by

                                  @deckingman said in Duet sometimes really slow? - I2C error or?:

                                  @dc42,

                                  David. As I'm waiting for some filament to arrive, the machine is just sitting here idle. Is there anything I can do to attempt to provoke the misbehaviour? I was thinking along the lines of writing a little script that would generate a gcode file that simply toggled one of the duex5 fans on and off. Or may send multiple M260 commands. Is there any point in me doing that?

                                  Yes, you could try that.

                                  Duet WiFi hardware designer and firmware engineer
                                  Please do not ask me for Duet support via PM or email, use the forum
                                  http://www.escher3d.com, https://miscsolutions.wordpress.com

                                  1 Reply Last reply Reply Quote 0
                                  • GizmotronX5000undefined
                                    GizmotronX5000 @dc42
                                    last edited by GizmotronX5000

                                    @dc42

                                    1. M122
                                      === Diagnostics ===
                                      RepRapFirmware for Duet 2 WiFi/Ethernet version 2.02(RTOS) running on Duet Ethernet 1.02 or later + DueX5
                                      Board ID: 08DDM-9FAM2-LW4SD-6J9F2-3S46R-K2XBW
                                      Used output buffers: 1 of 20 (14 max)
                                      === RTOS ===
                                      Static ram: 25524
                                      Dynamic ram: 98292 of which 0 recycled
                                      Exception stack ram used: 384
                                      Never used ram: 6872
                                      Tasks: NETWORK(ready,544) HEAT(blocked,1232) MAIN(running,3812) IDLE(ready,200)
                                      Owned mutexes:
                                      === Platform ===
                                      Last reset 00:16:58 ago, cause: power up
                                      Last software reset at 2019-01-23 14:44, reason: User, spinning module GCodes, available RAM 6776 bytes (slot 3)
                                      Software reset code 0x0003 HFSR 0x00000000 CFSR 0x00000000 ICSR 0x0441f000 BFAR 0xe000ed38 SP 0xffffffff Task 0x4e49414d
                                      Error status: 0
                                      Free file entries: 10
                                      SD card 0 detected, interface speed: 20.0MBytes/sec
                                      SD card longest block write time: 15.9ms, max retries 0
                                      MCU temperature: min 31.3, current 31.5, max 31.9
                                      Supply voltage: min 12.0, current 12.3, max 12.4, under voltage events: 0, over voltage events: 0, power good: yes
                                      Driver 0: standstill, SG min/max 37/510
                                      Driver 1: standstill, SG min/max 70/544
                                      Driver 2: standstill, SG min/max 63/552
                                      Driver 3: standstill, SG min/max not available
                                      Driver 4: standstill, SG min/max not available
                                      Driver 5: standstill, SG min/max not available
                                      Driver 6: standstill, SG min/max 0/462
                                      Driver 7: standstill, SG min/max 0/0
                                      Driver 8: standstill, SG min/max 0/0
                                      Driver 9: standstill, SG min/max not available
                                      Date/time: 2019-01-23 15:17:17
                                      Cache data hit count 4294967295
                                      Slowest loop: 59.17ms; fastest: 29.15ms
                                      I2C nak errors 0, send timeouts 63402, receive timeouts 0, finishTimeouts 63402
                                      === Move ===
                                      Hiccups: 0, StepErrors: 0, LaErrors: 0, FreeDm: 240, MinFreeDm: 237, MaxWait: 181633ms, Underruns: 0, 0
                                      Scheduled moves: 21, completed moves: 21
                                      Bed compensation in use: none
                                      Bed probe heights: 0.000 0.000 0.000 0.000 0.000
                                      === Heat ===
                                      Bed heaters = 0 -1 -1 -1, chamberHeaters = -1 -1
                                      Heater 0 is on, I-accum = 0.0
                                      Heater 1 is on, I-accum = 0.0
                                      === GCodes ===
                                      Segments left: 0
                                      Stack records: 1 allocated, 0 in use
                                      Movement lock held by null
                                      http is idle in state(s) 0
                                      telnet is idle in state(s) 0
                                      file is idle in state(s) 0
                                      serial is idle in state(s) 0
                                      aux is idle in state(s) 0
                                      daemon is idle in state(s) 0
                                      queue is idle in state(s) 0
                                      autopause is idle in state(s) 0
                                      Code queue is empty.
                                      === Network ===
                                      Slowest loop: 63.08ms; fastest: 0.03ms
                                      Responder states: HTTP(0) HTTP(0) HTTP(0) HTTP(0) FTP(0) Telnet(0) Telnet(0)
                                      HTTP sessions: 1 of 8
                                      Interface state 5, link 100Mbps full duplex

                                    2. The Duex5 endstops do not work as I had previously thought. The endstops on the Duet work, but not the Duex5.

                                    3. M122 right after pressing the endstops a few times (most lines removed):
                                      M122
                                      Date/time: 2019-01-23 15:18:05
                                      Cache data hit count 4294967295
                                      Slowest loop: 59.10ms; fastest: 0.08ms
                                      I2C nak errors 0, send timeouts 4797, receive timeouts 0, finishTimeouts 4797

                                    4. No fans are actually connected to the Duex5, so I can't test this. I can configure a dummy fan to the Duex5 for next time though. All fans on the Duet work fine.

                                    5. M122 (after messing around with duet fans)
                                      Date/time: 2019-01-23 15:22:28
                                      Cache data hit count 4294967295
                                      Slowest loop: 59.11ms; fastest: 0.08ms
                                      I2C nak errors 0, send timeouts 17551, receive timeouts 0, finishTimeouts 17551

                                    6. No changes. Just sending M122 every few seconds.

                                    M122
                                    Date/time: 2019-01-23 15:23:31
                                    Cache data hit count 4294967295
                                    Slowest loop: 59.11ms; fastest: 29.47ms
                                    I2C nak errors 0, send timeouts 10480, receive timeouts 0, finishTimeouts 10480

                                    M122
                                    Date/time: 2019-01-23 15:24:00
                                    Cache data hit count 4294967295
                                    Slowest loop: 59.10ms; fastest: 29.46ms
                                    I2C nak errors 0, send timeouts 4900, receive timeouts 0, finishTimeouts 4900

                                    M122
                                    Date/time: 2019-01-23 15:24:42
                                    Cache data hit count 4294967295
                                    Slowest loop: 59.10ms; fastest: 29.47ms
                                    I2C nak errors 0, send timeouts 6885, receive timeouts 0, finishTimeouts 6885

                                    I'm assuming the error count starts over each time I send M122. But the number is constantly changing. The lowest I saw was 195 from sending M122 back to back as fast as I could manually from the console. Looks like about 160-170 errors per second on average (164 seems to be the usual) regardless of what commands I send or which endstops I press.

                                    Edit:
                                    I let it idle in this state for about 15 minutes. The average was 166.2 errors per second. It's very consistent.

                                    1 Reply Last reply Reply Quote 0
                                    • deckingmanundefined
                                      deckingman
                                      last edited by

                                      I can add a bit to what @GizmotronX5000 has come with in that I do have fans connected to the Duex5 and that they did not respond to any commands while the machine was in error state (neither did the duex endstops).

                                      Ian
                                      https://somei3deas.wordpress.com/
                                      https://www.youtube.com/@deckingman

                                      1 Reply Last reply Reply Quote 0
                                      • dc42undefined
                                        dc42 administrators
                                        last edited by

                                        Thanks, you have both confirmed that the DueX5 isn't responding to I2C traffic at all, and the Duet is repeatedly trying (and failing) to communicate with it.

                                        Duet WiFi hardware designer and firmware engineer
                                        Please do not ask me for Duet support via PM or email, use the forum
                                        http://www.escher3d.com, https://miscsolutions.wordpress.com

                                        1 Reply Last reply Reply Quote 0
                                        • TBSundefined
                                          TBS
                                          last edited by TBS

                                          @dc42: Are there any news about this error?
                                          When does a new release candidate appear?

                                          Thanks for answering.

                                          1 Reply Last reply Reply Quote 0
                                          • dc42undefined
                                            dc42 administrators
                                            last edited by dc42

                                            For now my recommendation to anyone having this problem is:

                                            1. Make sure that the wiring of the ground side of the VIN terminals on the Duet and DueX follows our recommendations.

                                            2. Keep stepper motor cables and other sources of noise at least a few cm away from the ribbon cable connecting the Duet and DueX.

                                            3. Try adding the extra pullup resistors as I describe earlier in this thread.

                                            The problem I have is that I don't know what triggers this issue.

                                            Duet WiFi hardware designer and firmware engineer
                                            Please do not ask me for Duet support via PM or email, use the forum
                                            http://www.escher3d.com, https://miscsolutions.wordpress.com

                                            GizmotronX5000undefined 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Unless otherwise noted, all forum content is licensed under CC-BY-SA