sanitizer_symbolizer_fuchsia.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. //===-- sanitizer_symbolizer_fuchsia.h -----------------------------------===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. //
  9. // This file is shared between various sanitizers' runtime libraries.
  10. //
  11. // Define Fuchsia's string formats and limits for the markup symbolizer.
  12. //===----------------------------------------------------------------------===//
  13. #ifndef SANITIZER_SYMBOLIZER_FUCHSIA_H
  14. #define SANITIZER_SYMBOLIZER_FUCHSIA_H
  15. #include "sanitizer_internal_defs.h"
  16. namespace __sanitizer {
  17. // See the spec at:
  18. // https://fuchsia.googlesource.com/zircon/+/master/docs/symbolizer_markup.md
  19. // This is used by UBSan for type names, and by ASan for global variable names.
  20. constexpr const char *kFormatDemangle = "{{{symbol:%s}}}";
  21. constexpr uptr kFormatDemangleMax = 1024; // Arbitrary.
  22. // Function name or equivalent from PC location.
  23. constexpr const char *kFormatFunction = "{{{pc:%p}}}";
  24. constexpr uptr kFormatFunctionMax = 64; // More than big enough for 64-bit hex.
  25. // Global variable name or equivalent from data memory address.
  26. constexpr const char *kFormatData = "{{{data:%p}}}";
  27. // One frame in a backtrace (printed on a line by itself).
  28. constexpr const char *kFormatFrame = "{{{bt:%u:%p}}}";
  29. // Dump trigger element.
  30. #define FORMAT_DUMPFILE "{{{dumpfile:%s:%s}}}"
  31. } // namespace __sanitizer
  32. #endif // SANITIZER_SYMBOLIZER_FUCHSIA_H