From d2052c74bd4d81b5da5ba38f0fc3718eb85eee91 Mon Sep 17 00:00:00 2001 From: Lorenzo Gentile Date: Wed, 23 Oct 2024 16:06:23 +0200 Subject: [PATCH] 1427 remove refunds for selfdestruct (#1442) --- .../module/constants/GlobalConstants.java | 47 ++++++++++++++++++- .../zktracer/opcode/gas/GasConstants.java | 1 - .../opcode/gas/projector/SelfDestruct.java | 5 -- 3 files changed, 45 insertions(+), 8 deletions(-) diff --git a/arithmetization/src/main/java/net/consensys/linea/zktracer/module/constants/GlobalConstants.java b/arithmetization/src/main/java/net/consensys/linea/zktracer/module/constants/GlobalConstants.java index 35bf9bb3c0..0397c833f2 100644 --- a/arithmetization/src/main/java/net/consensys/linea/zktracer/module/constants/GlobalConstants.java +++ b/arithmetization/src/main/java/net/consensys/linea/zktracer/module/constants/GlobalConstants.java @@ -16,6 +16,12 @@ package net.consensys.linea.zktracer.module.constants; import java.math.BigInteger; +import java.nio.MappedByteBuffer; +import java.util.ArrayList; +import java.util.BitSet; +import java.util.List; + +import net.consensys.linea.zktracer.ColumnHeader; /** * WARNING: This code is generated automatically. @@ -320,8 +326,7 @@ public class GlobalConstants { public static final int PHASE_RIPEMD_RESULT = 0x4; public static final int PHASE_SHA2_DATA = 0x1; public static final int PHASE_SHA2_RESULT = 0x2; - public static final int REFUND_CONST_R_SCLEAR = 0x3a98; - public static final int REFUND_CONST_R_SELFDESTRUCT = 0x5dc0; + public static final int REFUND_CONST_R_SCLEAR = 0x12c0; public static final int RLP_ADDR_RECIPE_1 = 0x1; public static final int RLP_ADDR_RECIPE_2 = 0x2; public static final int RLP_PREFIX_INT_LONG = 0xb7; @@ -356,4 +361,42 @@ public class GlobalConstants { public static final int WCP_INST_LEQ = 0xf; public static final int WORD_SIZE = 0x20; public static final int WORD_SIZE_MO = 0x1f; + + private final BitSet filled = new BitSet(); + private int currentLine = 0; + + static List headers(int length) { + List headers = new ArrayList<>(); + return headers; + } + + public GlobalConstants(List buffers) {} + + public int size() { + if (!filled.isEmpty()) { + throw new RuntimeException("Cannot measure a trace with a non-validated row."); + } + + return this.currentLine; + } + + public GlobalConstants validateRow() { + filled.clear(); + this.currentLine++; + + return this; + } + + public GlobalConstants fillAndValidateRow() { + filled.clear(); + this.currentLine++; + + return this; + } + + public void build() { + if (!filled.isEmpty()) { + throw new IllegalStateException("Cannot build trace with a non-validated row."); + } + } } diff --git a/arithmetization/src/main/java/net/consensys/linea/zktracer/opcode/gas/GasConstants.java b/arithmetization/src/main/java/net/consensys/linea/zktracer/opcode/gas/GasConstants.java index fbec05f21d..22756cf349 100644 --- a/arithmetization/src/main/java/net/consensys/linea/zktracer/opcode/gas/GasConstants.java +++ b/arithmetization/src/main/java/net/consensys/linea/zktracer/opcode/gas/GasConstants.java @@ -38,7 +38,6 @@ public enum GasConstants { G_S_SET(GlobalConstants.GAS_CONST_G_SSET), G_S_RESET(GlobalConstants.GAS_CONST_G_SRESET), R_S_CLEAR(GlobalConstants.REFUND_CONST_R_SCLEAR), - R_SELF_DESTRUCT(GlobalConstants.REFUND_CONST_R_SELFDESTRUCT), G_SELF_DESTRUCT(GlobalConstants.GAS_CONST_G_SELFDESTRUCT), G_CREATE(GlobalConstants.GAS_CONST_G_CREATE), G_CODE_DEPOSIT(GlobalConstants.GAS_CONST_G_CODE_DEPOSIT), diff --git a/arithmetization/src/main/java/net/consensys/linea/zktracer/opcode/gas/projector/SelfDestruct.java b/arithmetization/src/main/java/net/consensys/linea/zktracer/opcode/gas/projector/SelfDestruct.java index 65759c58d1..a83c17bb3d 100644 --- a/arithmetization/src/main/java/net/consensys/linea/zktracer/opcode/gas/projector/SelfDestruct.java +++ b/arithmetization/src/main/java/net/consensys/linea/zktracer/opcode/gas/projector/SelfDestruct.java @@ -73,9 +73,4 @@ public long accountCreation() { return 0L; } } - - @Override - public long refund() { - return GlobalConstants.REFUND_CONST_R_SELFDESTRUCT; - } }