%verify "executed" %verify "field already resolved" %verify "field not yet resolved" %verify "field cannot be resolved" /* * General 32-bit SPUT handler. * * for: sput, sput-object, sput-boolean, sput-byte, sput-char, sput-short */ /* op vAA, field@BBBB */ GET_GLUE(%ecx) movzwl 2(rPC),%eax # eax<- field ref BBBB movl offGlue_methodClassDex(%ecx),%ecx # ecx<- DvmDex movl offDvmDex_pResFields(%ecx),%ecx # ecx<- dvmDex->pResFields movl (%ecx,%eax,4),%eax # eax<- resolved StaticField ptr testl %eax,%eax # resolved entry null? je .L${opcode}_resolve # if not, make it so .L${opcode}_finish: # field ptr in eax movzbl rINST_HI,%ecx # ecx<- AA GET_VREG_WORD(rINST_FULL,%ecx,0) # rINST_FULL<- lsw GET_VREG_WORD(%ecx,%ecx,1) # ecx<- msw movl rINST_FULL,offStaticField_value(%eax) FETCH_INST_WORD(2) ADVANCE_PC(2) movl %ecx,4+offStaticField_value(%eax) GOTO_NEXT %break /* * Go resolve the field */ .L${opcode}_resolve: GET_GLUE(%ecx) movzwl 2(rPC),%eax # eax<- field ref BBBB movl offGlue_method(%ecx),%ecx # ecx<- current method EXPORT_PC() # could throw, need to export movl offMethod_clazz(%ecx),%ecx # ecx<- method->clazz SPILL(rPC) movl %eax,OUT_ARG1(%esp) movl %ecx,OUT_ARG0(%esp) call dvmResolveStaticField # eax<- resolved StaticField ptr UNSPILL(rPC) testl %eax,%eax jne .L${opcode}_finish # success, continue jmp common_exceptionThrown # no, handle exception