mirror of
https://github.com/tiagovignatti/intel-gpu-tools.git
synced 2025-06-13 02:46:23 +00:00
lib: add igt_vlog to print varargs
... and put it to immediate use in igt_display_log. To make this all add up also drop the return value of igt_display_log, no one really cared anyway. Aside: I've noticed that every time another subtest runs (at least with kms_pipe_crc_basic) the log indent level moves one up ... Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
1e9e1baba3
commit
bd53d722dd
@ -1074,3 +1074,30 @@ void igt_log(enum igt_log_level level, const char *format, ...)
|
|||||||
vprintf(format, args);
|
vprintf(format, args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* igt_vlog:
|
||||||
|
* @level: #igt_log_level
|
||||||
|
* @format: format string
|
||||||
|
* @args: variable arguments lists
|
||||||
|
*
|
||||||
|
* This is the generic logging helper function using an explicit varargs
|
||||||
|
* structure and hence useful to implement domain-specific logging
|
||||||
|
* functions.
|
||||||
|
*
|
||||||
|
* If there is no need to wrap up a vararg list in the caller it is simpler to
|
||||||
|
* just use igt_log().
|
||||||
|
*/
|
||||||
|
void igt_vlog(enum igt_log_level level, const char *format, va_list args)
|
||||||
|
{
|
||||||
|
assert(format);
|
||||||
|
|
||||||
|
if (igt_log_level > level)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (level == IGT_LOG_WARN) {
|
||||||
|
fflush(stdout);
|
||||||
|
vfprintf(stderr, format, args);
|
||||||
|
} else
|
||||||
|
vprintf(format, args);
|
||||||
|
}
|
||||||
|
@ -389,6 +389,7 @@ enum igt_log_level {
|
|||||||
};
|
};
|
||||||
__attribute__((format(printf, 2, 3)))
|
__attribute__((format(printf, 2, 3)))
|
||||||
void igt_log(enum igt_log_level level, const char *format, ...);
|
void igt_log(enum igt_log_level level, const char *format, ...);
|
||||||
|
void igt_vlog(enum igt_log_level level, const char *format, va_list args);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* igt_debug:
|
* igt_debug:
|
||||||
|
@ -817,23 +817,18 @@ const char *plane_name(enum igt_plane p)
|
|||||||
} while (0)
|
} while (0)
|
||||||
#define LOG(d, fmt, ...) igt_display_log(d, fmt, ## __VA_ARGS__)
|
#define LOG(d, fmt, ...) igt_display_log(d, fmt, ## __VA_ARGS__)
|
||||||
|
|
||||||
static int __attribute__((format(printf, 2, 3)))
|
static void __attribute__((format(printf, 2, 3)))
|
||||||
igt_display_log(igt_display_t *display, const char *fmt, ...)
|
igt_display_log(igt_display_t *display, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
va_list args;
|
va_list args;
|
||||||
int n, i;
|
int i;
|
||||||
|
|
||||||
if (igt_log_level > IGT_LOG_DEBUG)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
n = printf("display: ");
|
igt_debug("display: ");
|
||||||
for (i = 0; i < display->log_shift; i++)
|
for (i = 0; i < display->log_shift; i++)
|
||||||
n += printf("%s", LOG_SPACES);
|
igt_debug("%s", LOG_SPACES);
|
||||||
n += vprintf(fmt, args);
|
igt_vlog(IGT_LOG_DEBUG, fmt, args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
|
|
||||||
return n;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void igt_display_log_shift(igt_display_t *display, int shift)
|
static void igt_display_log_shift(igt_display_t *display, int shift)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user