1 # Copyright (C) 2011 Apple Inc. All rights reserved.
3 # Redistribution and use in source and binary forms, with or without
4 # modification, are permitted provided that the following conditions
6 # 1. Redistributions of source code must retain the above copyright
7 # notice, this list of conditions and the following disclaimer.
8 # 2. Redistributions in binary form must reproduce the above copyright
9 # notice, this list of conditions and the following disclaimer in the
10 # documentation and/or other materials provided with the distribution.
12 # THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
13 # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
14 # THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
15 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
16 # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
17 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
18 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
19 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
20 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
21 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
22 # THE POSSIBILITY OF SUCH DAMAGE.
26 # Interesting invariant, which we take advantage of: branching instructions
27 # always begin with "b", and no non-branching instructions begin with "b".
28 # Terminal instructions are "jmp" and "ret".
68 "fii2d", # usage: fii2d <gpr with least significant bits>, <gpr with most significant bits>, <fpr>
69 "fd2ii", # usage: fd2ii <fpr>, <gpr with least significant bits>, <gpr with most significant bits>
263 "smulli", # Multiply two 32-bit words and produce a 64-bit word
264 "addis", # Add integers and set a flag.
265 "subis", # Same, but for subtraction.
266 "oris", # Same, but for bitwise or.
267 "addps" # addis but for pointers.
287 "loaddReversedAndIncrementAddress",
288 "storedReversedAndDecrementAddress",
297 "cloopCrash", # no operands
298 "cloopCallJSFunction", # operands: callee
299 "cloopCallNative", # operands: callee
300 "cloopCallSlowPath", # operands: callTarget, currentFrame, currentPC
302 # For debugging only:
303 # Takes no operands but simply emits whatever follows in // comments as
304 # a line of C++ code in the generated LLIntAssembly.h file. This can be
305 # used to insert instrumentation into the interpreter loop to inspect
306 # variables of interest. Do not leave these instructions in production
308 "cloopDo", # no operands
311 INSTRUCTIONS
= MACRO_INSTRUCTIONS + X86_INSTRUCTIONS + RISC_INSTRUCTIONS + MIPS_INSTRUCTIONS + SH4_INSTRUCTIONS + CXX_INSTRUCTIONS
313 INSTRUCTION_PATTERN
= Regexp
.new('\\A((' + INSTRUCTIONS
.join(')|(') +
'))\\Z')
315 def isBranch(instruction
)
319 def hasFallThrough(instruction
)
320 instruction !
= "ret" and instruction !
= "jmp"