未验证 提交 4d5a6064 编写于 作者: 石晓伟 提交者: GitHub

updates the pten allocation, test=develop (#38355)

* updates the pten allocation, test=develop

* avoids an error message, test=develop
上级 f50768e8
...@@ -28,8 +28,8 @@ class DefaultAllocator : public pten::Allocator { ...@@ -28,8 +28,8 @@ class DefaultAllocator : public pten::Allocator {
explicit DefaultAllocator(const paddle::platform::Place& place) explicit DefaultAllocator(const paddle::platform::Place& place)
: place_(place) {} : place_(place) {}
static void Delete(void* data) { static void Delete(Allocation* allocation) {
deleter_(static_cast<paddle::memory::Allocation*>(data)); deleter_(allocation->CastContextWithoutCheck<paddle::memory::Allocation>());
} }
Allocation Allocate(size_t bytes_size) override { Allocation Allocate(size_t bytes_size) override {
......
...@@ -55,29 +55,47 @@ class RawAllocator { ...@@ -55,29 +55,47 @@ class RawAllocator {
class Allocation final { class Allocation final {
public: public:
using Place = paddle::platform::Place; using Place = paddle::platform::Place;
using DeleterFnPtr = void (*)(void*); using DeleterFnPtr = void (*)(Allocation*);
Allocation() = default; Allocation() = default;
Allocation(Allocation&&) = default;
Allocation& operator=(Allocation&&) = default;
// Don't own resources, only provide access.
Allocation(void* data, const Place& place) : data_(data), place_(place) {} Allocation(void* data, const Place& place) : data_(data), place_(place) {}
Allocation(void* data, // Own resources.
void* ctx, Allocation(void* data, void* ctx, DeleterFnPtr deleter, const Place& place)
DeleterFnPtr ctx_deleter, : data_(data), ctx_(ctx), deleter_(deleter), place_(place) {}
const Place& place)
: data_(data), ctx_(ctx, ctx_deleter), place_(place) {}
Allocation(Allocation&& other) { swap(*this, other); }
Allocation& operator=(Allocation&& other) {
// Exchange them explicitly to avoid moving is equivalent
// to copying.
swap(*this, other);
return *this;
}
~Allocation() { Clear(); }
void* ptr() const noexcept { return data_; }
void* operator->() const noexcept { return data_; } void* operator->() const noexcept { return data_; }
operator bool() const noexcept { return data_ || ctx_.Get(); } operator bool() const noexcept { return data_ || ctx_; }
const Place& place() const noexcept { return place_; } const Place& place() const noexcept { return place_; }
void Clear() { void Clear() {
ctx_.Clear(); if (deleter_) {
deleter_(this);
}
ctx_ = nullptr;
deleter_ = nullptr;
data_ = nullptr; data_ = nullptr;
} }
DeleterFnPtr deleter() const noexcept { return deleter_; }
template <typename T>
T* CastContextWithoutCheck() const noexcept {
return static_cast<T*>(ctx_);
}
/// \brief Statically cast the void pointer of the context object to /// \brief Statically cast the void pointer of the context object to
/// the primitive type. Conversion of any pointer to void* and back /// the primitive type. Conversion of any pointer to void* and back
/// to pointer to the original cv type preserves its original value. /// to pointer to the original cv type preserves its original value.
...@@ -85,60 +103,31 @@ class Allocation final { ...@@ -85,60 +103,31 @@ class Allocation final {
/// \param expected_deleter The destructor passed in to enhance type /// \param expected_deleter The destructor passed in to enhance type
/// safety checking. /// safety checking.
template <typename T> template <typename T>
T* CastContext(DeleterFnPtr expected_deleter) const noexcept { T* CastContext(DeleterFnPtr expected_deleter) const {
if (ctx_.deleter() != expected_deleter) { PADDLE_ENFORCE_EQ(
return nullptr; deleter_ == expected_deleter,
} true,
return static_cast<T*>(ctx_.Get()); paddle::platform::errors::InvalidArgument(
"The deleter of the allocation does not match, so the pointer "
"cannot be safely removed."));
return CastContextWithoutCheck<T>();
} }
public:
class Context {
public:
Context() = default;
Context(void* ctx, DeleterFnPtr deleter) noexcept : ctx_(ctx),
deleter_(deleter) {}
Context(Context&& other) noexcept {
// Exchange them explicitly to avoid moving is equivalent
// to copying.
swap(*this, other);
}
Context& operator=(Context&& other) noexcept {
swap(*this, other);
return *this;
}
~Context() { Clear(); }
void Clear() {
if (deleter_) {
deleter_(ctx_);
}
ctx_ = nullptr;
deleter_ = nullptr;
}
void* Get() const noexcept { return ctx_; }
DeleterFnPtr deleter() const noexcept { return deleter_; }
void* Release() noexcept {
deleter_ = nullptr;
return ctx_;
}
friend void swap(Context& a, Context& b) noexcept;
private: private:
friend void swap(Allocation& a, Allocation& b) noexcept;
void* data_{nullptr};
void* ctx_{nullptr}; void* ctx_{nullptr};
DeleterFnPtr deleter_{nullptr}; DeleterFnPtr deleter_{nullptr};
};
private:
void* data_{nullptr};
Context ctx_;
// TODO(Shixiaowei02): Enum needs to be used instead to reduce // TODO(Shixiaowei02): Enum needs to be used instead to reduce
// the construction overhead by more than 50%. // the construction overhead by more than 50%.
Place place_; Place place_;
}; };
inline void swap(Allocation::Context& a, Allocation::Context& b) noexcept { inline void swap(Allocation& a, Allocation& b) noexcept {
::std::swap(a.data_, b.data_);
::std::swap(a.ctx_, b.ctx_); ::std::swap(a.ctx_, b.ctx_);
::std::swap(a.deleter_, b.deleter_); ::std::swap(a.deleter_, b.deleter_);
::std::swap(a.place_, b.place_);
} }
/// \brief Context compatible allocator interface. This allocator is /// \brief Context compatible allocator interface. This allocator is
......
...@@ -38,7 +38,9 @@ class HostAllocatorSample : public pten::RawAllocator { ...@@ -38,7 +38,9 @@ class HostAllocatorSample : public pten::RawAllocator {
class FancyAllocator : public pten::Allocator { class FancyAllocator : public pten::Allocator {
public: public:
static void Delete(void* data) { ::operator delete(data); } static void Delete(Allocation* allocation) {
::operator delete(allocation->ptr());
}
Allocation Allocate(size_t bytes_size) override { Allocation Allocate(size_t bytes_size) override {
void* data = ::operator new(bytes_size); void* data = ::operator new(bytes_size);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册