When showing an error like 'Socket service not loaded', the
error won't show up in the status for the socket, unless it is
marked as SYSTEMD_UNIT=*.socket. Marking it as SYSTEMD_UNIT=*.service,
when the service is non-existent, is not useful.
service = SERVICE(UNIT_DEREF(s->service));
if (UNIT(service)->load_state != UNIT_LOADED) {
service = SERVICE(UNIT_DEREF(s->service));
if (UNIT(service)->load_state != UNIT_LOADED) {
- log_error_unit(UNIT(service)->id,
"Socket service %s not loaded, refusing.",
UNIT(service)->id);
return -ENOENT;
"Socket service %s not loaded, refusing.",
UNIT(service)->id);
return -ENOENT;
if (service->state != SERVICE_DEAD &&
service->state != SERVICE_FAILED &&
service->state != SERVICE_AUTO_RESTART) {
if (service->state != SERVICE_DEAD &&
service->state != SERVICE_FAILED &&
service->state != SERVICE_AUTO_RESTART) {
- log_error_unit(UNIT(service)->id,
"Socket service %s already active, refusing.",
UNIT(service)->id);
return -EBUSY;
"Socket service %s already active, refusing.",
UNIT(service)->id);
return -EBUSY;
#ifdef HAVE_SYSV_COMPAT
if (service->is_sysv) {
#ifdef HAVE_SYSV_COMPAT
if (service->is_sysv) {
- log_error_unit(UNIT(s)->id,
"Using SysV services for socket activation is not supported. Refusing.");
return -ENOENT;
}
"Using SysV services for socket activation is not supported. Refusing.");
return -ENOENT;
}