VOXL 2 IO - 8 PWM channels & Futaba (SBUS) Rx
- 
					
					
					
					
 @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. 
- 
					
					
					
					
 @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 
- 
					
					
					
					
 @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 
- 
					
					
					
					
 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. 
- 
					
					
					
					
 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 
- 
					
					
					
					
 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 
- 
					
					
					
					
 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 
- 
					
					
					
					
 @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 
- 
					
					
					
					
 @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. 
- 
					
					
					
					
 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-esctools 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 
- 
					
					
					
					
 @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! 
- 
					
					
					
					
 @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-escintegration, but just to summarize, it will be very similar to sending RPM or power commands usingvoxl-esctools (which you may have already done with ModalAI ESCs), and M0065 will take the 4 commands sent out byvoxl-escand 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, butvoxl-escpython 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 
- 
					
					
					
					
 @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. 
- 
					
					
					
					
 @Gary-Holmgren , can you help me understand your set up better? Are you already using a ModalAI esc with 4 outputs and want to add another 4? Is the reason for going to dshot due to the fact that ModalAI esc does not support 8 outputs? By the way, ModalAI esc does have support for changing direction in real time, but i am not sure if PX4 has this ability to command negative rpms (mainly, the mixer would need to do that). Alex 
- 
					
					
					
					
 @Alex-Kushleyev Yes of course, I am trying to experiment with ground vehicles but in order for proper operation the motors need to reverse direction for forward and reverse driving. I dont have a modalai in my setup. I wanted to have 4 channels of dshot so my motors could allow for forward and reverse operation, and since the other 4 PWM are still available on the M0064, I could use them for other servo/actuators. I am trying to understand how others may have configured the UGV or rover options using voxl2/ESC combos but have had no luck in having a working setup. 
- 
					
					
					
					
 @Alex-Kushleyev Im starting to think the problem may be my 4in1 ESC I have chosen to power the motors as its meant for drone motors not drive motors. Although I dont see why it wouldn't work since turtlemode allows you to reverse motor direction on demand. I guess I dont know what PX4 expects for an ESC of that vehicle type as there is no documentation I could find on what ESC to use. 
- 
					
					
					
					
 Is your ground vehicle a direct drive BLDC (or do you have a gear box?). Direct drive motors usually require FOC control because wheels typically spin much slower than drone propellers and you need frequent start / stop and high torque / low speed operation. Do you have an ESC that uses FOC control with dshot input? Non-FOC control would work if you have a gearbox, but there may still be some jittering at very low RPM. Alex 
- 
					
					
					
					
 @Alex-Kushleyev Yes it does have a gearbox, and good to know I considered using FOC for avoiding it but I needed quite a bit of torque. This is the ESC im currently using as it supports PWM/dshot/etc but its just a basic 4in1 meant for flight so I am not sure if I can confugure it to otput bidirectionally ex: 1500uS is zero 1050 is full reverse and 1950 is full forward. 
- 
					
					
					
					
 @Gary-Holmgren, do you have any ModalAI ESCs? If so, which one? I can help you test it with a geared BLDC motor. Alex 
- 
					
					
					
					
 @Alex-Kushleyev Unfortunately I do not have one, but if that is the only solution here I would think about getting one.