ethereum.byzantium.vm.instructions.stack

Ethereum Virtual Machine (EVM) Stack Instructions ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

.. contents:: Table of Contents :backlinks: none :local:

Introduction

Implementations of the EVM stack related instructions.

pop

Remove item from stack.

Parameters

evm : The current EVM frame.

def pop(evm: Evm) -> None:
26
    """
27
    Remove item from stack.
28
29
    Parameters
30
    ----------
31
    evm :
32
        The current EVM frame.
33
34
    """
35
    # STACK
36
    stack.pop(evm.stack)
37
38
    # GAS
39
    charge_gas(evm, GAS_BASE)
40
41
    # OPERATION
42
    pass
43
44
    # PROGRAM COUNTER
45
    evm.pc += Uint(1)

push_n

Pushes a N-byte immediate onto the stack.

Parameters

evm : The current EVM frame.

num_bytes : The number of immediate bytes to be read from the code and pushed to the stack.

def push_n(evm: Evm, ​​num_bytes: int) -> None:
49
    """
50
    Pushes a N-byte immediate onto the stack.
51
52
    Parameters
53
    ----------
54
    evm :
55
        The current EVM frame.
56
57
    num_bytes :
58
        The number of immediate bytes to be read from the code and pushed to
59
        the stack.
60
61
    """
62
    # STACK
63
    pass
64
65
    # GAS
66
    charge_gas(evm, GAS_VERY_LOW)
67
68
    # OPERATION
69
    data_to_push = U256.from_be_bytes(
70
        buffer_read(evm.code, U256(evm.pc + Uint(1)), U256(num_bytes))
71
    )
72
    stack.push(evm.stack, data_to_push)
73
74
    # PROGRAM COUNTER
75
    evm.pc += Uint(1) + Uint(num_bytes)

dup_n

Duplicate the Nth stack item (from top of the stack) to the top of stack.

Parameters

evm : The current EVM frame.

item_number : The stack item number (0-indexed from top of stack) to be duplicated to the top of stack.

def dup_n(evm: Evm, ​​item_number: int) -> None:
79
    """
80
    Duplicate the Nth stack item (from top of the stack) to the top of stack.
81
82
    Parameters
83
    ----------
84
    evm :
85
        The current EVM frame.
86
87
    item_number :
88
        The stack item number (0-indexed from top of stack) to be duplicated
89
        to the top of stack.
90
91
    """
92
    # STACK
93
    pass
94
95
    # GAS
96
    charge_gas(evm, GAS_VERY_LOW)
97
    if item_number >= len(evm.stack):
98
        raise StackUnderflowError
99
    data_to_duplicate = evm.stack[len(evm.stack) - 1 - item_number]
100
    stack.push(evm.stack, data_to_duplicate)
101
102
    # PROGRAM COUNTER
103
    evm.pc += Uint(1)

swap_n

Swap the top and the item_number element of the stack, where the top of the stack is position zero.

If item_number is zero, this function does nothing (which should not be possible, since there is no SWAP0 instruction).

Parameters

evm : The current EVM frame.

item_number : The stack item number (0-indexed from top of stack) to be swapped with the top of stack element.

def swap_n(evm: Evm, ​​item_number: int) -> None:
107
    """
108
    Swap the top and the `item_number` element of the stack, where
109
    the top of the stack is position zero.
110
111
    If `item_number` is zero, this function does nothing (which should not be
112
    possible, since there is no `SWAP0` instruction).
113
114
    Parameters
115
    ----------
116
    evm :
117
        The current EVM frame.
118
119
    item_number :
120
        The stack item number (0-indexed from top of stack) to be swapped
121
        with the top of stack element.
122
123
    """
124
    # STACK
125
    pass
126
127
    # GAS
128
    charge_gas(evm, GAS_VERY_LOW)
129
    if item_number >= len(evm.stack):
130
        raise StackUnderflowError
131
    evm.stack[-1], evm.stack[-1 - item_number] = (
132
        evm.stack[-1 - item_number],
133
        evm.stack[-1],
134
    )
135
136
    # PROGRAM COUNTER
137
    evm.pc += Uint(1)

push1

140
push1 = partial(push_n, num_bytes=1)

push2

141
push2 = partial(push_n, num_bytes=2)

push3

142
push3 = partial(push_n, num_bytes=3)

push4

143
push4 = partial(push_n, num_bytes=4)

push5

144
push5 = partial(push_n, num_bytes=5)

push6

145
push6 = partial(push_n, num_bytes=6)

push7

146
push7 = partial(push_n, num_bytes=7)

push8

147
push8 = partial(push_n, num_bytes=8)

push9

148
push9 = partial(push_n, num_bytes=9)

push10

149
push10 = partial(push_n, num_bytes=10)

push11

150
push11 = partial(push_n, num_bytes=11)

push12

151
push12 = partial(push_n, num_bytes=12)

push13

152
push13 = partial(push_n, num_bytes=13)

push14

153
push14 = partial(push_n, num_bytes=14)

push15

154
push15 = partial(push_n, num_bytes=15)

push16

155
push16 = partial(push_n, num_bytes=16)

push17

156
push17 = partial(push_n, num_bytes=17)

push18

157
push18 = partial(push_n, num_bytes=18)

push19

158
push19 = partial(push_n, num_bytes=19)

push20

159
push20 = partial(push_n, num_bytes=20)

push21

160
push21 = partial(push_n, num_bytes=21)

push22

161
push22 = partial(push_n, num_bytes=22)

push23

162
push23 = partial(push_n, num_bytes=23)

push24

163
push24 = partial(push_n, num_bytes=24)

push25

164
push25 = partial(push_n, num_bytes=25)

push26

165
push26 = partial(push_n, num_bytes=26)

push27

166
push27 = partial(push_n, num_bytes=27)

push28

167
push28 = partial(push_n, num_bytes=28)

push29

168
push29 = partial(push_n, num_bytes=29)

push30

169
push30 = partial(push_n, num_bytes=30)

push31

170
push31 = partial(push_n, num_bytes=31)

push32

171
push32 = partial(push_n, num_bytes=32)

dup1

173
dup1 = partial(dup_n, item_number=0)

dup2

174
dup2 = partial(dup_n, item_number=1)

dup3

175
dup3 = partial(dup_n, item_number=2)

dup4

176
dup4 = partial(dup_n, item_number=3)

dup5

177
dup5 = partial(dup_n, item_number=4)

dup6

178
dup6 = partial(dup_n, item_number=5)

dup7

179
dup7 = partial(dup_n, item_number=6)

dup8

180
dup8 = partial(dup_n, item_number=7)

dup9

181
dup9 = partial(dup_n, item_number=8)

dup10

182
dup10 = partial(dup_n, item_number=9)

dup11

183
dup11 = partial(dup_n, item_number=10)

dup12

184
dup12 = partial(dup_n, item_number=11)

dup13

185
dup13 = partial(dup_n, item_number=12)

dup14

186
dup14 = partial(dup_n, item_number=13)

dup15

187
dup15 = partial(dup_n, item_number=14)

dup16

188
dup16 = partial(dup_n, item_number=15)

swap1

190
swap1 = partial(swap_n, item_number=1)

swap2

191
swap2 = partial(swap_n, item_number=2)

swap3

192
swap3 = partial(swap_n, item_number=3)

swap4

193
swap4 = partial(swap_n, item_number=4)

swap5

194
swap5 = partial(swap_n, item_number=5)

swap6

195
swap6 = partial(swap_n, item_number=6)

swap7

196
swap7 = partial(swap_n, item_number=7)

swap8

197
swap8 = partial(swap_n, item_number=8)

swap9

198
swap9 = partial(swap_n, item_number=9)

swap10

199
swap10 = partial(swap_n, item_number=10)

swap11

200
swap11 = partial(swap_n, item_number=11)

swap12

201
swap12 = partial(swap_n, item_number=12)

swap13

202
swap13 = partial(swap_n, item_number=13)

swap14

203
swap14 = partial(swap_n, item_number=14)

swap15

204
swap15 = partial(swap_n, item_number=15)

swap16

205
swap16 = partial(swap_n, item_number=16)