Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

EIP-1153: Transient storage opcodes #4118

Merged
merged 67 commits into from
Feb 3, 2023
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
67 commits
Select commit Hold shift + click to select a range
518a259
Exploratory changes
codyborn Jul 13, 2022
930066b
Add Shanghai fork
codyborn Jul 15, 2022
20a5c86
Multi-contract tests
codyborn Jul 15, 2022
b77a993
More tests; handle transient state across frames
codyborn Jul 16, 2022
4edfd8d
Moar tests
codyborn Jul 16, 2022
85d06e3
Backward sync exception improvements (#4092)
fab-10 Jul 13, 2022
6af79cb
Finalised blocks should not prevent reorgs in BWS (#4097)
gezero Jul 14, 2022
82d0cb6
delegate all the block checks and validation to the block import phas…
fab-10 Jul 14, 2022
4564178
Ignore 2 tests that assume that the system language is English, if th…
daniellehrner Jul 14, 2022
5b41dcf
Fix PR 4098 (#4106)
fab-10 Jul 14, 2022
0a65802
log execution errors at right level, stops transition message propaga…
jflo Jul 14, 2022
ad0890a
Add experimental config option to enable v5 discovery (#4103)
Gabriel-Trintinalia Jul 15, 2022
e520669
Move Taccat to Emeritus (#4033)
shemnon Jul 15, 2022
743fa0a
Remove hash to append from the queue only if the step succeeds (#4105)
fab-10 Jul 15, 2022
df43a9d
Create backward sync retries on demand (#4095)
fab-10 Jul 15, 2022
21a7054
Update checkpoint sync for merge (#4085)
matkt Jul 15, 2022
d61e457
Remove unintended changes
codyborn Jul 16, 2022
c126cd5
Organize bytecode enum
codyborn Jul 16, 2022
75d74aa
Remove extra space
codyborn Jul 16, 2022
b6bf7fc
Updates to address PR feedback
codyborn Jul 28, 2022
57f1fd2
TreeMap -> HashMap
codyborn Jul 28, 2022
188d201
Remove shanghai hf config
codyborn Jul 29, 2022
a1708a4
Merge with main
codyborn Jul 31, 2022
4f0a43b
Missed some changes in the merge
codyborn Jul 31, 2022
612ee73
Whitespace style fix
codyborn Jul 31, 2022
04ffcae
Remove eip from all_forks.json
codyborn Aug 1, 2022
8623f48
Clear transient storage after each transaction
codyborn Aug 2, 2022
0ad50e6
Style fixes
codyborn Aug 4, 2022
d1db3b2
Merge branch 'main' into eip1153
codyborn Aug 4, 2022
03ad001
Simple performance test
codyborn Aug 4, 2022
45f603c
javadoc ByteCodeBuilder, undo unintended change
codyborn Aug 6, 2022
42ce2ec
correct javadoc typos
codyborn Aug 6, 2022
2c24e18
style fix
codyborn Aug 6, 2022
9b3f8d8
Move transient performance test to jmh suite
codyborn Aug 8, 2022
114446d
Remove commented out line
codyborn Aug 8, 2022
7e108d5
Upgrade Web3J (#3752)
diega Aug 4, 2022
9d63c64
Fix ConcurrentModificationException on ReattemptPendingPeerRequests (…
Gabriel-Trintinalia Aug 4, 2022
c46b1bf
Log unexpected exceptions in execution engine rpc (#4222)
siladu Aug 5, 2022
b68a6a7
correct fallback ttd to correct value (#4223)
daniellehrner Aug 7, 2022
b937710
Enclave public key length constraint removed for private transactions…
freemanzMrojo Aug 8, 2022
26714f1
Merge branch 'main' into eip1153
codyborn Aug 8, 2022
34451ae
Merge branch 'main' into eip1153
codyborn Aug 9, 2022
7bf6470
Merge branch 'main' into eip1153
codyborn Aug 10, 2022
47b1f31
Merge branch 'main' into eip1153
codyborn Aug 10, 2022
4b1c2a7
Merge branch 'main' into eip1153
codyborn Aug 12, 2022
c0c3c92
Merge branch 'main' into eip1153
codyborn Aug 21, 2022
a0cc8df
Add 1153 as ExperimentalEIP cmd line
codyborn Aug 31, 2022
d184d71
Merge branch 'main' into eip1153
codyborn Aug 31, 2022
a950795
Merge upstream
codyborn Nov 30, 2022
ed3ccad
Merge upstream
codyborn Nov 30, 2022
1a0b0fd
Fix tests
codyborn Dec 3, 2022
dd3f4bd
Merge pull request #1 from codyborn/merge1153
codyborn Dec 3, 2022
ab4285d
Update tests
codyborn Nov 30, 2022
206923f
Merge branch 'eip1153' of https://github.com/codyborn/besu into eip1153
codyborn Dec 3, 2022
bed8c06
Fix merge issue
codyborn Dec 3, 2022
7e86124
Spotless fix
codyborn Dec 3, 2022
6cce1ce
Add experimental EIPs back into BesuCommand
codyborn Dec 4, 2022
aafce49
Fix merge artifacts
codyborn Dec 4, 2022
0cbedf4
Revert reference test external-resources
codyborn Dec 4, 2022
8eadf09
Merge branch 'main' into eip1153
codyborn Dec 5, 2022
82af1b8
ugly merge
shemnon Jan 26, 2023
0439c40
finish removing CLI feature flag
shemnon Jan 26, 2023
22b0cf1
Move transient storage to the MessageFrame
shemnon Jan 26, 2023
9580690
Merge remote-tracking branch 'upstream/main' into eip1153
shemnon Jan 26, 2023
6b8fa64
javadoc
shemnon Jan 26, 2023
56f04be
spotless
shemnon Jan 26, 2023
4ab15e6
Merge branch 'main' into eip1153
shemnon Feb 3, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 0 additions & 7 deletions besu/src/main/java/org/hyperledger/besu/cli/BesuCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -1383,7 +1383,6 @@ public int parse(
.setCaseInsensitiveEnumValuesAllowed(true);

handleStableOptions();
enableExperimentalEIPs();
addSubCommands(resultHandler, in);
registerConverters();
handleUnstableOptions();
Expand Down Expand Up @@ -1451,12 +1450,6 @@ void setBesuConfiguration(final BesuConfiguration pluginCommonConfiguration) {
this.pluginCommonConfiguration = pluginCommonConfiguration;
}

private BesuCommand enableExperimentalEIPs() {
// Usage of static command line flags is strictly reserved for experimental EIPs
commandLine.addMixin("experimentalEIPs", ExperimentalEIPs.class);
return this;
}

private void addSubCommands(
final AbstractParseResultHandler<List<Object>> resultHandler, final InputStream in) {
commandLine.addSubcommand(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,8 @@ default boolean isConsensusMigration() {

OptionalLong getMergeNetSplitBlockNumber();

OptionalLong getShandongBlockNumber();

OptionalLong getEIP1153BlockNumber();

Optional<Wei> getBaseFeePerGas();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -278,6 +278,11 @@ public OptionalLong getMergeNetSplitBlockNumber() {
return getOptionalLong("mergenetsplitblock");
}

@Override
public OptionalLong getShandongBlockNumber() {
return getOptionalLong("shandongblock");
}

@Override
public OptionalLong getEIP1153BlockNumber() {
return getOptionalLong("eip1153Block");
Expand Down Expand Up @@ -433,6 +438,7 @@ public Map<String, Object> asMap() {
getArrowGlacierBlockNumber().ifPresent(l -> builder.put("arrowGlacierBlock", l));
getGrayGlacierBlockNumber().ifPresent(l -> builder.put("grayGlacierBlock", l));
getMergeNetSplitBlockNumber().ifPresent(l -> builder.put("mergeNetSplitBlock", l));
getShandongBlockNumber().ifPresent(l -> builder.put("shandongBlock", l));
getEIP1153BlockNumber().ifPresent(l -> builder.put("eip1153Block", l));
getTerminalBlockNumber().ifPresent(l -> builder.put("terminalBlockNumber", l));
getTerminalBlockHash().ifPresent(h -> builder.put("terminalBlockHash", h.toHexString()));
Expand Down Expand Up @@ -557,6 +563,7 @@ public List<Long> getForks() {
getArrowGlacierBlockNumber(),
getGrayGlacierBlockNumber(),
getMergeNetSplitBlockNumber(),
getShandongBlockNumber(),
getEIP1153BlockNumber(),
getEcip1015BlockNumber(),
getDieHardBlockNumber(),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ public class StubGenesisConfigOptions implements GenesisConfigOptions {
private OptionalLong arrowGlacierBlockNumber = OptionalLong.empty();
private OptionalLong grayGlacierBlockNumber = OptionalLong.empty();
private OptionalLong mergeNetSplitBlockNumber = OptionalLong.empty();
private OptionalLong shandongBlockNumber = OptionalLong.empty();
private OptionalLong eip1153BlockNumber = OptionalLong.empty();
private OptionalLong terminalBlockNumber = OptionalLong.empty();
private Optional<Hash> terminalBlockHash = Optional.empty();
Expand All @@ -70,7 +71,7 @@ public class StubGenesisConfigOptions implements GenesisConfigOptions {
private QbftConfigOptions qbftConfigOptions = JsonQbftConfigOptions.DEFAULT;
private BftConfigOptions bftConfigOptions = JsonBftConfigOptions.DEFAULT;
private TransitionsConfigOptions transitions = TransitionsConfigOptions.DEFAULT;
private static final DiscoveryOptions DISCOVERY_OPTIONS = DiscoveryOptions.DEFAULT;
private final DiscoveryOptions discoveryOptions = DiscoveryOptions.DEFAULT;

@Override
public String getConsensusEngine() {
Expand Down Expand Up @@ -134,7 +135,7 @@ public QbftConfigOptions getQbftConfigOptions() {

@Override
public DiscoveryOptions getDiscoveryOptions() {
return DISCOVERY_OPTIONS;
return discoveryOptions;
}

@Override
Expand Down Expand Up @@ -217,6 +218,11 @@ public OptionalLong getMergeNetSplitBlockNumber() {
return mergeNetSplitBlockNumber;
}

@Override
public OptionalLong getShandongBlockNumber() {
return shandongBlockNumber;
}

@Override
public OptionalLong getEIP1153BlockNumber() {
return eip1153BlockNumber;
Expand Down Expand Up @@ -325,13 +331,21 @@ public Optional<BigInteger> getChainId() {
@Override
public Map<String, Object> asMap() {
final ImmutableMap.Builder<String, Object> builder = ImmutableMap.builder();
getChainId().ifPresent(id -> builder.put("chainId", id));
getChainId().ifPresent(chainId -> builder.put("chainId", chainId));

// mainnet fork blocks
getHomesteadBlockNumber().ifPresent(l -> builder.put("homesteadBlock", l));
getDaoForkBlock().ifPresent(l -> builder.put("daoForkBlock", l));
getDaoForkBlock()
.ifPresent(
l -> {
builder.put("daoForkBlock", l);
});
getTangerineWhistleBlockNumber().ifPresent(l -> builder.put("eip150Block", l));
getSpuriousDragonBlockNumber().ifPresent(l -> builder.put("eip158Block", l));
getSpuriousDragonBlockNumber()
.ifPresent(
l -> {
builder.put("eip158Block", l);
});
getByzantiumBlockNumber().ifPresent(l -> builder.put("byzantiumBlock", l));
getConstantinopleBlockNumber().ifPresent(l -> builder.put("constantinopleBlock", l));
getPetersburgBlockNumber().ifPresent(l -> builder.put("petersburgBlock", l));
Expand All @@ -342,6 +356,7 @@ public Map<String, Object> asMap() {
getArrowGlacierBlockNumber().ifPresent(l -> builder.put("arrowGlacierBlock", l));
getGrayGlacierBlockNumber().ifPresent(l -> builder.put("grayGlacierBlock", l));
getMergeNetSplitBlockNumber().ifPresent(l -> builder.put("mergeNetSplitBlock", l));
getShandongBlockNumber().ifPresent(l -> builder.put("shandongBlock", l));
getEIP1153BlockNumber().ifPresent(l -> builder.put("eip1153Block", l));
getTerminalBlockNumber().ifPresent(l -> builder.put("terminalBlockNumber", l));
getTerminalBlockHash().ifPresent(h -> builder.put("terminalBlockHash", h));
Expand Down Expand Up @@ -486,6 +501,11 @@ public StubGenesisConfigOptions mergeNetSplitBlock(final long blockNumber) {
return this;
}

public StubGenesisConfigOptions shandongBlock(final long blockNumber) {
shandongBlockNumber = OptionalLong.of(blockNumber);
return this;
}

public StubGenesisConfigOptions eip1153Block(final long blockNumber) {
eip1153BlockNumber = OptionalLong.of(blockNumber);
return this;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -290,10 +290,12 @@ public void commit() {
storageToUpdate.remove(updatedAddress);
}

tracked.clearTransientStorage();
if (tracked.getStorageWasCleared()) {
tracked.setStorageWasCleared(false); // storage already cleared for this transaction
}

// TODO maybe add address preimage?
}
tracked.clearTransientStorage();
});
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -185,6 +185,17 @@ public ProtocolSpecBuilder parisDefinition(final GenesisConfigOptions genesisCon
evmConfiguration);
}

public ProtocolSpecBuilder shandongDefinition(final GenesisConfigOptions genesisConfigOptions) {
return MainnetProtocolSpecs.shandongDefinition(
chainId,
contractSizeLimit,
evmStackSize,
isRevertReasonEnabled,
genesisConfigOptions,
quorumCompatibilityMode,
evmConfiguration);
}

public ProtocolSpecBuilder eip1153Definition(final GenesisConfigOptions genesisConfigOptions) {
codyborn marked this conversation as resolved.
Show resolved Hide resolved
return MainnetProtocolSpecs.eip1153Definition(
chainId,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -637,6 +637,62 @@ static ProtocolSpecBuilder parisDefinition(
.name("ParisFork");
}

static ProtocolSpecBuilder shandongDefinition(
final Optional<BigInteger> chainId,
final OptionalInt configContractSizeLimit,
final OptionalInt configStackSizeLimit,
final boolean enableRevertReason,
final GenesisConfigOptions genesisConfigOptions,
final boolean quorumCompatibilityMode,
final EvmConfiguration evmConfiguration) {
final int stackSizeLimit = configStackSizeLimit.orElse(MessageFrame.DEFAULT_MAX_STACK_SIZE);
final long londonForkBlockNumber = genesisConfigOptions.getLondonBlockNumber().orElse(0L);
final BaseFeeMarket londonFeeMarket =
genesisConfigOptions.isZeroBaseFee()
? FeeMarket.zeroBaseFee(londonForkBlockNumber)
: FeeMarket.london(londonForkBlockNumber, genesisConfigOptions.getBaseFeePerGas());
final int contractSizeLimit =
configContractSizeLimit.orElse(SPURIOUS_DRAGON_CONTRACT_SIZE_LIMIT);

return parisDefinition(
chainId,
configContractSizeLimit,
configStackSizeLimit,
enableRevertReason,
genesisConfigOptions,
quorumCompatibilityMode,
evmConfiguration)
.evmBuilder(
(gasCalculator, jdCacheConfig) ->
MainnetEVMs.shandong(
gasCalculator, chainId.orElse(BigInteger.ZERO), evmConfiguration))
.transactionProcessorBuilder(
(gasCalculator,
transactionValidator,
contractCreationProcessor,
messageCallProcessor) ->
new MainnetTransactionProcessor(
gasCalculator,
transactionValidator,
contractCreationProcessor,
messageCallProcessor,
true,
true,
stackSizeLimit,
londonFeeMarket,
CoinbaseFeePriceCalculator.eip1559()))
.contractCreationProcessorBuilder(
(gasCalculator, evm) ->
new ContractCreationProcessor(
gasCalculator,
evm,
true,
List.of(MaxCodeSizeRule.of(contractSizeLimit), CachedInvalidCodeRule.of()),
1,
SPURIOUS_DRAGON_FORCE_DELETE_WHEN_EMPTY_ADDRESSES))
.name("Shandong");
}

// TODO EIP-1153 change for the actual fork name when known
static ProtocolSpecBuilder eip1153Definition(
final Optional<BigInteger> chainId,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ public void tstoreInsufficientGas() {
frame.pushStackItem(UInt256.fromHexString("0x01"));

final OperationResult result = operation.execute(frame, null);
assertThat(result.getHaltReason()).isEqualTo(Optional.of(INSUFFICIENT_GAS));
assertThat(result.getHaltReason()).isEqualTo(INSUFFICIENT_GAS);
}

@Test
Expand All @@ -98,7 +98,7 @@ public void tStoreSimpleTest() {
frame.pushStackItem(UInt256.fromHexString("0x01"));

final OperationResult result = operation.execute(frame, null);
assertThat(result.getHaltReason()).isEqualTo(Optional.empty());
assertThat(result.getHaltReason()).isEqualTo(null);
}

@Test
Expand All @@ -111,7 +111,7 @@ public void tLoadEmpty() {
final TLoadOperation tload = new TLoadOperation(gasCalculator);
frame.pushStackItem(UInt256.fromHexString("0x01"));
final OperationResult tloadResult = tload.execute(frame, null);
assertThat(tloadResult.getHaltReason()).isEqualTo(Optional.empty());
assertThat(tloadResult.getHaltReason()).isEqualTo(null);
UInt256 tloadValue = UInt256.fromBytes(frame.popStackItem());
assertThat(tloadValue).isEqualTo(UInt256.ZERO);
}
Expand All @@ -127,19 +127,19 @@ public void tStoreTLoad() {
frame.pushStackItem(UInt256.fromHexString("0x01"));

final OperationResult result = tstore.execute(frame, null);
assertThat(result.getHaltReason()).isEqualTo(Optional.empty());
assertThat(result.getHaltReason()).isEqualTo(null);

TLoadOperation tload = new TLoadOperation(gasCalculator);
frame.pushStackItem(UInt256.fromHexString("0x01"));
OperationResult tloadResult = tload.execute(frame, null);
assertThat(tloadResult.getHaltReason()).isEqualTo(Optional.empty());
assertThat(tloadResult.getHaltReason()).isEqualTo(null);
UInt256 tloadValue = UInt256.fromBytes(frame.popStackItem());
assertThat(tloadValue).isEqualTo(UInt256.ONE);

// Loading from a different location returns default value
frame.pushStackItem(UInt256.fromHexString("0x02"));
tloadResult = tload.execute(frame, null);
assertThat(tloadResult.getHaltReason()).isEqualTo(Optional.empty());
assertThat(tloadResult.getHaltReason()).isEqualTo(null);
tloadValue = UInt256.fromBytes(frame.popStackItem());
assertThat(tloadValue).isEqualTo(UInt256.ZERO);
}
Expand All @@ -155,19 +155,19 @@ public void tStoreUpdate() {
frame.pushStackItem(UInt256.fromHexString("0x01"));

OperationResult result = tstore.execute(frame, null);
assertThat(result.getHaltReason()).isEqualTo(Optional.empty());
assertThat(result.getHaltReason()).isEqualTo(null);

// Store 2 at position 1
frame.pushStackItem(UInt256.fromHexString("0x02"));
frame.pushStackItem(UInt256.fromHexString("0x01"));

result = tstore.execute(frame, null);
assertThat(result.getHaltReason()).isEqualTo(Optional.empty());
assertThat(result.getHaltReason()).isEqualTo(null);

final TLoadOperation tload = new TLoadOperation(gasCalculator);
frame.pushStackItem(UInt256.fromHexString("0x01"));
final OperationResult tloadResult = tload.execute(frame, null);
assertThat(tloadResult.getHaltReason()).isEqualTo(Optional.empty());
assertThat(tloadResult.getHaltReason()).isEqualTo(null);
UInt256 tloadValue = UInt256.fromBytes(frame.popStackItem());
assertThat(tloadValue).isEqualTo(UInt256.fromHexString("0x02"));
}
Expand All @@ -184,15 +184,15 @@ public void noGasRefundFromTransientState() {
frame.pushStackItem(UInt256.fromHexString("0x01"));

OperationResult result = tstore.execute(frame, null);
assertThat(result.getHaltReason()).isEqualTo(Optional.empty());
assertThat(result.getHaltReason()).isEqualTo(null);

// Reset value to 0
frame.pushStackItem(UInt256.fromHexString("0x00"));
frame.pushStackItem(UInt256.fromHexString("0x01"));

result = tstore.execute(frame, null);
assertThat(result.getHaltReason()).isEqualTo(Optional.empty());
assertThat(result.getHaltReason()).isEqualTo(null);

assertThat(result.getGasCost()).isEqualTo(OptionalLong.of(100L));
assertThat(result.getGasCost()).isEqualTo(100L);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,13 @@ public static ReferenceTestProtocolSchedules create() {
"ArrowGlacier", createSchedule(new StubGenesisConfigOptions().arrowGlacierBlock(0)));
builder.put("GrayGlacier", createSchedule(new StubGenesisConfigOptions().grayGlacierBlock(0)));
builder.put(
"MergeNetSplit", createSchedule(new StubGenesisConfigOptions().mergeNetSplitBlock(0)));
"Merge",
createSchedule(new StubGenesisConfigOptions().mergeNetSplitBlock(0).baseFeePerGas(0x0a)));
builder.put(
"Shanghai",
createSchedule(new StubGenesisConfigOptions().shandongBlock(0).baseFeePerGas(0x0a)));
builder.put("Shandong", createSchedule(new StubGenesisConfigOptions().shandongBlock(0)));
builder.put("MergeNetSplit", createSchedule(new StubGenesisConfigOptions().mergeNetSplitBlock(0)));
builder.put("EIP1153", createSchedule(new StubGenesisConfigOptions().eip1153Block(0)));
return new ReferenceTestProtocolSchedules(builder.build());
}
Expand Down
Submodule external-resources updated 63 files
+1 −0 .gitignore
+168 −0 BlockchainTests/ValidBlocks/bcEIP1153/tloadDoesNotPersistAcrossBlocks.json
+140 −0 BlockchainTests/ValidBlocks/bcEIP1153/tloadDoesNotPersistCrossTxn.json
+85 −85 BlockchainTests/ValidBlocks/bcEIP1559/burnVerify.json
+0 −709 BlockchainTests/ValidBlocks/bcEIP1559/burnVerifyLondon.json
+126 −133 BlockchainTests/ValidBlocks/bcEIP1559/tips.json
+0 −1,295 BlockchainTests/ValidBlocks/bcEIP1559/tipsLondon.json
+0 −7,056 DifficultyTests/dfGrayGlacier/difficultyGrayGlacier.json
+0 −4,016 DifficultyTests/dfGrayGlacier/difficultyGrayGlacierForkBlock.json
+0 −7,056 DifficultyTests/dfGrayGlacier/difficultyGrayGlacierMinus1.json
+0 −1,632 DifficultyTests/dfGrayGlacier/difficultyGrayGlacierTimeDiff1.json
+0 −1,632 DifficultyTests/dfGrayGlacier/difficultyGrayGlacierTimeDiff2.json
+76 −0 GeneralStateTests/stEIP1153/01_tloadBeginningTxn.json
+75 −0 GeneralStateTests/stEIP1153/02_tloadAfterTstore.json
+76 −0 GeneralStateTests/stEIP1153/03_tloadAfterStoreIs0.json
+83 −0 GeneralStateTests/stEIP1153/04_tloadAfterCall.json
+75 −0 GeneralStateTests/stEIP1153/05_tloadReentrancy.json
+75 −0 GeneralStateTests/stEIP1153/06_tstoreInReentrancyCall.json
+75 −0 GeneralStateTests/stEIP1153/07_tloadAfterReentrancyStore.json
+76 −0 GeneralStateTests/stEIP1153/08_revertUndoesTransientStore.json
+76 −0 GeneralStateTests/stEIP1153/09_revertUndoesAll.json
+76 −0 GeneralStateTests/stEIP1153/10_revertUndoesStoreAfterReturn.json
+82 −0 GeneralStateTests/stEIP1153/11_tstoreDelegateCall.json
+82 −0 GeneralStateTests/stEIP1153/12_tloadDelegateCall.json
+76 −0 GeneralStateTests/stEIP1153/13_tloadStaticCall.json
+76 −0 GeneralStateTests/stEIP1153/14_revertAfterNestedStaticcall.json
+77 −0 GeneralStateTests/stEIP1153/15_tstoreCannotBeDosd.json
+76 −0 GeneralStateTests/stEIP1153/16_tloadGas.json
+76 −0 GeneralStateTests/stEIP1153/17_tstoreGas.json
+76 −0 GeneralStateTests/stEIP1153/18_tloadAfterStore.json
+0 −81 GeneralStateTests/stExample/mergeTest.json
+3 −13 docs/blockchain-tutorial.rst
+3 −5 docs/test_filler/test_blockheader.rst
+106 −0 src/BlockchainTestsFiller/ValidBlocks/bcEIP1153/tloadDoesNotPersistAcrossBlocksFiller.yml
+104 −0 src/BlockchainTestsFiller/ValidBlocks/bcEIP1153/tloadDoesNotPersistCrossTxnFiller.yml
+15 −22 src/BlockchainTestsFiller/ValidBlocks/bcEIP1559/burnVerifyFiller.yml
+0 −465 src/BlockchainTestsFiller/ValidBlocks/bcEIP1559/burnVerifyLondonFiller.yml
+3 −9 src/BlockchainTestsFiller/ValidBlocks/bcEIP1559/tipsFiller.yml
+0 −637 src/BlockchainTestsFiller/ValidBlocks/bcEIP1559/tipsLondonFiller.yml
+0 −13 src/DifficultyTestsFiller/dfGrayGlacier/difficultyGrayGlacierFiller.json
+0 −13 src/DifficultyTestsFiller/dfGrayGlacier/difficultyGrayGlacierForkBlockFiller.json
+0 −13 src/DifficultyTestsFiller/dfGrayGlacier/difficultyGrayGlacierMinus1Filler.json
+0 −13 src/DifficultyTestsFiller/dfGrayGlacier/difficultyGrayGlacierTimeDiff1Filler.json
+0 −13 src/DifficultyTestsFiller/dfGrayGlacier/difficultyGrayGlacierTimeDiff2Filler.json
+60 −0 src/GeneralStateTestsFiller/stEIP1153/01_tloadBeginningTxnFiller.yml
+61 −0 src/GeneralStateTestsFiller/stEIP1153/02_tloadAfterTstoreFiller.yml
+63 −0 src/GeneralStateTestsFiller/stEIP1153/03_tloadAfterStoreIs0Filler.yml
+80 −0 src/GeneralStateTestsFiller/stEIP1153/04_tloadAfterCallFiller.yml
+110 −0 src/GeneralStateTestsFiller/stEIP1153/05_tloadReentrancyFiller.yml
+107 −0 src/GeneralStateTestsFiller/stEIP1153/06_tstoreInReentrancyCallFiller.yml
+99 −0 src/GeneralStateTestsFiller/stEIP1153/07_tloadAfterReentrancyStoreFiller.yml
+100 −0 src/GeneralStateTestsFiller/stEIP1153/08_revertUndoesTransientStoreFiller.yml
+93 −0 src/GeneralStateTestsFiller/stEIP1153/09_revertUndoesAllFiller.yml
+113 −0 src/GeneralStateTestsFiller/stEIP1153/10_revertUndoesStoreAfterReturnFiller.yml
+75 −0 src/GeneralStateTestsFiller/stEIP1153/11_tstoreDelegateCallFiller.yml
+73 −0 src/GeneralStateTestsFiller/stEIP1153/12_tloadDelegateCallFiller.yml
+90 −0 src/GeneralStateTestsFiller/stEIP1153/13_tloadStaticCallFiller.yml
+116 −0 src/GeneralStateTestsFiller/stEIP1153/14_revertAfterNestedStaticcallFiller.yml
+96 −0 src/GeneralStateTestsFiller/stEIP1153/15_tstoreCannotBeDosdFiller.yml
+81 −0 src/GeneralStateTestsFiller/stEIP1153/16_tloadGasFiller.yml
+81 −0 src/GeneralStateTestsFiller/stEIP1153/17_tstoreGasFiller.yml
+61 −0 src/GeneralStateTestsFiller/stEIP1153/18_tloadAfterStoreFiller.yml
+0 −69 src/GeneralStateTestsFiller/stExample/mergeTestFiller.yml
Loading