mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-10-29 05:40:27 -04:00
fix trace logging
This commit is contained in:
parent
214a0e27d8
commit
430b749d53
3 changed files with 24 additions and 14 deletions
|
|
@ -49,14 +49,19 @@ do_logv (SpaLog *log,
|
|||
{
|
||||
DebugLog *l = SPA_CONTAINER_OF (log, DebugLog, log);
|
||||
char text[1024], location[1024];
|
||||
static const char *levels[] = { "-", "E", "W", "I", "D", "T", };
|
||||
static const char *levels[] = { "-", "E", "W", "I", "D", "T", "*T*"};
|
||||
int size;
|
||||
bool do_trace = (level == SPA_LOG_LEVEL_TRACE && l->source);
|
||||
|
||||
vsnprintf (text, sizeof(text), fmt, args);
|
||||
|
||||
if ((do_trace = (level == SPA_LOG_LEVEL_TRACE && l->source)))
|
||||
level++;
|
||||
|
||||
size = snprintf (location, sizeof(location), "[%s][%s:%i %s()] %s\n",
|
||||
levels[level], strrchr (file, '/')+1, line, func, text);
|
||||
|
||||
if (SPA_UNLIKELY (level == SPA_LOG_LEVEL_TRACE && l->source)) {
|
||||
if (SPA_UNLIKELY (do_trace)) {
|
||||
uint32_t index;
|
||||
uint64_t count = 1;
|
||||
|
||||
|
|
@ -68,7 +73,7 @@ do_logv (SpaLog *log,
|
|||
|
||||
write (l->source->fd, &count, sizeof(uint64_t));
|
||||
} else
|
||||
fputs (location, stderr);
|
||||
fputs (location, stdout);
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
@ -119,20 +124,21 @@ on_trace_event (SpaSource *source)
|
|||
fprintf (stderr, "failed to read event fd: %s", strerror (errno));
|
||||
|
||||
while ((avail = spa_ringbuffer_get_read_index (&log.trace_rb, &index)) > 0) {
|
||||
uint32_t offset, first, written;
|
||||
uint32_t offset, first;
|
||||
|
||||
if (avail > log.trace_rb.size) {
|
||||
fprintf (stderr, "\n** trace overflow ** %d\n", avail);
|
||||
index += avail - log.trace_rb.size;
|
||||
avail = log.trace_rb.size;
|
||||
}
|
||||
offset = index & log.trace_rb.mask;
|
||||
first = SPA_MIN (avail, log.trace_rb.size - offset);
|
||||
|
||||
written = fprintf (stderr, "%*s", first, log.trace_data + offset);
|
||||
fwrite (log.trace_data + offset, first, 1, stderr);
|
||||
if (SPA_UNLIKELY (avail > first)) {
|
||||
written += fprintf (stderr, "%*s", avail - first, log.trace_data + first);
|
||||
fwrite (log.trace_data, avail - first, 1, stderr);
|
||||
}
|
||||
spa_ringbuffer_read_update (&log.trace_rb, index + written);
|
||||
spa_ringbuffer_read_update (&log.trace_rb, index + avail);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -42,7 +42,7 @@ main (int argc, char *argv[])
|
|||
}
|
||||
|
||||
loop = pinos_main_loop_new ();
|
||||
#if 0
|
||||
#if 1
|
||||
{
|
||||
SpaSource *source;
|
||||
source = pinos_loop_add_event (loop->loop, NULL, NULL);
|
||||
|
|
|
|||
|
|
@ -465,14 +465,18 @@ do_logv (SpaLog *log,
|
|||
{
|
||||
DebugLog *l = SPA_CONTAINER_OF (log, DebugLog, log);
|
||||
char text[512], location[1024];
|
||||
static const char *levels[] = { "-", "E", "W", "I", "D", "T", };
|
||||
static const char *levels[] = { "-", "E", "W", "I", "D", "T", "*T*" };
|
||||
int size;
|
||||
bool do_trace;
|
||||
|
||||
if ((do_trace = (level == SPA_LOG_LEVEL_TRACE && l->source)))
|
||||
level++;
|
||||
|
||||
vsnprintf (text, sizeof(text), fmt, args);
|
||||
size = snprintf (location, sizeof(location), "[%s][%s:%i %s()] %s\n",
|
||||
levels[level], strrchr (file, '/')+1, line, func, text);
|
||||
|
||||
if (SPA_UNLIKELY (level == SPA_LOG_LEVEL_TRACE) && l->source) {
|
||||
if (SPA_UNLIKELY (do_trace)) {
|
||||
uint32_t index;
|
||||
uint64_t count = 1;
|
||||
|
||||
|
|
@ -528,7 +532,7 @@ on_trace_event (SpaSource *source)
|
|||
fprintf (stderr, "failed to read event fd: %s", strerror (errno));
|
||||
|
||||
while ((avail = spa_ringbuffer_get_read_index (&log.trace_rb, &index)) > 0) {
|
||||
uint32_t offset, first, written;
|
||||
uint32_t offset, first;
|
||||
|
||||
if (avail > log.trace_rb.size) {
|
||||
index += avail - log.trace_rb.size;
|
||||
|
|
@ -537,11 +541,11 @@ on_trace_event (SpaSource *source)
|
|||
offset = index & log.trace_rb.mask;
|
||||
first = SPA_MIN (avail, log.trace_rb.size - offset);
|
||||
|
||||
written = fprintf (stderr, "%*s", first, log.trace_data + offset);
|
||||
fwrite (log.trace_data + offset, first, 1, stderr);
|
||||
if (SPA_UNLIKELY (avail > first)) {
|
||||
written += fprintf (stderr, "%*s", avail - first, log.trace_data + first);
|
||||
fwrite (log.trace_data, avail - first, 1, stderr);
|
||||
}
|
||||
spa_ringbuffer_read_update (&log.trace_rb, index + written);
|
||||
spa_ringbuffer_read_update (&log.trace_rb, index + avail);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue