The fd for writing to log process is non-blocking. When sending options
to log process, it was done with write_full(), which stopped whenever
EAGAIN was returned. This error was simply ignored, and the logging code
thought that the prefix was successfully changed (or the IP was sent).
This mainly caused a problem when processes were reused and log process
was busy. The prefix update could have failed, and the following logging
would be using the previous session's log prefix, i.e. log lines could have
been logged for the wrong user/session.
Broken by
9372e48b702a3af5705785e08fbf47b0e37f2047
str = t_strdup_printf("\001%c%s %s=%s\n", LOG_TYPE_OPTION+1,
my_pid, key, value);
- (void)write_full(STDERR_FILENO, str, strlen(str));
+ (void)log_fd_write(STDERR_FILENO, (const unsigned char *)str,
+ strlen(str));
}
static void i_failure_send_option(const char *key, const char *value)