Commit 1224e35
fix: eliminate phantom BAL entries at opcode level
Previously, addresses could be loaded into the Journal (and thus the
EIP-7928 BAL) during gas calculation and then immediately untracked when
the operation ran OOG. This is replaced with worst-case pre-checks that
abort before any DB load.
CALL: replace access_cost pre-check with getCallGasCost(spec, pre_is_cold,
transfers_value, false) worst-case check before loading the target account.
EXTCODECOPY: charge warm/cold + copy + memory gas before h.codeInfo().
SELFDESTRUCT: worst-case pre-check (cold + G_NEWACCOUNT) before h.selfdestruct().
CREATE: move Amsterdam balance check before js.loadAccount(new_addr).
Since phantoms can no longer enter the BAL, remove the entire untracking
machinery: untrackAddress, forceTrackAddress, bal_untracked from
JournalInner; the corresponding Journal(DB) wrapper methods; and
untrackAddress/forceTrackAddress from the JournalVTable and Host.
isTrackedAddress simplified (no untracked set to consult).
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>1 parent 80cc8bf commit 1224e35
File tree
4 files changed
+63
-133
lines changed- src
- context
- interpreter
- opcodes
4 files changed
+63
-133
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
442 | 442 | | |
443 | 443 | | |
444 | 444 | | |
445 | | - | |
446 | | - | |
447 | 445 | | |
448 | 446 | | |
449 | 447 | | |
| |||
460 | 458 | | |
461 | 459 | | |
462 | 460 | | |
463 | | - | |
464 | 461 | | |
465 | 462 | | |
466 | 463 | | |
| |||
483 | 480 | | |
484 | 481 | | |
485 | 482 | | |
486 | | - | |
487 | 483 | | |
488 | 484 | | |
489 | 485 | | |
| |||
516 | 512 | | |
517 | 513 | | |
518 | 514 | | |
519 | | - | |
520 | | - | |
521 | | - | |
522 | | - | |
523 | | - | |
524 | | - | |
525 | | - | |
526 | | - | |
527 | | - | |
528 | | - | |
529 | | - | |
530 | | - | |
531 | | - | |
532 | | - | |
533 | | - | |
| 515 | + | |
| 516 | + | |
534 | 517 | | |
535 | | - | |
536 | | - | |
537 | | - | |
| 518 | + | |
538 | 519 | | |
539 | 520 | | |
540 | 521 | | |
| |||
634 | 615 | | |
635 | 616 | | |
636 | 617 | | |
637 | | - | |
638 | 618 | | |
639 | 619 | | |
640 | 620 | | |
| |||
685 | 665 | | |
686 | 666 | | |
687 | 667 | | |
688 | | - | |
689 | 668 | | |
690 | 669 | | |
691 | 670 | | |
| |||
1623 | 1602 | | |
1624 | 1603 | | |
1625 | 1604 | | |
1626 | | - | |
1627 | | - | |
1628 | | - | |
1629 | | - | |
1630 | | - | |
1631 | | - | |
1632 | | - | |
1633 | | - | |
1634 | | - | |
1635 | | - | |
1636 | | - | |
| 1605 | + | |
1637 | 1606 | | |
1638 | 1607 | | |
1639 | 1608 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
114 | 114 | | |
115 | 115 | | |
116 | 116 | | |
117 | | - | |
118 | | - | |
119 | 117 | | |
120 | 118 | | |
121 | 119 | | |
| |||
139 | 137 | | |
140 | 138 | | |
141 | 139 | | |
142 | | - | |
143 | | - | |
144 | 140 | | |
145 | 141 | | |
146 | 142 | | |
| |||
167 | 163 | | |
168 | 164 | | |
169 | 165 | | |
170 | | - | |
171 | | - | |
172 | | - | |
173 | | - | |
174 | | - | |
175 | | - | |
176 | 166 | | |
177 | 167 | | |
178 | 168 | | |
| |||
345 | 335 | | |
346 | 336 | | |
347 | 337 | | |
348 | | - | |
349 | | - | |
350 | | - | |
351 | | - | |
352 | | - | |
353 | | - | |
354 | | - | |
355 | | - | |
356 | | - | |
357 | | - | |
358 | 338 | | |
359 | 339 | | |
360 | 340 | | |
| |||
684 | 664 | | |
685 | 665 | | |
686 | 666 | | |
687 | | - | |
688 | 667 | | |
689 | 668 | | |
690 | 669 | | |
691 | 670 | | |
692 | | - | |
693 | 671 | | |
694 | 672 | | |
695 | 673 | | |
| |||
782 | 760 | | |
783 | 761 | | |
784 | 762 | | |
785 | | - | |
786 | | - | |
787 | | - | |
788 | | - | |
789 | | - | |
790 | | - | |
791 | | - | |
792 | | - | |
793 | | - | |
794 | | - | |
795 | | - | |
796 | | - | |
| 763 | + | |
| 764 | + | |
| 765 | + | |
| 766 | + | |
| 767 | + | |
| 768 | + | |
797 | 769 | | |
798 | 770 | | |
799 | | - | |
800 | | - | |
801 | | - | |
802 | | - | |
| 771 | + | |
| 772 | + | |
803 | 773 | | |
804 | 774 | | |
805 | 775 | | |
806 | 776 | | |
| 777 | + | |
| 778 | + | |
807 | 779 | | |
808 | 780 | | |
809 | 781 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
132 | 132 | | |
133 | 133 | | |
134 | 134 | | |
135 | | - | |
136 | | - | |
137 | | - | |
138 | 135 | | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
139 | 141 | | |
140 | | - | |
141 | | - | |
| 142 | + | |
| 143 | + | |
142 | 144 | | |
143 | 145 | | |
144 | 146 | | |
| |||
147 | 149 | | |
148 | 150 | | |
149 | 151 | | |
150 | | - | |
151 | 152 | | |
152 | 153 | | |
153 | 154 | | |
| |||
175 | 176 | | |
176 | 177 | | |
177 | 178 | | |
| 179 | + | |
178 | 180 | | |
179 | | - | |
180 | | - | |
181 | | - | |
182 | | - | |
183 | | - | |
184 | | - | |
185 | | - | |
186 | 181 | | |
187 | 182 | | |
188 | 183 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
153 | 153 | | |
154 | 154 | | |
155 | 155 | | |
156 | | - | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
157 | 160 | | |
158 | 161 | | |
159 | 162 | | |
| |||
162 | 165 | | |
163 | 166 | | |
164 | 167 | | |
165 | | - | |
166 | | - | |
167 | | - | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
168 | 171 | | |
169 | 172 | | |
170 | 173 | | |
171 | 174 | | |
172 | | - | |
173 | | - | |
174 | | - | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
175 | 183 | | |
176 | 184 | | |
177 | 185 | | |
178 | 186 | | |
179 | | - | |
180 | | - | |
181 | | - | |
182 | | - | |
183 | | - | |
| 187 | + | |
184 | 188 | | |
185 | 189 | | |
186 | 190 | | |
187 | | - | |
188 | | - | |
| 191 | + | |
189 | 192 | | |
190 | 193 | | |
191 | | - | |
192 | | - | |
193 | | - | |
194 | | - | |
195 | | - | |
196 | | - | |
197 | | - | |
198 | | - | |
199 | | - | |
200 | | - | |
201 | | - | |
202 | | - | |
203 | | - | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
204 | 199 | | |
205 | 200 | | |
206 | 201 | | |
207 | | - | |
208 | | - | |
209 | | - | |
210 | | - | |
211 | | - | |
212 | | - | |
213 | | - | |
| 202 | + | |
214 | 203 | | |
215 | | - | |
216 | | - | |
217 | | - | |
218 | | - | |
219 | | - | |
| 204 | + | |
| 205 | + | |
220 | 206 | | |
221 | 207 | | |
222 | 208 | | |
| |||
605 | 591 | | |
606 | 592 | | |
607 | 593 | | |
| 594 | + | |
| 595 | + | |
| 596 | + | |
| 597 | + | |
| 598 | + | |
| 599 | + | |
| 600 | + | |
| 601 | + | |
| 602 | + | |
| 603 | + | |
| 604 | + | |
| 605 | + | |
| 606 | + | |
| 607 | + | |
608 | 608 | | |
609 | 609 | | |
610 | 610 | | |
| |||
631 | 631 | | |
632 | 632 | | |
633 | 633 | | |
634 | | - | |
635 | | - | |
636 | | - | |
637 | | - | |
638 | | - | |
639 | | - | |
640 | | - | |
641 | | - | |
| 634 | + | |
| 635 | + | |
642 | 636 | | |
643 | 637 | | |
644 | 638 | | |
| |||
0 commit comments