From 565cfc888e9422748ddc48b0327abd8f41ec1770 Mon Sep 17 00:00:00 2001 From: lawnjelly Date: Tue, 16 Feb 2021 18:00:20 +0000 Subject: [PATCH] Batching - fix a couple of minor valgrind bugs. Valgrind reported two instances of reading uninitialized memory in the batching. They are both pretty benign (as evidenced by no bug reports) but wise to close these. The first is that when changing batch from a default batch it reads the batch color which is not set (as it is not relevant for default batches). The segment of code is not necessary when it has already deemed a batch change necessary (which will occur from a default batch). In addition this means that the count of color changes will be more accurate, rather than having a possible random value in. The second is that on initialization _set_texture_rect_mode is called before the state has been properly initialized (it is initialized at the beginning of each canvas_begin, but this occurs outside of that). --- drivers/gles2/rasterizer_canvas_base_gles2.cpp | 4 ++++ drivers/gles_common/rasterizer_canvas_batcher.h | 2 +- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/gles2/rasterizer_canvas_base_gles2.cpp b/drivers/gles2/rasterizer_canvas_base_gles2.cpp index 5032ea9019e..7d930b54118 100644 --- a/drivers/gles2/rasterizer_canvas_base_gles2.cpp +++ b/drivers/gles2/rasterizer_canvas_base_gles2.cpp @@ -1063,6 +1063,10 @@ void RasterizerCanvasBaseGLES2::initialize() { state.canvas_shader.init(); + state.using_light_angle = false; + state.using_large_vertex = false; + state.using_modulate = false; + _set_texture_rect_mode(true); state.canvas_shader.set_conditional(CanvasShaderGLES2::USE_RGBA_SHADOWS, storage->config.use_rgba_2d_shadows); diff --git a/drivers/gles_common/rasterizer_canvas_batcher.h b/drivers/gles_common/rasterizer_canvas_batcher.h index 1b51c9daf26..545033aac05 100644 --- a/drivers/gles_common/rasterizer_canvas_batcher.h +++ b/drivers/gles_common/rasterizer_canvas_batcher.h @@ -1900,7 +1900,7 @@ bool C_PREAMBLE::_prefill_rect(RasterizerCanvas::Item::CommandRect *rect, FillSt // we need to treat color change separately because we need to count these // to decide whether to switch on the fly to colored vertices. - if (!r_fill_state.curr_batch->color.equals(col)) { + if (!change_batch && !r_fill_state.curr_batch->color.equals(col)) { change_batch = true; bdata.total_color_changes++; }