gallium: add interface for driver queries like performance counters, etc.
authorMarek Olšák <maraeo@gmail.com>
Thu, 21 Mar 2013 18:32:24 +0000 (19:32 +0100)
committerMarek Olšák <maraeo@gmail.com>
Tue, 26 Mar 2013 00:28:19 +0000 (01:28 +0100)
The pipe query interface is reused. The list of available queries can be
obtained using pipe_screen::get_driver_query_info.

Reviewed-by: Brian Paul <brianp@vmware.com>
src/gallium/auxiliary/util/u_inlines.h
src/gallium/include/pipe/p_defines.h
src/gallium/include/pipe/p_screen.h

index ba745ebb5fb6ca370119824954149a425ceee071..719ba25ba60c840ac06b208bbccb1c14b520c3bb 100644 (file)
@@ -517,7 +517,7 @@ util_query_clear_result(union pipe_query_result *result, unsigned type)
       memset(&result->pipeline_statistics, 0, sizeof(result->pipeline_statistics));
       break;
    default:
-      assert(0);
+      memset(result, 0, sizeof(*result));
    }
 }
 
index f59e78a1a9e6b02012014e473f146066e3caaf54..51694ea312aa5dd5505862847cacb085af98b12c 100644 (file)
@@ -397,6 +397,10 @@ enum pipe_flush_flags {
 #define PIPE_QUERY_PIPELINE_STATISTICS  10
 #define PIPE_QUERY_TYPES                11
 
+/* start of driver queries,
+ * see pipe_screen::get_driver_query_info */
+#define PIPE_QUERY_DRIVER_SPECIFIC     256
+
 
 /**
  * Conditional rendering modes
@@ -649,6 +653,14 @@ union pipe_color_union
    unsigned int ui[4];
 };
 
+struct pipe_driver_query_info
+{
+   const char *name;
+   unsigned query_type; /* PIPE_QUERY_DRIVER_SPECIFIC + i */
+   uint64_t max_value; /* max value that can be returned */
+   boolean uses_byte_units; /* whether the result is in bytes */
+};
+
 #ifdef __cplusplus
 }
 #endif
index 754cfd7c2e6f74a4dcdba6530df98ec60ae3990c..c487e8ec8a408be9a3524346e108a14b12817237 100644 (file)
@@ -206,6 +206,17 @@ struct pipe_screen {
                             struct pipe_fence_handle *fence,
                             uint64_t timeout );
 
+   /**
+    * Returns a driver-specific query.
+    *
+    * If \p info is NULL, the number of available queries is returned.
+    * Otherwise, the driver query at the specified \p index is returned
+    * in \p info. The function returns non-zero on success.
+    */
+   int (*get_driver_query_info)(struct pipe_screen *screen,
+                                unsigned index,
+                                struct pipe_driver_query_info *info);
+
 };