[llvm-commits] CVS: llvm/lib/System/DynamicLibrary.cpp
Reid Spencer
reid at x10sys.com
Fri Jan 19 13:41:19 PST 2007
Changes in directory llvm/lib/System:
DynamicLibrary.cpp updated: 1.21 -> 1.22
---
Log message:
Help the lli interpreter find the stderr/stdin/stdout symbols. These are
needed for output to be generated. On Linux these are both global vars and
macro definitions so we have to special case Linux.
---
Diffs of the changes: (+19 -3)
DynamicLibrary.cpp | 22 +++++++++++++++++++---
1 files changed, 19 insertions(+), 3 deletions(-)
Index: llvm/lib/System/DynamicLibrary.cpp
diff -u llvm/lib/System/DynamicLibrary.cpp:1.21 llvm/lib/System/DynamicLibrary.cpp:1.22
--- llvm/lib/System/DynamicLibrary.cpp:1.21 Fri Jan 19 15:30:39 2007
+++ llvm/lib/System/DynamicLibrary.cpp Fri Jan 19 15:41:04 2007
@@ -164,11 +164,23 @@
}
#undef EXPLICIT_SYMBOL
#endif
+
+// This macro returns the address of a well-known, explicit symbol
#define EXPLICIT_SYMBOL(SYM) \
if (!strcmp(symbolName, #SYM)) return &SYM
- // Try a few well known symbols just to give lli a shot at working.
- // Note that on some systems stdin, etc. are macros so we have to
- // avoid attempting to take the address of a macro :)
+
+// On linux we have a weird situation. The stderr/out/in symbols are both
+// macros and global variables because of standards requirements. So, we
+// boldly use the EXPLICIT_SYMBOL macro without checking for a #define first.
+#if defined(__linux__)
+ {
+ EXPLICIT_SYMBOL(stderr);
+ EXPLICIT_SYMBOL(stdout);
+ EXPLICIT_SYMBOL(stdin);
+ }
+#else
+ // For everything else, we want to check to make sure the symbol isn't defined
+ // as a macro before using EXPLICIT_SYMBOL.
{
#ifndef stdin
EXPLICIT_SYMBOL(stdin);
@@ -179,7 +191,11 @@
#ifndef stderr
EXPLICIT_SYMBOL(stderr);
#endif
+#ifndef errno
+ EXPLICIT_SYMBOL(errno);
+#endif
}
+#endif
#undef EXPLICIT_SYMBOL
return 0;
More information about the llvm-commits
mailing list