From cdfc5796e2b1cf90c3c14c7bbd75215e96a9f782 Mon Sep 17 00:00:00 2001 From: ahamlat Date: Thu, 2 Feb 2023 11:28:19 +0100 Subject: [PATCH] Improve withdrawals processing performance (#5026) * Improve withdrawals processing performance * Add a changelog entry * refactoring + remove the changelog entry as we have not change logs for the withdrawals Signed-off-by: Ameziane H --- .../src/main/java/org/hyperledger/besu/datatypes/GWei.java | 5 ++++- .../besu/ethereum/bonsai/BonsaiWorldStateUpdater.java | 3 ++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/datatypes/src/main/java/org/hyperledger/besu/datatypes/GWei.java b/datatypes/src/main/java/org/hyperledger/besu/datatypes/GWei.java index 06e3667690d..0ebc6a9b8e8 100644 --- a/datatypes/src/main/java/org/hyperledger/besu/datatypes/GWei.java +++ b/datatypes/src/main/java/org/hyperledger/besu/datatypes/GWei.java @@ -34,6 +34,9 @@ public final class GWei extends BaseUInt64Value implements Quantity { /** The constant MAX_GWEI. */ public static final GWei MAX_GWEI = of(UInt64.MAX_VALUE); + /** The constant GWEI_TO_WEI_MULTIPLIER. */ + private static final BigInteger GWEI_TO_WEI_MULTIPLIER = BigInteger.valueOf(1_000_000_000L); + /** * Instantiates a new GWei. * @@ -111,7 +114,7 @@ public static GWei fromHexString(final String str) { * @return Wei */ public Wei getAsWei() { - return Wei.of(getAsBigInteger().multiply(BigInteger.TEN.pow(9))); + return Wei.of(getAsBigInteger().multiply(GWEI_TO_WEI_MULTIPLIER)); } @Override diff --git a/ethereum/core/src/main/java/org/hyperledger/besu/ethereum/bonsai/BonsaiWorldStateUpdater.java b/ethereum/core/src/main/java/org/hyperledger/besu/ethereum/bonsai/BonsaiWorldStateUpdater.java index 28e1d7fcce7..592861d268e 100644 --- a/ethereum/core/src/main/java/org/hyperledger/besu/ethereum/bonsai/BonsaiWorldStateUpdater.java +++ b/ethereum/core/src/main/java/org/hyperledger/besu/ethereum/bonsai/BonsaiWorldStateUpdater.java @@ -284,7 +284,8 @@ public void commit() { new BonsaiValue<>(wrappedWorldView().getCode(addr).orElse(null), null)); pendingCode.setUpdated(updatedAccount.getCode()); } - + // This is especially to avoid unnecessary computation for withdrawals + if (updatedAccount.getUpdatedStorage().isEmpty()) return; final StorageConsumingMap> pendingStorageUpdates = storageToUpdate.computeIfAbsent( updatedAddress,