X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=log.c;h=08509b32b0150f85a55d76c38776d00d856be159;hb=033ace1e7965ebf215f6fba2102de5b716ebfede;hp=a16baafc97846f68e08b1d466eff67ed130b24ae;hpb=1f39e5556fc0418ac6d1bd8531a91c94836a6350;p=fio.git diff --git a/log.c b/log.c index a16baafc..08509b32 100644 --- a/log.c +++ b/log.c @@ -12,6 +12,7 @@ int log_valist(const char *str, va_list args) size_t len; len = vsnprintf(buffer, sizeof(buffer), str, args); + len = min(len, sizeof(buffer) - 1); if (log_syslog) syslog(LOG_INFO, "%s", buffer); @@ -21,6 +22,16 @@ int log_valist(const char *str, va_list args) return len; } +int log_local_buf(const char *buf, size_t len) +{ + if (log_syslog) + syslog(LOG_INFO, "%s", buf); + else + len = fwrite(buf, len, 1, f_out); + + return len; +} + int log_local(const char *format, ...) { char buffer[1024]; @@ -30,6 +41,7 @@ int log_local(const char *format, ...) va_start(args, format); len = vsnprintf(buffer, sizeof(buffer), format, args); va_end(args); + len = min(len, sizeof(buffer) - 1); if (log_syslog) syslog(LOG_INFO, "%s", buffer); @@ -48,10 +60,14 @@ int log_info(const char *format, ...) va_start(args, format); len = vsnprintf(buffer, sizeof(buffer), format, args); va_end(args); + len = min(len, sizeof(buffer) - 1); if (is_backend) return fio_server_text_output(buffer, len); - else + else if (log_syslog) { + syslog(LOG_INFO, "%s", buffer); + return len; + } else return fwrite(buffer, len, 1, f_out); } @@ -64,10 +80,14 @@ int log_err(const char *format, ...) va_start(args, format); len = vsnprintf(buffer, sizeof(buffer), format, args); va_end(args); + len = min(len, sizeof(buffer) - 1); if (is_backend) return fio_server_text_output(buffer, len); - else { + else if (log_syslog) { + syslog(LOG_INFO, "%s", buffer); + return len; + } else { if (f_err != stderr) { int fio_unused ret;