Program Listing for File MemoryOperation.hpp

Return to documentation for file (umpire/op/MemoryOperation.hpp)

//////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2016-20, Lawrence Livermore National Security, LLC and Umpire
// project contributors. See the COPYRIGHT file for details.
//
// SPDX-License-Identifier: (MIT)
//////////////////////////////////////////////////////////////////////////////
#ifndef UMPIRE_MemoryOperation_HPP
#define UMPIRE_MemoryOperation_HPP

#include <cstddef>

#include "umpire/util/AllocationRecord.hpp"

namespace umpire {
namespace op {

/*!
 * \brief Base class of an operation on memory.
 *
 * Neither the transfrom or apply methods are pure virtual, so inheriting
 * classes only need overload the appropriate method. However, both methods
 * will throw an error if called.
 */
class MemoryOperation {
  public:
    virtual ~MemoryOperation() = default;

    /*!
     * \brief Transfrom length bytes of memory from src_ptr to dst_ptr.
     *
     * \param src_ptr Pointer to source memory location.
     * \param dst_ptr Pointer to destinatino memory location.
     * \param src_allocation AllocationRecord of source.
     * \param dst_allocation AllocationRecord of destination.
     * \param length Number of bytes to transform.
     *
     * \throws util::Exception
     */
    virtual void transform(
        void* src_ptr,
        void** dst_ptr,
        util::AllocationRecord *src_allocation,
        util::AllocationRecord *dst_allocation,
        std::size_t length);

    /*!
     * \brief Apply val to the first length bytes of src_ptr.
     *
     * \param src_ptr Pointer to source memory location.
     * \param src_allocation AllocationRecord of source.
     * \param val Value to apply.
     * \param length Number of bytes to modify.
     *
     * \throws util::Exception
     */
    virtual void apply(
        void* src_ptr,
        util::AllocationRecord *src_allocation,
        int val,
        std::size_t length);
};

} // end of namespace op
} // end of namespace umpire

#endif // UMPIRE_MemoryOperation_HPP