ModalAI Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    VOXL 2 IO - 8 PWM channels & Futaba (SBUS) Rx

    Ask your questions right here!
    3
    31
    3822
    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.
    • K
      konwersa
      last edited by konwersa

      I want to drive 5 motors and 2 servos from the VOXL 2 IO module.

      I saw that the latest firmware only supports 4 PWM channels for now and am curious if the firmware development for this module is a high priority, or, rather, is the ModalAI team expecting to push out a new firmware to support 8 PWM channels soon? Soon being within April.
      This is a necessary function for my platform.

      Additionally, I want to connect a Futaba receiver to the RC SBUS port on the VOXL 2 IO module at J3; however, the Futaba is a 5V system (power & signal) and its SBUS is inverted from the FrSky SBUS.
      Is it currently necessary for me to step down and invert the signal before connecting the Futaba Rx to J3 of the VOXL 2 IO module?

      • Futaba R7014SB
      Alex KushleyevA 1 Reply Last reply Reply Quote 0
      • Alex KushleyevA
        Alex Kushleyev ModalAI Team @konwersa
        last edited by

        @konwersa , we have been beta testing updated firmware that enables 8 PWM channels and supports standard SBUS on J3. Please see my post here (scroll down to my post March 19). There are instructions how to install updated firmware to M0065 and use a new branch of PX4 that supports this. Several forum users have been testing this and we should have this officially released within several weeks.

        J3 provides 5V output for the SBUS receiver and has level inverters for the signal. see more information in the data sheet https://docs.modalai.com/voxl2-io-datasheet/

        This thread has additional discussion on this topic and also a pre-built .deb with px4 that supports the new feature : https://forum.modalai.com/topic/3265/additional-voxl-2-pwm-ouputs/ (link to px4 deb on March 28)

        Alex

        K 2 Replies Last reply Reply Quote 0
        • Alex KushleyevA Alex Kushleyev referenced this topic on
        • K
          konwersa @Alex Kushleyev
          last edited by

          That's great! Thank you @Alex-Kushleyev

          1 Reply Last reply Reply Quote 0
          • K
            konwersa @Alex Kushleyev
            last edited by

            @Alex-Kushleyev , Are there any plans for the VOXL 2 IO Module to support DShot?

            Alex KushleyevA 1 Reply Last reply Reply Quote 0
            • Alex KushleyevA
              Alex Kushleyev ModalAI Team @konwersa
              last edited by

              @konwersa , what are you expecting to gain by using dshot? It would help us if you can explain your use case. Thank you!

              K 1 Reply Last reply Reply Quote 0
              • K
                konwersa @Alex Kushleyev
                last edited by konwersa

                @Alex-Kushleyev , we like the ability to have controls and telemetry on 1-wire and, most importantly, it simplifies ESC calibration. We don't want our customers to deal with ESC calibration in the field.

                Alex KushleyevA 1 Reply Last reply Reply Quote 0
                • Alex KushleyevA
                  Alex Kushleyev ModalAI Team @konwersa
                  last edited by Alex Kushleyev

                  @konwersa , have you considered using ModalAi escs? We use uart protocol which is more robust than dshot (it has been a standard for decades). Uart interface provides telemetry from each esc. Additionally, our ESC does closed loop RPM control for maximum performance. After a one time calibration using your motor and propeller, no other calibration is required, just load correct esc params to all ESCs.

                  We also provide tools to fine tune esc performance and plot the results for visual confirmation and you can run automated tests using python scripts.

                  K 1 Reply Last reply Reply Quote 0
                  • K
                    konwersa @Alex Kushleyev
                    last edited by

                    @Alex-Kushleyev , we did consider using ModalAI's ESCs, but our configuration is now a lift-cruise (5 motors) and we will be using the APD 40F3.

                    Alex KushleyevA 1 Reply Last reply Reply Quote 0
                    • Alex KushleyevA
                      Alex Kushleyev ModalAI Team @konwersa
                      last edited by

                      @konwersa , thank you for clarifying, I understand.

                      The dshot support is not currently on our official release roadmap, but we have experimented with it using M0065.

                      To help me understand better your use case, a few more questions..

                      • in your application you would need 5 dshot outputs, correct?
                      • when you talk about ESC telemetry, are you referring to bi-directional dshot or the uart-based telemetry? (do you know the difference?)
                      • do you also need M0065 for RC input (SBUS or something else)?

                      Alex

                      K 1 Reply Last reply Reply Quote 0
                      • K
                        konwersa @Alex Kushleyev
                        last edited by konwersa

                        @Alex-Kushleyev , I appreciate your effort to understand our needs.

                        I'm only vaguely familiar with dshot. To my knowledge, bi-directional dshot makes use of 1 wire for control & telemetry with 16-bit data packets for control (idk how big the telemetry packets are).

                        I am not sure of the difference between bi-directional dshot & uart-based telemetry aside from the fact that the uart telemetry uses a separate telemetry wire.

                        As of right now, we would need:

                        • 5 dshot outputs for the ESCs - bi-directional dshot would be ideal for wiring simplicity
                        • 2 PWM outputs to our servos (control surfaces)
                        • M0065 for RC input - Futaba SBUS
                        • I also want to use the spare (8th) "PWM" on the M0065 as a GPIO to control a low power mode for my GPS

                        I haven't dealt with the various ESC control & telemetry protocols yet. If you have any information to add to or correct my understanding, I would be happy to learn more.

                        Alex

                        Alex KushleyevA 1 Reply Last reply Reply Quote 0
                        • Alex KushleyevA
                          Alex Kushleyev ModalAI Team @konwersa
                          last edited by Alex Kushleyev

                          @konwersa ,

                          Here is a good resource that describes dshot, telemetry and bi-directional dshot : https://brushlesswhoop.com/dshot-and-bidirectional-dshot/

                          Uart telemetry is the easiest from software point of view and would only need one wire on a typical 4-in-1 esc, but in your case you would need a extra wire from each esc.

                          Standard bi-directional dshot provides rpm feedback only (for rpm-based filtering of gyro data). There is also extended dshot telemetry which supposedly can provide voltage, current, esc temperature.

                          Can you please take a look at the article and clarify which telemetry data you would need from the esc?

                          I am not sure yet if receiving dshot response on single wire with dsjot commands is possible on m0065, we have not tried it. I would need to look into that.

                          K 1 Reply Last reply Reply Quote 0
                          • K
                            konwersa @Alex Kushleyev
                            last edited by konwersa

                            @Alex-Kushleyev

                            Thank you for the resource! We certainly had some confusion regarding dshot, bi-directional dshot, and esc telemetry interfaces.

                            In the long term, we will need to obtain all of the available telemetry via the UART telemetry interface. The telemetry interface is something we will have to account for in a later hardware revision in a month or two.

                            We are developing a quick & dirty Rev 1 platform right now, so we will forgo the ESC telemetry & dshot for the time being.

                            On Rev 2 of our hardware, I will be looking to incorporate dshot control (5 channels) and the serial telemetry (5 channels). From the telemetry, we want RPM, voltage, current, temp - all the bells & whistles.

                            So, the topic of discussion now is less about telemetry (as I will have to create a design in Rev 2 to accomodate our telemetry needs) and more about the capabilities of the M0065 moving forward.

                            M0065 needs on J1 include

                            • dshot control x5
                            • pwm control x2
                            • gpio x1

                            I may also look into potentially repurposing J2

                            Alex KushleyevA 1 Reply Last reply Reply Quote 0
                            • Alex KushleyevA
                              Alex Kushleyev ModalAI Team @konwersa
                              last edited by Alex Kushleyev

                              @konwersa ,

                              Thank you for clarifying. In my testing, I have confirmed the ESC telemetry (not dshot telemetry) by repurposing J2 for UART rx that received the telemetry data. So i would request the telemetry via DSHOT commands (for one ESC at a time so that uart packets from different ESCs do not collide) and receive the packet via uart on J2 and parse it. This exists in the experimental code.

                              For DSHOT output, we have implemented 4x dshot outputs so far, but up to 6 should be supported by hardware. I would need to double check that you could mix dshot and pwm, there could be a limitation due to shared hardware timer between different output pins.

                              As for GPIO on/off, i believe it is possible to use the existing PWM functionality to just make the pulse width equal to 100% so that the pin always stays high (just need to make sure there is no glitch) or 0% for the pin to always stay low. That would be nice so that there is no need for additional GPIO interface.

                              Please give me a few days to check a few things, mainly to make sure that we can do 5 dshot and 3x pwm (1 pwm used as gpio)

                              Alex

                              K 1 Reply Last reply Reply Quote 1
                              • K
                                konwersa @Alex Kushleyev
                                last edited by

                                @Alex-Kushleyev

                                I'm glad that we were on the same page with repurposing J2 for the ESC telemetry! Using a PWM at 100% or 0% is a great idea to avoid reconfiguring the pins.

                                @Alex-Kushleyev said in VOXL 2 IO - 8 PWM channels & Futaba (SBUS) Rx:

                                Please give me a few days to check a few things, mainly to make sure that we can do 5 dshot and 3x pwm (1 pwm used as gpio)

                                Have you confirmed the status of mixing dshot & pwm as well as the possibility of 5 dshot channels?

                                Alex

                                Alex KushleyevA 1 Reply Last reply Reply Quote 0
                                • Alex KushleyevA
                                  Alex Kushleyev ModalAI Team @konwersa
                                  last edited by

                                  @konwersa , I am sorry for not getting back to you sooner. DSHOT support in M0065 is still a possibility but I do not have a specific timeline for implementing this, also considering that you have a very specific use case, which would need a custom firmware because M0065 does not support arbitrary configuration of the 8 IO pins due to the fact that the hardware timers are shared between pins and only certain combinations are possible.

                                  I did double check that the hardware can support 5x dshot, 2x pwm, and 1x gpio (but not 5x dshot and 3x pwm due to a timer conflict), but it would be a very specific pin assignment (which is not really a problem as long as you know what it is).

                                  A much more common use case would be 4 dshot + 4 pwm, which would be much easier for us to support. This is what we have prototyped, but the feature has not marked for a release. If there is enough demand from the users, it would make the decision easier, otherwise it is hard to prioritize it..

                                  If you have other options for your dshot application, please consider pursuing those, since I cannot give you a clear timeline for the feature you requested.

                                  Alex

                                  Gary HolmgrenG 1 Reply Last reply Reply Quote 1
                                  • Gary HolmgrenG
                                    Gary Holmgren @Alex Kushleyev
                                    last edited by

                                    @Alex-Kushleyev Hi, I am developing a project that would require the 4 dshot outputs on the voxl2 IO expander. Is this somehting you would be able to help with? Currently at a standstill on trying to figure out what hardware to use but if the voxl2 can support the dshot outputs that would make this ALOT easier design wise.

                                    Alex KushleyevA 1 Reply Last reply Reply Quote 0
                                    • Alex KushleyevA
                                      Alex Kushleyev ModalAI Team @Gary Holmgren
                                      last edited by

                                      Hi @Gary-Holmgren,

                                      We do have experimental firmware for M0065 that is capable of outputting 4 DSHOT600 signals and reading back UART telemetry (not dshot telemetry, which would come back on the 4 pwm signals.. may be able to do implement dshot telemetry, but who knows if we ever get to it 🙂 ).

                                      I am actually about to work on some dshot-related items and was going to use M0065 to generate dshot signals for testing another device, so this might be good timing.

                                      The current state of the firmware is that it has been tested on the bench (very little) but i would definitely not fly with it before putting in at least several hours of continuous bench testing with different inputs.

                                      Nice thing is that voxl-esc tools can be used to test M0065 in dshot mode, so test scripts can be written to bench test the firmware to ensure proper operation. You can also use the PX4 driver in VOLX2 with slight modifications for flight (eventually).

                                      If you would like to test this firmware, i have to warn you that it will come with NO GUARANTEES because it has not been through any rigorous testing. However, you should be able to perform sufficient testing, if you are willing and I can help with the software tools for testing. I can't say for sure that this feature will be ever officially supported, but the test firmware will be available and I will try to address issues if they come up. I should be able to share test firmware in about a week or so, when i go back to working on it and get a chance to test.

                                      Alex

                                      Gary HolmgrenG 1 Reply Last reply Reply Quote 0
                                      • Gary HolmgrenG
                                        Gary Holmgren @Alex Kushleyev
                                        last edited by

                                        @Alex-Kushleyev This is good news! So for the 4 dshot channels I wouldn't need it for flight just to drive bldc motors bidirectionally. I am under the impression the FCv2 also has dshot capability? However when i try to select dshot in the actuators tab in QGC for FCv2 and reboot the actuators have no output. Works fine with PWM however but there is no bidirectionaity there. I am wondering what might be the best option since there is no real risk of crashing.

                                        Would you be able to clarify a little more on how I can implement voxl-esc tools to set the dshot outputs on the M0065?

                                        Really appreciate the quick response!

                                        Alex KushleyevA 1 Reply Last reply Reply Quote 0
                                        • Alex KushleyevA
                                          Alex Kushleyev ModalAI Team @Gary Holmgren
                                          last edited by

                                          @Gary-Holmgren , I have not used dshot on flight core (v1 or v2), but based on the following, i believe at least it should be working on Flight Core V1: https://docs.modalai.com/flight-core-pwm-esc-calibration/ (there is a mention of dshot and I am pretty sure we had that working). Not sure about V2, but i will ask. If you have a Flight Core V1, maybe worth giving it a shot.

                                          If there is no risk of crashing a drone, that certainly makes things a bit easier and you should be able to get to testing much sooner.

                                          I will provide more details about voxl-esc integration, but just to summarize, it will be very similar to sending RPM or power commands using voxl-esc tools (which you may have already done with ModalAI ESCs), and M0065 will take the 4 commands sent out by voxl-esc and convert them to dshot outputs. At the low level, M0065 will basically continuously receive UART packets of a certain type that contains 4x 11-bit throttle values and some other flags and generate the Dshot signal using PWM + DMA. You should be able to send that control packet to M0065 from any device that has UART, but voxl-esc python tools make it a bit easier to get started (and you can use these python tools either on voxl2 or a linux PC). I like to do my experimental testing using a fast Linux PC to reduce any latency with UART communication.

                                          What device are you actually planning to use for calculating the dshot values to be sent to the motors? Is it VOXL2 or something else (does not matter, just curious).

                                          Alex

                                          Gary HolmgrenG 1 Reply Last reply Reply Quote 0
                                          • Gary HolmgrenG
                                            Gary Holmgren @Alex Kushleyev
                                            last edited by

                                            @Alex-Kushleyev Ahh I only have the FCv2. I have a quick linux machine to work with and planned to do this work either on that or the voxl2. I guess my ultimate goal is to have the ability for PX4 to use esc's in the actuators tab bidirectionally. I am wondering how I would make the change to have the M0064 output dshot permanently after verifying test commands so px4 can control the motors to operate in two directions using my 4in1 dshot supported ESC.

                                            I seen an alternative solution here where two voxl-esc's can be wired in parallel together but just using separate ID's to get 8 channels. Wold these ESC's also support bi-directional operation in PX4? It would be a decent cost to implement these so I am hoping my current setup can work but if it proves too difficult to get working I might consider if these are more plug and play.

                                            Alex KushleyevA 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Powered by NodeBB | Contributors