Transaction: Don't calculate contractAddress redundantly

Each place in `call_evm` that sets up an EVM call calculates the new contract
address for contract creations.  But it's redundant, because `newComputation`
ignores the provided value and does the calculation again.

Remove the unused address calculation.

This is also a step to merging different entry points and EVMC.  This change
ends up with the same value in both `msg.contractAddress` and `msg.codeAddress`
for every entry point, and this is good because it matches the EVMC message
structure, where they are replaced by only one value called `msg.destination`

Signed-off-by: Jamie Lokier <jamie@shareable.org>
This commit is contained in:
Jamie Lokier 2021-05-14 16:49:21 +01:00
parent fa74dc909e
commit 745129c4ac
No known key found for this signature in database
GPG Key ID: CBC25C68435C30A2

View File

@ -36,11 +36,7 @@ proc rpcSetupComputation(vmState: BaseVMState, call: RpcCallData,
depth: 0, depth: 0,
gas: gasLimit, gas: gasLimit,
sender: call.source, sender: call.source,
contractAddress: contractAddress: call.to,
if not call.contractCreation:
call.to
else:
generateAddress(call.source, vmState.readOnlyStateDB.getNonce(call.source)),
codeAddress: call.to, codeAddress: call.to,
value: call.value, value: call.value,
data: call.data data: call.data
@ -163,7 +159,7 @@ proc txSetupComputation(tx: Transaction, sender: EthAddress, vmState: BaseVMStat
depth: 0, depth: 0,
gas: gas, gas: gas,
sender: sender, sender: sender,
contractAddress: tx.getRecipient(sender), contractAddress: tx.to,
codeAddress: tx.to, codeAddress: tx.to,
value: tx.value, value: tx.value,
data: tx.payload data: tx.payload
@ -297,7 +293,7 @@ proc fixtureSetupComputation(vmState: BaseVMState, call: RpcCallData,
depth: 0, depth: 0,
gas: call.gas, # Differs from `rpcSetupComputation` gas: call.gas, # Differs from `rpcSetupComputation`
sender: call.source, sender: call.source,
contractAddress: call.to, # Differs from `rpcSetupComputation` contractAddress: call.to,
codeAddress: call.to, codeAddress: call.to,
value: call.value, value: call.value,
data: call.data data: call.data