5/5
_Follow along with this video:_ --- ### Stepping Through the Execution Alright! This is very exciting, let's start by grabbing the compiled runtime bytecode of our contract. ``` huffc src/horseStoreV1/HorseStore.huff --bin-runtime 5f3560e01c8063cdfead2e1461001a5763e026c0171461001b575b5b ``` Entering this bytecode into the evm.codes playground we should see our contract, broken down into it's individual opcodes. Make note of the two distinct `JUMPDEST` codes at the bottom of the call list.  If we assure that the calldata we're passing begins with the updateHorseNumber function selector, things should be business as usual, until reach our first `JUMPI` code.  We can see our first `JUMPI` code pertains to one of the JUMPDEST codes at the bottom of our list of operations. Because we're passing JUMPI this location, and a 1 (which represents a matching selector), we would expect our next step to jump our execution to this location further in the code-bypassing the second check entirely.  And that's exactly what happens! Great work! 🎉I encourage you to experiment further before moving forward, try placing different contracts into the evm.codes playground and investigating how their opcodes function and interact. The more experience you have with these concepts the better!
Follow along with this video:
Alright! This is very exciting, let's start by grabbing the compiled runtime bytecode of our contract.
Entering this bytecode into the evm.codes playground we should see our contract, broken down into it's individual opcodes. Make note of the two distinct JUMPDEST
codes at the bottom of the call list.
If we assure that the calldata we're passing begins with the updateHorseNumber function selector, things should be business as usual, until reach our first JUMPI
code.
We can see our first JUMPI
code pertains to one of the JUMPDEST codes at the bottom of our list of operations. Because we're passing JUMPI this location, and a 1 (which represents a matching selector), we would expect our next step to jump our execution to this location further in the code-bypassing the second check entirely.
And that's exactly what happens! Great work! 🎉I encourage you to experiment further before moving forward, try placing different contracts into the evm.codes playground and investigating how their opcodes function and interact. The more experience you have with these concepts the better!
A deep dive into the JUMP and JUMPDEST Opcode. This lesson shows you how to use the JUMP and JUMPDEST opcodes to control the flow of execution in your Solidity code, giving you more control and flexibility. You'll learn what the JUMP and JUMPDEST opcodes do and how they can be used to create more complex smart contracts. The lesson also provides practical examples that you can try out for yourself to understand how these opcodes can be used in different scenarios.
Previous lesson
Previous
Next lesson
Next
Give us feedback
Course Overview
About the course
Assembly
Writing smart contracts using Huff and Yul
Ethereum Virtual Machine OPCodes
Formal verification testing
Smart contract invariant testing
Halmos, Certora, Kontrol
Security researcher
$49,999 - $120,000 (avg. salary)
Smart Contract Auditor
$100,000 - $200,000 (avg. salary)
Guest lecturers:
Last updated on August 11, 2025
Duration: 30min
Duration: 4h 38min
Duration: 3h 57min
Duration: 1h 56min
Course Overview
About the course
Assembly
Writing smart contracts using Huff and Yul
Ethereum Virtual Machine OPCodes
Formal verification testing
Smart contract invariant testing
Halmos, Certora, Kontrol
Security researcher
$49,999 - $120,000 (avg. salary)
Smart Contract Auditor
$100,000 - $200,000 (avg. salary)
Guest lecturers:
Last updated on August 11, 2025