| //===--- Debug.cpp -------- Debug utilities ----------------------- C++ -*-===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file contains debug utilities |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include "Debug.h" |
| #include "Configuration.h" |
| #include "Interface.h" |
| #include "Mapping.h" |
| #include "Types.h" |
| |
| using namespace _OMP; |
| |
| #pragma omp declare target |
| |
| extern "C" { |
| void __assert_assume(bool condition) { __builtin_assume(condition); } |
| |
| void __assert_fail(const char *assertion, const char *file, unsigned line, |
| const char *function) { |
| PRINTF("%s:%u: %s: Assertion `%s' failed.\n", file, line, function, |
| assertion); |
| __builtin_trap(); |
| } |
| |
| #pragma omp begin declare variant match( \ |
| device = {arch(nvptx, nvptx64)}, implementation = {extension(match_any)}) |
| int32_t vprintf(const char *, void *); |
| namespace impl { |
| static int32_t omp_vprintf(const char *Format, void *Arguments, uint32_t) { |
| return vprintf(Format, Arguments); |
| } |
| } // namespace impl |
| #pragma omp end declare variant |
| |
| // We do not have a vprintf implementation for AMD GPU yet so we use a stub. |
| #pragma omp begin declare variant match(device = {arch(amdgcn)}) |
| namespace impl { |
| static int32_t omp_vprintf(const char *Format, void *Arguments, uint32_t) { |
| return -1; |
| } |
| } // namespace impl |
| #pragma omp end declare variant |
| |
| int32_t __llvm_omp_vprintf(const char *Format, void *Arguments, uint32_t Size) { |
| return impl::omp_vprintf(Format, Arguments, Size); |
| } |
| } |
| |
| /// Current indentation level for the function trace. Only accessed by thread 0. |
| __attribute__((loader_uninitialized)) |
| static uint32_t Level; |
| #pragma omp allocate(Level) allocator(omp_pteam_mem_alloc) |
| |
| DebugEntryRAII::DebugEntryRAII(const char *File, const unsigned Line, |
| const char *Function) { |
| if (config::isDebugMode(config::DebugKind::FunctionTracing) && |
| mapping::getThreadIdInBlock() == 0 && mapping::getBlockId() == 0) { |
| |
| for (int I = 0; I < Level; ++I) |
| PRINTF("%s", " "); |
| |
| PRINTF("%s:%u: Thread %u Entering %s\n", File, Line, |
| mapping::getThreadIdInBlock(), Function); |
| Level++; |
| } |
| } |
| |
| DebugEntryRAII::~DebugEntryRAII() { |
| if (config::isDebugMode(config::DebugKind::FunctionTracing) && |
| mapping::getThreadIdInBlock() == 0 && mapping::getBlockId() == 0) |
| Level--; |
| } |
| |
| void DebugEntryRAII::init() { Level = 0; } |
| |
| #pragma omp end declare target |