mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
AP_HAL_Linux: deprecate and warn on legacy --uartX option use
This commit is contained in:
parent
14180b5b93
commit
e460a19b17
@ -87,6 +87,19 @@ static SPIUARTDriver serial3Driver;
|
|||||||
static UARTDriver serial3Driver(false);
|
static UARTDriver serial3Driver(false);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static UARTDriver* serialDrivers[] = {
|
||||||
|
&serial0Driver,
|
||||||
|
&serial1Driver,
|
||||||
|
&serial2Driver,
|
||||||
|
&serial3Driver,
|
||||||
|
&serial4Driver,
|
||||||
|
&serial5Driver,
|
||||||
|
&serial6Driver,
|
||||||
|
&serial7Driver,
|
||||||
|
&serial8Driver,
|
||||||
|
&serial9Driver,
|
||||||
|
};
|
||||||
|
|
||||||
#if CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_NAVIO || \
|
#if CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_NAVIO || \
|
||||||
CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_ERLEBRAIN2 || \
|
CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_ERLEBRAIN2 || \
|
||||||
CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_BH || \
|
CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_BH || \
|
||||||
@ -287,9 +300,9 @@ void _usage(void)
|
|||||||
printf("\tserial (0 through 9 available):\n");
|
printf("\tserial (0 through 9 available):\n");
|
||||||
printf("\t --serial0 /dev/ttyO4\n");
|
printf("\t --serial0 /dev/ttyO4\n");
|
||||||
printf("\t --serial3 /dev/ttyS1\n");
|
printf("\t --serial3 /dev/ttyS1\n");
|
||||||
printf("\tlegacy UART options still work, their mappings are:\n");
|
printf("\tlegacy UART options are deprecated, their mappings are:\n");
|
||||||
printf("\t -A/--uartA is SERIAL0\n");
|
printf("\t -A/--uartA is SERIAL0\n");
|
||||||
printf("\t -C/--uartC is SERIAL1\n");
|
printf("\t -C/--uartC is SERIAL1\n"); // ordering captures the historical use of uartB as SERIAL3
|
||||||
printf("\t -D/--uartD is SERIAL2\n");
|
printf("\t -D/--uartD is SERIAL2\n");
|
||||||
printf("\t -B/--uartB is SERIAL3\n");
|
printf("\t -B/--uartB is SERIAL3\n");
|
||||||
printf("\t -E/--uartE is SERIAL4\n");
|
printf("\t -E/--uartE is SERIAL4\n");
|
||||||
@ -331,28 +344,41 @@ void HAL_Linux::run(int argc, char* const argv[], Callbacks* callbacks) const
|
|||||||
const char *module_path = AP_MODULE_DEFAULT_DIRECTORY;
|
const char *module_path = AP_MODULE_DEFAULT_DIRECTORY;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
enum long_options {
|
||||||
|
CMDLINE_SERIAL0 = 1, // must be in 0-9 order and numbered consecutively
|
||||||
|
CMDLINE_SERIAL1,
|
||||||
|
CMDLINE_SERIAL2,
|
||||||
|
CMDLINE_SERIAL3,
|
||||||
|
CMDLINE_SERIAL4,
|
||||||
|
CMDLINE_SERIAL5,
|
||||||
|
CMDLINE_SERIAL6,
|
||||||
|
CMDLINE_SERIAL7,
|
||||||
|
CMDLINE_SERIAL8,
|
||||||
|
CMDLINE_SERIAL9,
|
||||||
|
};
|
||||||
|
|
||||||
int opt;
|
int opt;
|
||||||
const struct GetOptLong::option options[] = {
|
const struct GetOptLong::option options[] = {
|
||||||
{"uartA", true, 0, 'A'},
|
{"uartA", true, 0, 'A'},
|
||||||
{"serial0", true, 0, 'A'},
|
|
||||||
{"uartC", true, 0, 'C'}, // ordering captures the historical use of uartB as SERIAL3
|
|
||||||
{"serial1", true, 0, 'C'},
|
|
||||||
{"uartD", true, 0, 'D'},
|
|
||||||
{"serial2", true, 0, 'D'},
|
|
||||||
{"uartB", true, 0, 'B'},
|
{"uartB", true, 0, 'B'},
|
||||||
{"serial3", true, 0, 'B'},
|
{"uartC", true, 0, 'C'},
|
||||||
|
{"uartD", true, 0, 'D'},
|
||||||
{"uartE", true, 0, 'E'},
|
{"uartE", true, 0, 'E'},
|
||||||
{"serial4", true, 0, 'E'},
|
|
||||||
{"uartF", true, 0, 'F'},
|
{"uartF", true, 0, 'F'},
|
||||||
{"serial5", true, 0, 'F'},
|
|
||||||
{"uartG", true, 0, 'G'},
|
{"uartG", true, 0, 'G'},
|
||||||
{"serial6", true, 0, 'G'},
|
|
||||||
{"uartH", true, 0, 'H'},
|
{"uartH", true, 0, 'H'},
|
||||||
{"serial7", true, 0, 'H'},
|
|
||||||
{"uartI", true, 0, 'I'},
|
{"uartI", true, 0, 'I'},
|
||||||
{"serial8", true, 0, 'I'},
|
|
||||||
{"uartJ", true, 0, 'J'},
|
{"uartJ", true, 0, 'J'},
|
||||||
{"serial9", true, 0, 'J'},
|
{"serial0", true, 0, CMDLINE_SERIAL0},
|
||||||
|
{"serial1", true, 0, CMDLINE_SERIAL1},
|
||||||
|
{"serial2", true, 0, CMDLINE_SERIAL2},
|
||||||
|
{"serial3", true, 0, CMDLINE_SERIAL3},
|
||||||
|
{"serial4", true, 0, CMDLINE_SERIAL4},
|
||||||
|
{"serial5", true, 0, CMDLINE_SERIAL5},
|
||||||
|
{"serial6", true, 0, CMDLINE_SERIAL6},
|
||||||
|
{"serial7", true, 0, CMDLINE_SERIAL7},
|
||||||
|
{"serial8", true, 0, CMDLINE_SERIAL8},
|
||||||
|
{"serial9", true, 0, CMDLINE_SERIAL9},
|
||||||
{"log-directory", true, 0, 'l'},
|
{"log-directory", true, 0, 'l'},
|
||||||
{"terrain-directory", true, 0, 't'},
|
{"terrain-directory", true, 0, 't'},
|
||||||
{"storage-directory", true, 0, 's'},
|
{"storage-directory", true, 0, 's'},
|
||||||
@ -372,34 +398,36 @@ void HAL_Linux::run(int argc, char* const argv[], Callbacks* callbacks) const
|
|||||||
while ((opt = gopt.getoption()) != -1) {
|
while ((opt = gopt.getoption()) != -1) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'A':
|
case 'A':
|
||||||
serial0Driver.set_device_path(gopt.optarg);
|
|
||||||
break;
|
|
||||||
case 'C':
|
|
||||||
serial1Driver.set_device_path(gopt.optarg);
|
|
||||||
break;
|
|
||||||
case 'D':
|
|
||||||
serial2Driver.set_device_path(gopt.optarg);
|
|
||||||
break;
|
|
||||||
case 'B':
|
case 'B':
|
||||||
serial3Driver.set_device_path(gopt.optarg);
|
case 'C':
|
||||||
break;
|
case 'D':
|
||||||
case 'E':
|
case 'E':
|
||||||
serial4Driver.set_device_path(gopt.optarg);
|
|
||||||
break;
|
|
||||||
case 'F':
|
case 'F':
|
||||||
serial5Driver.set_device_path(gopt.optarg);
|
|
||||||
break;
|
|
||||||
case 'G':
|
case 'G':
|
||||||
serial6Driver.set_device_path(gopt.optarg);
|
|
||||||
break;
|
|
||||||
case 'H':
|
case 'H':
|
||||||
serial7Driver.set_device_path(gopt.optarg);
|
|
||||||
break;
|
|
||||||
case 'I':
|
case 'I':
|
||||||
serial8Driver.set_device_path(gopt.optarg);
|
case 'J': {
|
||||||
|
int uart_idx = opt - 'A';
|
||||||
|
// ordering captures the historical use of uartB as SERIAL3
|
||||||
|
static const uint8_t mapping[] = { 0, 3, 1, 2, 4, 5, 6, 7, 8, 9 };
|
||||||
|
int serial_idx = mapping[uart_idx];
|
||||||
|
printf("WARNING: deprecated option --uart%c/-%c will be removed in "
|
||||||
|
"a future release. Use --serial%d instead.\n",
|
||||||
|
(char)opt, (char)opt, serial_idx);
|
||||||
|
serialDrivers[serial_idx]->set_device_path(gopt.optarg);
|
||||||
break;
|
break;
|
||||||
case 'J':
|
}
|
||||||
serial9Driver.set_device_path(gopt.optarg);
|
case CMDLINE_SERIAL0:
|
||||||
|
case CMDLINE_SERIAL1:
|
||||||
|
case CMDLINE_SERIAL2:
|
||||||
|
case CMDLINE_SERIAL3:
|
||||||
|
case CMDLINE_SERIAL4:
|
||||||
|
case CMDLINE_SERIAL5:
|
||||||
|
case CMDLINE_SERIAL6:
|
||||||
|
case CMDLINE_SERIAL7:
|
||||||
|
case CMDLINE_SERIAL8:
|
||||||
|
case CMDLINE_SERIAL9:
|
||||||
|
serialDrivers[opt - CMDLINE_SERIAL0]->set_device_path(gopt.optarg);
|
||||||
break;
|
break;
|
||||||
case 'l':
|
case 'l':
|
||||||
utilInstance.set_custom_log_directory(gopt.optarg);
|
utilInstance.set_custom_log_directory(gopt.optarg);
|
||||||
|
Loading…
Reference in New Issue
Block a user