diff options
author | scherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-27 18:59:27 +0000 |
---|---|---|
committer | scherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-27 18:59:27 +0000 |
commit | 0afbf34c72160e15d145a1d6bbfc6f796bc3b7fa (patch) | |
tree | e74a85fe9c85b0127bfcc716c555663603d1fb18 /media/bench | |
parent | 8391a30911633d75933729bc785a29384cc738ff (diff) | |
download | chromium_src-0afbf34c72160e15d145a1d6bbfc6f796bc3b7fa.zip chromium_src-0afbf34c72160e15d145a1d6bbfc6f796bc3b7fa.tar.gz chromium_src-0afbf34c72160e15d145a1d6bbfc6f796bc3b7fa.tar.bz2 |
Fix memory leaks in media_bench.
BUG=25855,25945
TEST=valgrind should report no leaks caused by media_bench itself
Review URL: http://codereview.chromium.org/332038
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@30228 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'media/bench')
-rw-r--r-- | media/bench/bench.cc | 31 |
1 files changed, 19 insertions, 12 deletions
diff --git a/media/bench/bench.cc b/media/bench/bench.cc index 03e9d0f..529e03f 100644 --- a/media/bench/bench.cc +++ b/media/bench/bench.cc @@ -317,12 +317,13 @@ int main(int argc, const char** argv) { } // Buffer used for audio decoding. - int16* samples = - reinterpret_cast<int16*>(av_malloc(AVCODEC_MAX_AUDIO_FRAME_SIZE)); + scoped_ptr_malloc<int16, media::ScopedPtrAVFree> samples( + reinterpret_cast<int16*>(av_malloc(AVCODEC_MAX_AUDIO_FRAME_SIZE))); // Buffer used for video decoding. - AVFrame* frame = avcodec_alloc_frame(); - if (!frame) { + scoped_ptr_malloc<AVFrame, media::ScopedPtrAVFree> frame( + avcodec_alloc_frame()); + if (!frame.get()) { std::cerr << "Error: avcodec_alloc_frame for " << in_path << std::endl; return 1; @@ -363,7 +364,7 @@ int main(int argc, const char** argv) { int size_out = AVCODEC_MAX_AUDIO_FRAME_SIZE; base::TimeTicks decode_start = base::TimeTicks::HighResNow(); - result = avcodec_decode_audio3(codec_context, samples, &size_out, + result = avcodec_decode_audio3(codec_context, samples.get(), &size_out, &packet); base::TimeDelta delta = base::TimeTicks::HighResNow() - decode_start; @@ -373,28 +374,29 @@ int main(int argc, const char** argv) { read_result = 0; // Force continuation. if (output) { - if (fwrite(samples, 1, size_out, output) != + if (fwrite(samples.get(), 1, size_out, output) != static_cast<size_t>(size_out)) { std::cerr << "Error: Could not write " << size_out << " bytes for " << in_path << std::endl; return 1; } } + + const uint8* u8_samples = + reinterpret_cast<const uint8*>(samples.get()); if (hash_djb2) { - hash_value = DJB2Hash(reinterpret_cast<const uint8*>(samples), - size_out, hash_value); + hash_value = DJB2Hash(u8_samples, size_out, hash_value); } if (hash_md5) { - MD5Update(&ctx, reinterpret_cast<const uint8*>(samples), - size_out); + MD5Update(&ctx, u8_samples, size_out); } } } else if (target_codec == CODEC_TYPE_VIDEO) { int got_picture = 0; base::TimeTicks decode_start = base::TimeTicks::HighResNow(); - result = avcodec_decode_video2(codec_context, frame, &got_picture, - &packet); + result = avcodec_decode_video2(codec_context, frame.get(), + &got_picture, &packet); base::TimeDelta delta = base::TimeTicks::HighResNow() - decode_start; if (got_picture) { @@ -474,8 +476,13 @@ int main(int argc, const char** argv) { base::TimeDelta total = base::TimeTicks::HighResNow() - start; LeaveTimingSection(); + // Clean up. if (output) file_util::CloseFile(output); + if (codec_context) + avcodec_close(codec_context); + if (format_context) + av_close_input_file(format_context); // Calculate the sum of times. Note that some of these may be zero. double sum = 0; |