mirror of
https://github.com/webmproject/libwebp.git
synced 2024-12-27 06:08:21 +01:00
Merge "fix multiple allocation for transform buffer"
This commit is contained in:
commit
2b4fe33e00
@ -1114,6 +1114,12 @@ static WebPEncodingError WriteImage(const WebPPicture* const pic,
|
|||||||
|
|
||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void ClearTransformBuffer(VP8LEncoder* const enc) {
|
||||||
|
WebPSafeFree(enc->transform_mem_);
|
||||||
|
enc->transform_mem_ = NULL;
|
||||||
|
enc->transform_mem_size_ = 0;
|
||||||
|
}
|
||||||
|
|
||||||
// Allocates the memory for argb (W x H) buffer, 2 rows of context for
|
// Allocates the memory for argb (W x H) buffer, 2 rows of context for
|
||||||
// prediction and transform data.
|
// prediction and transform data.
|
||||||
// Flags influencing the memory allocated:
|
// Flags influencing the memory allocated:
|
||||||
@ -1122,7 +1128,6 @@ static WebPEncodingError WriteImage(const WebPPicture* const pic,
|
|||||||
static WebPEncodingError AllocateTransformBuffer(VP8LEncoder* const enc,
|
static WebPEncodingError AllocateTransformBuffer(VP8LEncoder* const enc,
|
||||||
int width, int height) {
|
int width, int height) {
|
||||||
WebPEncodingError err = VP8_ENC_OK;
|
WebPEncodingError err = VP8_ENC_OK;
|
||||||
if (enc->argb_ == NULL) {
|
|
||||||
const int tile_size = 1 << enc->transform_bits_;
|
const int tile_size = 1 << enc->transform_bits_;
|
||||||
const uint64_t image_size = width * height;
|
const uint64_t image_size = width * height;
|
||||||
// Ensure enough size for tiles, as well as for two scanlines and two
|
// Ensure enough size for tiles, as well as for two scanlines and two
|
||||||
@ -1134,31 +1139,32 @@ static WebPEncodingError AllocateTransformBuffer(VP8LEncoder* const enc,
|
|||||||
? VP8LSubSampleSize(width, enc->transform_bits_) *
|
? VP8LSubSampleSize(width, enc->transform_bits_) *
|
||||||
VP8LSubSampleSize(height, enc->transform_bits_)
|
VP8LSubSampleSize(height, enc->transform_bits_)
|
||||||
: 0;
|
: 0;
|
||||||
const uint64_t total_size =
|
const uint64_t mem_size =
|
||||||
image_size + WEBP_ALIGN_CST +
|
image_size + WEBP_ALIGN_CST +
|
||||||
argb_scratch_size + WEBP_ALIGN_CST +
|
argb_scratch_size + WEBP_ALIGN_CST +
|
||||||
(uint64_t)transform_data_size;
|
(uint64_t)transform_data_size;
|
||||||
uint32_t* mem = (uint32_t*)WebPSafeMalloc(total_size, sizeof(*mem));
|
uint32_t* mem = enc->transform_mem_;
|
||||||
|
if (mem == NULL || mem_size > enc->transform_mem_size_) {
|
||||||
|
ClearTransformBuffer(enc);
|
||||||
|
mem = (uint32_t*)WebPSafeMalloc(mem_size, sizeof(*mem));
|
||||||
if (mem == NULL) {
|
if (mem == NULL) {
|
||||||
err = VP8_ENC_ERROR_OUT_OF_MEMORY;
|
err = VP8_ENC_ERROR_OUT_OF_MEMORY;
|
||||||
goto Error;
|
goto Error;
|
||||||
|
}
|
||||||
|
enc->transform_mem_ = mem;
|
||||||
|
enc->transform_mem_size_ = (size_t)mem_size;
|
||||||
}
|
}
|
||||||
enc->argb_ = mem;
|
enc->argb_ = mem;
|
||||||
mem = (uint32_t*)WEBP_ALIGN(mem + image_size);
|
mem = (uint32_t*)WEBP_ALIGN(mem + image_size);
|
||||||
enc->argb_scratch_ = mem;
|
enc->argb_scratch_ = mem;
|
||||||
mem = (uint32_t*)WEBP_ALIGN(mem + argb_scratch_size);
|
mem = (uint32_t*)WEBP_ALIGN(mem + argb_scratch_size);
|
||||||
enc->transform_data_ = mem;
|
enc->transform_data_ = mem;
|
||||||
|
|
||||||
enc->current_width_ = width;
|
enc->current_width_ = width;
|
||||||
}
|
|
||||||
Error:
|
Error:
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ClearTransformBuffer(VP8LEncoder* const enc) {
|
|
||||||
WebPSafeFree(enc->argb_);
|
|
||||||
enc->argb_ = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static WebPEncodingError MakeInputImageCopy(VP8LEncoder* const enc) {
|
static WebPEncodingError MakeInputImageCopy(VP8LEncoder* const enc) {
|
||||||
WebPEncodingError err = VP8_ENC_OK;
|
WebPEncodingError err = VP8_ENC_OK;
|
||||||
const WebPPicture* const picture = enc->pic_;
|
const WebPPicture* const picture = enc->pic_;
|
||||||
|
@ -32,6 +32,9 @@ typedef struct {
|
|||||||
uint32_t* argb_scratch_; // Scratch memory for argb rows
|
uint32_t* argb_scratch_; // Scratch memory for argb rows
|
||||||
// (used for prediction).
|
// (used for prediction).
|
||||||
uint32_t* transform_data_; // Scratch memory for transform data.
|
uint32_t* transform_data_; // Scratch memory for transform data.
|
||||||
|
uint32_t* transform_mem_; // Currently allocated memory.
|
||||||
|
size_t transform_mem_size_; // Currently allocated memory size.
|
||||||
|
|
||||||
int current_width_; // Corresponds to packed image width.
|
int current_width_; // Corresponds to packed image width.
|
||||||
|
|
||||||
// Encoding parameters derived from quality parameter.
|
// Encoding parameters derived from quality parameter.
|
||||||
|
Loading…
Reference in New Issue
Block a user