*/
#include "context.h"
-
#include "metrics.h"
+#include "xmalloc.h"
-void
-context_enter (fips_api_t api, void *system_context_id unused)
+context_t *current_context;
+
+static context_t *
+context_create (fips_api_t api, void *system_context_id)
{
+ context_t *ctx;
+
+ ctx = xcalloc (1, sizeof (*ctx));
+
+ ctx->system_id = system_context_id;
+
fips_dispatch_init (api);
- metrics_info_init ();
+ metrics_info_init (&ctx->metrics_info);
+
+ return ctx;
+}
+
+static void
+context_destroy (context_t *ctx)
+{
+ metrics_info_fini (&ctx->metrics_info);
+}
+
+void
+context_enter (fips_api_t api, void *system_context_id)
+{
+ /* Do nothing if the application is setting the same context
+ * as is already current. */
+ if (current_context && current_context->system_id == system_context_id)
+ return;
+
+ if (current_context)
+ context_destroy (current_context);
+
+ current_context = context_create (api, system_context_id);
metrics_set_current_op (METRICS_OP_SHADER + 0);
metrics_counter_start ();
void
context_leave (void)
{
- metrics_info_fini ();
+ context_t *ctx = current_context;
+ timer_query_t *timer, *timer_next;
+ monitor_t *monitor, *monitor_next;
+
+ if (ctx == NULL)
+ return;
+
+ metrics_collect_available ();
+
+ if (ctx->timer_begun_id) {
+ glEndQuery (GL_TIME_ELAPSED);
+ glDeleteQueries (1, &ctx->timer_begun_id);
+ ctx->timer_begun_id = 0;
+ }
+
+ for (timer = ctx->timer_head;
+ timer;
+ timer = timer_next)
+ {
+ glDeleteQueries (1, &timer->id);
+ timer_next = timer->next;
+ free (timer);
+ }
+ ctx->timer_head = NULL;
+ ctx->timer_tail = NULL;
+
+ if (ctx->monitor_begun_id) {
+ glEndPerfMonitorAMD (ctx->monitor_begun_id);
+ glDeletePerfMonitorsAMD (1, &ctx->monitor_begun_id);
+ ctx->monitor_begun_id = 0;
+ }
+
+ for (monitor = ctx->monitor_head;
+ monitor;
+ monitor = monitor_next)
+ {
+ glDeletePerfMonitorsAMD (1, &monitor->id);
+ monitor_next = monitor->next;
+ free (monitor);
+ }
+ ctx->monitor_head = NULL;
+ ctx->monitor_tail = NULL;
+
+ ctx->monitors_in_flight = 0;
+}
+
+context_t *
+context_get_current (void)
+{
+ return current_context;
}