-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdebug.v
1671 lines (1385 loc) · 90.5 KB
/
debug.v
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
Require Import List.
Require Import bbv.Word.
Require Import Coq.NArith.NArith.
Require Import FORVES.constants.
Import Constants.
Require Import FORVES.program.
Import Program.
Require Import FORVES.block_equiv_checker.
Import BlockEquivChecker.
Require Import FORVES.symbolic_state.
Import SymbolicState.
Require Import FORVES.stack_operation_instructions.
Import StackOpInstrs.
Require Import FORVES.execution_state.
Import ExecutionState.
Require Import FORVES.concrete_interpreter.
Import ConcreteInterpreter.
Require Import FORVES.optimizations_def.
Import Optimizations_Def.
Require Import FORVES.optimizations.sub_x_x.
Import Opt_sub_x_x.
Require Import FORVES.optimizations.and_address.
Import Opt_and_address.
Require Import FORVES.symbolic_execution.
Import SymbolicExecution.
Require Import FORVES.storage_ops_solvers.
Import StorageOpsSolvers.
Require Import FORVES.storage_ops_solvers_impl.
Import StorageOpsSolversImpl.
Require Import FORVES.memory_ops_solvers.
Import MemoryOpsSolvers.
Require Import FORVES.memory_ops_solvers_impl.
Import MemoryOpsSolversImpl.
Require Import FORVES.symbolic_state_cmp.
Import SymbolicStateCmp.
Require Import FORVES.valid_symbolic_state.
Import ValidSymbolicState.
Require Import FORVES.symbolic_execution_soundness.
Import SymbolicExecutionSoundness.
Require Import FORVES.symbolic_state_eval.
Import SymbolicStateEval.
Require Import FORVES.symbolic_state.
Import SymbolicState.
Require Import FORVES.symbolic_state_cmp_impl.
Import SymbolicStateCmpImpl.
Require Import FORVES.sstack_val_cmp_impl.
Import SStackValCmpImpl.
Require Import FORVES.sstack_val_cmp_impl_soundness.
Import SStackValCmpImplSoundness.
Require Import FORVES.sha3_cmp_impl.
Import SHA3CmpImpl.
Require Import FORVES.sha3_cmp_impl_soundness.
Import SHA3CmpImplSoundness.
Require Import FORVES.storage_cmp_impl.
Import StorageCmpImpl.
Require Import FORVES.storage_cmp_impl_soundness.
Import StorageCmpImplSoundness.
Require Import FORVES.memory_cmp_impl.
Import MemoryCmpImpl.
Require Import FORVES.memory_cmp_impl_soundness.
Import MemoryCmpImplSoundness.
Require Import FORVES.storage_ops_solvers_impl.
Import StorageOpsSolversImpl.
Require Import FORVES.storage_ops_solvers_impl_soundness.
Import StorageOpsSolversImplSoundness.
Require Import FORVES.memory_ops_solvers_impl.
Import MemoryOpsSolversImpl.
Require Import FORVES.memory_ops_solvers_impl_soundness.
Import MemoryOpsSolversImplSoundness.
Require Import FORVES.misc.
Import Misc.
Require Import FORVES.optimizations_common.
Import Optimizations_Common.
Require Import FORVES.parser.
Import Parser.
From Coq Require Import Strings.String.
From Coq Require Import Lists.List. Import ListNotations.
(* For debugging with print_id *)
(* From ReductionEffect Require Import PrintingEffect. *)
Module Debug.
(* string to block that always succeed *)
Definition str2block (s : string) : block :=
match parse_block s with
| None => []
| Some b => b
end.
(*Compute
(str2block "ADD PUSH1 0x20 ADD MLOAD PUSH32 0xFF00000000000000000000000000000000000000000000000000000000000000 AND DUP5 DUP5 PUSH1 0x64 DUP2 PUSH1 0x1c").
*)
Inductive sstack_val_dbg : Type :=
| Val' (val: N)
| InStackVar' (var: nat)
| FreshVar' (var: nat).
Definition sstack_dbg : Type := list sstack_val_dbg.
Definition smemory_dbg : Type := memory_updates sstack_val_dbg.
Definition sstorage_dbg : Type := storage_updates sstack_val_dbg.
Inductive smap_value_dbg : Type :=
| SymBasicVal' (val: sstack_val_dbg)
| SymMETAPUSH' (cat: N) (val: N)
| SymOp' (label : stack_op_instr) (args : sstack_dbg)
| SymMLOAD' (offset: sstack_val_dbg) (smem : smemory_dbg)
| SymSLOAD' (key: sstack_val_dbg) (sstrg : sstorage_dbg)
| SymSHA3' (offset: sstack_val_dbg) (size: sstack_val_dbg) (smem : smemory_dbg).
Definition sbinding_dbg : Type := nat*smap_value_dbg.
Definition sbindings_dbg : Type := list sbinding_dbg.
Inductive smap_dbg := SymMap' (maxid : nat) (bindings: sbindings_dbg).
Inductive sstate_dbg :=
| SymExState' (instk_height: nat) (sstk: sstack_dbg) (smem: smemory_dbg)
(sstg: sstorage_dbg) (sexts : sexternals) (sm: smap_dbg).
Definition sstack_val_to_dbg (v: sstack_val) : sstack_val_dbg :=
match v with
| Val v => Val' (wordToN v)
| InStackVar var => InStackVar' var
| FreshVar var => FreshVar' var
end.
Definition sstack_to_dbg (s: sstack) : sstack_dbg :=
map sstack_val_to_dbg s.
Definition memory_update_to_dbg (mu: memory_update sstack_val) :
memory_update sstack_val_dbg :=
match mu with
| U_MSTORE _ offset value => U_MSTORE sstack_val_dbg (sstack_val_to_dbg offset)
(sstack_val_to_dbg value)
| U_MSTORE8 _ offset value => U_MSTORE8 sstack_val_dbg (sstack_val_to_dbg offset)
(sstack_val_to_dbg value)
end.
Definition smemory_to_dbg (mem: smemory) : smemory_dbg :=
map memory_update_to_dbg mem.
Definition sstorage_update_to_dbg (su: storage_update sstack_val) :
storage_update sstack_val_dbg :=
match su with
| U_SSTORE _ key value => U_SSTORE sstack_val_dbg (sstack_val_to_dbg key)
(sstack_val_to_dbg value)
end.
Definition sstorage_to_dbg (sto: sstorage) : sstorage_dbg :=
map sstorage_update_to_dbg sto.
Definition smap_value_to_dbg (smv: smap_value) : smap_value_dbg :=
match smv with
| SymBasicVal v => SymBasicVal' (sstack_val_to_dbg v)
| SymMETAPUSH cat v => SymMETAPUSH' cat v
| SymOp label args => SymOp' label (sstack_to_dbg args)
| SymMLOAD offset smem => SymMLOAD' (sstack_val_to_dbg offset)
(smemory_to_dbg smem)
| SymSLOAD key sstrg => SymSLOAD' (sstack_val_to_dbg key)
(sstorage_to_dbg sstrg)
| SymSHA3 offset size smem => SymSHA3' (sstack_val_to_dbg offset)
(sstack_val_to_dbg size)
(smemory_to_dbg smem)
end.
Definition sbinding_to_dbg (b: sbinding) : sbinding_dbg :=
match b with
| (n,v) => (n, smap_value_to_dbg v)
end.
Definition sbindings_to_dbg (bs: sbindings) : sbindings_dbg :=
map sbinding_to_dbg bs.
Definition smap_to_dbg (sm: smap) : smap_dbg :=
match sm with
| SymMap m bs => SymMap' m (sbindings_to_dbg bs)
end.
Definition sstate_to_dbg (s: sstate) : sstate_dbg :=
match s with
| SymExState instk_height sstk smem sstg sexts sm =>
SymExState' instk_height (sstack_to_dbg sstk) (smemory_to_dbg smem)
(sstorage_to_dbg sstg) sexts (smap_to_dbg sm)
end.
Definition evm_eq_block_chkr'_dbg
(memory_updater: smemory_updater_ext_type)
(storage_updater: sstorage_updater_ext_type)
(mload_solver: mload_solver_ext_type)
(sload_solver: sload_solver_ext_type)
(sstack_value_cmp_ext: sstack_val_cmp_ext_2_t)
(smemory_cmp_ext: smemory_cmp_ext_t)
(sstorage_cmp_ext: sstorage_cmp_ext_t)
(sha3_cmp_ext: sha3_cmp_ext_t)
(*(opt: optim)*)
(opt_pipeline: opt_pipeline)
(opt_step_rep: nat)
(opt_pipeline_rep: nat)
(***)
(opt_p p: block)
(k: nat)
: (bool * option sstate_dbg * option sstate_dbg) :=
let sstack_value_cmp_1 := sstack_value_cmp_ext smemory_cmp_ext sstorage_cmp_ext sha3_cmp_ext in
let memory_updater' := memory_updater sstack_value_cmp_1 in
let storage_updater' := storage_updater sstack_value_cmp_1 in
let mload_solver' := mload_solver sstack_value_cmp_1 in
let sload_solver' := sload_solver sstack_value_cmp_1 in
match evm_sym_exec memory_updater' storage_updater' mload_solver' sload_solver' opt_p k evm_stack_opm with
| None => (false, None, None)
| Some sst_opt =>
match evm_sym_exec memory_updater' storage_updater' mload_solver' sload_solver' p k evm_stack_opm with
| None => (false, Some (sstate_to_dbg sst_opt), None)
| Some sst_p => (* Builds optimization *)
let maxid := S (max (get_maxidx_smap (get_smap_sst sst_opt)) (get_maxidx_smap (get_smap_sst sst_p))) in
let sstack_value_cmp := sstack_value_cmp_1 maxid in
let opt := apply_opt_n_times_pipeline_k opt_pipeline
sstack_value_cmp opt_step_rep
opt_pipeline_rep in
let (sst_opt', _) := opt sst_opt in
let (sst_p', _) := opt sst_p in
let d := S (max (get_maxidx_smap (get_smap_sst sst_opt')) (get_maxidx_smap (get_smap_sst sst_p'))) in
let sstack_value_cmp := sstack_value_cmp_1 d in
let smemory_cmp := smemory_cmp_ext sstack_value_cmp in
let sstorage_cmp := sstorage_cmp_ext sstack_value_cmp in
(sstate_cmp sstack_value_cmp smemory_cmp sstorage_cmp sst_p' sst_opt' evm_stack_opm,
Some (sstate_to_dbg sst_opt'), Some (sstate_to_dbg sst_p'))
end
end.
Definition evm_eq_block_chkr_lazy_dbg
(memory_updater_tag: available_smemory_updaters)
(storage_updater_tag: available_sstorage_updaters)
(mload_solver_tag: available_mload_solvers)
(sload_solver_tag: available_sload_solvers)
(sstack_value_cmp_tag: available_sstack_val_cmp)
(memory_cmp_tag: available_memory_cmp)
(storage_cmp_tag: available_storage_cmp)
(sha3_cmp_tag: available_sha3_cmp)
(*(opt: optim)*)
(optimization_steps: list_opt_steps)
(opt_step_rep: nat)
(opt_pipeline_rep: nat) :=
match get_smemory_updater memory_updater_tag with
| SMemUpdater memory_updater _ =>
match get_sstorage_updater storage_updater_tag with
| SStrgUpdater storage_updater _ =>
match get_mload_solver mload_solver_tag with
| MLoadSolver mload_solver _ =>
match get_sload_solver sload_solver_tag with
| SLoadSolver sload_solver _ =>
match get_sstack_val_cmp sstack_value_cmp_tag with
| SStackValCmp sstack_val_cmp _ _ =>
match get_memory_cmp memory_cmp_tag with
| SMemCmp memory_cmp _ =>
match get_storage_cmp storage_cmp_tag with
| SStrgCmp storage_cmp _ =>
match get_sha3_cmp sha3_cmp_tag with
| SHA3Cmp sha3_cmp _ =>
match get_pipeline optimization_steps with
| opt_pipeline =>
fun (opt_p p: block) (k: nat) =>
evm_eq_block_chkr'_dbg memory_updater storage_updater mload_solver sload_solver sstack_val_cmp memory_cmp storage_cmp sha3_cmp opt_pipeline opt_step_rep opt_pipeline_rep opt_p p k
end
end
end
end
end
end
end
end
end.
(*
(* Rule ADD(ADD(Const, X), Y) = ADD(Const, ADD(X, Y)) *)
Eval cbv in
let b1 := str2block "PUSH1 0x1 ADD ADD" in
let b2 := str2block "ADD PUSH1 0x1 ADD" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
*)
(* blocks from blockTraces_dec_1_2022_false_negative.4.txt *)
(*
(* Example 12 *)
Eval cbv in
let b1 := str2block "PUSH1 0x20 SWAP1 DUP2 MUL SWAP2 SWAP1 SWAP2 ADD ADD MLOAD MLOAD PUSH1 0x1 METAPUSH 5 0x245" in
let b2 := str2block "PUSH1 0x20 MUL PUSH1 0x20 ADD ADD MLOAD PUSH1 0x0 ADD MLOAD PUSH1 0x1 PUSH1 0x2 DUP2 LT METAPUSH 5 0x245 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
*)
(*
(* Example 11 *)
Eval cbv in
let b1 := str2block "PUSH1 0x20 SWAP1 DUP2 MUL SWAP2 SWAP1 SWAP2 ADD ADD MLOAD MLOAD PUSH1 0x0 METAPUSH 5 0x237" in
let b2 := str2block "PUSH1 0x20 MUL PUSH1 0x20 ADD ADD MLOAD PUSH1 0x0 ADD MLOAD PUSH1 0x0 PUSH1 0x2 DUP2 LT METAPUSH 5 0x237 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
*)
(*
Big example, unable to execute with coqc with basic memory comparator
*)
(*
Eval cbv in
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD DUP1 DUP3 ADD DUP3 MSTORE PUSH32 0x1C76476F4DEF4BB94541D57EBBA1193381FFA7AA76ADA664DD31C16024C43F59 DUP2 MSTORE PUSH32 0x3034DD2920F673E204FEE2811C678745FC819B55D3E9D294E45C9B03A76AEF41 PUSH1 0x20 DUP1 DUP4 ADD SWAP2 SWAP1 SWAP2 MSTORE SWAP1 DUP4 MSTORE DUP2 MLOAD DUP1 DUP4 ADD DUP4 MSTORE PUSH32 0x111E129F1CF1097710D41C4AC70FCDFA5BA2023C6FF1CBEAC322DE49D1B6DF7C DUP2 MSTORE PUSH32 0x103188585E2364128FE25C70558F1560F4F9350BAF3959E603CC91486E110936 DUP2 DUP4 ADD MSTORE DUP4 DUP3 ADD MSTORE DUP2 MLOAD PUSH1 0x80 DUP1 DUP3 ADD DUP5 MSTORE PUSH32 0x1213D2149B006137FCFB23036606F848D638D576A120CA981B5B1A5F9300B3EE DUP3 DUP6 ADD SWAP1 DUP2 MSTORE PUSH32 0x2276CF730CF493CD95D64677BBB75FC42DB72513A4C1E387B476D056F80AA75F PUSH1 0x60 DUP1 DUP6 ADD SWAP2 SWAP1 SWAP2 MSTORE SWAP1 DUP4 MSTORE DUP5 MLOAD DUP1 DUP7 ADD DUP7 MSTORE PUSH32 0x21EE6226D31426322AFCDA621464D0611D226783262E21BB3BC86B537E986237 DUP2 MSTORE PUSH32 0x96DF1F82DFF337DD5972E32A8AD43E28A78A96A823EF1CD4DEBE12B6552EA5F DUP2 DUP7 ADD MSTORE DUP4 DUP6 ADD MSTORE DUP6 DUP6 ADD SWAP3 SWAP1 SWAP3 MSTORE DUP4 MLOAD DUP1 DUP6 ADD DUP6 MSTORE PUSH32 0x6967A1237EBFECA9AAAE0D6D0BAB8E28C198C5A339EF8A2407E31CDAC516DB9 DUP2 MSTORE PUSH32 0xE4E3ED0898BA2CE904A02B739CAF9931F9B43C600154592CEE5239435F91F76 DUP2 DUP6 ADD MSTORE SWAP2 DUP6 ADD SWAP2 SWAP1 SWAP2 MSTORE DUP3 MLOAD DUP1 DUP5 ADD DUP5 MSTORE PUSH32 0xF25929BCB43D5A57391564615C9E70A992B10EAFA4DB109709649CF48C50DD2 DUP2 MSTORE PUSH32 0x16DA2F5CB6BE7A0AA72C440C53C9BBDFEC6C36C7D515536431B3A865468ACBBA DUP2 DUP5 ADD MSTORE SWAP1 DUP5 ADD MSTORE DUP2 MLOAD DUP1 DUP4 ADD DUP4 MSTORE PUSH32 0x1B9E027BD5CFC2CB5DB82D4DC9677AC795EC500ECD47DEEE3B5DA006D6D049B8 DUP2 MSTORE PUSH32 0x1E8CFD56691C1245342D15EFF3D1CE17C85FED7538C3614D46996D8F85A5C226 DUP2 DUP4 ADD MSTORE PUSH1 0xA0 DUP5 ADD MSTORE DUP2 MLOAD DUP1 DUP4 ADD DUP4 MSTORE PUSH32 0x1ABB4A25EB9379AE96C84FFF9F0540ABCFC0A0D11AEDA02D4F37E4BAF74CB0C1 DUP2 MSTORE PUSH32 0x1FF09A73B455ECA26257DC97DBE2C2572E162A9EEFC4CE83AC7869B267ACC4DE DUP2 DUP4 ADD MSTORE PUSH1 0xE0 DUP5 ADD MSTORE DUP2 MLOAD DUP1 DUP4 ADD SWAP1 SWAP3 MSTORE PUSH32 0x2F2EA0B3DA1E8EF11914ACF8B2E1B32D99DF51F5F4F206FC6B947EAE860EDDB6 DUP3 MSTORE PUSH32 0x68134DDB33DC888EF446B648D72338684D678D2EB2371C61A50734D78DA4B72 SWAP1 DUP3 ADD MSTORE PUSH1 0xC0 DUP3 ADD MSTORE DUP2 MLOAD PUSH32 0x1EEC35A0E955CAD4BEE5846AE0F1D0B742D8636B278450C534E38E06A60509F9 SWAP1 DUP4 SWAP1 PUSH1 0x0 SWAP1 ISZERO ISZERO METAPUSH 5 0x41 JUMPI" in
let b2 := str2block "PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x1C76476F4DEF4BB94541D57EBBA1193381FFA7AA76ADA664DD31C16024C43F59 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x3034DD2920F673E204FEE2811C678745FC819B55D3E9D294E45C9B03A76AEF41 DUP2 MSTORE POP DUP2 PUSH1 0x0 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x111E129F1CF1097710D41C4AC70FCDFA5BA2023C6FF1CBEAC322DE49D1B6DF7C DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x103188585E2364128FE25C70558F1560F4F9350BAF3959E603CC91486E110936 DUP2 MSTORE POP DUP2 PUSH1 0x20 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x1213D2149B006137FCFB23036606F848D638D576A120CA981B5B1A5F9300B3EE DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x2276CF730CF493CD95D64677BBB75FC42DB72513A4C1E387B476D056F80AA75F DUP2 MSTORE POP DUP2 MSTORE PUSH1 0x20 ADD PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x21EE6226D31426322AFCDA621464D0611D226783262E21BB3BC86B537E986237 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x96DF1F82DFF337DD5972E32A8AD43E28A78A96A823EF1CD4DEBE12B6552EA5F DUP2 MSTORE POP DUP2 MSTORE POP DUP2 PUSH1 0x40 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x6967A1237EBFECA9AAAE0D6D0BAB8E28C198C5A339EF8A2407E31CDAC516DB9 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0xE4E3ED0898BA2CE904A02B739CAF9931F9B43C600154592CEE5239435F91F76 DUP2 MSTORE POP DUP2 PUSH1 0x60 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0xF25929BCB43D5A57391564615C9E70A992B10EAFA4DB109709649CF48C50DD2 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x16DA2F5CB6BE7A0AA72C440C53C9BBDFEC6C36C7D515536431B3A865468ACBBA DUP2 MSTORE POP DUP2 PUSH1 0x80 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x1B9E027BD5CFC2CB5DB82D4DC9677AC795EC500ECD47DEEE3B5DA006D6D049B8 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x1E8CFD56691C1245342D15EFF3D1CE17C85FED7538C3614D46996D8F85A5C226 DUP2 MSTORE POP DUP2 PUSH1 0xA0 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x1ABB4A25EB9379AE96C84FFF9F0540ABCFC0A0D11AEDA02D4F37E4BAF74CB0C1 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x1FF09A73B455ECA26257DC97DBE2C2572E162A9EEFC4CE83AC7869B267ACC4DE DUP2 MSTORE POP DUP2 PUSH1 0xE0 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x2F2EA0B3DA1E8EF11914ACF8B2E1B32D99DF51F5F4F206FC6B947EAE860EDDB6 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x68134DDB33DC888EF446B648D72338684D678D2EB2371C61A50734D78DA4B72 DUP2 MSTORE POP DUP2 PUSH1 0xC0 ADD DUP2 SWAP1 MSTORE POP PUSH32 0x1EEC35A0E955CAD4BEE5846AE0F1D0B742D8636B278450C534E38E06A60509F9 DUP3 PUSH1 0x0 DUP2 MLOAD DUP2 LT METAPUSH 5 0x41 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Trivial SMemCmp_Trivial
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
*)
(* blocks from blockTraces_dec_1_2022_false_negative.3.txt *)
(*
(* NOT *)
(* Example: 1 *)
(* store --> ADD(ADD(MUL(32, xO), x1), 32) =? ADD(ADD(32,MUL(32,x0)), x1) *)
Eval cbv in
let b1 := str2block "PUSH1 0x20 SWAP1 DUP2 MUL SWAP2 SWAP1 SWAP2 ADD ADD MSTORE DUP1 METAPUSH 5 0x266 DUP2 METAPUSH 5 0x171" in
let b2 := str2block "PUSH1 0x20 MUL PUSH1 0x20 ADD ADD DUP2 DUP2 MSTORE POP POP DUP1 DUP1 METAPUSH 5 0x266 SWAP1 METAPUSH 5 0x171" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 5).
*)
(* Example: 4 *)
(* ISZERO(ISZERO(SLT(X, Y))) = SLT(X,Y)
*)
(*Eval cbv in
let b1 := str2block "PUSH8 0xDE0B6B3A7640000 SWAP2 DUP3 DUP3 SLT METAPUSH 5 0x533 JUMPI" in
let b2 := str2block "PUSH8 0xDE0B6B3A7640000 SWAP2 DUP3 DUP3 SLT ISZERO PUSH1 0x0 EQ METAPUSH 5 0x533 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 3).
*)
(*
(* NOT *)
(* Example: 5 *)
(*
# ADD(ADD(Const, X), Y) = ADD(Const, ADD(X, Y))
# SHR(X, SHL(X, SHR(X, V))) = SHR(X, V)
# AND(16777215, AND(255,X)) = AND(255, X)
# AND(255, SHR(248,X)) = SHR(248, X)
*)
Eval cbv in
let b1 := str2block "ADD PUSH1 0x20 ADD MLOAD METAPUSH 5 0x85 SWAP3 SWAP2 PUSH1 0xF8 SWAP2 SWAP1 SWAP2 SHR SWAP1 SHL METAPUSH 5 0x86" in
let b2 := str2block "PUSH1 0x20 ADD ADD MLOAD PUSH1 0xF8 SHR PUSH1 0xF8 SHL PUSH1 0xF8 SHR PUSH1 0xFF AND PUSH3 0xFFFFFF AND SWAP1 SHL METAPUSH 5 0x85 SWAP2 SWAP1 METAPUSH 5 0x86" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 6).
(* NOT *)
(* Example: 6 *)
(* AND(63, SHR(6, AND(16777215, X))) = AND(63, SHR(6, X))
AND(255, AND(63, X)) = AND(X, 63)
*)
Eval cbv in
let b1 := str2block "DUP6 MLOAD SWAP1 SWAP2 POP DUP6 SWAP1 PUSH1 0x3F PUSH1 0x12 DUP5 SWAP1 SHR AND SWAP1 DUP2 LT METAPUSH 5 0x89 JUMPI" in
let b2 := str2block "SWAP1 POP DUP5 PUSH1 0x12 DUP3 PUSH3 0xFFFFFF AND SWAP1 SHR PUSH1 0x3F AND PUSH1 0xFF AND DUP2 MLOAD DUP2 LT METAPUSH 5 0x89 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 6).
(* NOT *)
(* Example: 7 *)
(* a) Combine SHR-SHL by constant
https://github.com/ethereum/solidity/blob/7893614a31fbeacd1966994e310ed4f760772658/libevmasm/RuleList.h#L530
SHL(248, SHR(248, X)) = AND(0xFF00..00, X)
b) ADD(ADD(Const, X), Y) = ADD(Const, ADD(X, Y))
*)
Eval cbv in
let b1 := str2block "POP DUP5 MLOAD DUP6 SWAP1 PUSH1 0x3F PUSH1 0xC DUP5 SWAP1 SHR AND SWAP1 DUP2 LT METAPUSH 5 0x94 JUMPI" in
let b2 := str2block "POP DUP5 PUSH1 0xC DUP3 PUSH3 0xFFFFFF AND SWAP1 SHR PUSH1 0x3F AND PUSH1 0xFF AND DUP2 MLOAD DUP2 LT METAPUSH 5 0x94 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 6).
(* NOT *)
(* Example: 8 *)
(* AND(63, SHR(6, AND(16777215, X))) = AND(63, SHR(6, X))
AND(255, AND(63, X)) = AND(X, 63)
*)
Eval cbv in
let b1 := str2block "POP DUP5 MLOAD DUP6 SWAP1 PUSH1 0x3F PUSH1 0xC DUP5 SWAP1 SHR AND SWAP1 DUP2 LT METAPUSH 5 0x94 JUMPI" in
let b2 := str2block "POP DUP5 PUSH1 0xC DUP3 PUSH3 0xFFFFFF AND SWAP1 SHR PUSH1 0x3F AND PUSH1 0xFF AND DUP2 MLOAD DUP2 LT METAPUSH 5 0x94 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 6).
(* NOT *)
(* Example: 9 *)
(* a) Combine SHR-SHL by constant
https://github.com/ethereum/solidity/blob/7893614a31fbeacd1966994e310ed4f760772658/libevmasm/RuleList.h#L530
SHL(248, SHR(248, X)) = AND(0xFF00..00, X)
b) ADD(ADD(Const, X), Y) = ADD(Const, ADD(X, Y))
*)
Eval cbv in
let b1 := str2block "ADD PUSH1 0x20 ADD MLOAD PUSH32 0xFF00000000000000000000000000000000000000000000000000000000000000 AND DUP5 DUP5 METAPUSH 5 0x95 DUP2 METAPUSH 5 0x28" in
let b2 := str2block "PUSH1 0x20 ADD ADD MLOAD PUSH1 0xF8 SHR PUSH1 0xF8 SHL DUP5 DUP5 DUP1 METAPUSH 5 0x95 SWAP1 METAPUSH 5 0x28" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 6).
(* NOT *)
(* Example: 10 *)
(* AND(63, SHR(6, AND(16777215, X))) = AND(63, SHR(6, X))
AND(255, AND(63, X)) = AND(X, 63)
*)
Eval cbv in
let b1 := str2block "POP DUP5 MLOAD DUP6 SWAP1 PUSH1 0x3F PUSH1 0x6 DUP5 SWAP1 SHR AND SWAP1 DUP2 LT METAPUSH 5 0x99 JUMPI" in
let b2 := str2block "POP DUP5 PUSH1 0x6 DUP3 PUSH3 0xFFFFFF AND SWAP1 SHR PUSH1 0x3F AND PUSH1 0xFF AND DUP2 MLOAD DUP2 LT METAPUSH 5 0x99 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 6).
(* NOT *)
(* Example: 11 *)
(* a) Combine SHR-SHL by constant
https://github.com/ethereum/solidity/blob/7893614a31fbeacd1966994e310ed4f760772658/libevmasm/RuleList.h#L530
SHL(248, SHR(248, X)) = AND(0xFF00..00, X)
b) ADD(ADD(Const, X), Y) = ADD(Const, ADD(X, Y))
*)
Eval cbv in
let b1 := str2block "ADD PUSH1 0x20 ADD MLOAD PUSH32 0xFF00000000000000000000000000000000000000000000000000000000000000 AND DUP5 DUP5 METAPUSH 5 0x100 DUP2 METAPUSH 5 0x28" in
let b2 := str2block "PUSH1 0x20 ADD ADD MLOAD PUSH1 0xF8 SHR PUSH1 0xF8 SHL DUP5 DUP5 DUP1 METAPUSH 5 0x100 SWAP1 METAPUSH 5 0x28" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 6).
(* NOT *)
(* Example: 12 *)
(* a) Combine SHR-SHL by constant
https://github.com/ethereum/solidity/blob/7893614a31fbeacd1966994e310ed4f760772658/libevmasm/RuleList.h#L530
SHL(248, SHR(248, X)) = AND(0xFF00..00, X)
b) ADD(ADD(Const, X), Y) = ADD(Const, ADD(X, Y))
*)
Eval cbv in
let b1 := str2block "ADD PUSH1 0x20 ADD MLOAD PUSH32 0xFF00000000000000000000000000000000000000000000000000000000000000 AND DUP5 DUP5 METAPUSH 5 0x105 DUP2 METAPUSH 5 0x28" in
let b2 := str2block "PUSH1 0x20 ADD ADD MLOAD PUSH1 0xF8 SHR PUSH1 0xF8 SHL DUP5 DUP5 DUP1 METAPUSH 5 0x105 SWAP1 METAPUSH 5 0x28" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 6).
(* NOT *)
(* Example: 13 *)
(* store --> ADD(ADD(MUL(32, xO), x1), 32) =? ADD(ADD(32,MUL(32,x0)), x1) *)
Eval cbv in
let b1 := str2block "PUSH1 0x20 SWAP1 DUP2 MUL SWAP2 SWAP1 SWAP2 ADD ADD MSTORE PUSH1 0x0 METAPUSH 5 0x61 DUP4 DUP4 PUSH4 0xFFFFFFFF METAPUSH 5 0x62 AND" in
let b2 := str2block "PUSH1 0x20 MUL PUSH1 0x20 ADD ADD DUP2 SWAP1 MSTORE POP PUSH1 0x0 METAPUSH 5 0x61 DUP3 DUP5 METAPUSH 5 0x62 SWAP1 SWAP2 SWAP1 PUSH4 0xFFFFFFFF AND" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 5).
*)
(***********************************************)
(* Blocks from blockTraces_dec_1_2022_nodups.txt *)
(*
(* Block 47: *)
Compute
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD PUSH1 0x80 DUP1 DUP3 ADD DUP4 MSTORE PUSH32 0x209DD15EBFF5D46C4BD888E51A93CF99A7329636C63514396B4A452003A35BF7 DUP3 DUP5 ADD SWAP1 DUP2 MSTORE PUSH32 0x4BF11CA01483BFA8B34B43561848D28905960114C8AC04049AF4B6315A41678 PUSH1 0x60 DUP1 DUP6 ADD SWAP2 SWAP1 SWAP2 MSTORE SWAP1 DUP4 MSTORE DUP4 MLOAD DUP1 DUP6 ADD DUP6 MSTORE PUSH32 0x2BB8324AF6CFC93537A2AD1A445CFD0CA2A71ACD7AC41FADBF933C2A51BE344D DUP2 MSTORE PUSH32 0x120A2A4CF30C1BF9845F20C6FE39E07EA2CCE61F0C9BB048165FE5E4DE877550 PUSH1 0x20 DUP3 DUP2 ADD SWAP2 SWAP1 SWAP2 MSTORE DUP1 DUP6 ADD SWAP2 SWAP1 SWAP2 MSTORE SWAP3 DUP6 MSTORE DUP4 MLOAD DUP1 DUP6 ADD DUP6 MSTORE PUSH32 0x2ECA0C7238BF16E83E7A1E6C5D49540685FF51380F309842A98561558019FC02 DUP2 MSTORE PUSH32 0x3D3260361BB8451DE5FF5ECD17F010FF22F5C31CDF184E9020B06FA5997DB84 DUP2 DUP6 ADD MSTORE DUP6 DUP5 ADD MSTORE DUP4 MLOAD DUP1 DUP4 ADD DUP6 MSTORE PUSH32 0x2E89718AD33C8BED92E210E81D1853435399A271913A6520736A4729CF0D51EB DUP2 DUP7 ADD SWAP1 DUP2 MSTORE PUSH32 0x1A9E2FFA2E92599B68E44DE5BCF354FA2642BD4F26B259DAA6F7CE3ED57AEB3 DUP3 DUP5 ADD MSTORE DUP2 MSTORE DUP5 MLOAD DUP1 DUP7 ADD DUP7 MSTORE PUSH32 0x14A9A87B789A58AF499B314E13C3D65BEDE56C07EA2D418D6874857B70763713 DUP2 MSTORE PUSH32 0x178FB49A2D6CD347DC58973FF49613A20757D0FCC22079F9ABD10C3BAEE24590 DUP2 DUP7 ADD MSTORE DUP2 DUP6 ADD MSTORE DUP6 DUP6 ADD MSTORE DUP4 MLOAD DUP1 DUP4 ADD DUP6 MSTORE PUSH32 0x25F83C8B6AB9DE74E7DA488EF02645C5A16A6652C3C71A15DC37FE3A5DCB7CB1 DUP2 DUP7 ADD SWAP1 DUP2 MSTORE PUSH32 0x22ACDEDD6308E3BB230D226D16A105295F523A8A02BFC5E8BD2DA135AC4C245D DUP3 DUP5 ADD MSTORE DUP2 MSTORE DUP5 MLOAD DUP1 DUP7 ADD DUP7 MSTORE PUSH32 0x65BBAD92E7C4E31BF3757F1FE7362A63FBFEE50E7DC68DA116E67D600D9BF68 DUP2 MSTORE PUSH32 0x6D302580DC0661002994E7CD3A7F224E7DDC27802777486BF80F40E4CA3CFDB DUP2 DUP7 ADD MSTORE DUP2 DUP6 ADD MSTORE DUP6 DUP3 ADD MSTORE DUP4 MLOAD DUP1 DUP6 ADD DUP6 MSTORE PUSH32 0x15794AB061441E51D01E94640B7E3084A07E02C78CF3103C542BC5B298669F21 DUP2 MSTORE PUSH32 0x14DB745C6780E9DF549864CEC19C2DAF4531F6EC0C89CC1C7436CC4D8D300C6D DUP2 DUP6 ADD MSTORE DUP6 DUP4 ADD MSTORE DUP4 MLOAD DUP1 DUP4 ADD DUP6 MSTORE PUSH32 0x1F39E4E4AFC4BC74790A4A028AFF2C3D2538731FB755EDEFD8CB48D6EA589B5E DUP2 DUP7 ADD SWAP1 DUP2 MSTORE PUSH32 0x283F150794B6736F670D6A1033F9B46C6F5204F50813EB85C8DC4B59DB1C5D39 DUP3 DUP5 ADD MSTORE DUP2 MSTORE DUP5 MLOAD DUP1 DUP7 ADD DUP7 MSTORE PUSH32 0x140D97EE4D2B36D99BC49974D18ECCA3E7AD51011956051B464D9E27D46CC25E DUP2 MSTORE PUSH32 0x764BB98575BD466D32DB7B15F582B2D5C452B36AA394B789366E5E3CA5AABD4 DUP2 DUP7 ADD MSTORE DUP2 DUP6 ADD MSTORE PUSH1 0xA0 DUP7 ADD MSTORE DUP4 MLOAD SWAP2 DUP3 ADD DUP5 MSTORE PUSH32 0x217CEE0A9AD79A4493B5253E2E4E3A39FC2DF38419F230D341F60CB064A0AC29 DUP3 DUP6 ADD SWAP1 DUP2 MSTORE PUSH32 0xA3D76F140DB8418BA512272381446EB73958670F00CF46F1D9E64CBA057B53C SWAP2 DUP4 ADD SWAP2 SWAP1 SWAP2 MSTORE DUP2 MSTORE DUP3 MLOAD DUP1 DUP5 ADD SWAP1 SWAP4 MSTORE PUSH32 0x26F64A8EC70387A13E41430ED3EE4A7DB2059CC5FC13C067194BCC0CB49A9855 DUP4 MSTORE PUSH32 0x2FD72BD9EDB657346127DA132E5B82AB908F5816C826ACB499E22F2412D1A2D7 DUP4 DUP4 ADD MSTORE SWAP1 DUP2 ADD SWAP2 SWAP1 SWAP2 MSTORE PUSH1 0xC0 DUP3 ADD MSTORE PUSH1 0xA METAPUSH 5 0x278" in
let b2 := str2block "PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x209DD15EBFF5D46C4BD888E51A93CF99A7329636C63514396B4A452003A35BF7 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x4BF11CA01483BFA8B34B43561848D28905960114C8AC04049AF4B6315A41678 DUP2 MSTORE POP DUP2 MSTORE PUSH1 0x20 ADD PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x2BB8324AF6CFC93537A2AD1A445CFD0CA2A71ACD7AC41FADBF933C2A51BE344D DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x120A2A4CF30C1BF9845F20C6FE39E07EA2CCE61F0C9BB048165FE5E4DE877550 DUP2 MSTORE POP DUP2 MSTORE POP DUP2 PUSH1 0x0 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x2ECA0C7238BF16E83E7A1E6C5D49540685FF51380F309842A98561558019FC02 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x3D3260361BB8451DE5FF5ECD17F010FF22F5C31CDF184E9020B06FA5997DB84 DUP2 MSTORE POP DUP2 PUSH1 0x20 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x2E89718AD33C8BED92E210E81D1853435399A271913A6520736A4729CF0D51EB DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x1A9E2FFA2E92599B68E44DE5BCF354FA2642BD4F26B259DAA6F7CE3ED57AEB3 DUP2 MSTORE POP DUP2 MSTORE PUSH1 0x20 ADD PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x14A9A87B789A58AF499B314E13C3D65BEDE56C07EA2D418D6874857B70763713 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x178FB49A2D6CD347DC58973FF49613A20757D0FCC22079F9ABD10C3BAEE24590 DUP2 MSTORE POP DUP2 MSTORE POP DUP2 PUSH1 0x40 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x25F83C8B6AB9DE74E7DA488EF02645C5A16A6652C3C71A15DC37FE3A5DCB7CB1 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x22ACDEDD6308E3BB230D226D16A105295F523A8A02BFC5E8BD2DA135AC4C245D DUP2 MSTORE POP DUP2 MSTORE PUSH1 0x20 ADD PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x65BBAD92E7C4E31BF3757F1FE7362A63FBFEE50E7DC68DA116E67D600D9BF68 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x6D302580DC0661002994E7CD3A7F224E7DDC27802777486BF80F40E4CA3CFDB DUP2 MSTORE POP DUP2 MSTORE POP DUP2 PUSH1 0x60 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x15794AB061441E51D01E94640B7E3084A07E02C78CF3103C542BC5B298669F21 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x14DB745C6780E9DF549864CEC19C2DAF4531F6EC0C89CC1C7436CC4D8D300C6D DUP2 MSTORE POP DUP2 PUSH1 0x80 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x1F39E4E4AFC4BC74790A4A028AFF2C3D2538731FB755EDEFD8CB48D6EA589B5E DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x283F150794B6736F670D6A1033F9B46C6F5204F50813EB85C8DC4B59DB1C5D39 DUP2 MSTORE POP DUP2 MSTORE PUSH1 0x20 ADD PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x140D97EE4D2B36D99BC49974D18ECCA3E7AD51011956051B464D9E27D46CC25E DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x764BB98575BD466D32DB7B15F582B2D5C452B36AA394B789366E5E3CA5AABD4 DUP2 MSTORE POP DUP2 MSTORE POP DUP2 PUSH1 0xA0 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x217CEE0A9AD79A4493B5253E2E4E3A39FC2DF38419F230D341F60CB064A0AC29 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0xA3D76F140DB8418BA512272381446EB73958670F00CF46F1D9E64CBA057B53C DUP2 MSTORE POP DUP2 MSTORE PUSH1 0x20 ADD PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0x26F64A8EC70387A13E41430ED3EE4A7DB2059CC5FC13C067194BCC0CB49A9855 DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x2FD72BD9EDB657346127DA132E5B82AB908F5816C826ACB499E22F2412D1A2D7 DUP2 MSTORE POP DUP2 MSTORE POP DUP2 PUSH1 0xC0 ADD DUP2 SWAP1 MSTORE POP PUSH1 0xA PUSH8 0xFFFFFFFFFFFFFFFF DUP2 GT ISZERO METAPUSH 5 0x278 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 1 1 b1 b2 2).
*)
(*
(* Block 1021: *)
Compute
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD PUSH1 0x2 DUP1 DUP3 MSTORE PUSH1 0x60 DUP3 ADD SWAP1 SWAP3 MSTORE SWAP2 SWAP3 POP PUSH1 0x0 SWAP2 SWAP1" in
let b2 := str2block "SWAP1 POP PUSH1 0x0 PUSH1 0x2 PUSH1 0x40 MLOAD SWAP1 DUP1 DUP3 MSTORE DUP1 PUSH1 0x20 MUL PUSH1 0x20 ADD DUP3 ADD PUSH1 0x40 MSTORE DUP1 ISZERO METAPUSH 5 0x52 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
(* Block 1002: ADD(X,2^256-1) = SUB(X,1) *)
Compute
let b1 := str2block "SWAP1 MLOAD DUP3 MLOAD PUSH32 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF PUSH1 0x20 SWAP4 SWAP1 SWAP4 SUB PUSH2 0x100 EXP SWAP3 SWAP1 SWAP3 ADD SWAP2 DUP3 AND SWAP2 NOT AND OR SWAP1 MSTORE" in
let b2 := str2block "PUSH1 0x0 PUSH1 0x1 DUP3 PUSH1 0x20 SUB PUSH2 0x100 EXP SUB SWAP1 POP DUP1 NOT DUP4 MLOAD AND DUP2 DUP6 MLOAD AND DUP2 DUP2 OR DUP7 MSTORE POP POP POP POP POP POP" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 3).
(* Block 942: ADD(X, ADD(Y,Z)) = ADD(ADD(X,Y),Z) *)
Compute
let b1 := str2block "PUSH1 0x20 SWAP1 DUP2 MUL SWAP2 SWAP1 SWAP2 ADD ADD MSTORE PUSH1 0x0 METAPUSH 5 0x61 DUP4 DUP4 PUSH4 0xFFFFFFFF METAPUSH 5 0x62 AND" in
let b2 := str2block "PUSH1 0x20 MUL PUSH1 0x20 ADD ADD DUP2 SWAP1 MSTORE POP PUSH1 0x0 METAPUSH 5 0x61 DUP3 DUP5 METAPUSH 5 0x62 SWAP1 SWAP2 SWAP1 PUSH4 0xFFFFFFFF AND" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 5).
(* Block 837: ADD(X, ADD(Y,Z)) = ADD(ADD(X,Y),Z) *)
Compute
let b1 := str2block "ADD PUSH1 0x20 ADD MLOAD METAPUSH 5 0x85 SWAP3 SWAP2 PUSH1 0xF8 SWAP2 SWAP1 SWAP2 SHR SWAP1 SHL METAPUSH 5 0x86" in
let b2 := str2block "PUSH1 0x20 ADD ADD MLOAD PUSH1 0xF8 SHR PUSH1 0xF8 SHL PUSH1 0xF8 SHR PUSH1 0xFF AND PUSH3 0xFFFFFF AND SWAP1 SHL METAPUSH 5 0x85 SWAP2 SWAP1 METAPUSH 5 0x86" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 4).
(* Block 816: SLT(X,Y) = ISZERO(ISZERO(SLT(X,Y))) *)
Compute
let b1 := str2block "PUSH8 0xDE0B6B3A7640000 SWAP2 DUP3 DUP3 SLT METAPUSH 5 0x533 JUMPI" in
let b2 := str2block "PUSH8 0xDE0B6B3A7640000 SWAP2 DUP3 DUP3 SLT ISZERO PUSH1 0x0 EQ METAPUSH 5 0x533 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 5).
(* Block #650: ADD(X,2^256-N) = SUB(X,N) *)
Compute
let b1 := str2block "PUSH8 0xDE0B6B3A7640000 DUP2 MUL SWAP4 POP SWAP1 POP DUP4 DUP2 SAR PUSH32 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF21F494C589C0000 DUP2 ADD METAPUSH 5 0x270 JUMPI" in
let b2 := str2block "SWAP1 POP PUSH8 0xDE0B6B3A7640000 DUP2 MUL SWAP3 POP PUSH1 0x0 DUP2 DUP6 SWAP1 SAR SWAP1 POP PUSH8 0xDE0B6B3A7640000 DUP2 SUB METAPUSH 5 0x270 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 5).
(* Block #512: ADD(164, X) = ADD(160, ADD(4,X)) *)
Compute
let b1 := str2block "PUSH1 0x40 MLOAD PUSH32 0x8C379A000000000000000000000000000000000000000000000000000000000 DUP2 MSTORE PUSH1 0x20 PUSH1 0x4 DUP3 ADD MSTORE PUSH1 0x54 PUSH1 0x24 DUP3 ADD MSTORE PUSH32 0x4465706F736974436F6E74726163743A207265636F6E73747275637465642044 PUSH1 0x44 DUP3 ADD MSTORE PUSH32 0x65706F7369744461746120646F6573206E6F74206D6174636820737570706C69 PUSH1 0x64 DUP3 ADD MSTORE PUSH32 0x6564206465706F7369745F646174615F726F6F74000000000000000000000000 PUSH1 0x84 DUP3 ADD MSTORE PUSH1 0xA4 ADD METAPUSH 5 0x31" in
let b2 := str2block "PUSH1 0x40 MLOAD PUSH32 0x8C379A000000000000000000000000000000000000000000000000000000000 DUP2 MSTORE PUSH1 0x4 ADD METAPUSH 5 0x31 SWAP1 PUSH1 0x20 DUP1 DUP3 MSTORE PUSH1 0x54 SWAP1 DUP3 ADD MSTORE PUSH32 0x4465706F736974436F6E74726163743A207265636F6E73747275637465642044 PUSH1 0x40 DUP3 ADD MSTORE PUSH32 0x65706F7369744461746120646F6573206E6F74206D6174636820737570706C69 PUSH1 0x60 DUP3 ADD MSTORE PUSH32 0x6564206465706F7369745F646174615F726F6F74000000000000000000000000 PUSH1 0x80 DUP3 ADD MSTORE PUSH1 0xA0 ADD SWAP1" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
(* Block #510: ADD(96, X) = ADD(64, ADD(32,X)) *)
Compute
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD PUSH1 0x20 DUP2 ADD SWAP4 SWAP1 SWAP4 MSTORE DUP3 ADD MSTORE PUSH1 0x60 ADD METAPUSH 5 0x80" in
let b2 := str2block "PUSH1 0x40 MLOAD PUSH1 0x20 ADD METAPUSH 5 0x80 SWAP3 SWAP2 SWAP1 SWAP2 DUP3 MSTORE PUSH1 0x20 DUP3 ADD MSTORE PUSH1 0x40 ADD SWAP1" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
(* Block #505: ADD(132, X) = ADD(128, ADD(4,X)) *)
Compute
let b1 := str2block "PUSH1 0x40 MLOAD PUSH32 0x8C379A000000000000000000000000000000000000000000000000000000000 DUP2 MSTORE PUSH1 0x20 PUSH1 0x4 DUP3 ADD MSTORE PUSH1 0x36 PUSH1 0x24 DUP3 ADD MSTORE PUSH32 0x4465706F736974436F6E74726163743A20696E76616C69642077697468647261 PUSH1 0x44 DUP3 ADD MSTORE PUSH32 0x77616C5F63726564656E7469616C73206C656E67746800000000000000000000 PUSH1 0x64 DUP3 ADD MSTORE PUSH1 0x84 ADD METAPUSH 5 0x31" in
let b2 := str2block "PUSH1 0x40 MLOAD PUSH32 0x8C379A000000000000000000000000000000000000000000000000000000000 DUP2 MSTORE PUSH1 0x4 ADD METAPUSH 5 0x31 SWAP1 PUSH1 0x20 DUP1 DUP3 MSTORE PUSH1 0x36 SWAP1 DUP3 ADD MSTORE PUSH32 0x4465706F736974436F6E74726163743A20696E76616C69642077697468647261 PUSH1 0x40 DUP3 ADD MSTORE PUSH32 0x77616C5F63726564656E7469616C73206C656E67746800000000000000000000 PUSH1 0x60 DUP3 ADD MSTORE PUSH1 0x80 ADD SWAP1" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 1).
(* Block #504: ADD(132, X) = ADD(128, ADD(4,X)) *)
Compute
let b1 := str2block "PUSH1 0x40 MLOAD PUSH32 0x8C379A000000000000000000000000000000000000000000000000000000000 DUP2 MSTORE PUSH1 0x20 PUSH1 0x4 DUP3 ADD MSTORE PUSH1 0x26 PUSH1 0x24 DUP3 ADD MSTORE PUSH32 0x4465706F736974436F6E74726163743A20696E76616C6964207075626B657920 PUSH1 0x44 DUP3 ADD MSTORE PUSH32 0x6C656E6774680000000000000000000000000000000000000000000000000000 PUSH1 0x64 DUP3 ADD MSTORE PUSH1 0x84 ADD METAPUSH 5 0x31" in
let b2 := str2block "PUSH1 0x40 MLOAD PUSH32 0x8C379A000000000000000000000000000000000000000000000000000000000 DUP2 MSTORE PUSH1 0x4 ADD METAPUSH 5 0x31 SWAP1 PUSH1 0x20 DUP1 DUP3 MSTORE PUSH1 0x26 SWAP1 DUP3 ADD MSTORE PUSH32 0x4465706F736974436F6E74726163743A20696E76616C6964207075626B657920 PUSH1 0x40 DUP3 ADD MSTORE PUSH32 0x6C656E6774680000000000000000000000000000000000000000000000000000 PUSH1 0x60 DUP3 ADD MSTORE PUSH1 0x80 ADD SWAP1" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 1).
(* Block 448: JUMPI(X,0) can be removed *)
Compute
let b1 := str2block "POP" in
let b2 := str2block "POP PUSH1 0x0 METAPUSH 5 0x135 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 1).
(* Block 432: ADD(X,2^256-N) = SUB(X,N) *)
Compute
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD PUSH32 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE0 DUP2 DUP5 SUB ADD DUP2 MSTORE SWAP1 DUP3 SWAP1 MSTORE METAPUSH 5 0x59 SWAP2 METAPUSH 5 0x60" in
let b2 := str2block "PUSH1 0x40 MLOAD PUSH1 0x20 DUP2 DUP4 SUB SUB DUP2 MSTORE SWAP1 PUSH1 0x40 MSTORE PUSH1 0x40 MLOAD METAPUSH 5 0x59 SWAP2 SWAP1 METAPUSH 5 0x60" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 1).
(* Block #190: ADD(X, 2^256-N) = SUB(X,N) *)
Compute
let b1 := str2block "PUSH8 0xDE0B6B3A7640000 DUP2 MUL SWAP3 POP SWAP1 POP DUP3 DUP2 SHR PUSH32 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF21F494C589C0000 DUP2 ADD METAPUSH 5 0x131 JUMPI" in
let b2 := str2block "SWAP1 POP PUSH8 0xDE0B6B3A7640000 DUP2 MUL SWAP2 POP PUSH1 0x0 DUP2 DUP5 SWAP1 SHR SWAP1 POP PUSH8 0xDE0B6B3A7640000 DUP2 SUB METAPUSH 5 0x131 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 4).
(* Block #188: ISZERO(ISZERO(X)) = GT(X,0) *)
(* Would require more optimization rules for confluency:
- GT(GT(X,Y),0) = GT(X,Y)
- GT(LT(X,Y),0) = LT(X,Y)
- GT(EQ(X,Y),0) = EQ(X,Y)
*)
Compute
let b1 := str2block "POP PUSH8 0xDE0B6B3A7640000 DUP1 DUP3 MOD DUP1 ISZERO ISZERO SWAP2 SUB MUL ADD SWAP1" in
let b2 := str2block "PUSH8 0xDE0B6B3A7640000 DUP3 MOD DUP1 PUSH8 0xDE0B6B3A7640000 SUB PUSH1 0x0 DUP3 GT DUP2 MUL DUP5 ADD SWAP3 POP POP POP SWAP2 SWAP1 POP" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 3).
(* Block #137: ADD(X, 2^255) = SUB(X, 2^255) *)
Compute
let b1 := str2block "PUSH1 0x0 PUSH32 0x8000000000000000000000000000000000000000000000000000000000000000 DUP3 ADD METAPUSH 5 0x108 JUMPI" in
let b2 := str2block "PUSH1 0x0 PUSH1 0x1 PUSH1 0xFF SHL DUP3 SUB METAPUSH 5 0x108 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 1).
(* Block #88: JUMPI(X,0) can be removed *)
Compute
let b1 := str2block "POP PUSH1 0x40 DUP1 MLOAD PUSH1 0x3 DUP1 DUP3 MSTORE PUSH1 0x80 DUP3 ADD SWAP1 SWAP3 MSTORE SWAP2 SWAP3 POP PUSH1 0x0 SWAP2 SWAP1" in
let b2 := str2block "POP SWAP1 POP PUSH1 0x0 PUSH1 0x3 PUSH1 0x40 MLOAD SWAP1 DUP1 DUP3 MSTORE DUP1 PUSH1 0x20 MUL PUSH1 0x20 ADD DUP3 ADD PUSH1 0x40 MSTORE DUP1 ISZERO METAPUSH 5 0x330 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 4).
(* Block #87: JUMPI(X,0) can be removed *)
Compute
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD PUSH1 0x3 DUP1 DUP3 MSTORE PUSH1 0x80 DUP3 ADD SWAP1 SWAP3 MSTORE PUSH1 0x0 SWAP2 DUP3 SWAP2 SWAP1" in
let b2 := str2block "PUSH1 0x0 DUP1 PUSH1 0x3 PUSH1 0x40 MLOAD SWAP1 DUP1 DUP3 MSTORE DUP1 PUSH1 0x20 MUL PUSH1 0x20 ADD DUP3 ADD PUSH1 0x40 MSTORE DUP1 ISZERO METAPUSH 5 0x325 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 4).
(* Block #86: JUMPI(X,0) can be removed *)
Compute
let b1 := str2block "POP PUSH1 0x40 DUP1 MLOAD PUSH1 0x2 DUP1 DUP3 MSTORE PUSH1 0x60 DUP3 ADD SWAP1 SWAP3 MSTORE SWAP2 SWAP3 POP PUSH1 0x0 SWAP2 SWAP1" in
let b2 := str2block "POP SWAP1 POP PUSH1 0x0 PUSH1 0x2 PUSH1 0x40 MLOAD SWAP1 DUP1 DUP3 MSTORE DUP1 PUSH1 0x20 MUL PUSH1 0x20 ADD DUP3 ADD PUSH1 0x40 MSTORE DUP1 ISZERO METAPUSH 5 0x310 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 4).
(* Block #85: JUMPI(X,0) can be removed *)
Compute
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD PUSH1 0x2 DUP1 DUP3 MSTORE PUSH1 0x60 DUP3 ADD SWAP1 SWAP3 MSTORE PUSH1 0x0 SWAP2 DUP3 SWAP2 SWAP1" in
let b2 := str2block "PUSH1 0x0 DUP1 PUSH1 0x2 PUSH1 0x40 MLOAD SWAP1 DUP1 DUP3 MSTORE DUP1 PUSH1 0x20 MUL PUSH1 0x20 ADD DUP3 ADD PUSH1 0x40 MSTORE DUP1 ISZERO METAPUSH 5 0x305 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 4).
(* Block #75: JUMPI(X,0) can be removed *)
Compute
let b1 := str2block "POP PUSH1 0x40 DUP1 MLOAD PUSH1 0x2 DUP1 DUP3 MSTORE PUSH1 0x60 DUP3 ADD SWAP1 SWAP3 MSTORE SWAP2 SWAP3 POP PUSH1 0x0 SWAP2 SWAP1" in
let b2 := str2block "POP SWAP1 POP PUSH1 0x0 PUSH1 0x2 PUSH1 0x40 MLOAD SWAP1 DUP1 DUP3 MSTORE DUP1 PUSH1 0x20 MUL PUSH1 0x20 ADD DUP3 ADD PUSH1 0x40 MSTORE DUP1 ISZERO METAPUSH 5 0x73 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 4).
(* Block #73: JUMPI(X,0) can be removed *)
Compute
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD PUSH1 0x9 DUP1 DUP3 MSTORE PUSH2 0x140 DUP3 ADD SWAP1 SWAP3 MSTORE PUSH1 0x0 SWAP2 DUP3 SWAP2 SWAP1" in
let b2 := str2block "PUSH1 0x0 DUP1 PUSH1 0x9 PUSH1 0x40 MLOAD SWAP1 DUP1 DUP3 MSTORE DUP1 PUSH1 0x20 MUL PUSH1 0x20 ADD DUP3 ADD PUSH1 0x40 MSTORE DUP1 ISZERO METAPUSH 5 0x37 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 0).
(* Block #63: SUB(X, 2^256-1) = ADD(X,1) *)
Compute
let b1 := str2block "PUSH1 0x0 PUSH1 0x1 DUP3 ADD METAPUSH 5 0x379 JUMPI" in
let b2 := str2block "PUSH1 0x0 DUP1 NOT DUP3 SUB METAPUSH 5 0x379 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 1).
(* Block #56: ADD(X, 288) = ADD(32, ADD(256,X)) *)
Compute
let b1 := str2block "PUSH1 0x40 DUP1 MLOAD PUSH2 0x140 DUP2 ADD SWAP1 SWAP2 MSTORE PUSH1 0x0 PUSH2 0x100 DUP3 ADD DUP2 DUP2 MSTORE PUSH2 0x120 DUP4 ADD SWAP2 SWAP1 SWAP2 MSTORE DUP2 SWAP1 METAPUSH 5 0x346" in
let b2 := str2block "PUSH1 0x40 MLOAD DUP1 PUSH2 0x100 ADD PUSH1 0x40 MSTORE DUP1 METAPUSH 5 0x346 PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH1 0x0 DUP2 MSTORE PUSH1 0x20 ADD PUSH1 0x0 DUP2 MSTORE POP SWAP1" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 0).
(* Block #49: ISZERO(ISZERO(X)) = LT(0,X) *)
Compute
let b1 := str2block "POP PUSH1 0xE0 DUP3 ADD SWAP1 DUP2 MSTORE PUSH1 0x40 DUP1 MLOAD DUP1 DUP3 ADD SWAP1 SWAP2 MSTORE PUSH32 0xAEE46A7EA6E80A3675026DFA84019DEEE2A2DEDB1BBE11D7FE124CB3EFB4B5A DUP2 MSTORE PUSH32 0x44747B6E9176E13EDE3A4DFD0D33CCCA6321B9ACD23BF3683A60ADC0366EBAF PUSH1 0x20 DUP3 ADD MSTORE SWAP1 MLOAD DUP1 MLOAD PUSH1 0x0 SWAP1 ISZERO ISZERO METAPUSH 5 0x283 JUMPI" in
let b2 := str2block "POP DUP2 PUSH1 0xE0 ADD DUP2 SWAP1 MSTORE POP PUSH1 0x40 MLOAD DUP1 PUSH1 0x40 ADD PUSH1 0x40 MSTORE DUP1 PUSH32 0xAEE46A7EA6E80A3675026DFA84019DEEE2A2DEDB1BBE11D7FE124CB3EFB4B5A DUP2 MSTORE PUSH1 0x20 ADD PUSH32 0x44747B6E9176E13EDE3A4DFD0D33CCCA6321B9ACD23BF3683A60ADC0366EBAF DUP2 MSTORE POP DUP2 PUSH1 0xE0 ADD MLOAD PUSH1 0x0 DUP2 MLOAD DUP2 LT METAPUSH 5 0x283 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 3).
(* Block #44: ADD(ADD(X,Y),Z) = ADD(ADD(Z,X),Y) *)
Compute
let b1 := str2block "PUSH1 0x20 SWAP1 DUP2 MUL SWAP2 SWAP1 SWAP2 ADD ADD MSTORE DUP1 METAPUSH 5 0x266 DUP2 METAPUSH 5 0x171" in
let b2 := str2block "PUSH1 0x20 MUL PUSH1 0x20 ADD ADD DUP2 DUP2 MSTORE POP POP DUP1 DUP1 METAPUSH 5 0x266 SWAP1 METAPUSH 5 0x171" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 4).
(* Block #37: ADD(ADD(X,Y),Z) = ADD(ADD(Z,X),Y) *)
Compute
let b1 := str2block "PUSH1 0x20 SWAP1 DUP2 MUL SWAP2 SWAP1 SWAP2 ADD ADD MLOAD MLOAD PUSH1 0x1 METAPUSH 5 0x245" in
let b2 := str2block "PUSH1 0x20 MUL PUSH1 0x20 ADD ADD MLOAD PUSH1 0x0 ADD MLOAD PUSH1 0x1 PUSH1 0x2 DUP2 LT METAPUSH 5 0x245 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
(* Block #34: ADD(ADD(X,Y),Z) = ADD(ADD(Z,X),Y) *)
Compute
let b1 := str2block "PUSH1 0x20 SWAP1 DUP2 MUL SWAP2 SWAP1 SWAP2 ADD ADD MLOAD MLOAD PUSH1 0x0 METAPUSH 5 0x237" in
let b2 := str2block "PUSH1 0x20 MUL PUSH1 0x20 ADD ADD MLOAD PUSH1 0x0 ADD MLOAD PUSH1 0x0 PUSH1 0x2 DUP2 LT METAPUSH 5 0x237 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 2).
(***********************************************)
Compute
let b1 := str2block "PUSH1 0x0 DUP1 PUSH1 0x9 METAPUSH 5 0x35" in
let b2 := str2block "PUSH1 0x0 DUP1 PUSH1 0x9 PUSH8 0xFFFFFFFFFFFFFFFF DUP2 GT ISZERO METAPUSH 5 0x35 JUMPI" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 0).
(* Eval cbv in *)
Compute
let b1 := str2block "PUSH1 0xFF PUSH1 0x20 PUSH1 0x0 ADD MSTORE PUSH1 0xFF PUSH1 0x0 MSTORE PUSH1 0x40 MLOAD PUSH1 0x40 MLOAD" in
let b2 := str2block "PUSH1 0xFF PUSH1 0x20 MSTORE PUSH1 0xFF PUSH1 0x0 MSTORE PUSH1 0x40 MLOAD PUSH1 0x40 MLOAD" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 0).
Compute
let b1 := str2block "PUSH1 0x65 PUSH1 0x20 MSTORE PUSH1 0x1 PUSH1 0x1 PUSH1 0xa0 SHL SUB DUP9 DUP2 AND PUSH1 0x0 MSTORE DUP5 SWAP1 AND SWAP1 PUSH4 0x50d25bcd SWAP1 PUSH1 0x40 PUSH1 0x0 KECCAK256 PUSH1 0x40 MLOAD DUP1 PUSH1 0x4 ADD SWAP3 DUP5 PUSH1 0xe0 SHL SWAP1 SWAP2 MSTORE SWAP1 PUSH1 0x2 ADD DUP1 SLOAD PUSH1 0xff NOT AND SWAP1 SWAP2 PUSH1 0xff AND OR SWAP1 SSTORE PUSH1 0x20 PUSH1 0x40 MLOAD DUP1 DUP4 SUB DUP2 DUP7" in
let b2 := str2block "PUSH1 0x65 PUSH1 0x0 DUP10 PUSH1 0x1 PUSH1 0x1 PUSH1 0xa0 SHL SUB AND PUSH1 0x1 PUSH1 0x1 PUSH1 0xa0 SHL SUB AND DUP2 MSTORE PUSH1 0x20 ADD SWAP1 DUP2 MSTORE PUSH1 0x20 ADD PUSH1 0x0 KECCAK256 PUSH1 0x2 ADD PUSH1 0x0 PUSH2 0x100 EXP DUP2 SLOAD DUP2 PUSH1 0xff MUL NOT AND SWAP1 DUP4 PUSH1 0xff AND MUL OR SWAP1 SSTORE POP DUP3 PUSH1 0x1 PUSH1 0x1 PUSH1 0xa0 SHL SUB AND PUSH4 0x50d25bcd PUSH1 0x40 MLOAD DUP2 PUSH4 0xffffffff AND PUSH1 0xe0 SHL DUP2 MSTORE PUSH1 0x4 ADD PUSH1 0x20 PUSH1 0x40 MLOAD DUP1 DUP4 SUB DUP2 DUP7" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 8).
Compute
let b1 := str2block "PUSH1 0xFF PUSH1 0x20 PUSH1 0x0 ADD SSTORE PUSH1 0xFF PUSH1 0x0 SSTORE PUSH1 0x40 SLOAD PUSH1 0x40 SLOAD" in
let b2 := str2block "PUSH1 0xFF PUSH1 0x20 SSTORE PUSH1 0xFF PUSH1 0x0 SSTORE PUSH1 0x40 SLOAD PUSH1 0x40 SLOAD" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 0).
(*
Compute
let b1 := str2block "PUSH1 0xf SLOAD PUSH1 0xa0 SHR PUSH1 0xff AND ISZERO METAPUSH 5 0x145" in
let b2 := str2block "PUSH1 0xf SLOAD PUSH1 0x1 PUSH1 0xa0 SHL SWAP1 DIV PUSH1 0xff AND ISZERO METAPUSH 5 0x145" in
let h := 5 in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic_w_eq_chk SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 h).
(* Test of OPT_mem_solver *)
Compute
let b1 := str2block "PUSH1 0xFF PUSH1 0x5 MSTORE PUSH1 0x5 MLOAD" in
let b2 := str2block "PUSH1 0xFF PUSH1 0x5 MSTORE PUSH1 0x5 PUSH1 0x0 ADD MLOAD" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 0).
(* Test of OPT_strg_solver *)
Compute
let b1 := str2block "PUSH1 0xFF PUSH1 0x15 SSTORE PUSH1 0x15 SLOAD" in
let b2 := str2block "PUSH1 0xFF PUSH1 0x15 SSTORE PUSH1 0x0 PUSH1 0x15 ADD SLOAD" in
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_PO
SStrgCmp_Basic SHA3Cmp_Basic
all_optimization_steps 10 10 b1 b2 0).
(* From GASOL_gas_simp #1256*)
Compute
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_Basic
SStrgCmp_Basic SHA3Cmp_Trivial
all_optimization_steps 10 10
[PUSH 1 0x40; MLOAD; PUSH 1 0x40; MLOAD; OpInstr SUB]
[PUSH 1 0x0]
(*[PUSH 20 0xffffffffffffffffffffffffffffffffffffffff; OpInstr AND;
PUSH 32 0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925;
PUSH 1 0x0; PUSH 1 0x40; MLOAD]
[PUSH 1 0x1; PUSH 1 0x1; PUSH 1 0xa0; OpInstr SHL; OpInstr SUB; OpInstr AND;
PUSH 32 0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925;
PUSH 1 0x40; MLOAD; PUSH 1 0x40; MLOAD; DUP 1; SWAP 2; OpInstr SUB; SWAP 1]*)
1).
Compute
let memory_updater := basic_smemory_updater in
let storage_updater := basic_sstorage_updater in
let mload_solver := basic_mload_solver in
let sload_solver := basic_sload_solver in
let sstack_value_cmp_ext := basic_compare_sstack_val in
let smemory_cmp_ext := basic_memory_cmp in
let sstorage_cmp_ext := basic_storage_cmp in
let sha3_cmp_ext := trivial_sha3_cmp in
let sstack_value_cmp_1 := sstack_value_cmp_ext smemory_cmp_ext sstorage_cmp_ext sha3_cmp_ext in
let sstack_value_cmp := sstack_value_cmp_1 2 in
sstack_value_cmp (FreshVar 0) (FreshVar 1) 3 [(2, SymOp SUB [FreshVar 1; FreshVar 0]); (1, SymMLOAD (Val (natToWord 256 64)) []); (0, SymMLOAD (Val (natToWord 256 64)) [])] 3 [(2, SymOp SUB [FreshVar 1; FreshVar 0]); (1, SymMLOAD (Val (natToWord 256 64)) []); (0, SymMLOAD (Val (natToWord 256 64)) [])] 3 evm_stack_opm.
Compute
let memory_updater := basic_smemory_updater in
let storage_updater := basic_sstorage_updater in
let mload_solver := basic_mload_solver in
let sload_solver := basic_sload_solver in
let sstack_value_cmp_ext := basic_compare_sstack_val in
let smemory_cmp_ext := basic_memory_cmp in
let sstorage_cmp_ext := basic_storage_cmp in
let sha3_cmp_ext := trivial_sha3_cmp in
let sstack_value_cmp_1 := sstack_value_cmp_ext smemory_cmp_ext sstorage_cmp_ext sha3_cmp_ext in
let sstack_value_cmp := sstack_value_cmp_1 2 in
let sb := [(2, SymOp SUB [FreshVar 1; FreshVar 0]);
(1, SymMLOAD (Val (natToWord 256 64)) []);
(0, SymMLOAD (Val (natToWord 256 64)) [])] in
optimize_sub_x_x_sbinding (SymOp SUB [FreshVar 1; FreshVar 0])
sstack_value_cmp
sb
2
0
evm_stack_opm.
Compute (wordToN two_exp_160_minus_1).
(* From GASOL_gas_simp #846 *)
Compute
(evm_eq_block_chkr_lazy_dbg SMemUpdater_Basic SStrgUpdater_Basic
MLoadSolver_Basic SLoadSolver_Basic SStackValCmp_Basic SMemCmp_Basic
SStrgCmp_Basic SHA3Cmp_Trivial
all_optimization_steps 20 20
(*
[OpInstr ADDRESS]
[OpInstr ADDRESS; PUSH 1 0x1;PUSH 1 0x1; PUSH 1 0xa0; OpInstr SHL; OpInstr SUB;
OpInstr AND]
[OpInstr ADDRESS; PUSH 1 0x1; PUSH 1 0xa0; PUSH 1 0x2; OpInstr EXP;
OpInstr SUB; OpInstr AND]*)
[PUSH 20 0xffffffffffffffffffffffffffffffffffffffff; OpInstr AND;
OpInstr ADDRESS; PUSH 32 0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef;
PUSH 1 0x13; PUSH 1 0x40; MLOAD; PUSH 9 0x3635c9adc5dea00000; DUP 2]
[PUSH 1 0x1; PUSH 1 0x1; PUSH 1 0xa0; OpInstr SHL; OpInstr SUB; OpInstr AND;
OpInstr ADDRESS; PUSH 1 0x1; PUSH 1 0x1; PUSH 1 0xa0; OpInstr SHL; OpInstr SUB;
OpInstr AND; PUSH 32 0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef;
PUSH 9 0x3635c9adc5dea00000; PUSH 1 0x40; MLOAD; PUSH 1 0x13; SWAP 2; DUP 2]
1).
Compute (
let val := SymOp AND [FreshVar 5; FreshVar 3] in
let fcmp := basic_compare_sstack_val basic_memory_cmp basic_storage_cmp
trivial_sha3_cmp 1 in
let sb := [(2, SymOp AND [FreshVar 1; FreshVar 0]);
(1,