-
Notifications
You must be signed in to change notification settings - Fork 18k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
AP_MSP:add option for backward compatibility #26966
Conversation
I just want to say for the record I definitely don't agree with this with this. IMO the golden rule is "all settings on the AP if at all possible", so I think "don't mess with the TX reverse use the RC reverse" is correct. The alternative means "all settings on the AP except for RC channels which should be done on the TX" - what could justify making this exception? |
I'd suggest that rather than being "set the flag to get the OLD behavior", maybe it should be "set the flag to get the NEW behaviour" - so no impact on existing setups. |
Some testing results using my HD-Zero goggles:
4.6.0 master - which has #26304
This PR
|
yes dropped a conditional negative as I was debugging...fixed now so option is to provide OLD behavior....please retest... |
This is the exact point and purpose of my previous PR. Thus, I really don't think we should be adding this option at all. |
Whatever the history, we are where we are now. I'd still like to understand the philosophy for setting everything, from scaling, to expo, to servo direction, trims, everything relating to control configuration gets set on AP. Except one thing! RC reversal. Why that one exception? |
Not just RC reversal, but RC scale too (I.e. max, min, trim). And the reason for that is because not everyone has an OpenTX transmitter. A lot of people have transmitters where they can't adjust these things, and it might be reversed relative to what ArduPilot expects (I used one like this for the first year or two's worth of Blimp development). Thus you'd need to set the _REVERSED parameters. Same effect as what'd happen if you reversed one or more channels in OpenTX: You'd have to also reverse it in ArduPilot to get it going into the controllers in the right direction. Before my PR, people in this situation would just find that their eg HDZero stick commands are in the wrong direction and there's nothing they can do about it since changing _REVERSED has no effect on that and they can't change what their remote outputs. After my PR, people in this situation would find that as long as their vehicle is set up so the commands go into the controllers in the correct direction, then their HDZero stick commands would also work in the correct directions. |
We now have scaled passthrough options for all RC channels, so scaling can (should) also be done on the AP. |
So if this is about "people in this situation" with specific/limited transmitters, is it not a good idea to make it optional/selectable as this (Henry's) PR does, so that it can be used by those people, but doesn't affect those who don't need it? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since you requested my review, I thought I should probably put one in.
This PR uses an extra 128 bytes of flash, and while that's not much, I also don't see why this is necessary. The only "backward compatibility" this provides, AFAICT is compatibility with incorrectly setup aircraft. Much better for such users to fix their aircraft.
Thus, I am against this PR, unless someone has an example where this would be necessary in a correctly-setup aircraft.
My point was that people with limited transmitters need the fix in my PR to get correct stick commands. People who have OpenTX can work around it (by having specific reversals in OpenTX), but it's still more convenient to not have to do this. |
I'm not keen on this, I think users need to fix their broken setups |
#26304 will break any existing configuration relying on raw rc over MSP that use the AP RC input reversing parameter currently....this is primarily VTX and OSD stick commands and the user would have gotten used to the reversed sick patterns
while it is possible to reconfigure by changing both the TX reverse (assuming it has that ability...many old simple TXs do not but we may elect to consider them obsolete now) and the AP RCx_ reverse param...it is still a breaking setup change for some.
Our wiki recommends both ways of adjusting RC reverse...in one section it say avoid the RC reverse param if possible using TX reverse, in another it says don't mess with the TX reverse use the RC reverse...this wiki contradiction will be changed to the former recommendation but the previous PR still breaks some existing setups...with this option we offer those cases an easy reversion which can be mentioned in the wiki in the multiple RC setup mentions.
I am asking @timtuxworth to test this PR both with and without the option bit set in one of his setups for both VTX and HDzero if possible
note:I welcome coding efficiency suggestions since I am not skilled in that for sure