Home | History | Annotate | Download | only in armv5te
      1 %verify "executed"
      2 %verify "Class already resolved"
      3 %verify "Class not yet resolved"
      4 %verify "Class cannot be resolved"
      5     /* const/class vAA, Class@BBBB */
      6     FETCH(r1, 1)                        @ r1<- BBBB
      7     ldr     r2, [rSELF, #offThread_methodClassDex]  @ r2<- self->methodClassDex
      8     mov     r9, rINST, lsr #8           @ r9<- AA
      9     ldr     r2, [r2, #offDvmDex_pResClasses]   @ r2<- dvmDex->pResClasses
     10     ldr     r0, [r2, r1, lsl #2]        @ r0<- pResClasses[BBBB]
     11     cmp     r0, #0                      @ not yet resolved?
     12     beq     .L${opcode}_resolve
     13     FETCH_ADVANCE_INST(2)               @ advance rPC, load rINST
     14     SET_VREG(r0, r9)                    @ vAA<- r0
     15     GET_INST_OPCODE(ip)                 @ extract opcode from rINST
     16     GOTO_OPCODE(ip)                     @ jump to next instruction
     17 %break
     18 
     19     /*
     20      * Continuation if the Class has not yet been resolved.
     21      *  r1: BBBB (Class ref)
     22      *  r9: target register
     23      */
     24 .L${opcode}_resolve:
     25     EXPORT_PC()
     26     ldr     r0, [rSELF, #offThread_method] @ r0<- self->method
     27     mov     r2, #1                      @ r2<- true
     28     ldr     r0, [r0, #offMethod_clazz]  @ r0<- method->clazz
     29     bl      dvmResolveClass             @ r0<- Class reference
     30     cmp     r0, #0                      @ failed?
     31     beq     common_exceptionThrown      @ yup, handle the exception
     32     FETCH_ADVANCE_INST(2)               @ advance rPC, load rINST
     33     SET_VREG(r0, r9)                    @ vAA<- r0
     34     GET_INST_OPCODE(ip)                 @ extract opcode from rINST
     35     GOTO_OPCODE(ip)                     @ jump to next instruction
     36