diff options
author | Tamar Christina <tamar@zhox.com> | 2016-06-03 21:42:16 +0200 |
---|---|---|
committer | Ben Gamari <ben@smart-cactus.org> | 2016-06-03 21:42:32 +0200 |
commit | 37473722960a1066c3b45c94377ba08769b1375b (patch) | |
tree | cdaebe9089fc39d1077c765cfe152f4176f2afb4 /rts/RtsSymbolInfo.h | |
parent | 1dadd9a91454bb098e9c47d6c034b07e2e1e2529 (diff) | |
download | haskell-37473722960a1066c3b45c94377ba08769b1375b.tar.gz |
Refactored SymbolInfo to lower memory usage in RTS
Previously as part of #11223 a new struct `SymbolInfo` was introduced to
keep track it the weak symbol status of a symbol.
This structure also kept a copy of the calculated address of the symbol
which turns out was useful in ignoring non-weak zero-valued symbols.
The information was kept in an array so it means for every symbol two
extra bytes were kept even though the vast majority of symbols are
non-weak and non-zero valued.
This changes the array into a sparse map keeping this information only
for the symbols that are weak or zero-valued. This allows for a
reduction in the amount of information needed to be kept while giving up
a small (negligable) hit in performance as this information now has to
be looked up in hashmaps.
Test Plan: ./validate on all platforms that use the runtime linker.
For unix platforms please ensure `DYNAMIC_GHC_PROGRAMS=NO` is added to
your validate file.
Reviewers: simonmar, austin, erikd, bgamari
Reviewed By: simonmar, bgamari
Subscribers: thomie, #ghc_windows_task_force
Differential Revision: https://phabricator.haskell.org/D2184
GHC Trac Issues: #11816
Diffstat (limited to 'rts/RtsSymbolInfo.h')
-rw-r--r-- | rts/RtsSymbolInfo.h | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/rts/RtsSymbolInfo.h b/rts/RtsSymbolInfo.h new file mode 100644 index 0000000000..6987183d2a --- /dev/null +++ b/rts/RtsSymbolInfo.h @@ -0,0 +1,17 @@ +/* ----------------------------------------------------------------------------- + * + * (c) The GHC Team, 2000-2015 + * + * RTS Symbol Info + * + * ---------------------------------------------------------------------------*/ + +#ifndef RTS_SYMBOLINFO_H +#define RTS_SYMBOLINFO_H + +#include "LinkerInternals.h" + +HsBool isSymbolWeak(ObjectCode *owner, void *label); +void setWeakSymbol(ObjectCode *owner, void *label); + +#endif /* RTS_SYMBOLINFO_H */ |