mirror of
https://gitlab.freedesktop.org/emersion/libliftoff.git
synced 2025-01-13 20:01:35 +01:00
Add logging functions
This allows turning on and off debug logs, as well as defining a logging callback.
This commit is contained in:
parent
3671a64ade
commit
1ee86c6290
8 changed files with 110 additions and 31 deletions
71
display.c
71
display.c
|
@ -6,6 +6,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include "log.h"
|
||||||
#include "private.h"
|
#include "private.h"
|
||||||
|
|
||||||
static int guess_plane_zpos_from_type(struct liftoff_display *display,
|
static int guess_plane_zpos_from_type(struct liftoff_display *display,
|
||||||
|
@ -96,9 +97,9 @@ static struct liftoff_plane *plane_create(struct liftoff_display *display,
|
||||||
drmModeFreeObjectProperties(drm_props);
|
drmModeFreeObjectProperties(drm_props);
|
||||||
|
|
||||||
if (!has_type) {
|
if (!has_type) {
|
||||||
fprintf(stderr,
|
liftoff_log(LIFTOFF_ERROR,
|
||||||
"plane %"PRIu32" is missing the 'type' property\n",
|
"plane %"PRIu32" is missing the 'type' property",
|
||||||
plane->id);
|
plane->id);
|
||||||
free(plane);
|
free(plane);
|
||||||
return NULL;
|
return NULL;
|
||||||
} else if (!has_zpos) {
|
} else if (!has_zpos) {
|
||||||
|
@ -223,7 +224,8 @@ static bool plane_set_prop(struct liftoff_plane *plane, drmModeAtomicReq *req,
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
fprintf(stderr, " Setting %s = %"PRIu64"\n", prop->name, value);
|
liftoff_log(LIFTOFF_DEBUG, " Setting %s = %"PRIu64,
|
||||||
|
prop->name, value);
|
||||||
ret = drmModeAtomicAddProperty(req, plane->id, prop->id, value);
|
ret = drmModeAtomicAddProperty(req, plane->id, prop->id, value);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
perror("drmModeAtomicAddProperty");
|
perror("drmModeAtomicAddProperty");
|
||||||
|
@ -241,8 +243,9 @@ static bool set_plane_prop_str(struct liftoff_plane *plane,
|
||||||
|
|
||||||
prop = plane_get_property(plane, name);
|
prop = plane_get_property(plane, name);
|
||||||
if (prop == NULL) {
|
if (prop == NULL) {
|
||||||
fprintf(stderr, "plane %"PRIu32" is missing the %s property\n",
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
plane->id, name);
|
"plane %"PRIu32" is missing the %s property",
|
||||||
|
plane->id, name);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -564,8 +567,9 @@ bool output_choose_layers(struct liftoff_output *output,
|
||||||
goto skip;
|
goto skip;
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr, "Performing allocation for plane %"PRIu32" (%zu/%zu)\n",
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
plane->id, step->plane_idx + 1, result->planes_len);
|
"Performing allocation for plane %"PRIu32" (%zu/%zu)",
|
||||||
|
plane->id, step->plane_idx + 1, result->planes_len);
|
||||||
|
|
||||||
liftoff_list_for_each(layer, &output->layers, link) {
|
liftoff_list_for_each(layer, &output->layers, link) {
|
||||||
if (layer->plane != NULL) {
|
if (layer->plane != NULL) {
|
||||||
|
@ -583,9 +587,10 @@ bool output_choose_layers(struct liftoff_output *output,
|
||||||
has_allocated_layer_over(output, step, layer)) {
|
has_allocated_layer_over(output, step, layer)) {
|
||||||
/* This layer needs to be on top of the last
|
/* This layer needs to be on top of the last
|
||||||
* allocated one */
|
* allocated one */
|
||||||
fprintf(stderr, "Layer %p -> plane %"PRIu32": "
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
"layer zpos invalid\n",
|
"Layer %p -> plane %"PRIu32": "
|
||||||
(void *)layer, plane->id);
|
"layer zpos invalid",
|
||||||
|
(void *)layer, plane->id);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ((int)zpos_prop->value < step->last_layer_zpos &&
|
if ((int)zpos_prop->value < step->last_layer_zpos &&
|
||||||
|
@ -595,39 +600,44 @@ bool output_choose_layers(struct liftoff_output *output,
|
||||||
* last one (in practice, since planes are
|
* last one (in practice, since planes are
|
||||||
* sorted by zpos it means it has the same zpos,
|
* sorted by zpos it means it has the same zpos,
|
||||||
* ie. undefined ordering). */
|
* ie. undefined ordering). */
|
||||||
fprintf(stderr, "Layer %p -> plane %"PRIu32": "
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
"plane zpos invalid\n",
|
"Layer %p -> plane %"PRIu32": "
|
||||||
(void *)layer, plane->id);
|
"plane zpos invalid",
|
||||||
|
(void *)layer, plane->id);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (plane->type != DRM_PLANE_TYPE_PRIMARY &&
|
if (plane->type != DRM_PLANE_TYPE_PRIMARY &&
|
||||||
has_composited_layer_over(output, step, layer)) {
|
has_composited_layer_over(output, step, layer)) {
|
||||||
fprintf(stderr, "Layer %p -> plane %"PRIu32": "
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
"has composited layer on top\n",
|
"Layer %p -> plane %"PRIu32": "
|
||||||
(void *)layer, plane->id);
|
"has composited layer on top",
|
||||||
|
(void *)layer, plane->id);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Try to use this layer for the current plane */
|
/* Try to use this layer for the current plane */
|
||||||
fprintf(stderr, "Layer %p -> plane %"PRIu32": "
|
liftoff_log(LIFTOFF_DEBUG, "Layer %p -> plane %"PRIu32": "
|
||||||
"applying properties...\n", (void *)layer, plane->id);
|
"applying properties...",
|
||||||
|
(void *)layer, plane->id);
|
||||||
if (!plane_apply(plane, layer, result->req, &compatible)) {
|
if (!plane_apply(plane, layer, result->req, &compatible)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (!compatible) {
|
if (!compatible) {
|
||||||
fprintf(stderr, "Layer %p -> plane %"PRIu32": "
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
"incompatible properties\n",
|
"Layer %p -> plane %"PRIu32": "
|
||||||
(void *)layer, plane->id);
|
"incompatible properties",
|
||||||
|
(void *)layer, plane->id);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = drmModeAtomicCommit(display->drm_fd, result->req,
|
ret = drmModeAtomicCommit(display->drm_fd, result->req,
|
||||||
DRM_MODE_ATOMIC_TEST_ONLY, NULL);
|
DRM_MODE_ATOMIC_TEST_ONLY, NULL);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
fprintf(stderr, "Layer %p -> plane %"PRIu32": success\n",
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
(void *)layer, plane->id);
|
"Layer %p -> plane %"PRIu32": success",
|
||||||
|
(void *)layer, plane->id);
|
||||||
/* Continue with the next plane */
|
/* Continue with the next plane */
|
||||||
plane_step_init_next(&next_step, step, layer);
|
plane_step_init_next(&next_step, step, layer);
|
||||||
if (!output_choose_layers(output, result, &next_step)) {
|
if (!output_choose_layers(output, result, &next_step)) {
|
||||||
|
@ -675,7 +685,8 @@ bool liftoff_display_apply(struct liftoff_display *display, drmModeAtomicReq *re
|
||||||
to hit bandwidth limits because too many planes are enabled. */
|
to hit bandwidth limits because too many planes are enabled. */
|
||||||
liftoff_list_for_each(plane, &display->planes, link) {
|
liftoff_list_for_each(plane, &display->planes, link) {
|
||||||
if (plane->layer == NULL) {
|
if (plane->layer == NULL) {
|
||||||
fprintf(stderr, "Disabling plane %d\n", plane->id);
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
|
"Disabling plane %d", plane->id);
|
||||||
if (!plane_apply(plane, NULL, req, &compatible)) {
|
if (!plane_apply(plane, NULL, req, &compatible)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -714,8 +725,9 @@ bool liftoff_display_apply(struct liftoff_display *display, drmModeAtomicReq *re
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr, "Found plane allocation for output %p "
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
"with score=%d\n", (void *)output, result.best_score);
|
"Found plane allocation for output %p with "
|
||||||
|
"score=%d", (void *)output, result.best_score);
|
||||||
|
|
||||||
/* Apply the best allocation */
|
/* Apply the best allocation */
|
||||||
i = 0;
|
i = 0;
|
||||||
|
@ -726,8 +738,9 @@ bool liftoff_display_apply(struct liftoff_display *display, drmModeAtomicReq *re
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr, "Assigning layer %p to plane %"PRIu32"\n",
|
liftoff_log(LIFTOFF_DEBUG,
|
||||||
(void *)layer, plane->id);
|
"Assigning layer %p to plane %"PRIu32,
|
||||||
|
(void *)layer, plane->id);
|
||||||
if (!plane_apply(plane, layer, req, &compatible)) {
|
if (!plane_apply(plane, layer, req, &compatible)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#ifndef LIFTOFF_H
|
#ifndef LIFTOFF_H
|
||||||
#define LIFTOFF_H
|
#define LIFTOFF_H
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
@ -49,4 +50,16 @@ void liftoff_layer_set_property(struct liftoff_layer *layer, const char *name,
|
||||||
*/
|
*/
|
||||||
uint32_t liftoff_layer_get_plane_id(struct liftoff_layer *layer);
|
uint32_t liftoff_layer_get_plane_id(struct liftoff_layer *layer);
|
||||||
|
|
||||||
|
enum liftoff_log_importance {
|
||||||
|
LIFTOFF_SILENT,
|
||||||
|
LIFTOFF_DEBUG,
|
||||||
|
LIFTOFF_ERROR,
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef void (*liftoff_log_func)(enum liftoff_log_importance importance,
|
||||||
|
const char *fmt, va_list args);
|
||||||
|
|
||||||
|
void liftoff_log_init(enum liftoff_log_importance verbosity,
|
||||||
|
liftoff_log_func callback);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
15
include/log.h
Normal file
15
include/log.h
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#ifndef LOG_H
|
||||||
|
#define LOG_H
|
||||||
|
|
||||||
|
#include <libliftoff.h>
|
||||||
|
|
||||||
|
#ifdef __GNUC__
|
||||||
|
#define _LIFTOFF_ATTRIB_PRINTF(start, end) __attribute__((format(printf, start, end)))
|
||||||
|
#else
|
||||||
|
#define _LIFTOFF_ATTRIB_PRINTF(start, end)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void liftoff_log(enum liftoff_log_importance verbosity,
|
||||||
|
const char *format, ...) _LIFTOFF_ATTRIB_PRINTF(2, 3);
|
||||||
|
|
||||||
|
#endif
|
|
@ -1,8 +1,9 @@
|
||||||
#ifndef PRIVATE_H
|
#ifndef PRIVATE_H
|
||||||
#define PRIVATE_H
|
#define PRIVATE_H
|
||||||
|
|
||||||
#include "libliftoff.h"
|
#include <libliftoff.h>
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
|
#include "log.h"
|
||||||
|
|
||||||
struct liftoff_display {
|
struct liftoff_display {
|
||||||
int drm_fd;
|
int drm_fd;
|
||||||
|
|
3
layer.c
3
layer.c
|
@ -44,7 +44,8 @@ void liftoff_layer_set_property(struct liftoff_layer *layer, const char *name,
|
||||||
|
|
||||||
/* TODO: better error handling */
|
/* TODO: better error handling */
|
||||||
if (strcmp(name, "CRTC_ID") == 0) {
|
if (strcmp(name, "CRTC_ID") == 0) {
|
||||||
fprintf(stderr, "refusing to set a layer's CRTC_ID\n");
|
liftoff_log(LIFTOFF_ERROR,
|
||||||
|
"refusing to set a layer's CRTC_ID");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
33
log.c
Normal file
33
log.c
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include "log.h"
|
||||||
|
|
||||||
|
static enum liftoff_log_importance log_importance = LIFTOFF_ERROR;
|
||||||
|
|
||||||
|
static void log_stderr(enum liftoff_log_importance verbosity, const char *fmt,
|
||||||
|
va_list args)
|
||||||
|
{
|
||||||
|
vfprintf(stderr, fmt, args);
|
||||||
|
fprintf(stderr, "\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
static liftoff_log_func log_callback = log_stderr;
|
||||||
|
|
||||||
|
void liftoff_log_init(enum liftoff_log_importance verbosity,
|
||||||
|
liftoff_log_func callback) {
|
||||||
|
log_importance = verbosity;
|
||||||
|
if (callback) {
|
||||||
|
log_callback = callback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void liftoff_log(enum liftoff_log_importance verbosity, const char *fmt, ...)
|
||||||
|
{
|
||||||
|
if (verbosity > log_importance) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
va_list args;
|
||||||
|
va_start(args, fmt);
|
||||||
|
log_callback(verbosity, fmt, args);
|
||||||
|
va_end(args);
|
||||||
|
}
|
|
@ -30,6 +30,7 @@ liftoff_lib = library(
|
||||||
'display.c',
|
'display.c',
|
||||||
'layer.c',
|
'layer.c',
|
||||||
'list.c',
|
'list.c',
|
||||||
|
'log.c',
|
||||||
'output.c',
|
'output.c',
|
||||||
),
|
),
|
||||||
include_directories: liftoff_inc,
|
include_directories: liftoff_inc,
|
||||||
|
|
|
@ -564,6 +564,8 @@ int main(int argc, char *argv[]) {
|
||||||
const char *test_name;
|
const char *test_name;
|
||||||
size_t i;
|
size_t i;
|
||||||
|
|
||||||
|
liftoff_log_init(LIFTOFF_DEBUG, NULL);
|
||||||
|
|
||||||
if (argc != 2) {
|
if (argc != 2) {
|
||||||
fprintf(stderr, "usage: %s <test-name>\n", argv[0]);
|
fprintf(stderr, "usage: %s <test-name>\n", argv[0]);
|
||||||
return 1;
|
return 1;
|
||||||
|
|
Loading…
Reference in a new issue