mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
u/debug_gui: Add some tracing
This commit is contained in:
parent
a5de76095a
commit
667e6e73fa
|
@ -45,6 +45,7 @@ u_debug_gui_stop(struct u_debug_gui **debug_ui)
|
||||||
#include "util/u_file.h"
|
#include "util/u_file.h"
|
||||||
#include "util/u_debug.h"
|
#include "util/u_debug.h"
|
||||||
#include "util/u_debug_gui.h"
|
#include "util/u_debug_gui.h"
|
||||||
|
#include "util/u_trace_marker.h"
|
||||||
|
|
||||||
#include "ogl/ogl_api.h"
|
#include "ogl/ogl_api.h"
|
||||||
|
|
||||||
|
@ -94,6 +95,8 @@ struct gui_imgui
|
||||||
static void
|
static void
|
||||||
sdl2_window_init(struct u_debug_gui *p)
|
sdl2_window_init(struct u_debug_gui *p)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
const char *title = "Monado! ✨⚡🔥";
|
const char *title = "Monado! ✨⚡🔥";
|
||||||
int x = SDL_WINDOWPOS_UNDEFINED;
|
int x = SDL_WINDOWPOS_UNDEFINED;
|
||||||
int y = SDL_WINDOWPOS_UNDEFINED;
|
int y = SDL_WINDOWPOS_UNDEFINED;
|
||||||
|
@ -150,6 +153,8 @@ sdl2_window_init(struct u_debug_gui *p)
|
||||||
static void
|
static void
|
||||||
sdl2_loop_events(struct u_debug_gui *p)
|
sdl2_loop_events(struct u_debug_gui *p)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
|
|
||||||
while (SDL_PollEvent(&event)) {
|
while (SDL_PollEvent(&event)) {
|
||||||
|
@ -176,6 +181,8 @@ sdl2_loop_events(struct u_debug_gui *p)
|
||||||
static void
|
static void
|
||||||
sdl2_loop_new_frame(struct u_debug_gui *p)
|
sdl2_loop_new_frame(struct u_debug_gui *p)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
// Start the Dear ImGui frame
|
// Start the Dear ImGui frame
|
||||||
igImGui_ImplOpenGL3_NewFrame();
|
igImGui_ImplOpenGL3_NewFrame();
|
||||||
igImGui_ImplSDL2_NewFrame(p->win);
|
igImGui_ImplSDL2_NewFrame(p->win);
|
||||||
|
@ -187,6 +194,8 @@ sdl2_loop_new_frame(struct u_debug_gui *p)
|
||||||
static void
|
static void
|
||||||
sdl2_loop_show_scene(struct u_debug_gui *p, struct gui_imgui *gui)
|
sdl2_loop_show_scene(struct u_debug_gui *p, struct gui_imgui *gui)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
// Render the scene into it.
|
// Render the scene into it.
|
||||||
gui_scene_manager_render(&p->base);
|
gui_scene_manager_render(&p->base);
|
||||||
|
|
||||||
|
@ -204,6 +213,8 @@ sdl2_loop_show_scene(struct u_debug_gui *p, struct gui_imgui *gui)
|
||||||
static void
|
static void
|
||||||
sdl2_loop_render(struct u_debug_gui *p, struct gui_imgui *gui, ImGuiIO *io)
|
sdl2_loop_render(struct u_debug_gui *p, struct gui_imgui *gui, ImGuiIO *io)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
// Build the DrawData (EndFrame).
|
// Build the DrawData (EndFrame).
|
||||||
igRender();
|
igRender();
|
||||||
|
|
||||||
|
@ -264,6 +275,9 @@ sdl2_loop(struct u_debug_gui *p)
|
||||||
u_var_add_bool(&gui, &p->base.stopped, "Exit");
|
u_var_add_bool(&gui, &p->base.stopped, "Exit");
|
||||||
|
|
||||||
while (!p->base.stopped) {
|
while (!p->base.stopped) {
|
||||||
|
// All this counts as work.
|
||||||
|
XRT_TRACE_IDENT(frame);
|
||||||
|
|
||||||
sdl2_loop_events(p);
|
sdl2_loop_events(p);
|
||||||
|
|
||||||
sdl2_loop_new_frame(p);
|
sdl2_loop_new_frame(p);
|
||||||
|
@ -272,7 +286,9 @@ sdl2_loop(struct u_debug_gui *p)
|
||||||
|
|
||||||
sdl2_loop_render(p, &gui, io);
|
sdl2_loop_render(p, &gui, io);
|
||||||
|
|
||||||
|
XRT_TRACE_BEGIN(swap);
|
||||||
SDL_GL_SwapWindow(p->win);
|
SDL_GL_SwapWindow(p->win);
|
||||||
|
XRT_TRACE_END(swap);
|
||||||
|
|
||||||
// Update prober things.
|
// Update prober things.
|
||||||
gui_prober_update(&p->base);
|
gui_prober_update(&p->base);
|
||||||
|
@ -289,6 +305,8 @@ sdl2_loop(struct u_debug_gui *p)
|
||||||
static void
|
static void
|
||||||
sdl2_close(struct u_debug_gui *p)
|
sdl2_close(struct u_debug_gui *p)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
// All scenes should be destroyed by now.
|
// All scenes should be destroyed by now.
|
||||||
gui_scene_manager_destroy(&p->base);
|
gui_scene_manager_destroy(&p->base);
|
||||||
|
|
||||||
|
@ -312,6 +330,8 @@ sdl2_close(struct u_debug_gui *p)
|
||||||
static void *
|
static void *
|
||||||
u_debug_gui_run_thread(void *ptr)
|
u_debug_gui_run_thread(void *ptr)
|
||||||
{
|
{
|
||||||
|
U_TRACE_SET_THREAD_NAME("Debug GUI");
|
||||||
|
|
||||||
struct u_debug_gui *debug_gui = (struct u_debug_gui *)ptr;
|
struct u_debug_gui *debug_gui = (struct u_debug_gui *)ptr;
|
||||||
sdl2_window_init(debug_gui);
|
sdl2_window_init(debug_gui);
|
||||||
|
|
||||||
|
@ -325,6 +345,8 @@ u_debug_gui_run_thread(void *ptr)
|
||||||
int
|
int
|
||||||
u_debug_gui_create(struct u_debug_gui **out_debug_gui)
|
u_debug_gui_create(struct u_debug_gui **out_debug_gui)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
// Enabled?
|
// Enabled?
|
||||||
if (!debug_get_bool_option_gui()) {
|
if (!debug_get_bool_option_gui()) {
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -348,6 +370,8 @@ u_debug_gui_create(struct u_debug_gui **out_debug_gui)
|
||||||
void
|
void
|
||||||
u_debug_gui_start(struct u_debug_gui *debug_gui, struct xrt_instance *xinst, struct xrt_system_devices *xsysd)
|
u_debug_gui_start(struct u_debug_gui *debug_gui, struct xrt_instance *xinst, struct xrt_system_devices *xsysd)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
if (debug_gui == NULL) {
|
if (debug_gui == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -367,6 +391,8 @@ u_debug_gui_start(struct u_debug_gui *debug_gui, struct xrt_instance *xinst, str
|
||||||
void
|
void
|
||||||
u_debug_gui_stop(struct u_debug_gui **debug_gui)
|
u_debug_gui_stop(struct u_debug_gui **debug_gui)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
struct u_debug_gui *p = *(struct u_debug_gui **)debug_gui;
|
struct u_debug_gui *p = *(struct u_debug_gui **)debug_gui;
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in a new issue