Commit e28eae97 authored by xhwang@chromium.org's avatar xhwang@chromium.org

Use scoped_ptr<> and deleter for media::DecoderBuffer::data_.

BUG=150920
TEST=media_unittests pass


Review URL: https://chromiumcodereview.appspot.com/11642054

git-svn-id: svn://svn.chromium.org/chrome/trunk/src@175710 0039d316-1c4b-4281-b951-d872f2087c98
parent a45dcafa
...@@ -7,10 +7,6 @@ ...@@ -7,10 +7,6 @@
#include "base/logging.h" #include "base/logging.h"
#include "media/base/decrypt_config.h" #include "media/base/decrypt_config.h"
#if !defined(OS_ANDROID)
#include "base/memory/aligned_memory.h"
#endif
namespace media { namespace media {
DecoderBuffer::DecoderBuffer(int buffer_size) DecoderBuffer::DecoderBuffer(int buffer_size)
...@@ -23,33 +19,22 @@ DecoderBuffer::DecoderBuffer(const uint8* data, int buffer_size) ...@@ -23,33 +19,22 @@ DecoderBuffer::DecoderBuffer(const uint8* data, int buffer_size)
: Buffer(base::TimeDelta(), base::TimeDelta()), : Buffer(base::TimeDelta(), base::TimeDelta()),
buffer_size_(buffer_size) { buffer_size_(buffer_size) {
// Prevent invalid allocations. Also used to create end of stream buffers. // Prevent invalid allocations. Also used to create end of stream buffers.
if (!data) { if (!data || buffer_size <= 0) {
buffer_size_ = 0; buffer_size_ = 0;
data_ = NULL;
return; return;
} }
Initialize(); Initialize();
memcpy(data_, data, buffer_size_); memcpy(data_.get(), data, buffer_size_);
} }
DecoderBuffer::~DecoderBuffer() { DecoderBuffer::~DecoderBuffer() {}
#if !defined(OS_ANDROID)
base::AlignedFree(data_);
#else
delete[] data_;
#endif
}
void DecoderBuffer::Initialize() { void DecoderBuffer::Initialize() {
DCHECK_GE(buffer_size_, 0); DCHECK_GE(buffer_size_, 0);
#if !defined(OS_ANDROID) data_.reset(reinterpret_cast<uint8*>(
data_ = reinterpret_cast<uint8*>( base::AlignedAlloc(buffer_size_ + kPaddingSize, kAlignmentSize)));
base::AlignedAlloc(buffer_size_ + kPaddingSize, kAlignmentSize)); memset(data_.get() + buffer_size_, 0, kPaddingSize);
memset(data_ + buffer_size_, 0, kPaddingSize);
#else
data_ = new uint8[buffer_size_];
#endif
} }
scoped_refptr<DecoderBuffer> DecoderBuffer::CopyFrom(const uint8* data, scoped_refptr<DecoderBuffer> DecoderBuffer::CopyFrom(const uint8* data,
...@@ -63,7 +48,7 @@ scoped_refptr<DecoderBuffer> DecoderBuffer::CreateEOSBuffer() { ...@@ -63,7 +48,7 @@ scoped_refptr<DecoderBuffer> DecoderBuffer::CreateEOSBuffer() {
} }
const uint8* DecoderBuffer::GetData() const { const uint8* DecoderBuffer::GetData() const {
return data_; return data_.get();
} }
int DecoderBuffer::GetDataSize() const { int DecoderBuffer::GetDataSize() const {
...@@ -71,7 +56,7 @@ int DecoderBuffer::GetDataSize() const { ...@@ -71,7 +56,7 @@ int DecoderBuffer::GetDataSize() const {
} }
uint8* DecoderBuffer::GetWritableData() { uint8* DecoderBuffer::GetWritableData() {
return data_; return data_.get();
} }
const DecryptConfig* DecoderBuffer::GetDecryptConfig() const { const DecryptConfig* DecoderBuffer::GetDecryptConfig() const {
......
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#ifndef MEDIA_BASE_DECODER_BUFFER_H_ #ifndef MEDIA_BASE_DECODER_BUFFER_H_
#define MEDIA_BASE_DECODER_BUFFER_H_ #define MEDIA_BASE_DECODER_BUFFER_H_
#include "base/memory/aligned_memory.h"
#include "base/memory/scoped_ptr.h" #include "base/memory/scoped_ptr.h"
#include "build/build_config.h" #include "build/build_config.h"
#include "media/base/buffers.h" #include "media/base/buffers.h"
...@@ -62,7 +63,7 @@ class MEDIA_EXPORT DecoderBuffer : public Buffer { ...@@ -62,7 +63,7 @@ class MEDIA_EXPORT DecoderBuffer : public Buffer {
private: private:
int buffer_size_; int buffer_size_;
uint8* data_; scoped_ptr<uint8, base::ScopedPtrAlignedFree> data_;
scoped_ptr<DecryptConfig> decrypt_config_; scoped_ptr<DecryptConfig> decrypt_config_;
// Constructor helper method for memory allocations. // Constructor helper method for memory allocations.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment