summaryrefslogtreecommitdiff
path: root/vm/mterp/armv5te/OP_CONST_16.S
diff options
context:
space:
mode:
Diffstat (limited to 'vm/mterp/armv5te/OP_CONST_16.S')
-rw-r--r--vm/mterp/armv5te/OP_CONST_16.S8
1 files changed, 8 insertions, 0 deletions
diff --git a/vm/mterp/armv5te/OP_CONST_16.S b/vm/mterp/armv5te/OP_CONST_16.S
new file mode 100644
index 0000000..b5654a3
--- /dev/null
+++ b/vm/mterp/armv5te/OP_CONST_16.S
@@ -0,0 +1,8 @@
+%verify "executed"
+ /* const/16 vAA, #+BBBB */
+ FETCH_S(r0, 1) @ r0<- ssssBBBB (sign-extended)
+ mov r3, rINST, lsr #8 @ r3<- AA
+ FETCH_ADVANCE_INST(2) @ advance rPC, load rINST
+ SET_VREG(r0, r3) @ vAA<- r0
+ GET_INST_OPCODE(ip) @ extract opcode from rINST
+ GOTO_OPCODE(ip) @ jump to next instruction