37#include "llvm/Config/config.h"
51#include BACKTRACE_HEADER
60#include <mach-o/dyld.h>
62#if __has_include(<link.h>)
65#ifdef HAVE__UNWIND_BACKTRACE
73#undef HAVE__UNWIND_BACKTRACE
76#if ENABLE_BACKTRACES && defined(__MVS__)
82#include <sys/syscall.h>
87static void SignalHandler(
int Sig, siginfo_t *Info,
void *Context);
88static void SignalHandlerTerminate(
int Sig, siginfo_t *Info,
void *Context);
89static void InfoSignalHandler(
int Sig);
90static void InfoSignalHandlerTerminate(
int Sig);
92using SignalHandlerFunctionType = void (*)();
94static std::atomic<SignalHandlerFunctionType> InterruptFunction =
nullptr;
95static std::atomic<SignalHandlerFunctionType> InfoSignalFunction =
nullptr;
97static std::atomic<SignalHandlerFunctionType> OneShotPipeSignalFunction =
105class FileToRemoveList {
106 std::atomic<char *>
Filename =
nullptr;
107 std::atomic<FileToRemoveList *>
Next =
nullptr;
109 FileToRemoveList() =
default;
111 FileToRemoveList(
const std::string &str) :
Filename(strdup(str.
c_str())) {}
115 ~FileToRemoveList() {
116 if (FileToRemoveList *
N =
Next.exchange(
nullptr))
118 if (
char *
F =
Filename.exchange(
nullptr))
123 static void insert(std::atomic<FileToRemoveList *> &Head,
126 FileToRemoveList *NewHead =
new FileToRemoveList(
Filename);
127 std::atomic<FileToRemoveList *> *InsertionPoint = &Head;
128 FileToRemoveList *OldHead =
nullptr;
129 while (!InsertionPoint->compare_exchange_strong(OldHead, NewHead)) {
130 InsertionPoint = &OldHead->Next;
136 static void erase(std::atomic<FileToRemoveList *> &Head,
140 static ManagedStatic<sys::SmartMutex<true>> Lock;
141 sys::SmartScopedLock<true> Writer(*Lock);
143 for (FileToRemoveList *Current = Head.load(); Current;
144 Current = Current->Next.load()) {
145 if (
char *OldFilename = Current->Filename.load()) {
149 OldFilename = Current->Filename.exchange(
nullptr);
158 static void removeFile(
char *path) {
162 if (stat(path, &buf) != 0)
168 if (!S_ISREG(buf.st_mode))
177 static void removeAllFiles(std::atomic<FileToRemoveList *> &Head) {
182 FileToRemoveList *OldHead = Head.exchange(
nullptr);
184 for (FileToRemoveList *currentFile = OldHead; currentFile;
185 currentFile = currentFile->Next.load()) {
188 if (
char *path = currentFile->Filename.exchange(
nullptr)) {
192 currentFile->Filename.exchange(path);
197 Head.exchange(OldHead);
200static std::atomic<FileToRemoveList *> FilesToRemove =
nullptr;
205struct FilesToRemoveCleanup {
207 ~FilesToRemoveCleanup() {
208 FileToRemoveList *Head = FilesToRemove.exchange(
nullptr);
220static const int IntSigs[] = {SIGHUP, SIGINT, SIGTERM, SIGUSR2};
224static const int KillSigs[] = {SIGILL,
250static const int InfoSigs[] = {SIGUSR1
257static const size_t NumSigs = std::size(IntSigs) + std::size(KillSigs) +
258 std::size(InfoSigs) + 1 ;
260static std::atomic<unsigned> NumRegisteredSignals = 0;
264} RegisteredSignalInfo[NumSigs];
266#if defined(HAVE_SIGALTSTACK)
271static stack_t OldAltStack;
274static void CreateSigAltStack() {
275 const size_t AltStackSize = MINSIGSTKSZ + 64 * 1024;
281 if (sigaltstack(
nullptr, &OldAltStack) != 0 ||
282 OldAltStack.ss_flags & SS_ONSTACK ||
283 (OldAltStack.ss_sp && OldAltStack.ss_size >= AltStackSize))
286 stack_t AltStack = {};
287 AltStack.ss_sp =
static_cast<char *
>(
safe_malloc(AltStackSize));
288 NewAltStackPointer = AltStack.ss_sp;
289 AltStack.ss_size = AltStackSize;
290 if (sigaltstack(&AltStack, &OldAltStack) != 0)
291 free(AltStack.ss_sp);
294static void CreateSigAltStack() {}
297static void RegisterHandlers(
298 bool NeedsPOSIXUtilitySignalHandling =
false) {
306 if (NumRegisteredSignals.load() != 0)
313 enum class SignalKind { IsKill, IsInfo };
314 auto registerHandler = [&](
int Signal, SignalKind Kind) {
315 unsigned Index = NumRegisteredSignals.load();
316 assert(Index < std::size(RegisteredSignalInfo) &&
317 "Out of space for signal handlers!");
319 struct sigaction NewHandler;
322 case SignalKind::IsKill:
323 if (NeedsPOSIXUtilitySignalHandling)
326 NewHandler.sa_sigaction = SignalHandlerTerminate;
328 NewHandler.sa_sigaction = SignalHandler;
329 NewHandler.sa_flags = SA_NODEFER | SA_RESETHAND | SA_ONSTACK | SA_SIGINFO;
331 case SignalKind::IsInfo:
332 if (NeedsPOSIXUtilitySignalHandling)
335 NewHandler.sa_handler = InfoSignalHandlerTerminate;
337 NewHandler.sa_handler = InfoSignalHandler;
338 NewHandler.sa_flags = SA_ONSTACK;
341 sigemptyset(&NewHandler.sa_mask);
343 if (NeedsPOSIXUtilitySignalHandling) {
345 struct sigaction act;
346 if (sigaction(Signal, NULL, &act) == 0 && act.sa_handler != SIG_IGN)
347 sigaction(Signal, &NewHandler, &RegisteredSignalInfo[Index].SA);
349 sigaction(Signal, &NewHandler, &RegisteredSignalInfo[Index].SA);
351 RegisteredSignalInfo[Index].SigNo = Signal;
352 ++NumRegisteredSignals;
355 for (
auto S : IntSigs)
356 registerHandler(S, SignalKind::IsKill);
357 for (
auto S : KillSigs)
358 registerHandler(S, SignalKind::IsKill);
359 if (OneShotPipeSignalFunction)
360 registerHandler(SIGPIPE, SignalKind::IsKill);
361 for (
auto S : InfoSigs)
362 registerHandler(S, SignalKind::IsInfo);
367 for (
unsigned i = 0, e = NumRegisteredSignals.load(); i != e; ++i) {
368 sigaction(RegisteredSignalInfo[i].SigNo, &RegisteredSignalInfo[i].SA,
370 --NumRegisteredSignals;
375static void RemoveFilesToRemove() {
376 FileToRemoveList::removeAllFiles(FilesToRemove);
383 int Sig = (int)Context;
386 InfoSignalHandler(Sig);
390 RemoveFilesToRemove();
399static void SignalHandler(
int Sig, siginfo_t *Info,
void *Context) {
408 sigfillset(&SigMask);
409 sigprocmask(SIG_UNBLOCK, &SigMask,
nullptr);
412 RemoveFilesToRemove();
415 if (
auto OldOneShotPipeFunction =
416 OneShotPipeSignalFunction.exchange(
nullptr))
417 return OldOneShotPipeFunction();
421 if (
auto OldInterruptFunction = InterruptFunction.exchange(
nullptr))
422 return OldInterruptFunction();
424 if (Sig == SIGPIPE || IsIntSig) {
438 if (Sig == SIGILL || Sig == SIGFPE || Sig == SIGTRAP)
442#if defined(__linux__)
448 syscall(SYS_rt_tgsigqueueinfo, getpid(), syscall(SYS_gettid), Sig, Info);
449 if (retval != 0 && errno == EPERM)
454 if (Info->si_pid != getpid() && Info->si_pid != 0)
459static void SignalHandlerTerminate(
int Sig, siginfo_t *Info,
void *Context) {
460 SignalHandler(Sig, Info, Context);
468static void InfoSignalHandler(
int Sig) {
470 if (SignalHandlerFunctionType CurrentInfoFunction = InfoSignalFunction)
471 CurrentInfoFunction();
474static void InfoSignalHandlerTerminate(
int Sig) {
475 InfoSignalHandler(Sig);
477 if (Sig == SIGUSR1) {
487 RemoveFilesToRemove();
491 InterruptFunction.exchange(IF);
496 InfoSignalFunction.exchange(Handler);
501 OneShotPipeSignalFunction.exchange(Handler);
514 *FilesToRemoveCleanup;
515 FileToRemoveList::insert(FilesToRemove,
Filename.str());
522 FileToRemoveList::erase(FilesToRemove,
Filename.str());
529 bool NeedsPOSIXUtilitySignalHandling) {
532 RegisterHandlers(NeedsPOSIXUtilitySignalHandling);
535#if ENABLE_BACKTRACES && defined(HAVE_BACKTRACE) && \
536 (defined(__linux__) || defined(__FreeBSD__) || \
537 defined(__FreeBSD_kernel__) || defined(__NetBSD__) || \
538 defined(__OpenBSD__) || defined(__DragonFly__))
539struct DlIteratePhdrData {
543 const char **modules;
545 const char *main_exec_name;
548static int dl_iterate_phdr_cb(dl_phdr_info *
info,
size_t size,
void *arg) {
549 DlIteratePhdrData *
data = (DlIteratePhdrData *)arg;
552 for (
int i = 0; i <
info->dlpi_phnum; i++) {
553 const auto *phdr = &
info->dlpi_phdr[i];
554 if (phdr->p_type != PT_LOAD)
556 intptr_t beg =
info->dlpi_addr + phdr->p_vaddr;
557 intptr_t
end = beg + phdr->p_memsz;
558 for (
int j = 0;
j <
data->depth;
j++) {
559 if (
data->modules[j])
561 intptr_t addr = (intptr_t)
data->StackTrace[j];
562 if (beg <= addr && addr < end) {
564 data->offsets[
j] = addr -
info->dlpi_addr;
571#if LLVM_ENABLE_DEBUGLOC_TRACKING_ORIGIN
572#if !defined(HAVE_BACKTRACE)
573#error DebugLoc origin-tracking currently requires `backtrace()`.
577template <
unsigned long MaxDepth>
578int getStackTrace(std::array<void *, MaxDepth> &StackTrace) {
579 return backtrace(StackTrace.data(), MaxDepth);
581template int getStackTrace<16ul>(std::array<void *, 16ul> &);
589 const char **Modules, intptr_t *Offsets,
590 const char *MainExecutableName,
592 DlIteratePhdrData
data = {StackTrace,
Depth,
true,
593 Modules,
Offsets, MainExecutableName};
594 dl_iterate_phdr(dl_iterate_phdr_cb, &
data);
598class DSOMarkupPrinter {
600 const char *MainExecutableName;
601 size_t ModuleCount = 0;
606 : OS(OS), MainExecutableName(MainExecutableName) {}
609 void printDSOMarkup(dl_phdr_info *Info) {
613 OS <<
format(
"{{{module:%d:%s:elf:", ModuleCount,
614 IsFirst ? MainExecutableName : Info->dlpi_name);
619 for (
int I = 0;
I < Info->dlpi_phnum;
I++) {
620 const auto *Phdr = &Info->dlpi_phdr[
I];
621 if (Phdr->p_type != PT_LOAD)
623 uintptr_t StartAddress = Info->dlpi_addr + Phdr->p_vaddr;
624 uintptr_t ModuleRelativeAddress = Phdr->p_vaddr;
625 std::array<char, 4> ModeStr = modeStrFromFlags(Phdr->p_flags);
626 OS <<
format(
"{{{mmap:%#016x:%#x:load:%d:%s:%#016x}}}\n", StartAddress,
627 Phdr->p_memsz, ModuleCount, &ModeStr[0],
628 ModuleRelativeAddress);
636 static int printDSOMarkup(dl_phdr_info *Info,
size_t Size,
void *Arg) {
637 static_cast<DSOMarkupPrinter *
>(Arg)->printDSOMarkup(Info);
644 for (
int I = 0;
I < Info->dlpi_phnum;
I++) {
645 const auto *Phdr = &Info->dlpi_phdr[
I];
646 if (Phdr->p_type != PT_NOTE)
650 reinterpret_cast<const uint8_t *
>(Info->dlpi_addr + Phdr->p_vaddr),
652 while (Notes.size() > 12) {
654 Notes = Notes.drop_front(4);
656 Notes = Notes.drop_front(4);
658 Notes = Notes.drop_front(4);
661 auto CurPos =
reinterpret_cast<uintptr_t
>(Notes.data());
664 if (BytesUntilDesc >= Notes.size())
666 Notes = Notes.drop_front(BytesUntilDesc);
669 CurPos =
reinterpret_cast<uintptr_t
>(Notes.data());
672 if (BytesUntilNextNote > Notes.size())
674 Notes = Notes.drop_front(BytesUntilNextNote);
676 if (Type == 3 &&
Name.size() >= 3 &&
677 Name[0] ==
'G' && Name[1] ==
'N' && Name[2] ==
'U')
686 std::array<char, 4> modeStrFromFlags(
uint32_t Flags) {
687 std::array<char, 4>
Mode;
688 char *Cur = &
Mode[0];
701 const char *MainExecutableName) {
702 OS <<
"{{{reset}}}\n";
703 DSOMarkupPrinter MP(OS, MainExecutableName);
704 dl_iterate_phdr(DSOMarkupPrinter::printDSOMarkup, &MP);
708#elif ENABLE_BACKTRACES && defined(__APPLE__) && defined(__LP64__)
710 const char **Modules, intptr_t *Offsets,
711 const char *MainExecutableName,
713 uint32_t NumImgs = _dyld_image_count();
714 for (
uint32_t ImageIndex = 0; ImageIndex < NumImgs; ImageIndex++) {
715 const char *
Name = _dyld_get_image_name(ImageIndex);
716 intptr_t Slide = _dyld_get_image_vmaddr_slide(ImageIndex);
718 (
const struct mach_header_64 *)_dyld_get_image_header(ImageIndex);
721 auto Cmd = (
const struct load_command *)(&Header[1]);
722 for (
uint32_t CmdNum = 0; CmdNum < Header->ncmds; ++CmdNum) {
723 uint32_t BaseCmd = Cmd->cmd & ~LC_REQ_DYLD;
724 if (BaseCmd == LC_SEGMENT_64) {
725 auto CmdSeg64 = (
const struct segment_command_64 *)Cmd;
726 for (
int j = 0;
j <
Depth;
j++) {
729 intptr_t Addr = (intptr_t)StackTrace[j];
730 if ((intptr_t)CmdSeg64->vmaddr + Slide <= Addr &&
731 Addr < intptr_t(CmdSeg64->vmaddr + CmdSeg64->vmsize + Slide)) {
737 Cmd = (
const load_command *)(((
const char *)Cmd) + (Cmd->cmdsize));
744 const char *MainExecutableName) {
751 const char **Modules, intptr_t *Offsets,
752 const char *MainExecutableName,
758 const char *MainExecutableName) {
763#if ENABLE_BACKTRACES && defined(HAVE__UNWIND_BACKTRACE)
764static int unwindBacktrace(
void **StackTrace,
int MaxEntries) {
771 auto HandleFrame = [&](_Unwind_Context *Context) -> _Unwind_Reason_Code {
773 void *IP = (
void *)_Unwind_GetIP(Context);
775 return _URC_END_OF_STACK;
777 assert(Entries < MaxEntries &&
"recursively called after END_OF_STACK?");
779 StackTrace[Entries] = IP;
781 if (++Entries == MaxEntries)
782 return _URC_END_OF_STACK;
783 return _URC_NO_REASON;
787 [](_Unwind_Context *Context,
void *Handler) {
788 return (*
static_cast<decltype(HandleFrame) *
>(Handler))(Context);
790 static_cast<void *
>(&HandleFrame));
791 return std::max(Entries, 0);
795#if ENABLE_BACKTRACES && defined(__MVS__)
798 constexpr size_t MAX_ENTRY_NAME = UINT16_MAX;
800 constexpr size_t MAX_OTHER = 8;
801 int32_t dsa_format = -1;
802 void *caaptr = _gtca();
804 char compile_unit_name[MAX_OTHER];
805 void *compile_unit_address;
806 void *call_instruction_address =
nullptr;
807 char entry_name[MAX_ENTRY_NAME];
809 void *callers_instruction_address;
810 void *callers_dsaptr;
811 int32_t callers_dsa_format;
812 char statement_id[MAX_OTHER];
814 int32_t main_program;
820 void *dsaptr =
static_cast<char *
>(__builtin_frame_address(0)) - 2048;
822 OS <<
" DSA Adr EP +EP DSA "
826 int32_t compile_unit_name_length =
sizeof(compile_unit_name);
827 int32_t entry_name_length =
sizeof(entry_name);
828 int32_t statement_id_length =
sizeof(statement_id);
832 __CELQTBCK(&dsaptr, &dsa_format, &caaptr, &member_id, &compile_unit_name[0],
833 &compile_unit_name_length, &compile_unit_address,
834 &call_instruction_address, &entry_name[0], &entry_name_length,
835 &entry_address, &callers_instruction_address, &callers_dsaptr,
836 &callers_dsa_format, &statement_id[0], &statement_id_length,
837 &cibptr, &main_program, &fc);
839 OS <<
format(
"error: CELQTBCK returned severity %d message %d\n",
840 fc.tok_sev, fc.tok_msgno);
845 uintptr_t diff =
reinterpret_cast<uintptr_t
>(call_instruction_address) -
846 reinterpret_cast<uintptr_t
>(entry_address);
847 OS <<
format(
" %3d. 0x%016lX",
count, call_instruction_address);
848 OS <<
format(
" 0x%016lX +0x%08lX 0x%016lX", entry_address, diff, dsaptr);
852 OS <<
' ' << Str <<
'\n';
855 if (callers_dsaptr) {
856 dsaptr = callers_dsaptr;
857 dsa_format = callers_dsa_format;
858 call_instruction_address = callers_instruction_address;
875 static void *StackTrace[256];
877#if defined(HAVE_BACKTRACE)
880 depth = backtrace(StackTrace,
static_cast<int>(std::size(StackTrace)));
882#if defined(HAVE__UNWIND_BACKTRACE)
886 unwindBacktrace(StackTrace,
static_cast<int>(std::size(StackTrace)));
898 OS <<
"Stack dump without symbol names (ensure you have llvm-symbolizer in "
899 "your PATH or set the environment var `LLVM_SYMBOLIZER_PATH` to point "
901#if HAVE_DLOPEN && !defined(_AIX)
903 for (
int i = 0; i < depth; ++i) {
906 if (dladdr(StackTrace[i], &dlinfo) == 0) {
909 const char *
name = strrchr(dlinfo.dli_fname,
'/');
912 nwidth = strlen(dlinfo.dli_fname);
914 nwidth = strlen(
name) - 1;
917 width = std::max(nwidth, width);
920 for (
int i = 0; i < depth; ++i) {
925 if (dladdr(StackTrace[i], &dlinfo) == 0) {
926 OS <<
format(
" %-*s", width,
static_cast<const char *
>(
"(error)"));
927 dlinfo.dli_sname =
nullptr;
929 const char *
name = strrchr(dlinfo.dli_fname,
'/');
931 OS <<
format(
" %-*s", width, dlinfo.dli_fname);
936 OS <<
format(
" %#0*lx", (
int)(
sizeof(
void *) * 2) + 2,
937 (
unsigned long)StackTrace[i]);
939 if (dlinfo.dli_sname !=
nullptr) {
945 OS << dlinfo.dli_sname;
948 OS <<
format(
" + %tu", (
static_cast<const char *
>(StackTrace[i]) -
949 static_cast<const char *
>(dlinfo.dli_saddr)));
953#elif defined(HAVE_BACKTRACE)
960static void PrintStackTraceSignalHandler(
void *) {
969 bool DisableCrashReporting) {
974#if defined(__APPLE__) && ENABLE_CRASH_OVERRIDES
976 if (DisableCrashReporting || getenv(
"LLVM_DISABLE_CRASH_REPORT")) {
977 mach_port_t
self = mach_task_self();
979 exception_mask_t
mask = EXC_MASK_CRASH;
981 kern_return_t ret = task_set_exception_ports(
982 self,
mask, MACH_PORT_NULL,
983 EXCEPTION_STATE_IDENTITY | MACH_EXCEPTION_CODES, THREAD_STATE_NONE);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static constexpr unsigned long long mask(BlockVerifier::State S)
#define LLVM_ATTRIBUTE_USED
This file provides utility functions for converting between EBCDIC-1047 and UTF-8.
This file contains definitions of exit codes for exit() function.
static constexpr StringLiteral Filename
static cl::opt< RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode > Mode("regalloc-enable-advisor", cl::Hidden, cl::init(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Default), cl::desc("Enable regalloc advisor mode"), cl::values(clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Default, "default", "Default"), clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Release, "release", "precompiled"), clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Development, "development", "for training")))
This file provides utility classes that use RAII to save and restore values.
static LLVM_ATTRIBUTE_USED bool printSymbolizedStackTrace(StringRef Argv0, void **StackTrace, int Depth, llvm::raw_ostream &OS)
Helper that launches llvm-symbolizer and symbolizes a backtrace.
static bool findModulesAndOffsets(void **StackTrace, int Depth, const char **Modules, intptr_t *Offsets, const char *MainExecutableName, StringSaver &StrPool)
static bool printMarkupContext(raw_ostream &OS, const char *MainExecutableName)
static LLVM_ATTRIBUTE_USED bool printMarkupStackTrace(StringRef Argv0, void **StackTrace, int Depth, raw_ostream &OS)
static void insertSignalHandler(sys::SignalHandlerCallback FnPtr, void *Cookie)
static TableGen::Emitter::OptClass< SkeletonEmitter > X("gen-skeleton-class", "Generate example skeleton class")
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
ManagedStatic - This transparently changes the behavior of global statics to be lazily constructed on...
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
StringRef - Represent a constant reference to a string, i.e.
Saves strings in the provided stable storage and returns a StringRef with a stable character pointer.
This class implements an extremely fast bulk output stream that can only output to a stream.
LLVM_ABI void convertToUTF8(StringRef Source, SmallVectorImpl< char > &Result)
constexpr size_t NameSize
SmallVector< uint8_t, 10 > BuildID
A build ID in binary form.
ScopedSetting scopedDisable()
std::lock_guard< SmartMutex< mt_only > > SmartScopedLock
LLVM_ABI void DefaultOneShotPipeSignalHandler()
On Unix systems and Windows, this function exits with an "IO error" exit code.
LLVM_ABI void PrintStackTrace(raw_ostream &OS, int Depth=0)
Print the stack trace using the given raw_ostream object.
LLVM_ABI void DisableSystemDialogsOnCrash()
Disable all system dialog boxes that appear when the process crashes.
LLVM_ABI void unregisterHandlers()
LLVM_ABI void DontRemoveFileOnSignal(StringRef Filename)
This function removes a file from the list of files to be removed on signal delivery.
LLVM_ABI void AddSignalHandler(SignalHandlerCallback FnPtr, void *Cookie, bool NeedsPOSIXUtilitySignalHandling=false)
Add a function to be called when an abort/kill signal is delivered to the process.
LLVM_ABI bool RemoveFileOnSignal(StringRef Filename, std::string *ErrMsg=nullptr)
This function registers signal handlers to ensure that if a signal gets delivered that the named file...
LLVM_ABI void SetInfoSignalFunction(void(*Handler)())
Registers a function to be called when an "info" signal is delivered to the process.
LLVM_ABI void SetOneShotPipeSignalFunction(void(*Handler)())
Registers a function to be called in a "one-shot" manner when a pipe signal is delivered to the proce...
LLVM_ABI void SetInterruptFunction(void(*IF)())
This function registers a function to be called when the user "interrupts" the program (typically by ...
LLVM_ABI void RunSignalHandlers()
LLVM_ABI void CleanupOnSignal(uintptr_t Context)
This function does the following:
LLVM_ABI void RunInterruptHandlers()
This function runs all the registered interrupt handlers, including the removal of files registered b...
LLVM_ABI void PrintStackTraceOnErrorSignal(StringRef Argv0, bool DisableCrashReporting=false)
When an error signal (such as SIGABRT or SIGSEGV) is delivered to the process, print a stack trace an...
void(*)(void *) SignalHandlerCallback
This is an optimization pass for GlobalISel generic memory operations.
auto size(R &&Range, std::enable_if_t< std::is_base_of< std::random_access_iterator_tag, typename std::iterator_traits< decltype(Range.begin())>::iterator_category >::value, void > *=nullptr)
Get the size of a range.
SmallVectorImpl< T >::const_pointer c_str(SmallVectorImpl< T > &str)
void erase(Container &C, ValueType V)
Wrapper function to remove a value from a container:
DEMANGLE_ABI char * itaniumDemangle(std::string_view mangled_name, bool ParseParams=true)
Returns a non-NULL pointer to a NUL-terminated C style string that should be explicitly freed,...
constexpr T alignToPowerOf2(U Value, V Align)
Will overflow only if result is not representable in T.
LLVM_ATTRIBUTE_RETURNS_NONNULL void * safe_malloc(size_t Sz)
format_object< Ts... > format(const char *Fmt, const Ts &... Vals)
These are helper functions used to produce formatted output.
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
FunctionAddr VTableAddr Next
auto count(R &&Range, const E &Element)
Wrapper function around std::count to count the number of times an element Element occurs in the give...
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
A utility class that uses RAII to save and restore the value of a variable.