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

    Duet 3 and jetson Nano?

    Scheduled Pinned Locked Moved
    General Discussion
    8
    111
    8.9k
    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.
    • A Former User?
      A Former User
      last edited by

      For instance I could copy/paste the first part where you start DuetControlServer and point out that when you run the binary like that and it returns to the prompt, it is no longer running. And as such DuetWebServer will not work.

      You need to either run the binary in its own terminal or in the background; and more importantly find out why it says Duet is not available

      hanshogelandundefined 1 Reply Last reply Reply Quote 0
      • gtj0undefined
        gtj0
        last edited by

        The Duet Not Available is either that the GPIO or the SPI isn't configured correctly (not in the DSF).
        Unfortunately I don't have a Duet3 to test with yet so I'm kinda flying blind for the time being.
        The issue may be that the SPI instructions that I posted were for a generic Jetson Nano, not specific to the DSF. As such, it has both SPI ports configured. Unfortunately, the GPIO pin that's wired through to the Duet3 is also used by the second SPI port on the Nano so it may be interfering. I'm working on an updated SPI procedure that should be done in a few hours.

        hanshogelandundefined 1 Reply Last reply Reply Quote 0
        • hanshogelandundefined
          hanshogeland @A Former User
          last edited by

          @bearer yes I see, I made a mistake not adding the gpio group rights. I think I got connection now.

          hanshogelandundefined 1 Reply Last reply Reply Quote 0
          • hanshogelandundefined
            hanshogeland @hanshogeland
            last edited by

            @hanshogeland said in Duet 3 and jetson Nano?:

            @bearer yes I see, I made a mistake not adding the gpio group rights. I think I got connection now.

            Or I got another error now,

            hans@hans-desktop:~$ sudo /opt/dsf/bin/DuetControlServer
            Duet Control Server v1.0.3.3
            Written by Christian Hammacher for Duet3D
            Licensed under the terms of the GNU Public License Version 3

            Loading settings... Done!
            Initialising object model... Done!
            Connecting to RepRapFirmware... [warn] Bad header checksum (expected 0xffff, got 0x3b01)
            [warn] Note: RepRapFirmware didn't receive valid data either (code 0x00000005)
            Error: Duet is not available

            1 Reply Last reply Reply Quote 0
            • hanshogelandundefined
              hanshogeland @gtj0
              last edited by

              @gtj0 thx for your efforts, I couldn’t have come this far without you.

              1 Reply Last reply Reply Quote 0
              • gtj0undefined
                gtj0
                last edited by gtj0

                @hanshogeland I updated my github repo with files that enable spi1 only. It may help.
                Another thing you can try is to reduce the SPI bus speed as a test.
                In config.json, change
                "SpiFrequency": 1000000,
                to
                "SpiFrequency": 500000,

                That's 500KHz instead of 1MHz.

                You'll have to restart duetcontrolserver after making the change.

                https://github.com/gtjoseph/jetson-nano-support/tree/l4t_32.2.1

                hanshogelandundefined 1 Reply Last reply Reply Quote 1
                • hanshogelandundefined
                  hanshogeland @gtj0
                  last edited by

                  @gtj0 hi, I have flashed with only the spi1 support and tested again with the duetcontrolserver - it gives a similar error again.

                  hans@hans-desktop:~$ sudo /opt/dsf/bin/DuetControlServer
                  Duet Control Server v1.0.3.3
                  Written by Christian Hammacher for Duet3D
                  Licensed under the terms of the GNU Public License Version 3

                  Loading settings... Done!
                  Initialising object model... Done!
                  Connecting to RepRapFirmware... [warn] Bad header checksum (expected 0xffff, got 0x3b01)
                  [warn] Note: RepRapFirmware didn't receive valid data either (code 0x00000005)
                  Error: Duet is not available
                  hans@hans-desktop:~$ ls -al /dev/spi*
                  crw-rw---- 1 root gpio 153, 0 sep 21 01:18 /dev/spidev0.0
                  crw-rw---- 1 root gpio 153, 1 sep 21 01:18 /dev/spidev0.1

                  1 Reply Last reply Reply Quote 0
                  • gtj0undefined
                    gtj0
                    last edited by

                    Did you try lowering the spi frequency?

                    hanshogelandundefined 1 Reply Last reply Reply Quote 0
                    • hanshogelandundefined
                      hanshogeland @gtj0
                      last edited by

                      @gtj0 yes, I did that - this is the config, thx again for your help - I might have to wait until you have tested it yourself and that is fine also cause I am still building on my printer. Also I am thinking on getting a Rasberry to verify the card and cable, but I would say that should not be an issue at all.

                      "SpiFrequency": 500000,
                      "SocketPath": "/var/run/duet.sock",
                      "Backlog": 4,
                      "BaseDirectory": "/opt/dsf/sd",
                      "HostUpdateInterval": 4000,
                      "MaxMessageAge": 60.0,
                      "SpiBusID": 0,
                      "SpiChipSelectLine": 0,
                      "SpiTransferTimeout": 500,
                      "MaxSpiRetries": 3,
                      "SpiPollDelay": 25,
                      "TransferReadyPin": 13,
                      "MaxUpdateDelay": 250.0,
                      "FileInfoReadLimit": 32768,
                      "MaxLayerHeight": 0.9,
                      
                      1 Reply Last reply Reply Quote 0
                      • gtj0undefined
                        gtj0
                        last edited by

                        @hanshogeland I just uploaded DSF builds for 1.0.4.0. Suggest you give those a try.

                        1 Reply Last reply Reply Quote 0
                        • gtj0undefined
                          gtj0
                          last edited by

                          I'm seeing the same checksum issues. I think I have to tweak the drive strength and the timing a bit.
                          Working on it!

                          hanshogelandundefined 1 Reply Last reply Reply Quote 1
                          • hanshogelandundefined
                            hanshogeland @gtj0
                            last edited by

                            @gtj0 great! 🙂

                            1 Reply Last reply Reply Quote 0
                            • gtj0undefined
                              gtj0
                              last edited by

                              I figured it out. I stupidly forgot to set the MISO pins to TRISTATE so the data was getting corrupted.
                              Tested and things now seem fully operational.
                              Grab the new u-boot and dtb files from:
                              https://github.com/gtjoseph/jetson-nano-support/tree/l4t_32.2.1

                              hanshogelandundefined 1 Reply Last reply Reply Quote 4
                              • hanshogelandundefined
                                hanshogeland @gtj0
                                last edited by

                                @gtj0 Success!! Thank you fior your hard work of making it work Iḿ truly grateful 🙂 32fc5be7-e1cf-4a58-be99-c1d2fc6dbed0-image.png

                                1 Reply Last reply Reply Quote 2
                                • gtj0undefined
                                  gtj0
                                  last edited by

                                  Just a quick update...

                                  There are official 64 bit builds of Duet Software Framework available from Duet3D. All you have to do is create a file named /etc/apt/sources.list.d/duet3d.list with one line in it...

                                  deb https://pkg.duet3d.com/ stable armv7
                                  

                                  Even though armv7 is mentioned, you'll get the arm64 packages.

                                  Then copy the attached gpg key to /etc/apt/trusted.gpg.d/duet3d.gpg.
                                  duet3d.gpg.txt
                                  The .txt suffix was added just to satisfy the forum's upload restrictions so you need to remove it.

                                  Finally, do an apt-get update and apt-get install duetsoftwareframework

                                  hanshogelandundefined 1 Reply Last reply Reply Quote 4
                                  • hanshogelandundefined
                                    hanshogeland @gtj0
                                    last edited by

                                    @gtj0 said in Duet 3 and jetson Nano?:

                                    etc/apt/sources.list.d/duet3d.lis

                                    Yes, I´ve been thinking about this for a while and just like that the update I was waiting for :)!
                                    Followed your instructions and it worked like a charm, thank you so much.

                                    1 Reply Last reply Reply Quote 0
                                    • gtj0undefined
                                      gtj0
                                      last edited by

                                      Those packages have been up there for a while now but both @chrishamm and I forgot to tell anyone. 🙂

                                      1 Reply Last reply Reply Quote 1
                                      • HebigTundefined
                                        HebigT
                                        last edited by HebigT

                                        @gtj0

                                        I did a fresh install (both L4T & DSF) and I'm running into an issue:

                                        Monitoring DCS shows "Kernel SPI buffer" warning & "Duet is not available"

                                        jpomo@jpomo-desktop:~$ sudo /opt/dsf/bin/DuetControlServer
                                        Duet Control Server v1.2.3.0
                                        Written by Christian Hammacher for Duet3D
                                        Licensed under the terms of the GNU Public License Version 3
                                        
                                        [info] Settings loaded
                                        [info] Environment initialized
                                        **[warn] Kernel SPI buffer size is smaller than RepRapFirmware buffer size (4096 configured vs 8192 required)
                                        [error] Duet is not available**
                                        
                                        

                                        Here are my config files -

                                        http.json:

                                        {
                                          "Logging": {
                                            "LogLevel": {
                                              "Default": "Information"
                                            }
                                          },
                                          "Kestrel": {
                                            "Endpoints": {
                                              "Http": {
                                                "Url": "http://127.0.0.1"
                                              }
                                            }
                                          },
                                          "KeepAliveInterval": 30,
                                          "ModelRetryDelay": 5000,
                                          "UseCors": true,
                                          "UseStaticFiles": true,
                                          "SocketPath": "/var/run/dsf/dcs.sock",
                                          "WebSocketBufferSize": 8192
                                        }
                                        

                                        config.json

                                          "LogLevel": "info",
                                          "SocketDirectory": "/var/run/dsf",
                                          "SocketFile": "dcs.sock",
                                          "Backlog": 4,
                                          "SocketPollInterval": 2000,
                                          "BaseDirectory": "/opt/dsf/sd",
                                          "HostUpdateInterval": 4000,
                                          "ConfigUpdateInterval": 5000,
                                          "MaxMessageAge": 60.0,
                                          "SpiDevice": "/dev/spidev0.0",
                                          "SpiFrequency": 1000000,
                                          "SpiTransferTimeout": 500,
                                          "MaxSpiRetries": 3,
                                          "SpiPollDelay": 25,
                                          "GpioChipDevice": "/dev/gpiochip0",
                                          "TransferReadyPin": 13,
                                          "BufferedPrintCodes": 32,
                                          "BufferedMacroCodes": 16,
                                          "MaxBufferSpacePerChannel": 1536,
                                          "ModelUpdateInterval": 125,
                                          "MaxMachineModelLockTime": -1,
                                          "FileInfoReadLimitHeader": 12288,
                                          "FileInfoReadLimitFooter": 262144,
                                          "MaxLayerHeight": 0.9,
                                        

                                        Additonally,

                                        sudo systemctl status duetcontrolserver:

                                        jpomo@jpomo-desktop:~$ sudo systemctl status duetcontrolserver
                                        ● duetcontrolserver.service - Duet Control Server
                                           Loaded: loaded (/usr/lib/systemd/system/duetcontrolserver.service; enabled; vendor preset: ena
                                           Active: active (running) since Mon 2020-01-13 13:09:55 MST; 589ms ago
                                         Main PID: 17421 (DuetControlServ)
                                            Tasks: 9 (limit: 4182)
                                           CGroup: /system.slice/duetcontrolserver.service
                                                   └─17421 /opt/dsf/bin/DuetControlServer
                                        
                                        Jan 13 13:09:55 jpomo-desktop systemd[1]: Started Duet Control Server.
                                        Jan 13 13:09:56 jpomo-desktop DuetControlServer[17421]: Duet Control Server v1.2.3.0
                                        Jan 13 13:09:56 jpomo-desktop DuetControlServer[17421]: Written by Christian Hammacher for Duet3D
                                        Jan 13 13:09:56 jpomo-desktop DuetControlServer[17421]: Licensed under the terms of the GNU Publi
                                        
                                        

                                        sudo systemctl status duetwebserver:

                                        ● duetwebserver.service - Duet Web Server
                                           Loaded: loaded (/usr/lib/systemd/system/duetwebserver.service; enabled; vendor preset: enabled)
                                           Active: active (running) since Mon 2020-01-13 12:52:11 MST; 18min ago
                                         Main PID: 4592 (DuetWebServer)
                                            Tasks: 19 (limit: 4182)
                                           CGroup: /system.slice/duetwebserver.service
                                                   └─4592 /opt/dsf/bin/DuetWebServer
                                        
                                        Jan 13 13:10:26 jpomo-desktop DuetWebServer[4592]:    at System.Net.Sockets.Socket.Connect(EndPoint remoteEP)
                                        Jan 13 13:10:26 jpomo-desktop DuetWebServer[4592]:    at DuetAPIClient.BaseConnection.Connect(ClientInitMessage initMessage, String socketPath, CancellationToken cancellationToken
                                        Jan 13 13:10:26 jpomo-desktop DuetWebServer[4592]:    at DuetWebServer.Services.ModelObserver.Execute() in /home/christian/duet/DuetSoftwareFramework/src/DuetWebServer/Services/Mo
                                        Jan 13 13:10:31 jpomo-desktop DuetWebServer[4592]: warn: DuetWebServer.Services.ModelObserver[0]
                                        Jan 13 13:10:31 jpomo-desktop DuetWebServer[4592]:       Failed to synchronize machine model
                                        Jan 13 13:10:31 jpomo-desktop DuetWebServer[4592]: System.Net.Internals.SocketExceptionFactory+ExtendedSocketException (99): Cannot assign requested address /var/run/dsf/dcs.sock
                                        Jan 13 13:10:31 jpomo-desktop DuetWebServer[4592]:    at System.Net.Sockets.Socket.DoConnect(EndPoint endPointSnapshot, SocketAddress socketAddress)
                                        Jan 13 13:10:31 jpomo-desktop DuetWebServer[4592]:    at System.Net.Sockets.Socket.Connect(EndPoint remoteEP)
                                        Jan 13 13:10:31 jpomo-desktop DuetWebServer[4592]:    at DuetAPIClient.BaseConnection.Connect(ClientInitMessage initMessage, String socketPath, CancellationToken cancellationToken
                                        Jan 13 13:10:31 jpomo-desktop DuetWebServer[4592]:    at DuetWebServer.Services.ModelObserver.Execute() in /home/christian/duet/DuetSoftwareFramework/src/DuetWebServer/Services/Mo
                                        

                                        As far as I know, I have set the correct GPIO pin and SPI frequency.

                                        Any advice is appreciated!

                                        1 Reply Last reply Reply Quote 0
                                        • chrishammundefined
                                          chrishamm administrators
                                          last edited by

                                          Have a look at the note in https://duet3d.dozuki.com/Wiki/Getting_Started_With_Duet_3#Section_Enabling_SPI I haven't tested this on a Jetson Nano, though.

                                          Duet software engineer

                                          1 Reply Last reply Reply Quote 0
                                          • gtj0undefined
                                            gtj0
                                            last edited by

                                            @jpomo10 It's an easy fix...

                                            Create a file named /etc/modprobe.d/spidev.conf and put 1 line in it...

                                            options spidev bufsiz=8192
                                            

                                            Then reboot. You should be good to go after that.

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