Uploaded image for project: 'Byteman'
  1. Byteman
  2. BYTEMAN-216

NPE and unexpected error injecting trigger with synchronization and loops

    XMLWordPrintable

Details

    • Bug
    • Resolution: Duplicate
    • Major
    • None
    • 2.1.0
    • None
    • None

    Description

      When trying to instrument my code with Byteman 2.1.0, I always get the following error in stdout:

      exits unaccounted for in block B4
      

      Also, several NPEs occur. Here is the full output:

      Setting org.jboss.byteman.verbose=true
      Setting org.jboss.byteman.debug=true
      org.jboss.byteman.agent.Transformer : possible trigger for rule trace method call in class test.byteman.BytemanBugMonitorEnter
      RuleTriggerMethodAdapter.injectTriggerPoint : inserting trigger into test.byteman.BytemanBugMonitorEnter.getData(java.lang.String) java.lang.Object for rule trace method call
      exits unaccounted for in block B4
      org.jboss.byteman.agent.Transformer : unexpected error injecting trigger for rule trace method call into class test.byteman.BytemanBugMonitorEnter
      java.lang.NullPointerException
      java.lang.NullPointerException
      	at org.jboss.byteman.agent.adapter.cfg.CFG.computeContainment(CFG.java:1108)
      	at org.jboss.byteman.agent.adapter.cfg.CFG.carryForward(CFG.java:962)
      	at org.jboss.byteman.agent.adapter.cfg.CFG.split(CFG.java:1240)
      	at org.jboss.byteman.agent.adapter.RuleTriggerMethodAdapter.visitJumpInsn(RuleTriggerMethodAdapter.java:722)
      	at org.jboss.byteman.agent.adapter.EntryTriggerAdapter$EntryTriggerMethodAdapter.visitJumpInsn(EntryTriggerAdapter.java:176)
      	at org.jboss.byteman.objectweb.asm.tree.JumpInsnNode.accept(JumpInsnNode.java:83)
      	at org.jboss.byteman.objectweb.asm.tree.InsnList.accept(InsnList.java:170)
      	at org.jboss.byteman.objectweb.asm.tree.MethodNode.accept(MethodNode.java:470)
      	at org.jboss.byteman.objectweb.asm.commons.JSRInlinerAdapter.visitEnd(JSRInlinerAdapter.java:153)
      	at org.jboss.byteman.objectweb.asm.ClassReader.accept(ClassReader.java:1450)
      	at org.jboss.byteman.objectweb.asm.ClassReader.accept(ClassReader.java:394)
      	at org.jboss.byteman.agent.TransformContext.transform(TransformContext.java:150)
      	at org.jboss.byteman.agent.Transformer.transform(Transformer.java:674)
      	at org.jboss.byteman.agent.Transformer.tryTransform(Transformer.java:742)
      	at org.jboss.byteman.agent.Transformer.tryTransform(Transformer.java:713)
      	at org.jboss.byteman.agent.Transformer.transform(Transformer.java:243)
      	at sun.instrument.TransformerManager.transform(TransformerManager.java:169)
      	at sun.instrument.InstrumentationImpl.transform(InstrumentationImpl.java:365)
      	at java.lang.ClassLoader.defineClass1(Native Method)
      	at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
      	at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
      	at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
      	at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
      	at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
      	at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
      	at java.security.AccessController.doPrivileged(Native Method)
      	at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
      	at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
      	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
      	at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
      org.jboss.byteman.agent.Transformer : possible trigger for rule trace lock enter in class test.byteman.BytemanBugMonitorEnter
      RuleTriggerMethodAdapter.injectTriggerPoint : inserting trigger into test.byteman.BytemanBugMonitorEnter.getData(java.lang.String) java.lang.Object for rule trace lock enter
      exits unaccounted for in block B4
      org.jboss.byteman.agent.Transformer : unexpected error injecting trigger for rule trace lock enter into class test.byteman.BytemanBugMonitorEnter
      java.lang.NullPointerException
      java.lang.NullPointerException
      	at org.jboss.byteman.agent.adapter.cfg.CFG.computeContainment(CFG.java:1108)
      	at org.jboss.byteman.agent.adapter.cfg.CFG.carryForward(CFG.java:962)
      	at org.jboss.byteman.agent.adapter.cfg.CFG.split(CFG.java:1240)
      	at org.jboss.byteman.agent.adapter.RuleTriggerMethodAdapter.visitJumpInsn(RuleTriggerMethodAdapter.java:722)
      	at org.jboss.byteman.objectweb.asm.tree.JumpInsnNode.accept(JumpInsnNode.java:83)
      	at org.jboss.byteman.objectweb.asm.tree.InsnList.accept(InsnList.java:170)
      	at org.jboss.byteman.objectweb.asm.tree.MethodNode.accept(MethodNode.java:470)
      	at org.jboss.byteman.objectweb.asm.commons.JSRInlinerAdapter.visitEnd(JSRInlinerAdapter.java:153)
      	at org.jboss.byteman.objectweb.asm.ClassReader.accept(ClassReader.java:1450)
      	at org.jboss.byteman.objectweb.asm.ClassReader.accept(ClassReader.java:394)
      	at org.jboss.byteman.agent.TransformContext.transform(TransformContext.java:150)
      	at org.jboss.byteman.agent.Transformer.transform(Transformer.java:674)
      	at org.jboss.byteman.agent.Transformer.tryTransform(Transformer.java:742)
      	at org.jboss.byteman.agent.Transformer.tryTransform(Transformer.java:713)
      	at org.jboss.byteman.agent.Transformer.transform(Transformer.java:243)
      	at sun.instrument.TransformerManager.transform(TransformerManager.java:169)
      	at sun.instrument.InstrumentationImpl.transform(InstrumentationImpl.java:365)
      	at java.lang.ClassLoader.defineClass1(Native Method)
      	at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
      	at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
      	at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
      	at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
      	at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
      	at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
      	at java.security.AccessController.doPrivileged(Native Method)
      	at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
      	at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
      	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
      	at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
      org.jboss.byteman.agent.Transformer : possible trigger for rule trace lock exit in class test.byteman.BytemanBugMonitorEnter
      RuleTriggerMethodAdapter.injectTriggerPoint : inserting trigger into test.byteman.BytemanBugMonitorEnter.getData(java.lang.String) java.lang.Object for rule trace lock exit
      exits unaccounted for in block B4
      org.jboss.byteman.agent.Transformer : unexpected error injecting trigger for rule trace lock exit into class test.byteman.BytemanBugMonitorEnter
      java.lang.NullPointerException
      java.lang.NullPointerException
      	at org.jboss.byteman.agent.adapter.cfg.CFG.computeContainment(CFG.java:1108)
      	at org.jboss.byteman.agent.adapter.cfg.CFG.carryForward(CFG.java:962)
      	at org.jboss.byteman.agent.adapter.cfg.CFG.split(CFG.java:1240)
      	at org.jboss.byteman.agent.adapter.RuleTriggerMethodAdapter.visitJumpInsn(RuleTriggerMethodAdapter.java:722)
      	at org.jboss.byteman.objectweb.asm.tree.JumpInsnNode.accept(JumpInsnNode.java:83)
      	at org.jboss.byteman.objectweb.asm.tree.InsnList.accept(InsnList.java:170)
      	at org.jboss.byteman.objectweb.asm.tree.MethodNode.accept(MethodNode.java:470)
      	at org.jboss.byteman.objectweb.asm.commons.JSRInlinerAdapter.visitEnd(JSRInlinerAdapter.java:153)
      	at org.jboss.byteman.objectweb.asm.ClassReader.accept(ClassReader.java:1450)
      	at org.jboss.byteman.objectweb.asm.ClassReader.accept(ClassReader.java:394)
      	at org.jboss.byteman.agent.TransformContext.transform(TransformContext.java:150)
      	at org.jboss.byteman.agent.Transformer.transform(Transformer.java:674)
      	at org.jboss.byteman.agent.Transformer.tryTransform(Transformer.java:742)
      	at org.jboss.byteman.agent.Transformer.tryTransform(Transformer.java:713)
      	at org.jboss.byteman.agent.Transformer.transform(Transformer.java:243)
      	at sun.instrument.TransformerManager.transform(TransformerManager.java:169)
      	at sun.instrument.InstrumentationImpl.transform(InstrumentationImpl.java:365)
      	at java.lang.ClassLoader.defineClass1(Native Method)
      	at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
      	at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
      	at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
      	at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
      	at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
      	at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
      	at java.security.AccessController.doPrivileged(Native Method)
      	at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
      	at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
      	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
      	at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
      start
      done
      

      I extracted the relevant code snippet and rule (see attached source and rule files). They can be run with the following settings to reproduce the problem:

      -javaagent:lib/byteman.jar=script:bug-monitorenter.btm,prop:org.jboss.byteman.verbose=true,prop:org.jboss.byteman.debug=true
      

      Please note, that the problem disappears, when I remove the loop within the synchronization block (see XXX markers in the example code).

      Attachments

        1. bug-monitorenter.btm
          0.6 kB
          Wolfgang Schell
        2. BytemanBugMonitorEnter.class
          2 kB
          Wolfgang Schell
        3. BytemanBugMonitorEnter.java
          2 kB
          Wolfgang Schell
        4. BytemanBugMonitorEnter$DBIndex.class
          1 kB
          Wolfgang Schell

        Activity

          People

            rhn-engineering-adinn Andrew Dinn
            jetztgradnet Wolfgang Schell (Inactive)
            Votes:
            0 Vote for this issue
            Watchers:
            2 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: