Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2021-09-06 13:04:25 +0300
committerCampbell Barton <ideasman42@gmail.com>2021-09-06 13:04:25 +0300
commita0912ff5663b950222ef00485a3853bfb6001db4 (patch)
tree86d109d8543ae752e802af6d7f4998d3be218741 /source/blender
parent49f1695ed06792ea1f4d1a43d30170c407f227f8 (diff)
Cleanup: support passing in arbitrary buffers to IMB_allocFromBuffer
Also remove IB_metadata flag from the resulting imbuf as this image has no meta-data.
Diffstat (limited to 'source/blender')
-rw-r--r--source/blender/blenkernel/intern/main.c7
-rw-r--r--source/blender/imbuf/intern/allocimbuf.c12
2 files changed, 12 insertions, 7 deletions
diff --git a/source/blender/blenkernel/intern/main.c b/source/blender/blenkernel/intern/main.c
index bb33f5f9f87..981f1d4a623 100644
--- a/source/blender/blenkernel/intern/main.c
+++ b/source/blender/blenkernel/intern/main.c
@@ -405,11 +405,8 @@ ImBuf *BKE_main_thumbnail_to_imbuf(Main *bmain, BlendThumbnail *data)
}
if (data) {
- /* NOTE: we cannot use IMB_allocFromBuffer(), since it tries to dupalloc passed buffer,
- * which will fail here (we do not want to pass the first two ints!). */
- img = IMB_allocImBuf(
- (unsigned int)data->width, (unsigned int)data->height, 32, IB_rect | IB_metadata);
- memcpy(img->rect, data->rect, BLEN_THUMB_MEMSIZE(data->width, data->height) - sizeof(*data));
+ img = IMB_allocFromBuffer(
+ (const uint *)data->rect, NULL, (uint)data->width, (uint)data->height, 4);
}
return img;
diff --git a/source/blender/imbuf/intern/allocimbuf.c b/source/blender/imbuf/intern/allocimbuf.c
index 90c863878ff..d327981f583 100644
--- a/source/blender/imbuf/intern/allocimbuf.c
+++ b/source/blender/imbuf/intern/allocimbuf.c
@@ -445,13 +445,21 @@ struct ImBuf *IMB_allocFromBuffer(const unsigned int *rect,
ibuf = IMB_allocImBuf(w, h, 32, 0);
ibuf->channels = channels;
+
+ /* Avoid #MEM_dupallocN since the buffers might not be allocated using guarded-allocation. */
if (rectf) {
- ibuf->rect_float = MEM_dupallocN(rectf);
+ const size_t size = sizeof(float[4]) * w * h;
+ ibuf->rect_float = MEM_mallocN(sizeof(float[4]) * w * h, __func__);
+ memcpy(ibuf->rect_float, rectf, size);
+
ibuf->flags |= IB_rectfloat;
ibuf->mall |= IB_rectfloat;
}
if (rect) {
- ibuf->rect = MEM_dupallocN(rect);
+ const size_t size = sizeof(uchar[4]) * w * h;
+ ibuf->rect = MEM_mallocN(size, __func__);
+ memcpy(ibuf->rect, rect, size);
+
ibuf->flags |= IB_rect;
ibuf->mall |= IB_rect;
}