e28244f345
The previous implementation of DeviceAdapterRuntimeDetector caused multiple differing definitions of the same class to exist and was causing the runtime device tracker to report CUDA as disabled when it actually was enabled. The ODR was caused by having a default implementation for DeviceAdapterRuntimeDetector and a specific specialization for CUDA. If a library had both CUDA and C++ sources it would pick up both implementations and would have undefined behavior. In general it would think the CUDA backend was disabled. To avoid this kind of situation in the future I have reworked VTK-m so that each device adapter must implement DeviceAdapterRuntimeDetector for that device.
59 lines
2.0 KiB
C++
59 lines
2.0 KiB
C++
//============================================================================
|
|
// Copyright (c) Kitware, Inc.
|
|
// All rights reserved.
|
|
// See LICENSE.txt for details.
|
|
// This software is distributed WITHOUT ANY WARRANTY; without even
|
|
// the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
// PURPOSE. See the above copyright notice for more information.
|
|
//
|
|
// Copyright 2014 National Technology & Engineering Solutions of Sandia, LLC (NTESS).
|
|
// Copyright 2014 UT-Battelle, LLC.
|
|
// Copyright 2014 Los Alamos National Security.
|
|
//
|
|
// Under the terms of Contract DE-NA0003525 with NTESS,
|
|
// the U.S. Government retains certain rights in this software.
|
|
//
|
|
// Under the terms of Contract DE-AC52-06NA25396 with Los Alamos National
|
|
// Laboratory (LANL), the U.S. Government retains certain rights in
|
|
// this software.
|
|
//============================================================================
|
|
#ifndef vtk_m_cont_internal_DeviceAdapterError_h
|
|
#define vtk_m_cont_internal_DeviceAdapterError_h
|
|
|
|
#include <vtkm/cont/internal/DeviceAdapterTag.h>
|
|
|
|
/// This is an invalid DeviceAdapter. The point of this class is to include the
|
|
/// header file to make this invalid class the default DeviceAdapter. From that
|
|
/// point, you have to specify an appropriate DeviceAdapter or else get a
|
|
/// compile error.
|
|
///
|
|
VTKM_INVALID_DEVICE_ADAPTER(Error, VTKM_DEVICE_ADAPTER_ERROR);
|
|
|
|
namespace vtkm
|
|
{
|
|
namespace cont
|
|
{
|
|
|
|
/// \brief Class providing a Error runtime support detector.
|
|
///
|
|
/// The class provide the actual implementation used by
|
|
/// vtkm::cont::RuntimeDeviceInformation for the Error backend.
|
|
///
|
|
/// We will always state that the current machine doesn't support
|
|
/// the error backend.
|
|
///
|
|
template <class DeviceAdapterTag>
|
|
class DeviceAdapterRuntimeDetector;
|
|
|
|
template <>
|
|
class DeviceAdapterRuntimeDetector<vtkm::cont::DeviceAdapterTagError>
|
|
{
|
|
public:
|
|
/// Returns false as the Error Device can never be run on.
|
|
VTKM_CONT bool Exists() const { return false; }
|
|
};
|
|
}
|
|
}
|
|
|
|
#endif //vtk_m_cont_internal_DeviceAdapterError_h
|