aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar halcanary <halcanary@google.com>2015-02-27 10:39:28 -0800
committerGravatar Commit bot <commit-bot@chromium.org>2015-02-27 10:39:28 -0800
commite0638f8ecfb609c89cab1aa8b498ad3f368b89d3 (patch)
treed35858151eb0568ef4f0fc4f4487e3711e39baab
parent44977485bdac75c055c3fa638f118874ccd2d22f (diff)
Flate: fix valgrind miniz Conditional-jump-or-move-depends... error
-rw-r--r--src/core/SkFlate.cpp17
1 files changed, 12 insertions, 5 deletions
diff --git a/src/core/SkFlate.cpp b/src/core/SkFlate.cpp
index baf1c777a5..f990dc3f97 100644
--- a/src/core/SkFlate.cpp
+++ b/src/core/SkFlate.cpp
@@ -24,12 +24,19 @@ namespace {
// static
const size_t kBufferSize = 1024;
+static void* skia_alloc_func(void*, size_t items, size_t size) {
+ return sk_calloc_throw(items * size);
+}
+
+static void skia_free_func(void*, void* address) { sk_free(address); }
+
bool doFlate(bool compress, SkStream* src, SkWStream* dst) {
uint8_t inputBuffer[kBufferSize];
uint8_t outputBuffer[kBufferSize];
z_stream flateData;
- flateData.zalloc = NULL;
- flateData.zfree = NULL;
+ flateData.zalloc = &skia_alloc_func;
+ flateData.zfree = &skia_free_func;
+ flateData.opaque = NULL;
flateData.next_in = NULL;
flateData.avail_in = 0;
flateData.next_out = outputBuffer;
@@ -170,9 +177,9 @@ SkDeflateWStream::SkDeflateWStream(SkWStream* out)
if (!fImpl->fOut) {
return;
}
- fImpl->fZStream.zalloc = Z_NULL;
- fImpl->fZStream.zfree = Z_NULL;
- fImpl->fZStream.opaque = Z_NULL;
+ fImpl->fZStream.zalloc = &skia_alloc_func;
+ fImpl->fZStream.zfree = &skia_free_func;
+ fImpl->fZStream.opaque = NULL;
SkDEBUGCODE(int r =) deflateInit(&fImpl->fZStream, Z_DEFAULT_COMPRESSION);
SkASSERT(Z_OK == r);
}