void ProgramData::mark_dirty(Mask bits)
{
if(!dirty)
+ {
+ if(generation && !streaming)
+ {
+ streaming = true;
+ if(buffer && buffer->get_size())
+ recreate_buffer();
+ }
++generation;
+ }
dirty |= bits;
}
return programs.begin()+index;
}
+void ProgramData::recreate_buffer() const
+{
+ Buffer *old_buffer = buffer;
+ // Create the new buffer first to ensure it has a different address
+ buffer = new Buffer;
+ delete old_buffer;
+ if(last_buffer_block)
+ last_buffer_block->change_buffer(buffer);
+
+#ifdef DEBUG
+ if(!debug_name.empty())
+ buffer->set_debug_name(debug_name);
+#endif
+}
+
void ProgramData::update_block_uniform_indices(SharedBlock &block, const ReflectData::UniformBlockInfo &info) const
{
uint8_t *indices = block.indices.values;
if(info.bind_point>=0)
{
if(!buffer)
- {
- buffer = new Buffer();
-
-#ifdef DEBUG
- if(!debug_name.empty())
- buffer->set_debug_name(debug_name);
-#endif
- }
+ recreate_buffer();
block.block->use_buffer(buffer, last_buffer_block);
last_buffer_block = block.block;
prog_begin->masks.dirty = 0;
- if(last_buffer_block!=old_last_block)
+ if(last_buffer_block!=old_last_block || (buffer && !buffer->get_size()))
{
- unsigned required_size = last_buffer_block->get_required_buffer_size();
+ unsigned required_size = last_buffer_block->get_required_buffer_size(streaming);
if(last_buffer_block->get_required_buffer_size()>buffer->get_size())
{
if(buffer->get_size()>0)
- {
- delete buffer;
- buffer = new Buffer();
- last_buffer_block->change_buffer(buffer);
-
-#ifdef DEBUG
- if(!debug_name.empty())
- buffer->set_debug_name(debug_name);
-#endif
- }
+ recreate_buffer();
- buffer->storage(required_size, STREAMING);
+ buffer->storage(required_size, (streaming ? STREAMING : STATIC));
}
}
}