stabilize build system: depends, installer, boost/bdb fixes, cross targets groundwork

This commit is contained in:
2026-02-24 18:38:47 +00:00
parent da8c28aaeb
commit 65cb2619a7
13106 changed files with 2484322 additions and 1804 deletions
@@ -0,0 +1,88 @@
//---------------------------------------------------------------------------//
// Copyright (c) 2013 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_EXCEPTION_CONTEXT_ERROR_HPP
#define BOOST_COMPUTE_EXCEPTION_CONTEXT_ERROR_HPP
#include <exception>
namespace boost {
namespace compute {
class context;
/// \class context_error
/// \brief A run-time OpenCL context error.
///
/// The context_error exception is thrown when the OpenCL context encounters
/// an error condition. Boost.Compute is notified of these error conditions by
/// registering an error handler when creating context objects (via the
/// \c pfn_notify argument to the \c clCreateContext() function).
///
/// This exception is different than the opencl_error exception which is thrown
/// as a result of error caused when calling a single OpenCL API function.
///
/// \see opencl_error
class context_error : public std::exception
{
public:
/// Creates a new context error exception object.
context_error(const context *context,
const char *errinfo,
const void *private_info,
size_t private_info_size) throw()
: m_context(context),
m_errinfo(errinfo),
m_private_info(private_info),
m_private_info_size(private_info_size)
{
}
/// Destroys the context error object.
~context_error() throw()
{
}
/// Returns a string with a description of the error.
const char* what() const throw()
{
return m_errinfo;
}
/// Returns a pointer to the context object which generated the error
/// notification.
const context* get_context_ptr() const throw()
{
return m_context;
}
/// Returns a pointer to the private info memory block.
const void* get_private_info_ptr() const throw()
{
return m_private_info;
}
/// Returns the size of the private info memory block.
size_t get_private_info_size() const throw()
{
return m_private_info_size;
}
private:
const context *m_context;
const char *m_errinfo;
const void *m_private_info;
size_t m_private_info_size;
};
} // end compute namespace
} // end boost namespace
#endif // BOOST_COMPUTE_EXCEPTION_CONTEXT_ERROR_HPP
@@ -0,0 +1,48 @@
//---------------------------------------------------------------------------//
// Copyright (c) 2013-2015 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_EXCEPTION_NO_DEVICE_FOUND_HPP
#define BOOST_COMPUTE_EXCEPTION_NO_DEVICE_FOUND_HPP
#include <exception>
namespace boost {
namespace compute {
/// \class no_device_found
/// \brief Exception thrown when no OpenCL device is found
///
/// This exception is thrown when no valid OpenCL device can be found.
///
/// \see opencl_error
class no_device_found : public std::exception
{
public:
/// Creates a new no_device_found exception object.
no_device_found() throw()
{
}
/// Destroys the no_device_found exception object.
~no_device_found() throw()
{
}
/// Returns a string containing a human-readable error message.
const char* what() const throw()
{
return "No OpenCL device found";
}
};
} // end compute namespace
} // end boost namespace
#endif // BOOST_COMPUTE_EXCEPTION_NO_DEVICE_FOUND_HPP
@@ -0,0 +1,158 @@
//---------------------------------------------------------------------------//
// Copyright (c) 2013 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_EXCEPTION_OPENCL_ERROR_HPP
#define BOOST_COMPUTE_EXCEPTION_OPENCL_ERROR_HPP
#include <exception>
#include <string>
#include <sstream>
#include <boost/compute/cl.hpp>
namespace boost {
namespace compute {
/// \class opencl_error
/// \brief A run-time OpenCL error.
///
/// The opencl_error class represents an error returned from an OpenCL
/// function.
///
/// \see context_error
class opencl_error : public std::exception
{
public:
/// Creates a new opencl_error exception object for \p error.
explicit opencl_error(cl_int error) throw()
: m_error(error),
m_error_string(to_string(error))
{
}
/// Destroys the opencl_error object.
~opencl_error() throw()
{
}
/// Returns the numeric error code.
cl_int error_code() const throw()
{
return m_error;
}
/// Returns a string description of the error.
std::string error_string() const throw()
{
return m_error_string;
}
/// Returns a C-string description of the error.
const char* what() const throw()
{
return m_error_string.c_str();
}
/// Static function which converts the numeric OpenCL error code \p error
/// to a human-readable string.
///
/// For example:
/// \code
/// std::cout << opencl_error::to_string(CL_INVALID_KERNEL_ARGS) << std::endl;
/// \endcode
///
/// Will print "Invalid Kernel Arguments".
///
/// If the error code is unknown (e.g. not a valid OpenCL error), a string
/// containing "Unknown OpenCL Error" along with the error number will be
/// returned.
static std::string to_string(cl_int error)
{
switch(error){
case CL_SUCCESS: return "Success";
case CL_DEVICE_NOT_FOUND: return "Device Not Found";
case CL_DEVICE_NOT_AVAILABLE: return "Device Not Available";
case CL_COMPILER_NOT_AVAILABLE: return "Compiler Not Available";
case CL_MEM_OBJECT_ALLOCATION_FAILURE: return "Memory Object Allocation Failure";
case CL_OUT_OF_RESOURCES: return "Out of Resources";
case CL_OUT_OF_HOST_MEMORY: return "Out of Host Memory";
case CL_PROFILING_INFO_NOT_AVAILABLE: return "Profiling Information Not Available";
case CL_MEM_COPY_OVERLAP: return "Memory Copy Overlap";
case CL_IMAGE_FORMAT_MISMATCH: return "Image Format Mismatch";
case CL_IMAGE_FORMAT_NOT_SUPPORTED: return "Image Format Not Supported";
case CL_BUILD_PROGRAM_FAILURE: return "Build Program Failure";
case CL_MAP_FAILURE: return "Map Failure";
case CL_INVALID_VALUE: return "Invalid Value";
case CL_INVALID_DEVICE_TYPE: return "Invalid Device Type";
case CL_INVALID_PLATFORM: return "Invalid Platform";
case CL_INVALID_DEVICE: return "Invalid Device";
case CL_INVALID_CONTEXT: return "Invalid Context";
case CL_INVALID_QUEUE_PROPERTIES: return "Invalid Queue Properties";
case CL_INVALID_COMMAND_QUEUE: return "Invalid Command Queue";
case CL_INVALID_HOST_PTR: return "Invalid Host Pointer";
case CL_INVALID_MEM_OBJECT: return "Invalid Memory Object";
case CL_INVALID_IMAGE_FORMAT_DESCRIPTOR: return "Invalid Image Format Descriptor";
case CL_INVALID_IMAGE_SIZE: return "Invalid Image Size";
case CL_INVALID_SAMPLER: return "Invalid Sampler";
case CL_INVALID_BINARY: return "Invalid Binary";
case CL_INVALID_BUILD_OPTIONS: return "Invalid Build Options";
case CL_INVALID_PROGRAM: return "Invalid Program";
case CL_INVALID_PROGRAM_EXECUTABLE: return "Invalid Program Executable";
case CL_INVALID_KERNEL_NAME: return "Invalid Kernel Name";
case CL_INVALID_KERNEL_DEFINITION: return "Invalid Kernel Definition";
case CL_INVALID_KERNEL: return "Invalid Kernel";
case CL_INVALID_ARG_INDEX: return "Invalid Argument Index";
case CL_INVALID_ARG_VALUE: return "Invalid Argument Value";
case CL_INVALID_ARG_SIZE: return "Invalid Argument Size";
case CL_INVALID_KERNEL_ARGS: return "Invalid Kernel Arguments";
case CL_INVALID_WORK_DIMENSION: return "Invalid Work Dimension";
case CL_INVALID_WORK_GROUP_SIZE: return "Invalid Work Group Size";
case CL_INVALID_WORK_ITEM_SIZE: return "Invalid Work Item Size";
case CL_INVALID_GLOBAL_OFFSET: return "Invalid Global Offset";
case CL_INVALID_EVENT_WAIT_LIST: return "Invalid Event Wait List";
case CL_INVALID_EVENT: return "Invalid Event";
case CL_INVALID_OPERATION: return "Invalid Operation";
case CL_INVALID_GL_OBJECT: return "Invalid GL Object";
case CL_INVALID_BUFFER_SIZE: return "Invalid Buffer Size";
case CL_INVALID_MIP_LEVEL: return "Invalid MIP Level";
case CL_INVALID_GLOBAL_WORK_SIZE: return "Invalid Global Work Size";
#ifdef CL_VERSION_1_2
case CL_COMPILE_PROGRAM_FAILURE: return "Compile Program Failure";
case CL_LINKER_NOT_AVAILABLE: return "Linker Not Available";
case CL_LINK_PROGRAM_FAILURE: return "Link Program Failure";
case CL_DEVICE_PARTITION_FAILED: return "Device Partition Failed";
case CL_KERNEL_ARG_INFO_NOT_AVAILABLE: return "Kernel Argument Info Not Available";
case CL_INVALID_PROPERTY: return "Invalid Property";
case CL_INVALID_IMAGE_DESCRIPTOR: return "Invalid Image Descriptor";
case CL_INVALID_COMPILER_OPTIONS: return "Invalid Compiler Options";
case CL_INVALID_LINKER_OPTIONS: return "Invalid Linker Options";
case CL_INVALID_DEVICE_PARTITION_COUNT: return "Invalid Device Partition Count";
#endif // CL_VERSION_1_2
#ifdef CL_VERSION_2_0
case CL_INVALID_PIPE_SIZE: return "Invalid Pipe Size";
case CL_INVALID_DEVICE_QUEUE: return "Invalid Device Queue";
#endif
default: {
std::stringstream s;
s << "Unknown OpenCL Error (" << error << ")";
return s.str();
}
}
}
private:
cl_int m_error;
std::string m_error_string;
};
} // end compute namespace
} // end boost namespace
#endif // BOOST_COMPUTE_EXCEPTION_OPENCL_ERROR_HPP
@@ -0,0 +1,71 @@
//---------------------------------------------------------------------------//
// 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_EXCEPTION_UNSUPPORTED_EXTENSION_ERROR_HPP
#define BOOST_COMPUTE_EXCEPTION_UNSUPPORTED_EXTENSION_ERROR_HPP
#include <exception>
#include <sstream>
#include <string>
namespace boost {
namespace compute {
/// \class unsupported_extension_error
/// \brief Exception thrown when attempting to use an unsupported
/// OpenCL extension.
///
/// This exception is thrown when the user attempts to use an OpenCL
/// extension which is not supported on the platform and/or device.
///
/// An example of this is attempting to use CL-GL sharing on a non-GPU
/// device.
///
/// \see opencl_error
class unsupported_extension_error : public std::exception
{
public:
/// Creates a new unsupported extension error exception object indicating
/// that \p extension is not supported by the OpenCL platform or device.
explicit unsupported_extension_error(const char *extension) throw()
: m_extension(extension)
{
std::stringstream msg;
msg << "OpenCL extension " << extension << " not supported";
m_error_string = msg.str();
}
/// Destroys the unsupported extension error object.
~unsupported_extension_error() throw()
{
}
/// Returns the name of the unsupported extension.
std::string extension_name() const throw()
{
return m_extension;
}
/// Returns a string containing a human-readable error message containing
/// the name of the unsupported exception.
const char* what() const throw()
{
return m_error_string.c_str();
}
private:
std::string m_extension;
std::string m_error_string;
};
} // end compute namespace
} // end boost namespace
#endif // BOOST_COMPUTE_EXCEPTION_UNSUPPORTED_EXTENSION_ERROR_HPP