zbd: Fix max_open_zones checks
[fio.git] / log.h
1 #ifndef FIO_LOG_H
2 #define FIO_LOG_H
3
4 #include <stdio.h>
5 #include <stdarg.h>
6 #include <unistd.h>
7
8 #include "lib/output_buffer.h"
9
10 extern FILE *f_out;
11 extern FILE *f_err;
12
13 extern ssize_t log_err(const char *format, ...) __attribute__ ((__format__ (__printf__, 1, 2)));
14 extern ssize_t log_info(const char *format, ...) __attribute__ ((__format__ (__printf__, 1, 2)));
15 extern size_t __log_buf(struct buf_output *, const char *format, ...) __attribute__ ((__format__ (__printf__, 2, 3)));
16 extern size_t log_valist(const char *str, va_list);
17 extern void log_prevalist(int type, const char *str, va_list);
18 extern size_t log_info_buf(const char *buf, size_t len);
19 extern int log_info_flush(void);
20
21 #define log_buf(buf, format, args...)                   \
22 ({                                                      \
23         size_t __ret;                                   \
24         if ((buf) != NULL)                              \
25                 __ret = __log_buf(buf, format, ##args); \
26         else                                            \
27                 __ret = log_info(format, ##args);       \
28         __ret;                                          \
29 })
30
31 enum {
32         FIO_LOG_DEBUG   = 1,
33         FIO_LOG_INFO    = 2,
34         FIO_LOG_ERR     = 3,
35         FIO_LOG_NR      = 4,
36 };
37
38 extern const char *log_get_level(int level);
39
40 #endif