1# Copyright (C) 2007 The Android Open Source Project 2# 3# Licensed under the Apache License, Version 2.0 (the "License"); 4# you may not use this file except in compliance with the License. 5# You may obtain a copy of the License at 6# 7# http://www.apache.org/licenses/LICENSE-2.0 8# 9# Unless required by applicable law or agreed to in writing, software 10# distributed under the License is distributed on an "AS IS" BASIS, 11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12# See the License for the specific language governing permissions and 13# limitations under the License. 14 15# 16# Bytecode definition file 17# 18 19# One line per instruction format family. Each line consists of a 20# series of instruction formats that all take (potentially) compatible 21# arguments. The order is the preferred order (most to least 22# preferable) of formats, when more than one opcode could be used for 23# a given instruction's arguments. 24# 25# Note: The family that starts with 12x has a mix of both two- and 26# three- register formats. This is because some of the two-register 27# opcodes effectively take three, with a destination and two sources 28# where the destination and one of the sources have to be the same. 29 30# Regular formats 31format 10t 20t 30t 32format 10x 33format 11n 21s 21h 31i 51l 34format 11x 35format 12x 22x 23x 32x # See note, above. 36format 21c 31c 37format 21t 31t 38format 22b 22s 39format 22c 40format 22t 41format 35c 3rc 42format 45cc 4rcc 43 44# Optimized formats 45format 00x 46format 20bc 47format 22cs 48format 35mi 49format 35ms 50format 3rmi 51format 3rms 52 53# One line per opcode. Columns are: 54# hex for opcode 55# opcode name 56# format 57# has result register; one of: 58# y 59# n 60# index type; one of: 61# unknown -- used for undefined opcodes and breakpoint 62# none 63# varies 64# type-ref 65# string-ref 66# method-ref 67# field-ref 68# inline-method 69# vtable-offset 70# field-offset 71# method-and-proto-ref 72# call-site-ref 73# flags; pipe-combined combo of one or more of: 74# optimized -- optimized; not to be included in unoptimized dex files 75# branch -- might branch to an address 76# continue -- might continue to the next address in sequence 77# switch -- is a switch 78# throw -- might throw an exception 79# return -- is a return from method 80# invoke -- is a method invoke; this is only used for true 81# method invokes and notably *not* vm-implemented 82# execute-inline nor the nop-equivalent 83# invoke-direct-empty 84 85# 86# Regular opcodes (with a couple holes) 87# 88 89op 00 nop 10x n none continue 90op 01 move 12x y none continue 91op 02 move/from16 22x y none continue 92op 03 move/16 32x y none continue 93op 04 move-wide 12x y none continue 94op 05 move-wide/from16 22x y none continue 95op 06 move-wide/16 32x y none continue 96op 07 move-object 12x y none continue 97op 08 move-object/from16 22x y none continue 98op 09 move-object/16 32x y none continue 99op 0a move-result 11x y none continue 100op 0b move-result-wide 11x y none continue 101op 0c move-result-object 11x y none continue 102op 0d move-exception 11x y none continue 103op 0e return-void 10x n none return 104op 0f return 11x n none return 105op 10 return-wide 11x n none return 106op 11 return-object 11x n none return 107op 12 const/4 11n y none continue 108op 13 const/16 21s y none continue 109op 14 const 31i y none continue 110op 15 const/high16 21h y none continue 111op 16 const-wide/16 21s y none continue 112op 17 const-wide/32 31i y none continue 113op 18 const-wide 51l y none continue 114op 19 const-wide/high16 21h y none continue 115op 1a const-string 21c y string-ref continue|throw 116op 1b const-string/jumbo 31c y string-ref continue|throw 117op 1c const-class 21c y type-ref continue|throw 118op 1d monitor-enter 11x n none continue|throw 119op 1e monitor-exit 11x n none continue|throw 120op 1f check-cast 21c y type-ref continue|throw 121op 20 instance-of 22c y type-ref continue|throw 122op 21 array-length 12x y none continue|throw 123op 22 new-instance 21c y type-ref continue|throw 124op 23 new-array 22c y type-ref continue|throw 125op 24 filled-new-array 35c n type-ref continue|throw 126op 25 filled-new-array/range 3rc n type-ref continue|throw 127op 26 fill-array-data 31t n none continue 128op 27 throw 11x n none throw 129op 28 goto 10t n none branch 130op 29 goto/16 20t n none branch 131op 2a goto/32 30t n none branch 132op 2b packed-switch 31t n none continue|switch 133op 2c sparse-switch 31t n none continue|switch 134op 2d cmpl-float 23x y none continue 135op 2e cmpg-float 23x y none continue 136op 2f cmpl-double 23x y none continue 137op 30 cmpg-double 23x y none continue 138op 31 cmp-long 23x y none continue 139op 32 if-eq 22t n none continue|branch 140op 33 if-ne 22t n none continue|branch 141op 34 if-lt 22t n none continue|branch 142op 35 if-ge 22t n none continue|branch 143op 36 if-gt 22t n none continue|branch 144op 37 if-le 22t n none continue|branch 145op 38 if-eqz 21t n none continue|branch 146op 39 if-nez 21t n none continue|branch 147op 3a if-ltz 21t n none continue|branch 148op 3b if-gez 21t n none continue|branch 149op 3c if-gtz 21t n none continue|branch 150op 3d if-lez 21t n none continue|branch 151# unused: op 3e..43 152op 44 aget 23x y none continue|throw 153op 45 aget-wide 23x y none continue|throw 154op 46 aget-object 23x y none continue|throw 155op 47 aget-boolean 23x y none continue|throw 156op 48 aget-byte 23x y none continue|throw 157op 49 aget-char 23x y none continue|throw 158op 4a aget-short 23x y none continue|throw 159op 4b aput 23x n none continue|throw 160op 4c aput-wide 23x n none continue|throw 161op 4d aput-object 23x n none continue|throw 162op 4e aput-boolean 23x n none continue|throw 163op 4f aput-byte 23x n none continue|throw 164op 50 aput-char 23x n none continue|throw 165op 51 aput-short 23x n none continue|throw 166op 52 iget 22c y field-ref continue|throw 167op 53 iget-wide 22c y field-ref continue|throw 168op 54 iget-object 22c y field-ref continue|throw 169op 55 iget-boolean 22c y field-ref continue|throw 170op 56 iget-byte 22c y field-ref continue|throw 171op 57 iget-char 22c y field-ref continue|throw 172op 58 iget-short 22c y field-ref continue|throw 173op 59 iput 22c n field-ref continue|throw 174op 5a iput-wide 22c n field-ref continue|throw 175op 5b iput-object 22c n field-ref continue|throw 176op 5c iput-boolean 22c n field-ref continue|throw 177op 5d iput-byte 22c n field-ref continue|throw 178op 5e iput-char 22c n field-ref continue|throw 179op 5f iput-short 22c n field-ref continue|throw 180op 60 sget 21c y field-ref continue|throw 181op 61 sget-wide 21c y field-ref continue|throw 182op 62 sget-object 21c y field-ref continue|throw 183op 63 sget-boolean 21c y field-ref continue|throw 184op 64 sget-byte 21c y field-ref continue|throw 185op 65 sget-char 21c y field-ref continue|throw 186op 66 sget-short 21c y field-ref continue|throw 187op 67 sput 21c n field-ref continue|throw 188op 68 sput-wide 21c n field-ref continue|throw 189op 69 sput-object 21c n field-ref continue|throw 190op 6a sput-boolean 21c n field-ref continue|throw 191op 6b sput-byte 21c n field-ref continue|throw 192op 6c sput-char 21c n field-ref continue|throw 193op 6d sput-short 21c n field-ref continue|throw 194op 6e invoke-virtual 35c n method-ref continue|throw|invoke 195op 6f invoke-super 35c n method-ref continue|throw|invoke 196op 70 invoke-direct 35c n method-ref continue|throw|invoke 197op 71 invoke-static 35c n method-ref continue|throw|invoke 198op 72 invoke-interface 35c n method-ref continue|throw|invoke 199# unused: op 73 200op 74 invoke-virtual/range 3rc n method-ref continue|throw|invoke 201op 75 invoke-super/range 3rc n method-ref continue|throw|invoke 202op 76 invoke-direct/range 3rc n method-ref continue|throw|invoke 203op 77 invoke-static/range 3rc n method-ref continue|throw|invoke 204op 78 invoke-interface/range 3rc n method-ref continue|throw|invoke 205# unused: op 79..7a 206op 7b neg-int 12x y none continue 207op 7c not-int 12x y none continue 208op 7d neg-long 12x y none continue 209op 7e not-long 12x y none continue 210op 7f neg-float 12x y none continue 211op 80 neg-double 12x y none continue 212op 81 int-to-long 12x y none continue 213op 82 int-to-float 12x y none continue 214op 83 int-to-double 12x y none continue 215op 84 long-to-int 12x y none continue 216op 85 long-to-float 12x y none continue 217op 86 long-to-double 12x y none continue 218op 87 float-to-int 12x y none continue 219op 88 float-to-long 12x y none continue 220op 89 float-to-double 12x y none continue 221op 8a double-to-int 12x y none continue 222op 8b double-to-long 12x y none continue 223op 8c double-to-float 12x y none continue 224op 8d int-to-byte 12x y none continue 225op 8e int-to-char 12x y none continue 226op 8f int-to-short 12x y none continue 227op 90 add-int 23x y none continue 228op 91 sub-int 23x y none continue 229op 92 mul-int 23x y none continue 230op 93 div-int 23x y none continue|throw 231op 94 rem-int 23x y none continue|throw 232op 95 and-int 23x y none continue 233op 96 or-int 23x y none continue 234op 97 xor-int 23x y none continue 235op 98 shl-int 23x y none continue 236op 99 shr-int 23x y none continue 237op 9a ushr-int 23x y none continue 238op 9b add-long 23x y none continue 239op 9c sub-long 23x y none continue 240op 9d mul-long 23x y none continue 241op 9e div-long 23x y none continue|throw 242op 9f rem-long 23x y none continue|throw 243op a0 and-long 23x y none continue 244op a1 or-long 23x y none continue 245op a2 xor-long 23x y none continue 246op a3 shl-long 23x y none continue 247op a4 shr-long 23x y none continue 248op a5 ushr-long 23x y none continue 249op a6 add-float 23x y none continue 250op a7 sub-float 23x y none continue 251op a8 mul-float 23x y none continue 252op a9 div-float 23x y none continue 253op aa rem-float 23x y none continue 254op ab add-double 23x y none continue 255op ac sub-double 23x y none continue 256op ad mul-double 23x y none continue 257op ae div-double 23x y none continue 258op af rem-double 23x y none continue 259op b0 add-int/2addr 12x y none continue 260op b1 sub-int/2addr 12x y none continue 261op b2 mul-int/2addr 12x y none continue 262op b3 div-int/2addr 12x y none continue|throw 263op b4 rem-int/2addr 12x y none continue|throw 264op b5 and-int/2addr 12x y none continue 265op b6 or-int/2addr 12x y none continue 266op b7 xor-int/2addr 12x y none continue 267op b8 shl-int/2addr 12x y none continue 268op b9 shr-int/2addr 12x y none continue 269op ba ushr-int/2addr 12x y none continue 270op bb add-long/2addr 12x y none continue 271op bc sub-long/2addr 12x y none continue 272op bd mul-long/2addr 12x y none continue 273op be div-long/2addr 12x y none continue|throw 274op bf rem-long/2addr 12x y none continue|throw 275op c0 and-long/2addr 12x y none continue 276op c1 or-long/2addr 12x y none continue 277op c2 xor-long/2addr 12x y none continue 278op c3 shl-long/2addr 12x y none continue 279op c4 shr-long/2addr 12x y none continue 280op c5 ushr-long/2addr 12x y none continue 281op c6 add-float/2addr 12x y none continue 282op c7 sub-float/2addr 12x y none continue 283op c8 mul-float/2addr 12x y none continue 284op c9 div-float/2addr 12x y none continue 285op ca rem-float/2addr 12x y none continue 286op cb add-double/2addr 12x y none continue 287op cc sub-double/2addr 12x y none continue 288op cd mul-double/2addr 12x y none continue 289op ce div-double/2addr 12x y none continue 290op cf rem-double/2addr 12x y none continue 291op d0 add-int/lit16 22s y none continue 292op d1 rsub-int 22s y none continue 293op d2 mul-int/lit16 22s y none continue 294op d3 div-int/lit16 22s y none continue|throw 295op d4 rem-int/lit16 22s y none continue|throw 296op d5 and-int/lit16 22s y none continue 297op d6 or-int/lit16 22s y none continue 298op d7 xor-int/lit16 22s y none continue 299op d8 add-int/lit8 22b y none continue 300op d9 rsub-int/lit8 22b y none continue 301op da mul-int/lit8 22b y none continue 302op db div-int/lit8 22b y none continue|throw 303op dc rem-int/lit8 22b y none continue|throw 304op dd and-int/lit8 22b y none continue 305op de or-int/lit8 22b y none continue 306op df xor-int/lit8 22b y none continue 307op e0 shl-int/lit8 22b y none continue 308op e1 shr-int/lit8 22b y none continue 309op e2 ushr-int/lit8 22b y none continue 310 311# 312# Optimized opcodes (not valid in an unoptimized dex file) 313# 314 315op e3 +iget-volatile 22c y field-ref optimized|continue|throw 316op e4 +iput-volatile 22c n field-ref optimized|continue|throw 317op e5 +sget-volatile 21c y field-ref optimized|continue|throw 318op e6 +sput-volatile 21c n field-ref optimized|continue|throw 319op e7 +iget-object-volatile 22c y field-ref optimized|continue|throw 320op e8 +iget-wide-volatile 22c y field-ref optimized|continue|throw 321op e9 +iput-wide-volatile 22c n field-ref optimized|continue|throw 322op ea +sget-wide-volatile 21c y field-ref optimized|continue|throw 323op eb +sput-wide-volatile 21c n field-ref optimized|continue|throw 324 325# Technically "breakpoint" isn't really an optimized opcode, but it 326# fits the label in terms of not being valid in regular dex files. 327op ec ^breakpoint 00x n unknown optimized 328 329op ed ^throw-verification-error 20bc n varies optimized|throw 330op ee +execute-inline 35mi n inline-method optimized|continue|throw 331op ef +execute-inline/range 3rmi n inline-method optimized|continue|throw 332 333op f0 +invoke-object-init/range 35c n method-ref optimized|continue|throw|invoke 334op f1 +return-void-barrier 10x n none optimized|return 335op f2 +iget-quick 22cs y field-offset optimized|continue|throw 336op f3 +iget-wide-quick 22cs y field-offset optimized|continue|throw 337op f4 +iget-object-quick 22cs y field-offset optimized|continue|throw 338op f5 +iput-quick 22cs n field-offset optimized|continue|throw 339op f6 +iput-wide-quick 22cs n field-offset optimized|continue|throw 340op f7 +iput-object-quick 22cs n field-offset optimized|continue|throw 341op f8 +invoke-virtual-quick 35ms n vtable-offset optimized|continue|throw|invoke 342op f9 +invoke-virtual-quick/range 3rms n vtable-offset optimized|continue|throw|invoke 343 344# Invoke-polymorphic 345op fa invoke-polymorphic 45cc y method-and-proto-ref continue|throw|invoke 346op fb invoke-polymorphic/range 4rcc y method-and-proto-ref continue|throw|invoke 347op fc invoke-custom 35c y call-site-ref continue|throw|invoke 348op fd invoke-custom/range 3rc y call-site-ref continue|throw|invoke 349 350# More optimized opcodes (not valid in an unoptimized dex file) 351 352op fe +sput-object-volatile 21c n field-ref optimized|continue|throw 353 354# unused: op ff 355