/usr/include/boost/compute/pipe.hpp is in libboost1.62-dev 1.62.0+dfsg-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 | //---------------------------------------------------------------------------//
// Copyright (c) 2013-2014 Kyle Lutz <kyle.r.lutz@gmail.com>
//
// Distributed under the Boost Software License, Version 1.0
// See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt
//
// See http://boostorg.github.com/compute for more information.
//---------------------------------------------------------------------------//
#ifndef BOOST_COMPUTE_PIPE_HPP
#define BOOST_COMPUTE_PIPE_HPP
#include <boost/compute/cl.hpp>
#include <boost/compute/context.hpp>
#include <boost/compute/memory_object.hpp>
#include <boost/compute/exception/opencl_error.hpp>
#include <boost/compute/detail/get_object_info.hpp>
// pipe objects require opencl 2.0
#if defined(CL_VERSION_2_0) || defined(BOOST_COMPUTE_DOXYGEN_INVOKED)
namespace boost {
namespace compute {
/// \class pipe
/// \brief A FIFO data pipe
///
/// \opencl_version_warning{2,0}
///
/// \see memory_object
class pipe : public memory_object
{
public:
/// Creates a null pipe object.
pipe()
: memory_object()
{
}
/// Creates a pipe object for \p mem. If \p retain is \c true, the
/// reference count for \p mem will be incremented.
explicit pipe(cl_mem mem, bool retain = true)
: memory_object(mem, retain)
{
}
/// Creates a new pipe in \p context.
pipe(const context &context,
uint_ pipe_packet_size,
uint_ pipe_max_packets,
cl_mem_flags flags = read_write,
const cl_pipe_properties *properties = 0)
{
cl_int error = 0;
m_mem = clCreatePipe(context,
flags,
pipe_packet_size,
pipe_max_packets,
properties,
&error);
if(!m_mem){
BOOST_THROW_EXCEPTION(opencl_error(error));
}
}
/// Creates a new pipe object as a copy of \p other.
pipe(const pipe &other)
: memory_object(other)
{
}
/// Copies the pipe object from \p other to \c *this.
pipe& operator=(const pipe &other)
{
if(this != &other){
memory_object::operator=(other);
}
return *this;
}
#ifndef BOOST_COMPUTE_NO_RVALUE_REFERENCES
/// Move-constructs a new pipe object from \p other.
pipe(pipe&& other) BOOST_NOEXCEPT
: memory_object(std::move(other))
{
}
/// Move-assigns the pipe from \p other to \c *this.
pipe& operator=(pipe&& other) BOOST_NOEXCEPT
{
memory_object::operator=(std::move(other));
return *this;
}
#endif // BOOST_COMPUTE_NO_RVALUE_REFERENCES
/// Destroys the pipe object.
~pipe()
{
}
/// Returns the packet size.
uint_ packet_size() const
{
return get_info<uint_>(CL_PIPE_PACKET_SIZE);
}
/// Returns the max number of packets.
uint_ max_packets() const
{
return get_info<uint_>(CL_PIPE_MAX_PACKETS);
}
/// Returns information about the pipe.
///
/// \see_opencl2_ref{clGetPipeInfo}
template<class T>
T get_info(cl_pipe_info info) const
{
return detail::get_object_info<T>(clGetPipeInfo, m_mem, info);
}
/// \overload
template<int Enum>
typename detail::get_object_info_type<pipe, Enum>::type get_info() const;
};
/// \internal_ define get_info() specializations for pipe
BOOST_COMPUTE_DETAIL_DEFINE_GET_INFO_SPECIALIZATIONS(pipe,
((cl_uint, CL_PIPE_PACKET_SIZE))
((cl_uint, CL_PIPE_MAX_PACKETS))
)
namespace detail {
// set_kernel_arg specialization for pipe
template<>
struct set_kernel_arg<pipe>
{
void operator()(kernel &kernel_, size_t index, const pipe &pipe_)
{
kernel_.set_arg(index, pipe_.get());
}
};
} // end detail namespace
} // end compute namespace
} // end boost namespace
#endif // CL_VERSION_2_0
#endif // BOOST_COMPUTE_PIPE_HPP
|