Revert "openocd: remove command line flag -p/--pipe deprecated in v0.5.0"

This reverts commit d02e29daba.

Change-Id: I356854dd624d63439c673998f0e61b1bbca8a73b
This commit is contained in:
wangyanwen 2023-10-09 14:05:28 +08:00 committed by Huaqi Fang
parent b3b8ad2257
commit 2c2e861b34
2 changed files with 12 additions and 1 deletions

View File

@ -2198,6 +2198,9 @@ disables the gdb server.
When using "pipe", also use log_output to redirect the log When using "pipe", also use log_output to redirect the log
output to a file so as not to flood the stdin/out pipes. output to a file so as not to flood the stdin/out pipes.
The -p/--pipe option is deprecated and a warning is printed
as it is equivalent to passing in -c "gdb_port pipe; log_output openocd.log".
Any other string is interpreted as named pipe to listen to. Any other string is interpreted as named pipe to listen to.
Output pipe is the same name as input pipe, but with 'o' appended, Output pipe is the same name as input pipe, but with 'o' appended,
e.g. /var/gdb, /var/gdbo. e.g. /var/gdb, /var/gdbo.

View File

@ -44,6 +44,7 @@ static const struct option long_options[] = {
{"search", required_argument, NULL, 's'}, {"search", required_argument, NULL, 's'},
{"log_output", required_argument, NULL, 'l'}, {"log_output", required_argument, NULL, 'l'},
{"command", required_argument, NULL, 'c'}, {"command", required_argument, NULL, 'c'},
{"pipe", no_argument, NULL, 'p'},
{NULL, 0, NULL, 0} {NULL, 0, NULL, 0}
}; };
@ -270,7 +271,7 @@ int parse_cmdline_args(struct command_context *cmd_ctx, int argc, char *argv[])
/* getopt_long stores the option index here. */ /* getopt_long stores the option index here. */
int option_index = 0; int option_index = 0;
c = getopt_long(argc, argv, "hvd::l:f:s:c:", long_options, &option_index); c = getopt_long(argc, argv, "hvd::l:f:s:c:p", long_options, &option_index);
/* Detect the end of the options. */ /* Detect the end of the options. */
if (c == -1) if (c == -1)
@ -310,6 +311,13 @@ int parse_cmdline_args(struct command_context *cmd_ctx, int argc, char *argv[])
if (optarg) if (optarg)
add_config_command(optarg); add_config_command(optarg);
break; break;
case 'p':
/* to replicate the old syntax this needs to be synchronous
* otherwise the gdb stdin will overflow with the warning message */
command_run_line(cmd_ctx, "gdb_port pipe; log_output openocd.log");
LOG_WARNING("deprecated option: -p/--pipe. Use '-c \"gdb_port pipe; "
"log_output openocd.log\"' instead.");
break;
default: /* '?' */ default: /* '?' */
/* getopt will emit an error message, all we have to do is bail. */ /* getopt will emit an error message, all we have to do is bail. */
return ERROR_FAIL; return ERROR_FAIL;