465c1c0287
SWDEV-102733 - [OCL-LC-ROCm] Cmake build Write CMakeLists.txt to enable building with and without the DK environment - Change the coding convention of the runtime files. Use Google's Style (https://google.github.io/styleguide/cppguide.html). Affected files ... ... //depot/stg/opencl/drivers/opencl/.clang-format#1 add ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_agent_amd.h#2 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_command.cpp#13 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_context.cpp#53 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_counter.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_d3d10.cpp#15 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_d3d11.cpp#22 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_d3d9.cpp#32 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_debugger_amd.cpp#8 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_debugger_amd.h#7 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_device.cpp#61 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_event.cpp#10 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_execute.cpp#23 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_gl.cpp#53 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_icd.cpp#27 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_icd_amd.h#18 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_kernel.h#24 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_kernel_info_amd.cpp#3 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_kernel_info_amd.h#4 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_lqdflash_amd.cpp#17 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_lqdflash_amd.h#6 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_memobj.cpp#81 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_object.cpp#3 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_pipe.cpp#6 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_platform_amd.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_platform_amd.h#2 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_profile_amd.cpp#3 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_profile_amd.h#2 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_program.cpp#41 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_sampler.cpp#6 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_sdi_amd.cpp#3 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_sdi_amd.h#2 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_semaphore_amd.h#3 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_svm.cpp#20 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_thread_trace_amd.cpp#8 edit ... //depot/stg/opencl/drivers/opencl/api/opencl/amdocl/cl_thread_trace_amd.h#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/appprofile.cpp#17 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/appprofile.hpp#12 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/blit.cpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/blit.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/blitcl.cpp#11 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpubinary.cpp#11 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpubinary.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpubuiltins.cpp#13 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpubuiltins.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpucommand.cpp#66 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpucommand.hpp#40 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpudevice.cpp#280 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpudevice.hpp#96 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpufeat.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpukernel.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpumapping.cpp#6 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpumapping.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpuprogram.cpp#70 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpuprogram.hpp#14 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpusettings.cpp#33 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpusettings.hpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cputables.hpp#5 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpuvirtual.cpp#26 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/cpu/cpuvirtual.hpp#13 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/device.cpp#209 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/device.hpp#284 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuappprofile.cpp#12 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuappprofile.hpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpubinary.cpp#58 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpubinary.hpp#27 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpublit.cpp#126 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpublit.hpp#41 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpucompiler.cpp#156 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuconstbuf.cpp#10 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuconstbuf.hpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpucounters.cpp#12 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpucounters.hpp#9 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpudebugger.hpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpudebugmanager.cpp#10 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpudebugmanager.hpp#6 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpudefs.hpp#147 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpudevice.cpp#567 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpudevice.hpp#163 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpukernel.cpp#318 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpukernel.hpp#126 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpumemory.cpp#131 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpumemory.hpp#50 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuprintf.cpp#44 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuprintf.hpp#15 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuprogram.cpp#232 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuprogram.hpp#69 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuresource.cpp#238 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuresource.hpp#87 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpusched.hpp#19 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuschedcl.cpp#35 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuscsi.cpp#37 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpusettings.cpp#350 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpusettings.hpp#98 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gputhreadtrace.cpp#9 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gputhreadtrace.hpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gputimestamp.cpp#27 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gputimestamp.hpp#16 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gputrap.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuvirtual.cpp#410 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuvirtual.hpp#140 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuwavelimiter.cpp#13 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/gpu/gpuwavelimiter.hpp#9 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/hwdebug.cpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/hwdebug.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palappprofile.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palappprofile.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palbinary.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palbinary.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palblit.cpp#13 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palblit.hpp#5 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palcompiler.cpp#15 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palconstbuf.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palconstbuf.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palcounters.cpp#11 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palcounters.hpp#9 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldebugger.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldebugmanager.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldebugmanager.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldefs.hpp#16 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldevice.cpp#45 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldevice.hpp#16 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldeviced3d10.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldeviced3d11.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldeviced3d9.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paldevicegl.cpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palkernel.cpp#34 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palkernel.hpp#11 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palmemory.cpp#13 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palmemory.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palprintf.cpp#5 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palprintf.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palprogram.cpp#39 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palprogram.hpp#17 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palresource.cpp#28 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palresource.hpp#12 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palsched.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palschedcl.cpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palsettings.cpp#24 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palsettings.hpp#10 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palthreadtrace.cpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palthreadtrace.hpp#5 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paltimestamp.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paltimestamp.hpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/paltrap.hpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palvirtual.cpp#48 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palvirtual.hpp#21 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palwavelimiter.cpp#3 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/pal/palwavelimiter.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/mesa_glinterop.h#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocappprofile.cpp#6 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocappprofile.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocbinary.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocblit.cpp#17 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocblit.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/roccompiler.cpp#32 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/roccompilerlib.cpp#6 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/roccompilerlib.hpp#5 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocdefs.hpp#10 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocdevice.cpp#48 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocdevice.hpp#20 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocglinterop.cpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocglinterop.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rockernel.cpp#22 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rockernel.hpp#16 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocmemory.cpp#15 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocmemory.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocprintf.cpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocprintf.hpp#5 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocprogram.cpp#64 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocprogram.hpp#23 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocregisters.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocsettings.cpp#17 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocsettings.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocvirtual.cpp#34 edit ... //depot/stg/opencl/drivers/opencl/runtime/device/rocm/rocvirtual.hpp#10 edit ... //depot/stg/opencl/drivers/opencl/runtime/os/alloc.cpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/os/alloc.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/os/os.cpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/os/os.hpp#30 edit ... //depot/stg/opencl/drivers/opencl/runtime/os/os_posix.cpp#42 edit ... //depot/stg/opencl/drivers/opencl/runtime/os/os_win32.cpp#47 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/agent.cpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/agent.hpp#6 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/command.cpp#78 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/command.hpp#83 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/commandqueue.cpp#23 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/commandqueue.hpp#18 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/context.cpp#42 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/context.hpp#26 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/counter.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/interop.hpp#12 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/kernel.cpp#23 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/kernel.hpp#18 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/memory.cpp#127 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/memory.hpp#100 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/ndrange.cpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/ndrange.hpp#9 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/object.cpp#2 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/object.hpp#17 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/perfctr.hpp#5 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/program.cpp#86 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/program.hpp#41 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/runtime.cpp#35 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/runtime.hpp#4 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/sampler.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/platform/threadtrace.hpp#6 edit ... //depot/stg/opencl/drivers/opencl/runtime/thread/atomic.hpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/thread/monitor.cpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/thread/monitor.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/thread/semaphore.cpp#10 edit ... //depot/stg/opencl/drivers/opencl/runtime/thread/semaphore.hpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/thread/thread.cpp#14 edit ... //depot/stg/opencl/drivers/opencl/runtime/thread/thread.hpp#15 edit ... //depot/stg/opencl/drivers/opencl/runtime/top.hpp#26 edit ... //depot/stg/opencl/drivers/opencl/runtime/utils/concurrent.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/utils/debug.cpp#5 edit ... //depot/stg/opencl/drivers/opencl/runtime/utils/debug.hpp#7 edit ... //depot/stg/opencl/drivers/opencl/runtime/utils/flags.cpp#16 edit ... //depot/stg/opencl/drivers/opencl/runtime/utils/flags.hpp#271 edit ... //depot/stg/opencl/drivers/opencl/runtime/utils/macros.hpp#8 edit ... //depot/stg/opencl/drivers/opencl/runtime/utils/util.hpp#12 edit ... //depot/stg/opencl/drivers/opencl/runtime/utils/versions.hpp#2150 edit
638 řádky
20 KiB
C++
638 řádky
20 KiB
C++
//
|
|
// Copyright (c) 2008 Advanced Micro Devices, Inc. All rights reserved.
|
|
//
|
|
#include "top.hpp"
|
|
#include "device/appprofile.hpp"
|
|
#include "platform/program.hpp"
|
|
#include "platform/context.hpp"
|
|
#include "utils/options.hpp"
|
|
#include "utils/libUtils.h"
|
|
#include "utils/bif_section_labels.hpp"
|
|
#include "acl.h"
|
|
|
|
#include <cstdlib> // for malloc
|
|
#include <cstring> // for strcmp
|
|
#include <sstream>
|
|
#include <fstream>
|
|
#include <iostream>
|
|
#include <utility>
|
|
|
|
namespace amd {
|
|
|
|
Program::~Program() {
|
|
// Destroy all device programs
|
|
deviceprograms_t::const_iterator it, itEnd;
|
|
for (it = devicePrograms_.begin(), itEnd = devicePrograms_.end(); it != itEnd; ++it) {
|
|
delete it->second;
|
|
}
|
|
|
|
for (devicebinary_t::const_iterator IT = binary_.begin(), IE = binary_.end(); IT != IE; ++IT) {
|
|
const binary_t& Bin = IT->second;
|
|
if (Bin.first) {
|
|
delete[] Bin.first;
|
|
}
|
|
}
|
|
|
|
delete symbolTable_;
|
|
//! @todo Make sure we have destroyed all CPU specific objects
|
|
}
|
|
|
|
const Symbol* Program::findSymbol(const char* kernelName) const {
|
|
symbols_t::const_iterator it = symbolTable_->find(kernelName);
|
|
return (it == symbolTable_->end()) ? NULL : &it->second;
|
|
}
|
|
|
|
cl_int Program::addDeviceProgram(Device& device, const void* image, size_t length,
|
|
amd::option::Options* options) {
|
|
#if defined(WITH_LIGHTNING_COMPILER)
|
|
// LC binary must be in ELF format
|
|
if (image != NULL && !amd::isElfMagic((const char*)image)) {
|
|
return CL_INVALID_BINARY;
|
|
}
|
|
#else // !defined(WITH_LIGHTNING_COMPILER)
|
|
if (image != NULL &&
|
|
!aclValidateBinaryImage(image, length,
|
|
isSPIRV_ ? BINARY_TYPE_SPIRV : BINARY_TYPE_ELF | BINARY_TYPE_LLVM)) {
|
|
return CL_INVALID_BINARY;
|
|
}
|
|
#endif // !defined(WITH_LIGHTNING_COMPILER)
|
|
|
|
// Check if the device is already associated with this program
|
|
if (deviceList_.find(&device) != deviceList_.end()) {
|
|
return CL_INVALID_VALUE;
|
|
}
|
|
|
|
Device& rootDev = device.rootDevice();
|
|
|
|
// if the rootDev is already associated with a program
|
|
if (devicePrograms_[&rootDev] != NULL) {
|
|
return CL_SUCCESS;
|
|
}
|
|
bool emptyOptions = false;
|
|
amd::option::Options emptyOpts;
|
|
if (options == NULL) {
|
|
options = &emptyOpts;
|
|
emptyOptions = true;
|
|
}
|
|
|
|
#if !defined(WITH_LIGHTNING_COMPILER)
|
|
if (image != NULL && length != 0 && aclValidateBinaryImage(image, length, BINARY_TYPE_ELF)) {
|
|
acl_error errorCode;
|
|
aclBinary* binary = aclReadFromMem(image, length, &errorCode);
|
|
if (errorCode != ACL_SUCCESS) {
|
|
return CL_INVALID_BINARY;
|
|
}
|
|
const oclBIFSymbolStruct* symbol = findBIF30SymStruct(symOpenclCompilerOptions);
|
|
assert(symbol && "symbol not found");
|
|
std::string symName = std::string(symbol->str[bif::PRE]) + std::string(symbol->str[bif::POST]);
|
|
size_t symSize = 0;
|
|
const void* opts = aclExtractSymbol(device.compiler(), binary, &symSize, aclCOMMENT,
|
|
symName.c_str(), &errorCode);
|
|
// if we have options from binary and input options was not specified
|
|
if (opts != NULL && emptyOptions) {
|
|
std::string sBinOptions = std::string((char*)opts, symSize);
|
|
if (!amd::option::parseAllOptions(sBinOptions, *options)) {
|
|
programLog_ = options->optionsLog();
|
|
LogError("Parsing compilation options from binary failed.");
|
|
return CL_INVALID_COMPILER_OPTIONS;
|
|
}
|
|
}
|
|
options->oVariables->Legacy = isAMDILTarget(*aclutGetTargetInfo(binary));
|
|
aclBinaryFini(binary);
|
|
}
|
|
#endif // !defined(WITH_LIGHTNING_COMPILER)
|
|
options->oVariables->BinaryIsSpirv = isSPIRV_;
|
|
device::Program* program = rootDev.createProgram(options);
|
|
if (program == NULL) {
|
|
return CL_OUT_OF_HOST_MEMORY;
|
|
}
|
|
|
|
if (image != NULL) {
|
|
uint8_t* memory = binary(rootDev).first;
|
|
// clone 'binary' (it is owned by the host thread).
|
|
if (memory == NULL) {
|
|
memory = new (std::nothrow) uint8_t[length];
|
|
if (memory == NULL) {
|
|
delete program;
|
|
return CL_OUT_OF_HOST_MEMORY;
|
|
}
|
|
|
|
::memcpy(memory, image, length);
|
|
|
|
// Save the original image
|
|
binary_[&rootDev] = std::make_pair(memory, length);
|
|
}
|
|
|
|
if (!program->setBinary(reinterpret_cast<char*>(memory), length)) {
|
|
delete program;
|
|
return CL_INVALID_BINARY;
|
|
}
|
|
|
|
#if defined(WITH_LIGHTNING_COMPILER)
|
|
// load the compiler options from the binary if it is not provided
|
|
std::string sBinOptions = program->compileOptions();
|
|
if (!sBinOptions.empty() && emptyOptions) {
|
|
if (!amd::option::parseAllOptions(sBinOptions, *options)) {
|
|
programLog_ = options->optionsLog();
|
|
LogError("Parsing compilation options from binary failed.");
|
|
return CL_INVALID_COMPILER_OPTIONS;
|
|
}
|
|
}
|
|
#endif
|
|
}
|
|
|
|
devicePrograms_[&rootDev] = program;
|
|
|
|
deviceList_.insert(&device);
|
|
return CL_SUCCESS;
|
|
}
|
|
|
|
device::Program* Program::getDeviceProgram(const Device& device) const {
|
|
deviceprograms_t::const_iterator it = devicePrograms_.find(&device.rootDevice());
|
|
if (it == devicePrograms_.end()) {
|
|
return NULL;
|
|
}
|
|
return it->second;
|
|
}
|
|
|
|
Monitor Program::buildLock_("OCL build program", true);
|
|
|
|
cl_int Program::compile(const std::vector<Device*>& devices, size_t numHeaders,
|
|
const std::vector<const Program*>& headerPrograms,
|
|
const char** headerIncludeNames, const char* options,
|
|
void(CL_CALLBACK* notifyFptr)(cl_program, void*), void* data,
|
|
bool optionChangable) {
|
|
ScopedLock sl(buildLock_);
|
|
|
|
cl_int retval = CL_SUCCESS;
|
|
|
|
// Clear the program object
|
|
clear();
|
|
|
|
// Process build options.
|
|
std::string cppstr(options ? options : "");
|
|
|
|
// if there is a -ignore-env, adjust options.
|
|
if (cppstr.size() > 0) {
|
|
// Set the options to be the string after -ignore-env
|
|
size_t pos = cppstr.find("-ignore-env");
|
|
if (pos != std::string::npos) {
|
|
cppstr = cppstr.substr(pos + sizeof("-ignore-env"));
|
|
optionChangable = false;
|
|
}
|
|
}
|
|
option::Options parsedOptions;
|
|
if (!ParseAllOptions(cppstr, parsedOptions, optionChangable)) {
|
|
programLog_ = parsedOptions.optionsLog();
|
|
LogError("Parsing compile options failed.");
|
|
return CL_INVALID_COMPILER_OPTIONS;
|
|
}
|
|
|
|
std::vector<const std::string*> headers(numHeaders);
|
|
for (size_t i = 0; i < numHeaders; ++i) {
|
|
const std::string& header = headerPrograms[i]->sourceCode();
|
|
headers[i] = &header;
|
|
}
|
|
|
|
// Compile the program programs associated with the given devices.
|
|
std::vector<Device*>::const_iterator it;
|
|
for (it = devices.begin(); it != devices.end(); ++it) {
|
|
device::Program* devProgram = getDeviceProgram(**it);
|
|
if (devProgram == NULL) {
|
|
const binary_t& bin = binary(**it);
|
|
retval = addDeviceProgram(**it, bin.first, bin.second, &parsedOptions);
|
|
if (retval != CL_SUCCESS) {
|
|
return retval;
|
|
}
|
|
devProgram = getDeviceProgram(**it);
|
|
}
|
|
|
|
if (devProgram->type() == device::Program::TYPE_INTERMEDIATE || isSPIRV_) {
|
|
continue;
|
|
}
|
|
// We only build a Device-Program once
|
|
if (devProgram->buildStatus() != CL_BUILD_NONE) {
|
|
continue;
|
|
}
|
|
if (sourceCode_.empty()) {
|
|
return CL_INVALID_OPERATION;
|
|
}
|
|
cl_int result =
|
|
devProgram->compile(sourceCode_, headers, headerIncludeNames, options, &parsedOptions);
|
|
|
|
// Check if the previous device failed a build
|
|
if ((result != CL_SUCCESS) && (retval != CL_SUCCESS)) {
|
|
retval = CL_INVALID_OPERATION;
|
|
}
|
|
// Update the returned value with a build error
|
|
else if (result != CL_SUCCESS) {
|
|
retval = result;
|
|
}
|
|
}
|
|
|
|
if (notifyFptr != NULL) {
|
|
notifyFptr(as_cl(this), data);
|
|
}
|
|
|
|
return retval;
|
|
}
|
|
|
|
cl_int Program::link(const std::vector<Device*>& devices, size_t numInputs,
|
|
const std::vector<Program*>& inputPrograms, const char* options,
|
|
void(CL_CALLBACK* notifyFptr)(cl_program, void*), void* data,
|
|
bool optionChangable) {
|
|
ScopedLock sl(buildLock_);
|
|
cl_int retval = CL_SUCCESS;
|
|
|
|
if (symbolTable_ == NULL) {
|
|
symbolTable_ = new symbols_t;
|
|
if (symbolTable_ == NULL) {
|
|
return CL_OUT_OF_HOST_MEMORY;
|
|
}
|
|
}
|
|
|
|
// Clear the program object
|
|
clear();
|
|
|
|
// Process build options.
|
|
std::string cppstr(options ? options : "");
|
|
|
|
// if there is a -ignore-env, adjust options.
|
|
if (cppstr.size() > 0) {
|
|
// Set the options to be the string after -ignore-env
|
|
size_t pos = cppstr.find("-ignore-env");
|
|
if (pos != std::string::npos) {
|
|
cppstr = cppstr.substr(pos + sizeof("-ignore-env"));
|
|
optionChangable = false;
|
|
}
|
|
}
|
|
option::Options parsedOptions;
|
|
if (!ParseAllOptions(cppstr, parsedOptions, optionChangable, true)) {
|
|
programLog_ = parsedOptions.optionsLog();
|
|
LogError("Parsing link options failed.");
|
|
return CL_INVALID_LINKER_OPTIONS;
|
|
}
|
|
|
|
// Link the program programs associated with the given devices.
|
|
std::vector<Device*>::const_iterator it;
|
|
for (it = devices.begin(); it != devices.end(); ++it) {
|
|
// find the corresponding device program in each input program
|
|
std::vector<device::Program*> inputDevPrograms(numInputs);
|
|
bool found = false;
|
|
for (size_t i = 0; i < numInputs; ++i) {
|
|
Program& inputProgram = *inputPrograms[i];
|
|
if (inputProgram.isSPIRV_) {
|
|
parsedOptions.oVariables->BinaryIsSpirv = inputProgram.isSPIRV_;
|
|
}
|
|
deviceprograms_t inputDevProgs = inputProgram.devicePrograms();
|
|
deviceprograms_t::const_iterator findIt = inputDevProgs.find(*it);
|
|
if (findIt == inputDevProgs.end()) {
|
|
if (found) break;
|
|
continue;
|
|
}
|
|
inputDevPrograms[i] = findIt->second;
|
|
device::Program::binary_t binary = inputDevPrograms[i]->binary();
|
|
// Check the binary's target for the first found device program.
|
|
// TODO: Revise these binary's target checks
|
|
// and possibly remove them after switching to HSAIL by default.
|
|
#if !defined(WITH_LIGHTNING_COMPILER)
|
|
if (!found && binary.first != NULL && binary.second > 0) {
|
|
acl_error errorCode = ACL_SUCCESS;
|
|
void* mem = const_cast<void*>(binary.first);
|
|
aclBinary* aclBin = aclReadFromMem(mem, binary.second, &errorCode);
|
|
if (errorCode != ACL_SUCCESS) {
|
|
LogWarning("Error while linking: Could not read from raw binary.");
|
|
return CL_INVALID_BINARY;
|
|
}
|
|
if (isHSAILTarget(*aclutGetTargetInfo(aclBin))) {
|
|
parsedOptions.oVariables->Frontend = "clang";
|
|
} else if (isAMDILTarget(*aclutGetTargetInfo(aclBin))) {
|
|
parsedOptions.oVariables->Frontend = "edg";
|
|
}
|
|
aclBinaryFini(aclBin);
|
|
}
|
|
#endif // !defined(WITH_LIGHTNING_COMPILER)
|
|
found = true;
|
|
}
|
|
if (inputDevPrograms.size() == 0) {
|
|
continue;
|
|
}
|
|
if (inputDevPrograms.size() < numInputs) {
|
|
return CL_INVALID_VALUE;
|
|
}
|
|
|
|
device::Program* devProgram = getDeviceProgram(**it);
|
|
if (devProgram == NULL) {
|
|
const binary_t& bin = binary(**it);
|
|
retval = addDeviceProgram(**it, bin.first, bin.second, &parsedOptions);
|
|
if (retval != CL_SUCCESS) {
|
|
return retval;
|
|
}
|
|
devProgram = getDeviceProgram(**it);
|
|
}
|
|
|
|
// We only build a Device-Program once
|
|
if (devProgram->buildStatus() != CL_BUILD_NONE) {
|
|
continue;
|
|
}
|
|
cl_int result = devProgram->link(inputDevPrograms, options, &parsedOptions);
|
|
|
|
// Check if the previous device failed a build
|
|
if ((result != CL_SUCCESS) && (retval != CL_SUCCESS)) {
|
|
retval = CL_INVALID_OPERATION;
|
|
}
|
|
// Update the returned value with a build error
|
|
else if (result != CL_SUCCESS) {
|
|
retval = result;
|
|
}
|
|
}
|
|
|
|
if (retval != CL_SUCCESS) {
|
|
return retval;
|
|
}
|
|
|
|
// Rebuild the symbol table
|
|
deviceprograms_t::iterator sit;
|
|
for (sit = devicePrograms_.begin(); sit != devicePrograms_.end(); ++sit) {
|
|
const Device& device = *sit->first;
|
|
const device::Program& program = *sit->second;
|
|
|
|
const device::Program::kernels_t& kernels = program.kernels();
|
|
device::Program::kernels_t::const_iterator kit;
|
|
for (kit = kernels.begin(); kit != kernels.end(); ++kit) {
|
|
const std::string& name = kit->first;
|
|
const device::Kernel* devKernel = kit->second;
|
|
|
|
Symbol& symbol = (*symbolTable_)[name];
|
|
if (!symbol.setDeviceKernel(device, devKernel)) {
|
|
retval = CL_LINK_PROGRAM_FAILURE;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Create a string with all kernel names from the program
|
|
if (kernelNames_.length() == 0) {
|
|
amd::Program::symbols_t::const_iterator it;
|
|
for (it = symbols().begin(); it != symbols().end(); ++it) {
|
|
if (it != symbols().begin()) {
|
|
kernelNames_.append(1, ';');
|
|
}
|
|
kernelNames_.append(it->first.c_str());
|
|
}
|
|
}
|
|
|
|
if (notifyFptr != NULL) {
|
|
notifyFptr(as_cl(this), data);
|
|
}
|
|
|
|
return retval;
|
|
}
|
|
|
|
void Program::StubProgramSource(const std::string& app_name) {
|
|
static uint program_counter = 0;
|
|
std::fstream stub_read;
|
|
std::stringstream file_name;
|
|
std::string app_name_no_ext;
|
|
|
|
std::size_t length = app_name.rfind(".exe");
|
|
if (length == std::string::npos) {
|
|
length = app_name.size();
|
|
}
|
|
app_name_no_ext.assign(app_name.c_str(), length);
|
|
|
|
// Construct a unique file name for the CL program
|
|
file_name << app_name_no_ext << "_program_" << program_counter << ".cl";
|
|
|
|
stub_read.open(file_name.str().c_str(), (std::fstream::in | std::fstream::binary));
|
|
// Check if we have OpenCL program
|
|
if (stub_read.is_open()) {
|
|
// Find the stream size
|
|
stub_read.seekg(0, std::fstream::end);
|
|
size_t size = stub_read.tellg();
|
|
stub_read.seekg(0, std::ios::beg);
|
|
|
|
char* data = new char[size];
|
|
stub_read.read(data, size);
|
|
stub_read.close();
|
|
|
|
sourceCode_.assign(data, size);
|
|
delete[] data;
|
|
} else {
|
|
std::fstream stub_write;
|
|
stub_write.open(file_name.str().c_str(), (std::fstream::out | std::fstream::binary));
|
|
stub_write << sourceCode_;
|
|
stub_write.close();
|
|
}
|
|
program_counter++;
|
|
}
|
|
|
|
cl_int Program::build(const std::vector<Device*>& devices, const char* options,
|
|
void(CL_CALLBACK* notifyFptr)(cl_program, void*), void* data,
|
|
bool optionChangable) {
|
|
ScopedLock sl(buildLock_);
|
|
cl_int retval = CL_SUCCESS;
|
|
|
|
if (symbolTable_ == NULL) {
|
|
symbolTable_ = new symbols_t;
|
|
if (symbolTable_ == NULL) {
|
|
return CL_OUT_OF_HOST_MEMORY;
|
|
}
|
|
}
|
|
|
|
if (OCL_STUB_PROGRAMS && !sourceCode_.empty()) {
|
|
// The app name should be the samme for all device
|
|
StubProgramSource(devices[0]->appProfile()->appFileName());
|
|
}
|
|
|
|
// Clear the program object
|
|
clear();
|
|
|
|
// Process build options.
|
|
std::string cppstr(options ? options : "");
|
|
|
|
// if there is a -ignore-env, adjust options.
|
|
if (cppstr.size() > 0) {
|
|
// Set the options to be the string after -ignore-env
|
|
size_t pos = cppstr.find("-ignore-env");
|
|
if (pos != std::string::npos) {
|
|
cppstr = cppstr.substr(pos + sizeof("-ignore-env"));
|
|
optionChangable = false;
|
|
}
|
|
}
|
|
option::Options parsedOptions;
|
|
if (!ParseAllOptions(cppstr, parsedOptions, optionChangable)) {
|
|
programLog_ = parsedOptions.optionsLog();
|
|
LogError("Parsing compile options failed.");
|
|
return CL_INVALID_COMPILER_OPTIONS;
|
|
}
|
|
|
|
// Build the program programs associated with the given devices.
|
|
std::vector<Device*>::const_iterator it;
|
|
for (it = devices.begin(); it != devices.end(); ++it) {
|
|
device::Program* devProgram = getDeviceProgram(**it);
|
|
if (devProgram == NULL) {
|
|
const binary_t& bin = binary(**it);
|
|
if (sourceCode_.empty() && (bin.first == NULL)) {
|
|
retval = false;
|
|
continue;
|
|
}
|
|
retval = addDeviceProgram(**it, bin.first, bin.second, &parsedOptions);
|
|
if (retval != CL_SUCCESS) {
|
|
return retval;
|
|
}
|
|
devProgram = getDeviceProgram(**it);
|
|
}
|
|
|
|
parsedOptions.oVariables->AssumeAlias = true;
|
|
|
|
// We only build a Device-Program once
|
|
if (devProgram->buildStatus() != CL_BUILD_NONE) {
|
|
continue;
|
|
}
|
|
cl_int result = devProgram->build(sourceCode_, options, &parsedOptions);
|
|
|
|
// Check if the previous device failed a build
|
|
if ((result != CL_SUCCESS) && (retval != CL_SUCCESS)) {
|
|
retval = CL_INVALID_OPERATION;
|
|
}
|
|
// Update the returned value with a build error
|
|
else if (result != CL_SUCCESS) {
|
|
retval = result;
|
|
}
|
|
}
|
|
|
|
if (retval != CL_SUCCESS) {
|
|
return retval;
|
|
}
|
|
|
|
// Rebuild the symbol table
|
|
deviceprograms_t::iterator sit;
|
|
for (sit = devicePrograms_.begin(); sit != devicePrograms_.end(); ++sit) {
|
|
const Device& device = *sit->first;
|
|
const device::Program& program = *sit->second;
|
|
|
|
const device::Program::kernels_t& kernels = program.kernels();
|
|
device::Program::kernels_t::const_iterator kit;
|
|
for (kit = kernels.begin(); kit != kernels.end(); ++kit) {
|
|
const std::string& name = kit->first;
|
|
const device::Kernel* devKernel = kit->second;
|
|
|
|
Symbol& symbol = (*symbolTable_)[name];
|
|
if (!symbol.setDeviceKernel(device, devKernel)) {
|
|
retval = CL_BUILD_PROGRAM_FAILURE;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Create a string with all kernel names from the program
|
|
if (kernelNames_.length() == 0) {
|
|
amd::Program::symbols_t::const_iterator it;
|
|
for (it = symbols().begin(); it != symbols().end(); ++it) {
|
|
if (it != symbols().begin()) {
|
|
kernelNames_.append(1, ';');
|
|
}
|
|
kernelNames_.append(it->first.c_str());
|
|
}
|
|
}
|
|
|
|
if (notifyFptr != NULL) {
|
|
notifyFptr(as_cl(this), data);
|
|
}
|
|
|
|
return retval;
|
|
}
|
|
|
|
void Program::clear() {
|
|
deviceprograms_t::iterator sit;
|
|
|
|
// Destroy old programs if we have any
|
|
for (sit = devicePrograms_.begin(); sit != devicePrograms_.end(); ++sit) {
|
|
// Destroy device program
|
|
delete sit->second;
|
|
}
|
|
|
|
devicePrograms_.clear();
|
|
deviceList_.clear();
|
|
if (symbolTable_) symbolTable_->clear();
|
|
kernelNames_.clear();
|
|
}
|
|
|
|
int Program::GetOclCVersion(const char* clVer) {
|
|
// default version
|
|
int version = 12;
|
|
if (clVer == NULL) {
|
|
return version;
|
|
}
|
|
std::string clStd(clVer);
|
|
if (clStd.size() != 5) {
|
|
return version;
|
|
}
|
|
clStd.erase(0, 2);
|
|
clStd.erase(1, 1);
|
|
return std::stoi(clStd);
|
|
}
|
|
|
|
bool Program::ParseAllOptions(const std::string& options, option::Options& parsedOptions,
|
|
bool optionChangable, bool linkOptsOnly) {
|
|
std::string allOpts = options;
|
|
if (optionChangable) {
|
|
if (linkOptsOnly) {
|
|
if (AMD_OCL_LINK_OPTIONS != NULL) {
|
|
allOpts.append(" ");
|
|
allOpts.append(AMD_OCL_LINK_OPTIONS);
|
|
}
|
|
if (AMD_OCL_LINK_OPTIONS_APPEND != NULL) {
|
|
allOpts.append(" ");
|
|
allOpts.append(AMD_OCL_LINK_OPTIONS_APPEND);
|
|
}
|
|
} else {
|
|
if (AMD_OCL_BUILD_OPTIONS != NULL) {
|
|
allOpts.append(" ");
|
|
allOpts.append(AMD_OCL_BUILD_OPTIONS);
|
|
}
|
|
if (!Device::appProfile()->GetBuildOptsAppend().empty()) {
|
|
allOpts.append(" ");
|
|
allOpts.append(Device::appProfile()->GetBuildOptsAppend());
|
|
}
|
|
if (AMD_OCL_BUILD_OPTIONS_APPEND != NULL) {
|
|
allOpts.append(" ");
|
|
allOpts.append(AMD_OCL_BUILD_OPTIONS_APPEND);
|
|
}
|
|
}
|
|
}
|
|
return amd::option::parseAllOptions(allOpts, parsedOptions, linkOptsOnly);
|
|
}
|
|
|
|
bool Symbol::setDeviceKernel(const Device& device, const device::Kernel* func, bool noAlias) {
|
|
// FIXME_lmoriche: check that the signatures are compatible
|
|
if (deviceKernels_.size() == 0 || device.type() == CL_DEVICE_TYPE_CPU) {
|
|
signature_ = func->signature();
|
|
}
|
|
|
|
if (noAlias) {
|
|
deviceKernels_[&device] = func;
|
|
} else {
|
|
devKernelsNoOpt_[&device] = func;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
const device::Kernel* Symbol::getDeviceKernel(const Device& device, bool noAlias) const {
|
|
const devicekernels_t* devKernels = (noAlias) ? &deviceKernels_ : &devKernelsNoOpt_;
|
|
devicekernels_t::const_iterator itEnd = devKernels->end();
|
|
devicekernels_t::const_iterator it = devKernels->find(&device);
|
|
if (it != itEnd) {
|
|
return it->second;
|
|
}
|
|
|
|
for (it = devKernels->begin(); it != itEnd; ++it) {
|
|
if (it->first->isAncestor(&device)) {
|
|
return it->second;
|
|
}
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
} // namespace amd
|