// but if so, the threads' contexts need to be set up to share resources, since
// the EffectChain holds textures and other OpenGL objects that are tied to the
// context.
+//
+// Memory management (only relevant if you use multiple contexts):
+// See corresponding comment in resource_pool.h. This holds even if you don't
+// allocate your own ResourcePool, but let EffectChain hold its own.
-#include <GL/glew.h>
+#include <epoxy/gl.h>
#include <stdio.h>
#include <map>
#include <set>
Colorspace output_color_space;
GammaCurve output_gamma_curve;
AlphaType output_alpha_type;
+ bool needs_mipmaps; // Directly or indirectly.
friend class EffectChain;
};
// Unique per-phase to increase cacheability of compiled shaders.
std::map<Node *, std::string> effect_ids;
- // The geometry needed to draw this quad, bound to the vertex array
- // object. (Seemingly it's actually a win not to upload geometry every
- // frame, even for something as small as a quad, due to fewer state
- // changes.)
- GLuint vao;
- GLuint position_vbo, texcoord_vbo;
+ // For measurement of GPU time used.
+ GLuint timer_query_object;
+ uint64_t time_elapsed_ns;
+ uint64_t num_measured_iterations;
};
class EffectChain {
void finalize();
+ // Measure the GPU time used for each actual phase during rendering.
+ // Note that this is only available if GL_ARB_timer_query
+ // (or, equivalently, OpenGL 3.3) is available. Also note that measurement
+ // will incur a performance cost, as we wait for the measurements to
+ // complete at the end of rendering.
+ void enable_phase_timing(bool enable);
+ void reset_phase_timing();
+ void print_phase_timing();
//void render(unsigned char *src, unsigned char *dst);
void render_to_screen()
ResourcePool *resource_pool;
bool owns_resource_pool;
+
+ bool do_phase_timing;
};
} // namespace movit