AP_SerialManager: added options for each uart
used to control inversion of uarts
This commit is contained in:
parent
785c130a8f
commit
ac3b0a98ab
@ -148,7 +148,55 @@ const AP_Param::GroupInfo AP_SerialManager::var_info[] = {
|
|||||||
// @Values: 1:1200,2:2400,4:4800,9:9600,19:19200,38:38400,57:57600,111:111100,115:115200,500:500000,921:921600,1500:1500000
|
// @Values: 1:1200,2:2400,4:4800,9:9600,19:19200,38:38400,57:57600,111:111100,115:115200,500:500000,921:921600,1500:1500000
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
AP_GROUPINFO("6_BAUD", 13, AP_SerialManager, state[6].baud, SERIAL6_BAUD),
|
AP_GROUPINFO("6_BAUD", 13, AP_SerialManager, state[6].baud, SERIAL6_BAUD),
|
||||||
|
|
||||||
|
// @Param: 1_OPTIONS
|
||||||
|
// @DisplayName: Telem1 options
|
||||||
|
// @Description: Control over UART options
|
||||||
|
// @Bitmask: 0:InvertRX,1:InvertTX
|
||||||
|
// @User: Advanced
|
||||||
|
// @RebootRequired: True
|
||||||
|
AP_GROUPINFO("1_OPTIONS", 14, AP_SerialManager, state[1].options, 0),
|
||||||
|
|
||||||
|
// @Param: 2_OPTIONS
|
||||||
|
// @DisplayName: Telem2 options
|
||||||
|
// @Description: Control over UART options
|
||||||
|
// @Bitmask: 0:InvertRX,1:InvertTX
|
||||||
|
// @User: Advanced
|
||||||
|
// @RebootRequired: True
|
||||||
|
AP_GROUPINFO("2_OPTIONS", 15, AP_SerialManager, state[2].options, 0),
|
||||||
|
|
||||||
|
// @Param: 3_OPTIONS
|
||||||
|
// @DisplayName: Serial3 options
|
||||||
|
// @Description: Control over UART options
|
||||||
|
// @Bitmask: 0:InvertRX,1:InvertTX
|
||||||
|
// @User: Advanced
|
||||||
|
// @RebootRequired: True
|
||||||
|
AP_GROUPINFO("3_OPTIONS", 16, AP_SerialManager, state[3].options, 0),
|
||||||
|
|
||||||
|
// @Param: 4_OPTIONS
|
||||||
|
// @DisplayName: Serial4 options
|
||||||
|
// @Description: Control over UART options
|
||||||
|
// @Bitmask: 0:InvertRX,1:InvertTX
|
||||||
|
// @User: Advanced
|
||||||
|
// @RebootRequired: True
|
||||||
|
AP_GROUPINFO("4_OPTIONS", 17, AP_SerialManager, state[4].options, 0),
|
||||||
|
|
||||||
|
// @Param: 5_OPTIONS
|
||||||
|
// @DisplayName: Serial5 options
|
||||||
|
// @Description: Control over UART options
|
||||||
|
// @Bitmask: 0:InvertRX,1:InvertTX
|
||||||
|
// @User: Advanced
|
||||||
|
// @RebootRequired: True
|
||||||
|
AP_GROUPINFO("5_OPTIONS", 18, AP_SerialManager, state[5].options, 0),
|
||||||
|
|
||||||
|
// @Param: 6_OPTIONS
|
||||||
|
// @DisplayName: Serial6 options
|
||||||
|
// @Description: Control over UART options
|
||||||
|
// @Bitmask: 0:InvertRX,1:InvertTX
|
||||||
|
// @User: Advanced
|
||||||
|
// @RebootRequired: True
|
||||||
|
AP_GROUPINFO("6_OPTIONS", 19, AP_SerialManager, state[6].options, 0),
|
||||||
|
|
||||||
AP_GROUPEND
|
AP_GROUPEND
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -201,6 +249,12 @@ void AP_SerialManager::init()
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (state[i].uart != nullptr) {
|
if (state[i].uart != nullptr) {
|
||||||
|
|
||||||
|
// see if special options have been requested
|
||||||
|
if (state[i].protocol != SerialProtocol_None && state[i].options) {
|
||||||
|
set_options(i);
|
||||||
|
}
|
||||||
|
|
||||||
switch (state[i].protocol) {
|
switch (state[i].protocol) {
|
||||||
case SerialProtocol_None:
|
case SerialProtocol_None:
|
||||||
break;
|
break;
|
||||||
@ -425,6 +479,16 @@ bool AP_SerialManager::protocol_match(enum SerialProtocol protocol1, enum Serial
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// setup any special options
|
||||||
|
void AP_SerialManager::set_options(uint8_t i)
|
||||||
|
{
|
||||||
|
struct UARTState &opt = state[i];
|
||||||
|
// pass through to HAL
|
||||||
|
if (!opt.uart->set_options(opt.options)) {
|
||||||
|
hal.console->printf("Unable to setup options for Serial%u\n", i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
namespace AP {
|
namespace AP {
|
||||||
|
|
||||||
|
@ -147,6 +147,7 @@ private:
|
|||||||
AP_Int8 protocol;
|
AP_Int8 protocol;
|
||||||
AP_Int32 baud;
|
AP_Int32 baud;
|
||||||
AP_HAL::UARTDriver* uart;
|
AP_HAL::UARTDriver* uart;
|
||||||
|
AP_Int16 options;
|
||||||
} state[SERIALMANAGER_NUM_PORTS];
|
} state[SERIALMANAGER_NUM_PORTS];
|
||||||
|
|
||||||
// search through managed serial connections looking for the
|
// search through managed serial connections looking for the
|
||||||
@ -158,6 +159,9 @@ private:
|
|||||||
|
|
||||||
// protocol_match - returns true if the protocols match
|
// protocol_match - returns true if the protocols match
|
||||||
bool protocol_match(enum SerialProtocol protocol1, enum SerialProtocol protocol2) const;
|
bool protocol_match(enum SerialProtocol protocol1, enum SerialProtocol protocol2) const;
|
||||||
|
|
||||||
|
// setup any special options
|
||||||
|
void set_options(uint8_t i);
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace AP {
|
namespace AP {
|
||||||
|
Loading…
Reference in New Issue
Block a user