X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=effect_chain.h;h=716a970a3ab59748e99d94da43b2a9239fdca871;hb=f909bfe0621e8c844695ef327b71457893633cae;hp=ee387a954613edc8629b49762d720e339479d9ab;hpb=c6ee050546b6940ae19a74f92bdcc8d2b1f56d22;p=movit diff --git a/effect_chain.h b/effect_chain.h index ee387a9..716a970 100644 --- a/effect_chain.h +++ b/effect_chain.h @@ -394,10 +394,15 @@ public: // except that it is more efficient if the last phase contains a compute shader. // Thus, prefer this to render_to_fbo() where possible. // - // The format must currently be GL_RGBA16F, and only one destination - // texture is supported. Both of these restrictions will be lifted in the future. + // Only one destination texture is supported. This restriction will be lifted + // in the future. + // + // All destination textures must be exactly of size x , + // and must either come from the same ResourcePool the effect uses, or outlive + // the EffectChain (otherwise, we could be allocating FBOs that end up being + // stale). Textures must also have valid state; in particular, they must either + // be mipmap complete or have a non-mipmapped minification mode. // - // All destination textures must be exactly of size x . // width and height can not be zero. struct DestinationTexture { GLuint texnum; @@ -481,11 +486,11 @@ private: unsigned x, unsigned y, unsigned width, unsigned height); // Execute one phase, ie. set up all inputs, effects and outputs, and render the quad. - // If dest_texture is 0, uses whatever output is current (and the phase must not be + // If is empty, uses whatever output is current (and the phase must not be // a compute shader). void execute_phase(Phase *phase, const std::map &output_textures, - GLuint dest_texture, + const std::vector &destinations, std::set *generated_mipmaps); // Set up uniforms for one phase. The program must already be bound.