Commit f000fe32 authored by Umang Yadav's avatar Umang Yadav
Browse files

remove unnecesssary changes

parent 795bea35
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Weverything"
// SPDX-License-Identifier: MIT
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
......@@ -34,5 +31,3 @@ __device__ void s_nop()
}
} // namespace ck
#pragma clang diagnostic pop
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Weverything"
// SPDX-License-Identifier: MIT
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
......@@ -23,5 +20,3 @@ struct ThisThreadBlock
};
} // namespace ck
#pragma clang diagnostic pop
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Weverything"
// SPDX-License-Identifier: MIT
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
......@@ -166,5 +163,3 @@ struct transpose_vectors<int8_t, NX, NY>
};
} // namespace ck
#pragma clang diagnostic pop
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Weverything"
// SPDX-License-Identifier: MIT
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
......@@ -222,5 +219,3 @@ constexpr Tuple<Args&...> tie(Args&... args) noexcept
}
} // namespace ck
#pragma clang diagnostic pop
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Weverything"
// SPDX-License-Identifier: MIT
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
......@@ -82,5 +79,3 @@ __host__ __device__ constexpr auto transform_tuples(F f, const X& x, const Y& y,
}
} // namespace ck
#pragma clang diagnostic pop
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Weverything"
// SPDX-License-Identifier: MIT
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
......@@ -13,16 +10,25 @@
#ifdef __HIPCC_RTC__
namespace std {
// NOLINTNEXTLINE
#define MIGRAPHX_BUILTIN_TYPE_TRAIT1(name) \
template <class T> struct name : bool_constant<__##name(T)> {}
#define MIGRAPHX_BUILTIN_TYPE_TRAIT1(name) \
template <class T> \
struct name : bool_constant<__##name(T)> \
{ \
}
// NOLINTNEXTLINE
#define MIGRAPHX_BUILTIN_TYPE_TRAIT2(name) \
template <class T, class U> struct name : bool_constant<__##name(T, U)> {}
#define MIGRAPHX_BUILTIN_TYPE_TRAIT2(name) \
template <class T, class U> \
struct name : bool_constant<__##name(T, U)> \
{ \
}
// NOLINTNEXTLINE
#define MIGRAPHX_BUILTIN_TYPE_TRAITN(name) \
template <class... Ts> struct name : bool_constant<__##name(Ts...)> {}
#define MIGRAPHX_BUILTIN_TYPE_TRAITN(name) \
template <class... Ts> \
struct name : bool_constant<__##name(Ts...)> \
{ \
}
// MIGRAPHX_BUILTIN_TYPE_TRAIT1(is_arithmetic);
// MIGRAPHX_BUILTIN_TYPE_TRAIT1(is_destructible);
......@@ -70,202 +76,257 @@ MIGRAPHX_BUILTIN_TYPE_TRAIT2(is_trivially_assignable);
MIGRAPHX_BUILTIN_TYPE_TRAITN(is_constructible);
MIGRAPHX_BUILTIN_TYPE_TRAITN(is_nothrow_constructible);
MIGRAPHX_BUILTIN_TYPE_TRAITN(is_trivially_constructible);
template <class T> struct remove_reference {
typedef T type;
template <class T>
struct remove_reference
{
typedef T type;
};
template <class T> struct remove_reference<T &> {
typedef T type;
template <class T>
struct remove_reference<T&>
{
typedef T type;
};
template <class T> struct remove_reference<T &&> {
typedef T type;
template <class T>
struct remove_reference<T&&>
{
typedef T type;
};
template <class T> struct remove_const {
typedef T type;
template <class T>
struct remove_const
{
typedef T type;
};
template <class T> struct remove_const<const T> {
typedef T type;
template <class T>
struct remove_const<const T>
{
typedef T type;
};
template <class T> struct remove_volatile {
typedef T type;
template <class T>
struct remove_volatile
{
typedef T type;
};
template <class T> struct remove_volatile<volatile T> {
typedef T type;
template <class T>
struct remove_volatile<volatile T>
{
typedef T type;
};
template <class T> struct remove_cv {
typedef typename remove_volatile<typename remove_const<T>::type>::type type;
template <class T>
struct remove_cv
{
typedef typename remove_volatile<typename remove_const<T>::type>::type type;
};
template <class T> struct remove_pointer {
typedef T type;
template <class T>
struct remove_pointer
{
typedef T type;
};
template <class T> struct remove_pointer<T *> {
typedef T type;
template <class T>
struct remove_pointer<T*>
{
typedef T type;
};
template <class T> struct remove_pointer<T *const> {
typedef T type;
template <class T>
struct remove_pointer<T* const>
{
typedef T type;
};
template <class T> struct remove_pointer<T *volatile> {
typedef T type;
template <class T>
struct remove_pointer<T* volatile>
{
typedef T type;
};
template <class T> struct remove_pointer<T *const volatile> {
typedef T type;
template <class T>
struct remove_pointer<T* const volatile>
{
typedef T type;
};
template <class T> struct is_pointer_helper : std::false_type {};
template <class T>
struct is_pointer_helper : std::false_type
{
};
template <class T> struct is_pointer_helper<T *> : std::true_type {};
template <class T>
struct is_pointer_helper<T*> : std::true_type
{
};
template <class T>
struct is_pointer : is_pointer_helper<typename std::remove_cv<T>::type> {};
struct is_pointer : is_pointer_helper<typename std::remove_cv<T>::type>
{
};
template <typename T>
constexpr T &&forward(typename remove_reference<T>::type &t_) noexcept {
return static_cast<T &&>(t_);
constexpr T&& forward(typename remove_reference<T>::type& t_) noexcept
{
return static_cast<T&&>(t_);
}
template <typename T>
constexpr T &&forward(typename remove_reference<T>::type &&t_) noexcept {
return static_cast<T &&>(t_);
constexpr T&& forward(typename remove_reference<T>::type&& t_) noexcept
{
return static_cast<T&&>(t_);
}
template <typename T>
inline constexpr bool is_reference_v = is_reference<T>::value;
/// Default deleter
template <typename T>
struct default_delete {
void operator()(T* ptr) const { delete ptr; }
struct default_delete
{
void operator()(T* ptr) const { delete ptr; }
};
/// Partial specialization for deleting array types
template <typename T>
struct default_delete<T[]> {
void operator()(T* ptr) const { delete[] ptr; }
struct default_delete<T[]>
{
void operator()(T* ptr) const { delete[] ptr; }
};
/// std::unique_ptr
template <class T, class Deleter = default_delete<T> >
class unique_ptr {
public:
typedef T* pointer;
typedef T element_type;
typedef Deleter deleter_type;
private:
/// Pointer to memory
pointer _ptr;
/// Deleter
deleter_type _deleter;
public:
unique_ptr() : _ptr(nullptr) {}
unique_ptr(pointer p) : _ptr(p) {}
~unique_ptr() {
if (_ptr) {
_deleter(_ptr);
template <class T, class Deleter = default_delete<T>>
class unique_ptr
{
public:
typedef T* pointer;
typedef T element_type;
typedef Deleter deleter_type;
private:
/// Pointer to memory
pointer _ptr;
/// Deleter
deleter_type _deleter;
public:
unique_ptr() : _ptr(nullptr) {}
unique_ptr(pointer p) : _ptr(p) {}
~unique_ptr()
{
if(_ptr)
{
_deleter(_ptr);
}
}
/// Returns a pointer to the managed object or nullptr if no object is owned.
pointer get() const noexcept { return _ptr; }
/// Releases ownership of the managed object, if any
pointer release() noexcept
{
pointer p(_ptr);
_ptr = nullptr;
return p;
}
}
/// Returns a pointer to the managed object or nullptr if no object is owned.
pointer get() const noexcept { return _ptr; }
/// Releases ownership of the managed object, if any
pointer release() noexcept {
pointer p(_ptr);
_ptr = nullptr;
return p;
}
/// Replaces the managed object, deleting the old object.
void reset(pointer p = pointer()) noexcept {
pointer old_ptr = _ptr;
_ptr = p;
if (old_ptr != nullptr) {
get_deleter()(old_ptr);
/// Replaces the managed object, deleting the old object.
void reset(pointer p = pointer()) noexcept
{
pointer old_ptr = _ptr;
_ptr = p;
if(old_ptr != nullptr)
{
get_deleter()(old_ptr);
}
}
}
/// Swaps the managed objects with *this and another unique_ptr
void swap(unique_ptr& other) noexcept { swap(_ptr, other._ptr); }
/// Swaps the managed objects with *this and another unique_ptr
void swap(unique_ptr& other) noexcept { swap(_ptr, other._ptr); }
/// Returns the deleter object
Deleter& get_deleter() noexcept { return _deleter; }
/// Returns the deleter object
Deleter& get_deleter() noexcept { return _deleter; }
/// Returns the deleter object
Deleter const& get_deleter() const noexcept { return _deleter; }
/// Returns the deleter object
Deleter const& get_deleter() const noexcept { return _deleter; }
/// Checks whether an object is owned
operator bool() const noexcept { return _ptr != nullptr; }
/// Checks whether an object is owned
operator bool() const noexcept { return _ptr != nullptr; }
/// Dereferences the unique_ptr
T& operator*() const { return *_ptr; }
/// Dereferences the unique_ptr
T& operator*() const { return *_ptr; }
/// Returns a pointer to the managed object
pointer operator->() const noexcept { return _ptr; }
/// Returns a pointer to the managed object
pointer operator->() const noexcept { return _ptr; }
/// Array access to managed object
T& operator[](size_t i) const { return _ptr[i]; }
/// Array access to managed object
T& operator[](size_t i) const { return _ptr[i]; }
};
/// Specializes the swap algorithm
template <typename T, typename Deleter>
void swap(unique_ptr<T, Deleter>& lhs, unique_ptr<T, Deleter>& rhs) noexcept {
lhs.swap(rhs);
void swap(unique_ptr<T, Deleter>& lhs, unique_ptr<T, Deleter>& rhs) noexcept
{
lhs.swap(rhs);
}
template<class T>
struct remove_extent { using type = T; };
template<class T>
struct remove_extent<T[]> { using type = T; };
template<class T, std::size_t N>
struct remove_extent<T[N]> { using type = T; };
template <class T>
struct remove_extent
{
using type = T;
};
template< class T >
using remove_extent_t = typename remove_extent<T>::type;
template <class T>
struct remove_extent<T[]>
{
using type = T;
};
namespace detail
template <class T, std::size_t N>
struct remove_extent<T[N]>
{
template<class>
constexpr bool is_unbounded_array_v = false;
template<class T>
constexpr bool is_unbounded_array_v<T[]> = true;
template<class>
constexpr bool is_bounded_array_v = false;
template<class T, std::size_t N>
constexpr bool is_bounded_array_v<T[N]> = true;
using type = T;
};
template <class T>
using remove_extent_t = typename remove_extent<T>::type;
namespace detail {
template <class>
constexpr bool is_unbounded_array_v = false;
template <class T>
constexpr bool is_unbounded_array_v<T[]> = true;
template <class>
constexpr bool is_bounded_array_v = false;
template <class T, std::size_t N>
constexpr bool is_bounded_array_v<T[N]> = true;
} // namespace detail
template<class T, class... Args>
enable_if_t<!is_array<T>::value, unique_ptr<T>>
make_unique(Args&&... args)
template <class T, class... Args>
enable_if_t<!is_array<T>::value, unique_ptr<T>> make_unique(Args&&... args)
{
return unique_ptr<T>(new T(forward<Args>(args)...));
}
template<class T>
enable_if_t<detail::is_unbounded_array_v<T>, unique_ptr<T>>
make_unique(uint64_t n)
template <class T>
enable_if_t<detail::is_unbounded_array_v<T>, unique_ptr<T>> make_unique(uint64_t n)
{
return unique_ptr<T>(new remove_extent_t<T>[n]());
}
template<class T, class... Args>
template <class T, class... Args>
enable_if_t<detail::is_bounded_array_v<T>> make_unique(Args&&...) = delete;
} // namespace std
#endif
namespace ck {
template <typename X, typename Y>
struct is_same : public integral_constant<bool, false> {};
struct is_same : public integral_constant<bool, false>
{
};
template <typename X>
struct is_same<X, X> : public integral_constant<bool, true> {};
struct is_same<X, X> : public integral_constant<bool, true>
{
};
template <typename X, typename Y>
inline constexpr bool is_same_v = is_same<X, Y>::value;
......@@ -276,9 +337,11 @@ using remove_reference_t = typename std::remove_reference<T>::type;
template <typename T>
using remove_reference_t = typename std::remove_reference<T>::type;
template <typename T> using remove_cv_t = typename std::remove_cv<T>::type;
template <typename T>
using remove_cv_t = typename std::remove_cv<T>::type;
template <typename T> using remove_cvref_t = remove_cv_t<remove_reference_t<T>>;
template <typename T>
using remove_cvref_t = remove_cv_t<remove_reference_t<T>>;
template <typename T>
using remove_pointer_t = typename std::remove_pointer<T>::type;
......@@ -286,25 +349,24 @@ using remove_pointer_t = typename std::remove_pointer<T>::type;
template <typename T>
inline constexpr bool is_pointer_v = std::is_pointer<T>::value;
template <typename Y, typename X,
typename enable_if<sizeof(X) == sizeof(Y), bool>::type = false>
__host__ __device__ constexpr Y bit_cast(const X &x) {
template <typename Y, typename X, typename enable_if<sizeof(X) == sizeof(Y), bool>::type = false>
__host__ __device__ constexpr Y bit_cast(const X& x)
{
#if CK_EXPERIMENTAL_USE_MEMCPY_FOR_BIT_CAST
Y y;
Y y;
__builtin_memcpy(&y, &x, sizeof(X));
__builtin_memcpy(&y, &x, sizeof(X));
return y;
return y;
#else
union AsType {
X x;
Y y;
};
union AsType
{
X x;
Y y;
};
return AsType{x}.y;
return AsType{x}.y;
#endif
}
} // namespace ck
#pragma clang diagnostic pop
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