Commit afedabf
committed
[wasm-split] Split globals' transitive global dependencies
When a global is exclusively used by a secondary module, we can move it
to the secondary module. If its initializer contains a `global.get` of
another global, we exported it from the primary module to the secondary
module, even if it may not be used anywhere else.
When we split a global out to a secondary module, this PR computes the
transitive dependency of the split global, and if those globals in the
dependency are not used anywhere else in other modules, we move them to
the secondary module as well.
by 29%.
The running time of `wasm-split` hasn't really changed with this PR,
compared to #8441.
---
`wasm-objdump -h` result:
- Before (#8441)
Type start=0x0000000c end=0x00035d44 (size=0x00035d38) count: 11185
Import start=0x00035d49 end=0x003faf6f (size=0x003c5226) count: 56805
Function start=0x003faf73 end=0x0040de1f (size=0x00012eac) count: 62890
Table start=0x0040de22 end=0x0041195d (size=0x00003b3b) count: 2921
Tag start=0x0041195f end=0x00411963 (size=0x00000004) count: 1
Global start=0x00411967 end=0x005541c5 (size=0x0014285e) count: 47771
Export start=0x005541ca end=0x007c0a00 (size=0x0026c836) count: 59077
Start start=0x007c0a02 end=0x007c0a04 (size=0x00000002) start: 828
Elem start=0x007c0a08 end=0x0082a84b (size=0x00069e43) count: 12303
DataCount start=0x0082a84d end=0x0082a84e (size=0x00000001) count: 1
Code start=0x0082a853 end=0x00a5a159 (size=0x0022f906) count: 62890
Data start=0x00a5a15d end=0x00a79cea (size=0x0001fb8d) count: 1
```
- After (This PR)
```
Type start=0x0000000c end=0x00035d44 (size=0x00035d38) count: 11185
Import start=0x00035d48 end=0x00132efc (size=0x000fd1b4) count: 32642
Function start=0x00132f00 end=0x00145dac (size=0x00012eac) count: 62890
Table start=0x00145daf end=0x001498ea (size=0x00003b3b) count: 2921
Tag start=0x001498ec end=0x001498f0 (size=0x00000004) count: 1
Global start=0x001498f4 end=0x00289e60 (size=0x0014056c) count: 47728
Export start=0x00289e65 end=0x004977fe (size=0x0020d999) count: 35861
Start start=0x00497800 end=0x00497802 (size=0x00000002) start: 828
Elem start=0x00497806 end=0x00501649 (size=0x00069e43) count: 12303
DataCount start=0x0050164b end=0x0050164c (size=0x00000001) count: 1
Code start=0x00501651 end=0x00730f22 (size=0x0022f8d1) count: 62890
Data start=0x00730f26 end=0x00750ab3 (size=0x0001fb8d) count: 1
```
Note that while the decrease in the global section is small, we have a
significant size decrease in the import and the export sections, because
we used to import globals and export them just to relay those globals to
the secondary modules.1 parent 0a9f9b3 commit afedabf
File tree
2 files changed
+55
-22
lines changed- src/ir
- test/lit/wasm-split
2 files changed
+55
-22
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
583 | 583 | | |
584 | 584 | | |
585 | 585 | | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
| 593 | + | |
| 594 | + | |
| 595 | + | |
| 596 | + | |
| 597 | + | |
| 598 | + | |
| 599 | + | |
| 600 | + | |
| 601 | + | |
| 602 | + | |
| 603 | + | |
| 604 | + | |
586 | 605 | | |
587 | 606 | | |
588 | 607 | | |
| |||
977 | 996 | | |
978 | 997 | | |
979 | 998 | | |
980 | | - | |
| 999 | + | |
| 1000 | + | |
| 1001 | + | |
| 1002 | + | |
| 1003 | + | |
| 1004 | + | |
| 1005 | + | |
| 1006 | + | |
| 1007 | + | |
| 1008 | + | |
| 1009 | + | |
| 1010 | + | |
| 1011 | + | |
981 | 1012 | | |
982 | 1013 | | |
983 | 1014 | | |
| |||
1009 | 1040 | | |
1010 | 1041 | | |
1011 | 1042 | | |
1012 | | - | |
1013 | | - | |
1014 | | - | |
1015 | | - | |
| 1043 | + | |
| 1044 | + | |
| 1045 | + | |
| 1046 | + | |
| 1047 | + | |
1016 | 1048 | | |
1017 | | - | |
| 1049 | + | |
| 1050 | + | |
| 1051 | + | |
| 1052 | + | |
1018 | 1053 | | |
1019 | 1054 | | |
1020 | | - | |
| 1055 | + | |
1021 | 1056 | | |
1022 | 1057 | | |
1023 | | - | |
| 1058 | + | |
| 1059 | + | |
| 1060 | + | |
| 1061 | + | |
1024 | 1062 | | |
1025 | 1063 | | |
1026 | 1064 | | |
1027 | 1065 | | |
1028 | 1066 | | |
| 1067 | + | |
1029 | 1068 | | |
1030 | | - | |
| 1069 | + | |
1031 | 1070 | | |
1032 | 1071 | | |
1033 | 1072 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
6 | | - | |
7 | | - | |
| 6 | + | |
8 | 7 | | |
9 | 8 | | |
10 | | - | |
| 9 | + | |
11 | 10 | | |
12 | 11 | | |
13 | 12 | | |
14 | | - | |
| 13 | + | |
15 | 14 | | |
16 | 15 | | |
17 | | - | |
18 | | - | |
19 | | - | |
20 | | - | |
21 | | - | |
22 | | - | |
23 | | - | |
24 | | - | |
25 | | - | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
26 | 20 | | |
27 | 21 | | |
28 | 22 | | |
| |||
0 commit comments