[libunwind][AIX] Save/restore errno before/after system calls dlopen/dlsym/dlclose
authorXing Xue <xingxue@outlook.com>
Mon, 8 Aug 2022 21:21:30 +0000 (17:21 -0400)
committerXing Xue <xingxue@outlook.com>
Mon, 8 Aug 2022 21:21:30 +0000 (17:21 -0400)
commitcc8edbea7a5f26906ae3d1f7ba0dc5da8fc5afb5
tree56cbfb5fe965216181cd78745c780687d0d88d6a
parent8d7c1c55a43fc0eec3410fab0d4cbe6626522a56
[libunwind][AIX] Save/restore errno before/after system calls dlopen/dlsym/dlclose

Summary:
libunwind on AIX calls dlopen()/dlsym()/dlclose() to dynamically load libc++abi and get the personality for state table EH when it is running against the legacy xlcang++ compiler genereated applications. dlopen() sets errno to 0 when it is successful, which clobbers the value in errno from the user code. This seems to be an AIX bug that it should not set errno to 0 according to POSIX. We will open a bug report to AIX but in the mean time there won't be time line when AIX will have a fix and even AIX does fix it, it won't help earlier AIX releases in the field. This patch saves and restores errno before and after these calls so that user code can work as expected.

Reviewed by: compnerd, libunwind

Differential Revision: https://reviews.llvm.org/D131292
libunwind/src/UnwindCursor.hpp