2
0
mirror of https://github.com/checkpoint-restore/criu synced 2025-08-22 09:58:09 +00:00
criu/log.c

90 lines
1.4 KiB
C
Raw Normal View History

#include <stdlib.h>
#include <stdio.h>
#include <stdarg.h>
#include <errno.h>
#include <unistd.h>
#include <stdbool.h>
#include <limits.h>
#include <sys/types.h>
#include <sys/time.h>
#include <sys/resource.h>
#include <fcntl.h>
#include "compiler.h"
#include "types.h"
#include "util.h"
/* Note pr_ helpers rely on this descriptor! */
static int logfd = STDERR_FILENO;
int get_logfd(void)
{
return logfd;
}
int init_log(const char *name)
{
struct rlimit rlimit;
int fd = STDERR_FILENO;
if (getrlimit(RLIMIT_NOFILE, &rlimit)) {
pr_err("can't get rlimit: %m\n");
return -1;
}
if (name) {
fd = open(name, O_CREAT | O_WRONLY);
if (fd == -1) {
pr_perror("Can't create log file %s", name);
return -1;
}
}
logfd = rlimit.rlim_cur - 1;
if (reopen_fd_as(logfd, fd) < 0) {
pr_err("can't duplicate descriptor %d->%d: %m\n",
fd, logfd);
logfd = STDERR_FILENO;
goto err;
}
return 0;
err:
if (name)
close(fd);
return -1;
}
void fini_log(void)
{
if (logfd != STDERR_FILENO &&
logfd != STDIN_FILENO &&
logfd != STDOUT_FILENO)
close(logfd);
logfd = STDERR_FILENO;
}
static unsigned int loglevel = LOG_WARN;
void set_loglevel(unsigned int level)
{
if (!level)
loglevel = LOG_ERROR;
else
loglevel = level;
}
void printk_level(unsigned int level, const char *format, ...)
{
va_list params;
if (level <= loglevel) {
va_start(params, format);
vdprintf(get_logfd(), format, params);
va_end(params);
}
}