summaryrefslogtreecommitdiff
path: root/src/passes/stringify-walker.h
diff options
context:
space:
mode:
authorAshley Nelson <nashley@google.com>2023-07-21 14:15:45 -0700
committerGitHub <noreply@github.com>2023-07-21 14:15:45 -0700
commite2f5d79fd0f9bd12d69733e98b534ce63592bd57 (patch)
tree7f6c0b2878f421c0d94de05c741f0c137ca5f92b /src/passes/stringify-walker.h
parent84af3482c31bb33595cbb72f30070bc27eab721c (diff)
downloadbinaryen-e2f5d79fd0f9bd12d69733e98b534ce63592bd57.tar.gz
binaryen-e2f5d79fd0f9bd12d69733e98b534ce63592bd57.tar.bz2
binaryen-e2f5d79fd0f9bd12d69733e98b534ce63592bd57.zip
[Outlining] Changing stringify values to 32-bit (#5832)
The LLVM suffix tree expects to be provided with a vector of 32-bit unsigned integers. This PR makes it easier to integrate our wasm program string with the suffix tree. Because the range of possible values is reduced from 2^64 to 2^32, a signed integer was added to manage the next separator value and ensure we're using every possible negative number.
Diffstat (limited to 'src/passes/stringify-walker.h')
-rw-r--r--src/passes/stringify-walker.h11
1 files changed, 7 insertions, 4 deletions
diff --git a/src/passes/stringify-walker.h b/src/passes/stringify-walker.h
index 9563000d0..7e18d3d9e 100644
--- a/src/passes/stringify-walker.h
+++ b/src/passes/stringify-walker.h
@@ -113,17 +113,20 @@ struct StringifyEquator {
struct HashStringifyWalker : public StringifyWalker<HashStringifyWalker> {
// After calling walkModule, this vector contains the result of encoding a
- // wasm module as a string of uint64_t values. Each value represents either an
+ // wasm module as a string of uint32_t values. Each value represents either an
// Expression or a separator to mark the end of control flow.
- std::vector<uint64_t> hashString;
+ std::vector<uint32_t> hashString;
// A monotonic counter used to ensure that unique expressions in the
// module are assigned a unique value in the hashString
- uint64_t nextVal = 0;
+ uint32_t nextVal = 0;
+ // A monotonic counter used to ensure that each separator in the
+ // module is assigned a unique value in the hashString
+ int32_t nextSeparatorVal = -1;
// Contains a mapping of expression pointer to value to ensure we
// use the same value for matching expressions. A custom hasher and
// equator is provided in order to separate out evaluation of the if-condition
// when evaluating if expressions.
- std::unordered_map<Expression*, uint64_t, StringifyHasher, StringifyEquator>
+ std::unordered_map<Expression*, uint32_t, StringifyHasher, StringifyEquator>
exprToCounter;
void addUniqueSymbol();