mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-18 13:55:18 +03:00
Merge pull request #7415 from jflyper/bfdev-change-call-timing-of-vtxInit-after-device-parameter-init
[VTX] Follow-up to #7285 vtx changes
This commit is contained in:
commit
7eedfff428
6 changed files with 59 additions and 19 deletions
|
@ -128,30 +128,44 @@ bool vtxCommonGetDeviceCapability(const vtxDevice_t *vtxDevice, vtxDeviceCapabil
|
|||
|
||||
const char *vtxCommonLookupBandName(const vtxDevice_t *vtxDevice, int band)
|
||||
{
|
||||
return vtxDevice->bandNames[band];
|
||||
if (vtxDevice) {
|
||||
return vtxDevice->bandNames[band];
|
||||
} else {
|
||||
return "?";
|
||||
}
|
||||
}
|
||||
|
||||
char vtxCommonLookupBandLetter(const vtxDevice_t *vtxDevice, int band)
|
||||
{
|
||||
return vtxDevice->bandLetters[band];
|
||||
if (vtxDevice) {
|
||||
return vtxDevice->bandLetters[band];
|
||||
} else {
|
||||
return '?';
|
||||
}
|
||||
}
|
||||
|
||||
const char *vtxCommonLookupChannelName(const vtxDevice_t *vtxDevice, int channel)
|
||||
{
|
||||
return vtxDevice->channelNames[channel];
|
||||
if (vtxDevice) {
|
||||
return vtxDevice->channelNames[channel];
|
||||
} else {
|
||||
return "?";
|
||||
}
|
||||
}
|
||||
|
||||
//Converts frequency (in MHz) to band and channel values.
|
||||
bool vtxCommonLookupBandChan(const vtxDevice_t *vtxDevice, uint16_t freq, uint8_t *pBand, uint8_t *pChannel)
|
||||
{
|
||||
// Use reverse lookup order so that 5880Mhz
|
||||
// get Raceband 7 instead of Fatshark 8.
|
||||
for (int band = vtxDevice->capability.bandCount - 1 ; band >= 0 ; band--) {
|
||||
for (int channel = 0 ; channel < vtxDevice->capability.channelCount ; channel++) {
|
||||
if (vtxDevice->frequencyTable[band * vtxDevice->capability.channelCount + channel] == freq) {
|
||||
*pBand = band + 1;
|
||||
*pChannel = channel + 1;
|
||||
return true;
|
||||
if (vtxDevice) {
|
||||
// Use reverse lookup order so that 5880Mhz
|
||||
// get Raceband 7 instead of Fatshark 8.
|
||||
for (int band = vtxDevice->capability.bandCount - 1 ; band >= 0 ; band--) {
|
||||
for (int channel = 0 ; channel < vtxDevice->capability.channelCount ; channel++) {
|
||||
if (vtxDevice->frequencyTable[band * vtxDevice->capability.channelCount + channel] == freq) {
|
||||
*pBand = band + 1;
|
||||
*pChannel = channel + 1;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -168,21 +182,31 @@ bool vtxCommonLookupBandChan(const vtxDevice_t *vtxDevice, uint16_t freq, uint8_
|
|||
// Returns frequency value (in MHz), or 0 if band/channel out of range.
|
||||
uint16_t vtxCommonLookupFrequency(const vtxDevice_t *vtxDevice, int band, int channel)
|
||||
{
|
||||
if (band > 0 && band <= vtxDevice->capability.bandCount &&
|
||||
channel > 0 && channel <= vtxDevice->capability.channelCount) {
|
||||
return vtxDevice->frequencyTable[(band - 1) * vtxDevice->capability.channelCount + (channel - 1)];
|
||||
|
||||
if (vtxDevice) {
|
||||
if (band > 0 && band <= vtxDevice->capability.bandCount &&
|
||||
channel > 0 && channel <= vtxDevice->capability.channelCount) {
|
||||
return vtxDevice->frequencyTable[(band - 1) * vtxDevice->capability.channelCount + (channel - 1)];
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
const char *vtxCommonLookupPowerName(const vtxDevice_t *vtxDevice, int index)
|
||||
{
|
||||
return vtxDevice->powerNames[index];
|
||||
if (vtxDevice) {
|
||||
return vtxDevice->powerNames[index];
|
||||
} else {
|
||||
return "?";
|
||||
}
|
||||
}
|
||||
|
||||
uint16_t vtxCommonLookupPowerValue(const vtxDevice_t *vtxDevice, int index)
|
||||
{
|
||||
return vtxDevice->powerValues[index];
|
||||
if (vtxDevice) {
|
||||
return vtxDevice->powerValues[index];
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
|
|
@ -709,7 +709,6 @@ void init(void)
|
|||
|
||||
#if defined(USE_VTX_COMMON)
|
||||
vtxCommonInit();
|
||||
vtxInit();
|
||||
#endif
|
||||
|
||||
#ifdef USE_VTX_SMARTAUDIO
|
||||
|
|
|
@ -69,8 +69,16 @@ void vtxInit(void)
|
|||
{
|
||||
bool settingsUpdated = false;
|
||||
|
||||
vtxDevice_t *vtxDevice = vtxCommonDevice();
|
||||
|
||||
if (!vtxDevice) {
|
||||
// If a device is not registered, we don't have any table to refer.
|
||||
// Don't manipulate settings and just return in this case.
|
||||
return;
|
||||
}
|
||||
|
||||
// sync frequency in parameter group when band/channel are specified
|
||||
const uint16_t freq = vtxCommonLookupFrequency(vtxCommonDevice(), vtxSettingsConfig()->band, vtxSettingsConfig()->channel);
|
||||
const uint16_t freq = vtxCommonLookupFrequency(vtxDevice, vtxSettingsConfig()->band, vtxSettingsConfig()->channel);
|
||||
if (vtxSettingsConfig()->band && freq != vtxSettingsConfig()->freq) {
|
||||
vtxSettingsConfigMutable()->freq = freq;
|
||||
settingsUpdated = true;
|
||||
|
|
|
@ -36,6 +36,7 @@
|
|||
#include "drivers/time.h"
|
||||
#include "drivers/vtx_rtc6705.h"
|
||||
|
||||
#include "io/vtx.h"
|
||||
#include "io/vtx_rtc6705.h"
|
||||
#include "io/vtx_string.h"
|
||||
|
||||
|
@ -69,6 +70,8 @@ bool vtxRTC6705Init(void)
|
|||
|
||||
vtxCommonSetDevice(&vtxRTC6705);
|
||||
|
||||
vtxInit();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
@ -706,6 +706,8 @@ bool vtxSmartAudioInit(void)
|
|||
|
||||
vtxCommonSetDevice(&vtxSmartAudio);
|
||||
|
||||
vtxInit();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
@ -614,6 +614,7 @@ bool vtxTrampInit(void)
|
|||
return false;
|
||||
}
|
||||
|
||||
// XXX Effect of USE_VTX_COMMON should be reviewed, as following call to vtxInit will do nothing if vtxCommonSetDevice is not called.
|
||||
#if defined(USE_VTX_COMMON)
|
||||
vtxTramp.capability.bandCount = VTX_TRAMP_BAND_COUNT;
|
||||
vtxTramp.capability.channelCount = VTX_TRAMP_CHANNEL_COUNT;
|
||||
|
@ -626,8 +627,11 @@ bool vtxTrampInit(void)
|
|||
vtxTramp.powerValues = trampPowerTable;
|
||||
|
||||
vtxCommonSetDevice(&vtxTramp);
|
||||
|
||||
#endif
|
||||
|
||||
vtxInit();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue