X-Git-Url: https://git.sesse.net/?p=movit;a=blobdiff_plain;f=resource_pool.h;h=50e0da2c1207755c29c8eee56ec373d141c3275a;hp=0bb0a26e82fe87d1dc694292a5f98e306521503a;hb=4536fdf7952df0d8773c9bf3014fa25a50ca8ecf;hpb=ecab6f3b08bc0a995dd96542758031f1ba2c6a27 diff --git a/resource_pool.h b/resource_pool.h index 0bb0a26..50e0da2 100644 --- a/resource_pool.h +++ b/resource_pool.h @@ -29,7 +29,15 @@ public: // around after they are no longer in use (in case another EffectChain // wants that exact program later). Shaders are expensive to compile and do not // need a lot of resources to keep around, so this should be a reasonable number. - ResourcePool(size_t program_freelist_max_length = 100); + // + // texture_freelist_max_bytes is how many bytes of unused textures to keep around + // after they are no longer in use (in case a new texture of the same dimensions + // and format is needed). Note that the size estimate is very coarse; it does not + // take into account padding, metadata, and most importantly mipmapping. + // This means you should be prepared for actual memory usage of the freelist being + // twice this estimate or more. + ResourcePool(size_t program_freelist_max_length = 100, + size_t texture_freelist_max_bytes = 100 << 20); // 100 MB. ~ResourcePool(); // All remaining functions are intended for calls from EffectChain only. @@ -57,7 +65,7 @@ private: // Protects all the other elements in the class. pthread_mutex_t lock; - size_t program_freelist_max_length; + size_t program_freelist_max_length, texture_freelist_max_bytes; // A mapping from vertex/fragment shader source strings to compiled program number. std::map, GLuint> programs; @@ -71,8 +79,30 @@ private: std::map > program_shaders; // A list of programs that are no longer in use, most recently freed first. - // Once this reaches , + // Once this reaches , the last element + // will be deleted. std::list program_freelist; + + struct Texture2D { + GLint internal_format; + GLsizei width, height; + }; + + // A mapping from texture number to format details. This is filled if the + // texture is given out to a client or on the freelist, but not if it is + // deleted from the freelist. + std::map texture_formats; + + // A list of all textures that are release but not freed (most recently freed + // first), and an estimate of their current memory usage. Once + // goes above , + // elements are deleted off the end of the list until we are under the limit + // again. + std::list texture_freelist; + size_t texture_freelist_bytes; + + // See the caveats at the constructor. + static size_t estimate_texture_size(const Texture2D &texture_format); }; #endif // !defined(_MOVIT_RESOURCE_POOL_H)