In this PR I'm changing the way we provide the missing functions like strnlen() on z/OS from the separate header file to a wrapper around the system headers that declare these functions. This will be less intrusive. --------- Co-authored-by: Zibi Sarbinowski <zibi@ca.ibm.com>
63 lines
1.6 KiB
C++
63 lines
1.6 KiB
C++
//===-- Error.cpp -----------------------------------------------*- 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "Error.h"
|
|
#include "llvm/Config/llvm-config.h" // for LLVM_ON_UNIX
|
|
|
|
#ifdef LLVM_ON_UNIX
|
|
#include <string.h>
|
|
#endif // LLVM_ON_UNIX
|
|
|
|
namespace llvm {
|
|
namespace exegesis {
|
|
|
|
char ClusteringError::ID;
|
|
|
|
void ClusteringError::log(raw_ostream &OS) const { OS << Msg; }
|
|
|
|
std::error_code ClusteringError::convertToErrorCode() const {
|
|
return inconvertibleErrorCode();
|
|
}
|
|
|
|
char SnippetExecutionFailure::ID;
|
|
|
|
std::error_code SnippetExecutionFailure::convertToErrorCode() const {
|
|
return inconvertibleErrorCode();
|
|
}
|
|
|
|
char SnippetSegmentationFault::ID;
|
|
|
|
void SnippetSegmentationFault::log(raw_ostream &OS) const {
|
|
OS << "The snippet encountered a segmentation fault at address "
|
|
<< Twine::utohexstr(Address);
|
|
}
|
|
|
|
char SnippetSignal::ID;
|
|
|
|
void SnippetSignal::log(raw_ostream &OS) const {
|
|
OS << "snippet crashed while running";
|
|
#ifdef LLVM_ON_UNIX
|
|
OS << ": " << strsignal(SignalNumber);
|
|
#else
|
|
(void)SignalNumber;
|
|
#endif // LLVM_ON_UNIX
|
|
}
|
|
|
|
char PerfCounterNotFullyEnabled::ID;
|
|
|
|
std::error_code PerfCounterNotFullyEnabled::convertToErrorCode() const {
|
|
return inconvertibleErrorCode();
|
|
}
|
|
|
|
void PerfCounterNotFullyEnabled::log(raw_ostream &OS) const {
|
|
OS << "The perf counter was not scheduled on the CPU the entire time.";
|
|
}
|
|
|
|
} // namespace exegesis
|
|
} // namespace llvm
|