Commit 998cb27
authored
inference: reinfer and track missing code for inlining (#59413)
When code is potentially needed for inlining, but missing for any
reason, be sure to regenerate it during inference with the correct
`ci_meets_requirement` flags (SOURCE_MODE_GET_SOURCE instead of
NOT_REQUIRED) so it is prepared for the optimizer if needed.
This was supposed to be the correct fix for someone else's bug with
missing inlining when expected, but I don't remember what bug it was
anymore. It should however improve handling and tracking of code (and
worlds of code) during inference, which should help for building upon
this base.
```
julia> @atomic Base.method_instance(promote, (Float64,Int)).cache.inferred = 0x22 # mark with inlining cost, deleting code
julia> @code_typed 1.0+1 # this should regenerate the code, but on master instead results in:
CodeInfo(
@ promotion.jl:433 within `+`
1 ─ %1 = invoke Base.promote(x::Float64, y::Int64)::Tuple{Float64, Float64}
│ %2 = builtin Core.getfield(%1, 1)::Float64
│ %3 = builtin Core.getfield(%1, 2)::Float64
│ @ promotion.jl:433 within `+` @ float.jl:492
│ %4 = intrinsic Base.add_float(%2, %3)::Float64
└── return %4
) => Float64
```1 parent 5fcc944 commit 998cb27
File tree
24 files changed
+737
-656
lines changed- Compiler
- src
- ssair
- test
- contrib
- src
- stdlib/REPL/src
- test
24 files changed
+737
-656
lines changedLarge diffs are not rendered by default.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
4 | | - | |
5 | | - | |
6 | | - | |
7 | | - | |
8 | | - | |
9 | | - | |
10 | | - | |
11 | | - | |
12 | | - | |
13 | | - | |
14 | | - | |
15 | | - | |
16 | | - | |
17 | | - | |
18 | | - | |
19 | | - | |
20 | | - | |
21 | | - | |
22 | | - | |
23 | | - | |
24 | 3 | | |
25 | 4 | | |
26 | 5 | | |
| |||
49 | 28 | | |
50 | 29 | | |
51 | 30 | | |
52 | | - | |
| 31 | + | |
53 | 32 | | |
54 | | - | |
55 | | - | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
56 | 36 | | |
57 | | - | |
58 | | - | |
| 37 | + | |
| 38 | + | |
59 | 39 | | |
60 | | - | |
| 40 | + | |
| 41 | + | |
61 | 42 | | |
62 | | - | |
63 | | - | |
64 | | - | |
65 | 43 | | |
66 | | - | |
67 | | - | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
68 | 52 | | |
69 | 53 | | |
70 | | - | |
71 | | - | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
72 | 60 | | |
73 | 61 | | |
74 | 62 | | |
75 | 63 | | |
76 | 64 | | |
77 | 65 | | |
78 | | - | |
| 66 | + | |
79 | 67 | | |
80 | 68 | | |
81 | 69 | | |
82 | 70 | | |
83 | | - | |
84 | | - | |
85 | | - | |
86 | | - | |
87 | | - | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
89 | 89 | | |
90 | 90 | | |
91 | 91 | | |
92 | | - | |
| 92 | + | |
93 | 93 | | |
94 | 94 | | |
95 | 95 | | |
| |||
120 | 120 | | |
121 | 121 | | |
122 | 122 | | |
123 | | - | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
124 | 127 | | |
125 | 128 | | |
126 | 129 | | |
| |||
178 | 181 | | |
179 | 182 | | |
180 | 183 | | |
181 | | - | |
182 | | - | |
| 184 | + | |
183 | 185 | | |
184 | 186 | | |
185 | 187 | | |
186 | 188 | | |
187 | 189 | | |
188 | 190 | | |
189 | 191 | | |
190 | | - | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
191 | 195 | | |
192 | 196 | | |
193 | 197 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
217 | 217 | | |
218 | 218 | | |
219 | 219 | | |
220 | | - | |
221 | 220 | | |
222 | 221 | | |
223 | 222 | | |
| |||
262 | 261 | | |
263 | 262 | | |
264 | 263 | | |
265 | | - | |
| 264 | + | |
266 | 265 | | |
267 | 266 | | |
268 | 267 | | |
| |||
349 | 348 | | |
350 | 349 | | |
351 | 350 | | |
352 | | - | |
| 351 | + | |
353 | 352 | | |
354 | 353 | | |
355 | 354 | | |
| |||
392 | 391 | | |
393 | 392 | | |
394 | 393 | | |
395 | | - | |
| 394 | + | |
396 | 395 | | |
397 | 396 | | |
398 | 397 | | |
| |||
401 | 400 | | |
402 | 401 | | |
403 | 402 | | |
404 | | - | |
405 | | - | |
406 | | - | |
407 | 403 | | |
408 | 404 | | |
409 | 405 | | |
| |||
412 | 408 | | |
413 | 409 | | |
414 | 410 | | |
415 | | - | |
| 411 | + | |
416 | 412 | | |
417 | 413 | | |
418 | 414 | | |
| |||
615 | 611 | | |
616 | 612 | | |
617 | 613 | | |
618 | | - | |
619 | | - | |
620 | 614 | | |
621 | 615 | | |
622 | 616 | | |
| |||
821 | 815 | | |
822 | 816 | | |
823 | 817 | | |
824 | | - | |
| 818 | + | |
825 | 819 | | |
826 | 820 | | |
827 | 821 | | |
| |||
836 | 830 | | |
837 | 831 | | |
838 | 832 | | |
839 | | - | |
840 | | - | |
841 | | - | |
| 833 | + | |
| 834 | + | |
| 835 | + | |
| 836 | + | |
842 | 837 | | |
843 | 838 | | |
844 | 839 | | |
| |||
856 | 851 | | |
857 | 852 | | |
858 | 853 | | |
| 854 | + | |
| 855 | + | |
| 856 | + | |
859 | 857 | | |
860 | 858 | | |
861 | 859 | | |
862 | | - | |
| 860 | + | |
863 | 861 | | |
864 | 862 | | |
865 | 863 | | |
866 | 864 | | |
867 | 865 | | |
868 | | - | |
869 | | - | |
| 866 | + | |
| 867 | + | |
| 868 | + | |
| 869 | + | |
870 | 870 | | |
871 | | - | |
872 | 871 | | |
873 | 872 | | |
874 | 873 | | |
875 | 874 | | |
876 | 875 | | |
877 | 876 | | |
878 | 877 | | |
879 | | - | |
880 | | - | |
| 878 | + | |
| 879 | + | |
881 | 880 | | |
882 | 881 | | |
883 | 882 | | |
| |||
900 | 899 | | |
901 | 900 | | |
902 | 901 | | |
903 | | - | |
| 902 | + | |
904 | 903 | | |
905 | 904 | | |
906 | 905 | | |
| |||
964 | 963 | | |
965 | 964 | | |
966 | 965 | | |
967 | | - | |
968 | | - | |
969 | | - | |
970 | 966 | | |
971 | 967 | | |
972 | 968 | | |
| |||
986 | 982 | | |
987 | 983 | | |
988 | 984 | | |
989 | | - | |
990 | | - | |
991 | | - | |
| 985 | + | |
| 986 | + | |
| 987 | + | |
| 988 | + | |
| 989 | + | |
| 990 | + | |
| 991 | + | |
992 | 992 | | |
993 | 993 | | |
994 | 994 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
99 | 99 | | |
100 | 100 | | |
101 | 101 | | |
102 | | - | |
103 | | - | |
104 | | - | |
105 | | - | |
106 | | - | |
107 | | - | |
108 | | - | |
109 | | - | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
110 | 105 | | |
111 | 106 | | |
112 | 107 | | |
| |||
158 | 153 | | |
159 | 154 | | |
160 | 155 | | |
161 | | - | |
162 | 156 | | |
163 | 157 | | |
164 | 158 | | |
165 | 159 | | |
166 | 160 | | |
167 | | - | |
| 161 | + | |
168 | 162 | | |
169 | 163 | | |
170 | 164 | | |
171 | | - | |
| 165 | + | |
172 | 166 | | |
173 | 167 | | |
174 | 168 | | |
175 | | - | |
176 | | - | |
| 169 | + | |
177 | 170 | | |
178 | 171 | | |
179 | | - | |
180 | | - | |
| 172 | + | |
181 | 173 | | |
182 | | - | |
| 174 | + | |
183 | 175 | | |
184 | 176 | | |
185 | | - | |
| 177 | + | |
186 | 178 | | |
187 | | - | |
188 | | - | |
189 | | - | |
190 | | - | |
191 | | - | |
192 | | - | |
| 179 | + | |
193 | 180 | | |
194 | | - | |
| 181 | + | |
195 | 182 | | |
196 | 183 | | |
197 | 184 | | |
198 | 185 | | |
199 | | - | |
200 | | - | |
201 | | - | |
| 186 | + | |
| 187 | + | |
202 | 188 | | |
203 | 189 | | |
204 | 190 | | |
| |||
678 | 664 | | |
679 | 665 | | |
680 | 666 | | |
681 | | - | |
| 667 | + | |
682 | 668 | | |
683 | 669 | | |
684 | 670 | | |
685 | 671 | | |
686 | 672 | | |
687 | 673 | | |
688 | 674 | | |
689 | | - | |
| 675 | + | |
690 | 676 | | |
691 | 677 | | |
692 | 678 | | |
| |||
0 commit comments