diff options
author | Xinliang David Li <davidxl@google.com> | 2015-12-03 18:31:59 +0000 |
---|---|---|
committer | Xinliang David Li <davidxl@google.com> | 2015-12-03 18:31:59 +0000 |
commit | e9daa5252d3608e686b3a92770fb9fa52526ff96 (patch) | |
tree | 82055f4fc0ee343ee8728e84b589b50cd816df65 | |
parent | 4bc061bbb6fbd998278c440bf50260017853d64e (diff) |
[PGO] Introduce error report macro in profile-rt
Also added a test case for runtime error reporting.
git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@254625 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/profile/InstrProfiling.h | 4 | ||||
-rw-r--r-- | lib/profile/InstrProfilingFile.c | 8 | ||||
-rw-r--r-- | test/profile/instrprof-error.c | 12 |
3 files changed, 21 insertions, 3 deletions
diff --git a/lib/profile/InstrProfiling.h b/lib/profile/InstrProfiling.h index 7ee41c3f3..0aa24071b 100644 --- a/lib/profile/InstrProfiling.h +++ b/lib/profile/InstrProfiling.h @@ -163,4 +163,8 @@ uint64_t __llvm_profile_get_magic(void); /*! \brief Get the version of the file format. */ uint64_t __llvm_profile_get_version(void); +#define PROF_ERR(Format, ...) \ + if (getenv("LLVM_PROFILE_VERBOSE_ERRORS")) \ + fprintf(stderr, Format, __VA_ARGS__ ); + #endif /* PROFILE_INSTRPROFILING_H_ */ diff --git a/lib/profile/InstrProfilingFile.c b/lib/profile/InstrProfilingFile.c index 5663bab34..8e9d2dab5 100644 --- a/lib/profile/InstrProfilingFile.c +++ b/lib/profile/InstrProfilingFile.c @@ -193,13 +193,15 @@ int __llvm_profile_write_file(void) { int rc; /* Check the filename. */ - if (!__llvm_profile_CurrentFilename) + if (!__llvm_profile_CurrentFilename) { + PROF_ERR("LLVM Profile: Failed to write file : %s\n", "Filename not set"); return -1; + } /* Write the file. */ rc = writeFileWithName(__llvm_profile_CurrentFilename); - if (rc && getenv("LLVM_PROFILE_VERBOSE_ERRORS")) - fprintf(stderr, "LLVM Profile: Failed to write file \"%s\": %s\n", + if (rc) + PROF_ERR("LLVM Profile: Failed to write file \"%s\": %s\n", __llvm_profile_CurrentFilename, strerror(errno)); return rc; } diff --git a/test/profile/instrprof-error.c b/test/profile/instrprof-error.c new file mode 100644 index 000000000..4386d5321 --- /dev/null +++ b/test/profile/instrprof-error.c @@ -0,0 +1,12 @@ +// RUN: %clang_profgen -o %t -O3 %s +// RUN: touch %t.profraw +// RUN: chmod -w %t.profraw +// RUN: LLVM_PROFILE_FILE=%t.profraw LLVM_PROFILE_VERBOSE_ERRORS=1 %run %t 1 2>&1 | FileCheck %s +// RUN: chmod +w %t.profraw + +int main(int argc, const char *argv[]) { + if (argc < 2) + return 1; + return 0; +} +// CHECK: LLVM Profile: Failed to write file |