CREATE opcode: what does it really do?What does bytecode of blank contract do?When does a SUICIDE opcode becomes effective?Possible to create new contract via a proposal in the ethereum.org/dao framework?What are the two arguments to a RETURN opcode?Can the CALL opcode be used to create a contract?Transaction Error. Exception thrown in contract code. REVERT opcode when sending ETH to crowdsaleWhat happens in CALL when gas is set to 0?Ethereum opcode: meaning of first few instructions?callvalue opcode, for what?EVM SIGNEXTEND Opcode explanation

What is the intuitive meaning of having a linear relationship between the logs of two variables?

How does it work when somebody invests in my business?

Hostile work environment after whistle-blowing on coworker and our boss. What do I do?

How can a function with a hole (removable discontinuity) equal a function with no hole?

Sequence of Tenses: Translating the subjunctive

Why Were Madagascar and New Zealand Discovered So Late?

Lay out the Carpet

Gears on left are inverse to gears on right?

What does this 7 mean above the f flat

Is a stroke of luck acceptable after a series of unfavorable events?

Does "every" first-order theory have a finitely axiomatizable conservative extension?

Large drywall patch supports

Short story about space worker geeks who zone out by 'listening' to radiation from stars

Sort a list by elements of another list

How did Doctor Strange see the winning outcome in Avengers: Infinity War?

What's the purpose of "true" in bash "if sudo true; then"

How to draw lines on a tikz-cd diagram

Italian words for tools

Is there a good way to store credentials outside of a password manager?

Unexpected indention in bibliography items (beamer)

Is `x >> pure y` equivalent to `liftM (const y) x`

How do we know the LHC results are robust?

Is this apparent Class Action settlement a spam message?

Purchasing a ticket for someone else in another country?



CREATE opcode: what does it really do?


What does bytecode of blank contract do?When does a SUICIDE opcode becomes effective?Possible to create new contract via a proposal in the ethereum.org/dao framework?What are the two arguments to a RETURN opcode?Can the CALL opcode be used to create a contract?Transaction Error. Exception thrown in contract code. REVERT opcode when sending ETH to crowdsaleWhat happens in CALL when gas is set to 0?Ethereum opcode: meaning of first few instructions?callvalue opcode, for what?EVM SIGNEXTEND Opcode explanation













2















I am looking at the docs, but cannot really understand what CREATE opcode does. I can tell that CREATE does create a new smart contract from a memory chunk, pass the gas value to this new contract, then returns. But before returning, does it execute the new contract?



This confuses me because looking at the disassembly code of the smart contract bytecode, after CREATE, I cannot see any call to CALL after that, but then I still see a call to RETURNDATASIZE, which I suppose only happen after CALL. Without CALL, where it get returned data from?



Any enlighten, please?










share|improve this question


























    2















    I am looking at the docs, but cannot really understand what CREATE opcode does. I can tell that CREATE does create a new smart contract from a memory chunk, pass the gas value to this new contract, then returns. But before returning, does it execute the new contract?



    This confuses me because looking at the disassembly code of the smart contract bytecode, after CREATE, I cannot see any call to CALL after that, but then I still see a call to RETURNDATASIZE, which I suppose only happen after CALL. Without CALL, where it get returned data from?



    Any enlighten, please?










    share|improve this question
























      2












      2








      2








      I am looking at the docs, but cannot really understand what CREATE opcode does. I can tell that CREATE does create a new smart contract from a memory chunk, pass the gas value to this new contract, then returns. But before returning, does it execute the new contract?



      This confuses me because looking at the disassembly code of the smart contract bytecode, after CREATE, I cannot see any call to CALL after that, but then I still see a call to RETURNDATASIZE, which I suppose only happen after CALL. Without CALL, where it get returned data from?



      Any enlighten, please?










      share|improve this question














      I am looking at the docs, but cannot really understand what CREATE opcode does. I can tell that CREATE does create a new smart contract from a memory chunk, pass the gas value to this new contract, then returns. But before returning, does it execute the new contract?



      This confuses me because looking at the disassembly code of the smart contract bytecode, after CREATE, I cannot see any call to CALL after that, but then I still see a call to RETURNDATASIZE, which I suppose only happen after CALL. Without CALL, where it get returned data from?



      Any enlighten, please?







      opcode create






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked 1 hour ago









      user311703user311703

      1806




      1806




















          1 Answer
          1






          active

          oldest

          votes


















          5














          CREATE, in a way, does a built in CALL. What actually happens is that the data passed to call isn't the contract bytecode, it's the init bytecode.



          When CREATE opcode is executed, the EVM creates a call frame in the context of the new contract (e.g. address(this) is the new contracts address). This executes the data passed to CREATE as the code, which in higher level languages is basically the constructor. At the end of this init stuff, it returns the actual code of the contract that is stored in the state trie.



          The easiest way to think about it, which is also fairly accurate, is that the Solidity compiler takes all the executional code of the contract, compiles it to bytecode, and adds it as a return statement at the end of the constructor.






          share|improve this answer

























          • ah, so CREATE when creating a contract actually returns the contract bytecode, right? then after that, CALL will actually executes the contract?

            – user311703
            1 hour ago











          • Please could you tell me what is the best way to track/trace what is really happening at bytecode level? Does Remix a good tool to do this?

            – user311703
            1 hour ago











          • CREATE executes the code passed to it, and that code returns the contact bytecode, yes. Just wanted to be clear on that

            – flygoing
            55 mins ago











          • If you need to a call a function after it's created, then yeah, there would be a CALL right after. Remix is a pretty good way to track/trace on the bytecode level, it has pretty good EVM debugging tools for stepping in/out of bytecode

            – flygoing
            54 mins ago










          Your Answer








          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "642"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fethereum.stackexchange.com%2fquestions%2f68943%2fcreate-opcode-what-does-it-really-do%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          5














          CREATE, in a way, does a built in CALL. What actually happens is that the data passed to call isn't the contract bytecode, it's the init bytecode.



          When CREATE opcode is executed, the EVM creates a call frame in the context of the new contract (e.g. address(this) is the new contracts address). This executes the data passed to CREATE as the code, which in higher level languages is basically the constructor. At the end of this init stuff, it returns the actual code of the contract that is stored in the state trie.



          The easiest way to think about it, which is also fairly accurate, is that the Solidity compiler takes all the executional code of the contract, compiles it to bytecode, and adds it as a return statement at the end of the constructor.






          share|improve this answer

























          • ah, so CREATE when creating a contract actually returns the contract bytecode, right? then after that, CALL will actually executes the contract?

            – user311703
            1 hour ago











          • Please could you tell me what is the best way to track/trace what is really happening at bytecode level? Does Remix a good tool to do this?

            – user311703
            1 hour ago











          • CREATE executes the code passed to it, and that code returns the contact bytecode, yes. Just wanted to be clear on that

            – flygoing
            55 mins ago











          • If you need to a call a function after it's created, then yeah, there would be a CALL right after. Remix is a pretty good way to track/trace on the bytecode level, it has pretty good EVM debugging tools for stepping in/out of bytecode

            – flygoing
            54 mins ago















          5














          CREATE, in a way, does a built in CALL. What actually happens is that the data passed to call isn't the contract bytecode, it's the init bytecode.



          When CREATE opcode is executed, the EVM creates a call frame in the context of the new contract (e.g. address(this) is the new contracts address). This executes the data passed to CREATE as the code, which in higher level languages is basically the constructor. At the end of this init stuff, it returns the actual code of the contract that is stored in the state trie.



          The easiest way to think about it, which is also fairly accurate, is that the Solidity compiler takes all the executional code of the contract, compiles it to bytecode, and adds it as a return statement at the end of the constructor.






          share|improve this answer

























          • ah, so CREATE when creating a contract actually returns the contract bytecode, right? then after that, CALL will actually executes the contract?

            – user311703
            1 hour ago











          • Please could you tell me what is the best way to track/trace what is really happening at bytecode level? Does Remix a good tool to do this?

            – user311703
            1 hour ago











          • CREATE executes the code passed to it, and that code returns the contact bytecode, yes. Just wanted to be clear on that

            – flygoing
            55 mins ago











          • If you need to a call a function after it's created, then yeah, there would be a CALL right after. Remix is a pretty good way to track/trace on the bytecode level, it has pretty good EVM debugging tools for stepping in/out of bytecode

            – flygoing
            54 mins ago













          5












          5








          5







          CREATE, in a way, does a built in CALL. What actually happens is that the data passed to call isn't the contract bytecode, it's the init bytecode.



          When CREATE opcode is executed, the EVM creates a call frame in the context of the new contract (e.g. address(this) is the new contracts address). This executes the data passed to CREATE as the code, which in higher level languages is basically the constructor. At the end of this init stuff, it returns the actual code of the contract that is stored in the state trie.



          The easiest way to think about it, which is also fairly accurate, is that the Solidity compiler takes all the executional code of the contract, compiles it to bytecode, and adds it as a return statement at the end of the constructor.






          share|improve this answer















          CREATE, in a way, does a built in CALL. What actually happens is that the data passed to call isn't the contract bytecode, it's the init bytecode.



          When CREATE opcode is executed, the EVM creates a call frame in the context of the new contract (e.g. address(this) is the new contracts address). This executes the data passed to CREATE as the code, which in higher level languages is basically the constructor. At the end of this init stuff, it returns the actual code of the contract that is stored in the state trie.



          The easiest way to think about it, which is also fairly accurate, is that the Solidity compiler takes all the executional code of the contract, compiles it to bytecode, and adds it as a return statement at the end of the constructor.







          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited 1 hour ago

























          answered 1 hour ago









          flygoingflygoing

          7,580931




          7,580931












          • ah, so CREATE when creating a contract actually returns the contract bytecode, right? then after that, CALL will actually executes the contract?

            – user311703
            1 hour ago











          • Please could you tell me what is the best way to track/trace what is really happening at bytecode level? Does Remix a good tool to do this?

            – user311703
            1 hour ago











          • CREATE executes the code passed to it, and that code returns the contact bytecode, yes. Just wanted to be clear on that

            – flygoing
            55 mins ago











          • If you need to a call a function after it's created, then yeah, there would be a CALL right after. Remix is a pretty good way to track/trace on the bytecode level, it has pretty good EVM debugging tools for stepping in/out of bytecode

            – flygoing
            54 mins ago

















          • ah, so CREATE when creating a contract actually returns the contract bytecode, right? then after that, CALL will actually executes the contract?

            – user311703
            1 hour ago











          • Please could you tell me what is the best way to track/trace what is really happening at bytecode level? Does Remix a good tool to do this?

            – user311703
            1 hour ago











          • CREATE executes the code passed to it, and that code returns the contact bytecode, yes. Just wanted to be clear on that

            – flygoing
            55 mins ago











          • If you need to a call a function after it's created, then yeah, there would be a CALL right after. Remix is a pretty good way to track/trace on the bytecode level, it has pretty good EVM debugging tools for stepping in/out of bytecode

            – flygoing
            54 mins ago
















          ah, so CREATE when creating a contract actually returns the contract bytecode, right? then after that, CALL will actually executes the contract?

          – user311703
          1 hour ago





          ah, so CREATE when creating a contract actually returns the contract bytecode, right? then after that, CALL will actually executes the contract?

          – user311703
          1 hour ago













          Please could you tell me what is the best way to track/trace what is really happening at bytecode level? Does Remix a good tool to do this?

          – user311703
          1 hour ago





          Please could you tell me what is the best way to track/trace what is really happening at bytecode level? Does Remix a good tool to do this?

          – user311703
          1 hour ago













          CREATE executes the code passed to it, and that code returns the contact bytecode, yes. Just wanted to be clear on that

          – flygoing
          55 mins ago





          CREATE executes the code passed to it, and that code returns the contact bytecode, yes. Just wanted to be clear on that

          – flygoing
          55 mins ago













          If you need to a call a function after it's created, then yeah, there would be a CALL right after. Remix is a pretty good way to track/trace on the bytecode level, it has pretty good EVM debugging tools for stepping in/out of bytecode

          – flygoing
          54 mins ago





          If you need to a call a function after it's created, then yeah, there would be a CALL right after. Remix is a pretty good way to track/trace on the bytecode level, it has pretty good EVM debugging tools for stepping in/out of bytecode

          – flygoing
          54 mins ago

















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Ethereum Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fethereum.stackexchange.com%2fquestions%2f68943%2fcreate-opcode-what-does-it-really-do%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Category:Fedor von Bock Media in category "Fedor von Bock"Navigation menuUpload mediaISNI: 0000 0000 5511 3417VIAF ID: 24712551GND ID: 119294796Library of Congress authority ID: n96068363BnF ID: 12534305fSUDOC authorities ID: 034604189Open Library ID: OL338253ANKCR AUT ID: jn19990000869National Library of Israel ID: 000514068National Thesaurus for Author Names ID: 341574317ReasonatorScholiaStatistics

          Reverse int within the 32-bit signed integer range: [−2^31, 2^31 − 1]Combining two 32-bit integers into one 64-bit integerDetermine if an int is within rangeLossy packing 32 bit integer to 16 bitComputing the square root of a 64-bit integerKeeping integer addition within boundsSafe multiplication of two 64-bit signed integersLeetcode 10: Regular Expression MatchingSigned integer-to-ascii x86_64 assembler macroReverse the digits of an Integer“Add two numbers given in reverse order from a linked list”

          Kiel Indholdsfortegnelse Historie | Transport og færgeforbindelser | Sejlsport og anden sport | Kultur | Kendte personer fra Kiel | Noter | Litteratur | Eksterne henvisninger | Navigationsmenuwww.kiel.de54°19′31″N 10°8′26″Ø / 54.32528°N 10.14056°Ø / 54.32528; 10.14056Oberbürgermeister Dr. Ulf Kämpferwww.statistik-nord.deDen danske Stats StatistikKiels hjemmesiderrrWorldCat312794080n790547494030481-4