aboutsummaryrefslogtreecommitdiffstats
path: root/packages/contracts/src/2.0.0/protocol/Exchange/libs
diff options
context:
space:
mode:
authorAmir Bandeali <abandeali1@gmail.com>2018-08-08 07:27:02 +0800
committerAmir Bandeali <abandeali1@gmail.com>2018-08-09 02:15:38 +0800
commit149c07dfd2ef2e2102d66ebbdaf1268a1938f4af (patch)
tree22b847c74e8cf74ca627db10eaff1d1e7dcc4302 /packages/contracts/src/2.0.0/protocol/Exchange/libs
parent3d6cf503645386734bb552e09df2c6709e2ed45c (diff)
downloaddexon-0x-contracts-149c07dfd2ef2e2102d66ebbdaf1268a1938f4af.tar
dexon-0x-contracts-149c07dfd2ef2e2102d66ebbdaf1268a1938f4af.tar.gz
dexon-0x-contracts-149c07dfd2ef2e2102d66ebbdaf1268a1938f4af.tar.bz2
dexon-0x-contracts-149c07dfd2ef2e2102d66ebbdaf1268a1938f4af.tar.lz
dexon-0x-contracts-149c07dfd2ef2e2102d66ebbdaf1268a1938f4af.tar.xz
dexon-0x-contracts-149c07dfd2ef2e2102d66ebbdaf1268a1938f4af.tar.zst
dexon-0x-contracts-149c07dfd2ef2e2102d66ebbdaf1268a1938f4af.zip
Use asm for hashEIP712Message, increment free memory pointer after asm hashing functions
Diffstat (limited to 'packages/contracts/src/2.0.0/protocol/Exchange/libs')
-rw-r--r--packages/contracts/src/2.0.0/protocol/Exchange/libs/LibEIP712.sol25
1 files changed, 20 insertions, 5 deletions
diff --git a/packages/contracts/src/2.0.0/protocol/Exchange/libs/LibEIP712.sol b/packages/contracts/src/2.0.0/protocol/Exchange/libs/LibEIP712.sol
index c9e45189d..b02f7632e 100644
--- a/packages/contracts/src/2.0.0/protocol/Exchange/libs/LibEIP712.sol
+++ b/packages/contracts/src/2.0.0/protocol/Exchange/libs/LibEIP712.sol
@@ -61,11 +61,26 @@ contract LibEIP712 {
view
returns (bytes32 result)
{
- result = keccak256(abi.encodePacked(
- EIP191_HEADER,
- EIP712_DOMAIN_HASH,
- hashStruct
- ));
+ bytes32 eip712DomainHash = EIP712_DOMAIN_HASH;
+
+ // Assembly for more efficient computing:
+ // keccak256(abi.encodePacked(
+ // EIP191_HEADER,
+ // EIP712_DOMAIN_HASH,
+ // hashStruct
+ // ));
+
+ assembly {
+ // Load free memory pointer
+ let memPtr := mload(64)
+
+ mstore(memPtr, 0x1901000000000000000000000000000000000000000000000000000000000000) // EIP191 header
+ mstore(add(memPtr, 2), eip712DomainHash) // EIP712 domain hash
+ mstore(add(memPtr, 34), hashStruct) // Hash of struct
+
+ // Compute hash
+ result := keccak256(memPtr, 66)
+ }
return result;
}
}