summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2023-11-10 16:58:50 +0100
committerLennart Poettering <lennart@poettering.net>2023-11-13 15:45:16 +0100
commit95d548026f203c05c834bb3d829c01350efd7c53 (patch)
tree4556b5521187184478d18d4a572ac540ed9ead8c
parentutil-lib: share plymouth client code (diff)
downloadsystemd-95d548026f203c05c834bb3d829c01350efd7c53.tar.xz
systemd-95d548026f203c05c834bb3d829c01350efd7c53.zip
storagetm: show connection data also via plymouth
Pretty!
-rw-r--r--TODO1
-rw-r--r--src/storagetm/storagetm.c61
2 files changed, 56 insertions, 6 deletions
diff --git a/TODO b/TODO
index 04c232e37e..4e216a2cf4 100644
--- a/TODO
+++ b/TODO
@@ -182,7 +182,6 @@ Features:
as mass storage devices on systems that have a USB controller that can
operate in device mode
- add NVMe authentication
- - show login details also via plymouth
* add support for activating nvme-oF devices at boot automatically via kernel
cmdline, and maybe even support a syntax such as
diff --git a/src/storagetm/storagetm.c b/src/storagetm/storagetm.c
index dfde848434..8d36184b76 100644
--- a/src/storagetm/storagetm.c
+++ b/src/storagetm/storagetm.c
@@ -18,6 +18,7 @@
#include "main-func.h"
#include "parse-argument.h"
#include "path-util.h"
+#include "plymouth-util.h"
#include "pretty-print.h"
#include "process-util.h"
#include "random-util.h"
@@ -568,7 +569,41 @@ static int nvme_subsystem_report(NvmeSubsystem *subsystem, NvmePort *ipv4, NvmeP
return 0;
}
-static int nvme_port_report(NvmePort *port) {
+static int plymouth_send_text(const char *text) {
+ _cleanup_free_ char *plymouth_message = NULL;
+ int c, r;
+
+ assert(text);
+
+ c = asprintf(&plymouth_message,
+ "M\x02%c%s%c"
+ "A%c", /* pause spinner */
+ (int) strlen(text) + 1, text, '\x00',
+ '\x00');
+ if (c < 0)
+ return log_oom();
+
+ r = plymouth_send_raw(plymouth_message, c, SOCK_NONBLOCK);
+ if (r < 0)
+ return log_full_errno(ERRNO_IS_NO_PLYMOUTH(r) ? LOG_DEBUG : LOG_WARNING, r,
+ "Failed to communicate with plymouth, ignoring: %m");
+
+ return 0;
+}
+
+static int plymouth_notify_port(NvmePort *port, struct local_address *a) {
+ _cleanup_free_ char *m = NULL;
+
+ if (!port || !a)
+ return 0;
+
+ if (asprintf(&m, "nvme connect-all -t tcp -a %s -s %" PRIu16, IN_ADDR_TO_STRING(a->family, &a->address), port->portnr) < 0)
+ return log_oom();
+
+ return plymouth_send_text(m);
+}
+
+static int nvme_port_report(NvmePort *port, bool *plymouth_done) {
if (!port)
return 0;
@@ -590,6 +625,11 @@ static int nvme_port_report(NvmePort *port) {
IN_ADDR_TO_STRING(a->family, &a->address),
port->portnr);
+ if (plymouth_done && !*plymouth_done) {
+ (void) plymouth_notify_port(port, n_addresses > 0 ? addresses : NULL);
+ *plymouth_done = n_addresses > 0;
+ }
+
return 0;
}
@@ -861,8 +901,15 @@ static int on_display_refresh(sd_event_source *s, uint64_t usec, void *userdata)
if (isatty(STDERR_FILENO) > 0)
fputs(ANSI_HOME_CLEAR, stderr);
- (void) nvme_port_report(c->ipv4_port);
- (void) nvme_port_report(c->ipv6_port);
+ /* If we have both IPv4 and IPv6, we display IPv4 info via Plymouth, since it doesn't have much
+ * space, and IPv4 is simply shorter (and easy to type off screen) */
+
+ bool plymouth_done = false;
+ (void) nvme_port_report(c->ipv4_port, &plymouth_done);
+ (void) nvme_port_report(c->ipv6_port, &plymouth_done);
+
+ if (!plymouth_done)
+ (void) plymouth_send_text("Network disconnected.");
NvmeSubsystem *i;
HASHMAP_FOREACH(i, c->subsystems)
@@ -946,16 +993,20 @@ static int run(int argc, char* argv[]) {
if (r < 0)
return r;
- nvme_port_report(context.ipv4_port);
+ bool plymouth_done = false;
+ nvme_port_report(context.ipv4_port, &plymouth_done);
if (socket_ipv6_is_enabled()) {
r = nvme_port_add(arg_nqn, AF_INET6, &context.ipv6_port);
if (r < 0)
return r;
- nvme_port_report(context.ipv6_port);
+ nvme_port_report(context.ipv6_port, &plymouth_done);
}
+ if (!plymouth_done)
+ (void) plymouth_send_text("Network disconnected.");
+
NvmeSubsystem *i;
HASHMAP_FOREACH(i, context.subsystems) {
if (context.ipv4_port) {