diff options
author | Simon Marlow <marlowsd@gmail.com> | 2009-08-05 10:21:59 +0000 |
---|---|---|
committer | Simon Marlow <marlowsd@gmail.com> | 2009-08-05 10:21:59 +0000 |
commit | 7d7c187b4a12f1bb350e85cdb0115e19537cc704 (patch) | |
tree | 2bfcb2d4e6ebacce3e80dd8fa454452aa76c0049 /rts/posix | |
parent | acdd7c95066cf6505a4d2e8683f119146805af91 (diff) | |
download | haskell-7d7c187b4a12f1bb350e85cdb0115e19537cc704.tar.gz |
Declare RTS-private prototypes with __attribute__((visibility("hidden")))
This has no effect with static libraries, but when the RTS is in a
shared library it does two things:
- it prevents the function from being exposed by the shared library
- internal calls to the function can use the faster non-PLT calls,
because the function cannot be overriden at link time.
Diffstat (limited to 'rts/posix')
-rw-r--r-- | rts/posix/FileLock.h | 4 | ||||
-rw-r--r-- | rts/posix/Itimer.h | 2 | ||||
-rw-r--r-- | rts/posix/Signals.h | 6 | ||||
-rw-r--r-- | rts/posix/TTY.h | 3 |
4 files changed, 9 insertions, 6 deletions
diff --git a/rts/posix/FileLock.h b/rts/posix/FileLock.h index 2edee5ba6e..508cee8455 100644 --- a/rts/posix/FileLock.h +++ b/rts/posix/FileLock.h @@ -9,7 +9,7 @@ #ifndef POSIX_FILELOCK_H #define POSIX_FILELOCK_H -void initFileLocking(void); -void freeFileLocking(void); +RTS_PRIVATE void initFileLocking(void); +RTS_PRIVATE void freeFileLocking(void); #endif /* POSIX_FILELOCK_H */ diff --git a/rts/posix/Itimer.h b/rts/posix/Itimer.h index 4cae935710..b67c8c442e 100644 --- a/rts/posix/Itimer.h +++ b/rts/posix/Itimer.h @@ -9,6 +9,6 @@ #ifndef ITIMER_H #define ITIMER_H -extern lnat getourtimeofday ( void ); +RTS_PRIVATE lnat getourtimeofday ( void ); #endif /* ITIMER_H */ diff --git a/rts/posix/Signals.h b/rts/posix/Signals.h index e1d550fdad..30bc63ee46 100644 --- a/rts/posix/Signals.h +++ b/rts/posix/Signals.h @@ -13,7 +13,9 @@ # include <signal.h> #endif -extern rtsBool anyUserHandlers(void); +#pragma GCC visibility push(hidden) + +rtsBool anyUserHandlers(void); #if !defined(THREADED_RTS) extern siginfo_t pending_handler_buf[]; @@ -24,5 +26,7 @@ void startSignalHandlers(Capability *cap); extern StgInt *signal_handlers; +#pragma GCC visibility pop + #endif /* POSIX_SIGNALS_H */ diff --git a/rts/posix/TTY.h b/rts/posix/TTY.h index f291d30de4..7b8e16bb92 100644 --- a/rts/posix/TTY.h +++ b/rts/posix/TTY.h @@ -9,7 +9,6 @@ #ifndef POSIX_TTY_H #define POSIX_TTY_H -void resetTerminalSettings (void); +RTS_PRIVATE void resetTerminalSettings (void); #endif /* POSIX_TTY_H */ - |