aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/codegen/AsmCodeGen.cpp
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-12-05 01:57:07 +0800
committerchriseth <chris@ethereum.org>2018-12-06 21:32:04 +0800
commitf6ed29b88b0a721984173df04f04ad4c48d8711d (patch)
tree58d4f4345cea8c3f4b4d236203102638b835d9b3 /libsolidity/codegen/AsmCodeGen.cpp
parent4721cf332f0ca8af5fa16244c651cd6a635b3cdc (diff)
downloaddexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar
dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.gz
dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.bz2
dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.lz
dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.xz
dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.zst
dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.zip
Extend abstract assembly to be able to handle sub-objects.
Diffstat (limited to 'libsolidity/codegen/AsmCodeGen.cpp')
-rw-r--r--libsolidity/codegen/AsmCodeGen.cpp36
1 files changed, 36 insertions, 0 deletions
diff --git a/libsolidity/codegen/AsmCodeGen.cpp b/libsolidity/codegen/AsmCodeGen.cpp
index 4ca0c4e2..dfcc900b 100644
--- a/libsolidity/codegen/AsmCodeGen.cpp
+++ b/libsolidity/codegen/AsmCodeGen.cpp
@@ -27,10 +27,13 @@
#include <libyul/backends/evm/EVMCodeTransform.h>
#include <libevmasm/Assembly.h>
+#include <libevmasm/AssemblyItem.h>
#include <libevmasm/Instruction.h>
#include <liblangutil/SourceLocation.h>
+#include <libdevcore/FixedHash.h>
+
#include <memory>
#include <functional>
@@ -131,6 +134,39 @@ void EthAssemblyAdapter::appendAssemblySize()
m_assembly.appendProgramSize();
}
+pair<shared_ptr<AbstractAssembly>, AbstractAssembly::SubID> EthAssemblyAdapter::createSubAssembly()
+{
+ shared_ptr<eth::Assembly> assembly{make_shared<eth::Assembly>()};
+ auto sub = m_assembly.newSub(assembly);
+ return {make_shared<EthAssemblyAdapter>(*assembly), size_t(sub.data())};
+}
+
+void EthAssemblyAdapter::appendDataOffset(AbstractAssembly::SubID _sub)
+{
+ auto it = m_dataHashBySubId.find(_sub);
+ if (it == m_dataHashBySubId.end())
+ m_assembly.pushSubroutineOffset(size_t(_sub));
+ else
+ m_assembly << eth::AssemblyItem(eth::PushData, it->second);
+}
+
+void EthAssemblyAdapter::appendDataSize(AbstractAssembly::SubID _sub)
+{
+ auto it = m_dataHashBySubId.find(_sub);
+ if (it == m_dataHashBySubId.end())
+ m_assembly.pushSubroutineSize(size_t(_sub));
+ else
+ m_assembly << u256(m_assembly.data(h256(it->second)).size());
+}
+
+AbstractAssembly::SubID EthAssemblyAdapter::appendData(bytes const& _data)
+{
+ eth::AssemblyItem pushData = m_assembly.newData(_data);
+ SubID subID = m_nextDataCounter++;
+ m_dataHashBySubId[subID] = pushData.data();
+ return subID;
+}
+
EthAssemblyAdapter::LabelID EthAssemblyAdapter::assemblyTagToIdentifier(eth::AssemblyItem const& _tag)
{
u256 id = _tag.data();