obmc-console: Expose socket ID configuration for client and server
* Add a new option in the server configuration file to use a friendly ID
in the socket abstract path
* Add a new command-line option to the client to connect to a particular
server socket path.
Signed-off-by: Andrew Jeffery <andrew@aj.id.au>
Change-Id: I95440ca7c2c76d2c1ef00d92abc9e0ffc32cbf5a
diff --git a/console-client.c b/console-client.c
index af1094f..db8acd3 100644
--- a/console-client.c
+++ b/console-client.c
@@ -207,7 +207,7 @@
return 0;
}
-static int client_init(struct console_client *client)
+static int client_init(struct console_client *client, const char *socket_id)
{
struct sockaddr_un addr;
ssize_t len;
@@ -221,7 +221,7 @@
memset(&addr, 0, sizeof(addr));
addr.sun_family = AF_UNIX;
- len = console_socket_path(&addr, NULL);
+ len = console_socket_path(&addr, socket_id);
if (len < 0) {
if (errno)
warn("Failed to configure socket: %s", strerror(errno));
@@ -253,6 +253,7 @@
struct console_client _client, *client;
struct pollfd pollfds[2];
enum process_rc prc = PROCESS_OK;
+ const char *socket_id = NULL;
int rc;
client = &_client;
@@ -260,7 +261,7 @@
client->esc_type = ESC_TYPE_SSH;
for (;;) {
- rc = getopt(argc, argv, "e:");
+ rc = getopt(argc, argv, "e:i:");
if (rc == -1)
break;
@@ -273,16 +274,24 @@
client->esc_type = ESC_TYPE_STR;
client->esc_state.str.str = (const uint8_t*)optarg;
break;
+ case 'i':
+ if (optarg[0] == '\0') {
+ fprintf(stderr, "Socket ID str cannot be empty\n");
+ return EXIT_FAILURE;
+ }
+ socket_id = optarg;
+ break;
default:
fprintf(stderr,
"Usage: %s "
- "[-e <escape sequence>]\n",
+ "[-e <escape sequence>]"
+ "[-i <socket ID>]\n",
argv[0]);
return EXIT_FAILURE;
}
}
- rc = client_init(client);
+ rc = client_init(client, socket_id);
if (rc)
return EXIT_FAILURE;
diff --git a/socket-handler.c b/socket-handler.c
index 00044f4..a11ab24 100644
--- a/socket-handler.c
+++ b/socket-handler.c
@@ -302,7 +302,7 @@
}
static int socket_init(struct handler *handler, struct console *console,
- struct config *config __attribute__((unused)))
+ struct config *config)
{
struct socket_handler *sh = to_socket_handler(handler);
struct sockaddr_un addr;
@@ -322,7 +322,7 @@
memset(&addr, 0, sizeof(addr));
addr.sun_family = AF_UNIX;
- len = console_socket_path(&addr, NULL);
+ len = console_socket_path(&addr, config_get_value(config, "socket-id"));
if (len < 0) {
if (errno)
warn("Failed to configure socket: %s", strerror(errno));