Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-4130047

Java JDK 1.1.6+Symantec JITL : page fault crashes VM

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Duplicate
    • Icon: P2 P2
    • None
    • 1.1.6
    • vm-legacy

      Customer gets the following page fault when using the Symantec JIT 3.0 to be
      shipped with JDK 1.1.6 on win32

      Happens with all the 3.0 JIT builds we have tried.
      Doesn't happen without JIT, and did not happen with previous JIT V2.0 that
      was available for JDK 1.1.5

      Here's the technical info we have

      The app is always trying to make a network connection at the time of the
      crash ..

      RE caused an invalid page fault in
      module KERNEL32.DLL at 016f:bff79ff4.
      Registers:
      EAX=7fd49e61 CS=016f EIP=bff79ff4 EFLGS=00010202
      EBX=0555ff88 SS=0177 ESP=05460000 EBP=05460028
      ECX=05461dd8 DS=0177 ESI=00000001 FS=455f
      EDX=00000001 ES=0177 EDI=81641c54 GS=0000
      Bytes at CS:EIP:
      57 89 65 e8 75 04 33 c0 eb 54 85 c0 74 4b c7 45
      Stack dump:
      00000001 0555ff88 7fd49e61 00000001 0555ff88 102092e0 05461dd8 bffb88a8 bff781c8
      ffffffff 05461de8 bff7b3ef 7fd49e61 00000001 10209401 7fd49e61


         - it happens every time, under both 95 and NT
         - the crash is always at the same place in symcjit, but our java
           code is in one of two places (see below, in CastanetRequest)
         - it happens with the standard java.exe. doesn't make sense
           to try our own executable yet.

      Here is the assembly surrounding the line where the fault occurs:

      01F09B06 51 push ecx
      01F09B07 55 push ebp
      01F09B08 8B CE mov ecx,esi
      01F09B0A E8 E1 C6 FF FF call 01F061F0
      01F09B0F 57 push edi
      01F09B10 8B CE mov ecx,esi
      01F09B12 E8 19 CF FF FF call 01F06A30
      01F09B17 EB 3C jmp 01F09B55
      01F09B19 8B 56 78 mov edx,dword ptr [esi+78h]
      01F09B1C 8D 04 40 lea eax,dword ptr [eax+eax*2]
      01F09B1F 83 E1 21 and ecx,21h
      01F09B22 8D 04 80 lea eax,dword ptr [eax+eax*4]
      01F09B25 8D 04 82 lea eax,dword ptr [edx+eax*4]

      the crash occurs here:
      ==> 01F09B28 8B 10 mov edx,dword ptr [eax]

      01F09B2A 0B D1 or edx,ecx
      01F09B2C 89 10 mov dword ptr [eax],edx
      01F09B2E 88 4F 08 mov byte ptr [edi+8],cl
      01F09B31 C1 E9 04 shr ecx,4
      01F09B34 83 E1 02 and ecx,2
      01F09B37 C7 47 0C 0F 00 00 00 mov dword ptr [edi+0Ch],0Fh
      01F09B3E 51 push ecx
      01F09B3F 55 push ebp
      01F09B40 8B CE mov ecx,esi
      01F09B42 89 9E 48 02 00 00 mov dword ptr [esi+248h],ebx
      01F09B48 E8 A3 C5 FF FF call 01F060F0


      Here are the two thread dumps involved in the crash:

      Full thread dump:
          "Castanet Request" (TID:0xf7a1b8, sys_thread_t:0x8a9270,
      Win32ID:0x102, state:R) prio=4
              marimba.io.FastInputStream.readBuffer(Compiled Code)
             
      com.marimba.castanet.tuner.Protocol.handleRequest(Protocol.java:99)
              com.marimba.castanet.tuner.Request.run(Request.java:169)
              com.marimba.tools.util.ThreadPool.runClient(Compiled Code)
          "Init: http://mad:5282/amd/ChannelManager" (TID:0xf79cb8,
      sys_thread_t:0x8a49a0, Win32ID:0xed, state:CW) prio=5
              java.lang.Object.wait(Compiled Code)
          "Screen Updater" (TID:0xf78e48, sys_thread_t:0x89fc60, Win32ID:0x99,
      state:CW) prio=4
              java.lang.Object.wait(Compiled Code)
          "HTTP Proxy: 5283" (TID:0xf78a20, sys_thread_t:0x898c80,
      Win32ID:0xae, state:R) prio=5
              java.net.PlainSocketImpl.accept(Compiled Code)
          "File Server" (TID:0xf78ac0, sys_thread_t:0x8a5130, Win32ID:0xd8,
      state:R) prio=4
              java.net.PlainSocketImpl.accept(Compiled Code)
          "Icon Notifier" (TID:0xf77e90, sys_thread_t:0x8a3c30, Win32ID:0xe3,
      state:R) prio=5
              com.marimba.desktop.WindowsDesktop.run(WindowsDesktop.java:222)
              java.lang.Thread.run(Compiled Code)
          "Multicast Listener: tuner" (TID:0xf76fd8, sys_thread_t:0x8a8430,
      Win32ID:0xce, state:R) prio=4
              java.net.DatagramSocket.receive(Compiled Code)
          "RPC Listener: listener-7717-0" (TID:0xf76af0,
      sys_thread_t:0x8a2c40, Win32ID:0xef, state:R) prio=5
              java.net.PlainSocketImpl.accept(Compiled Code)
              java.net.ServerSocket.implAccept(Compiled Code)
              java.net.ServerSocket.accept(Compiled Code)
              com.marimba.rpc.RPCListener.run(Compiled Code)
              com.marimba.tools.util.ThreadPool.runClient(Compiled Code)
              com.marimba.tools.util.ThreadPool.run(Compiled Code)
          "AWT-Windows" (TID:0xf6ba60, sys_thread_t:0x8873d0, Win32ID:0xad,
      state:R) prio=5
              sun.awt.windows.WToolkit.run(WToolkit.java:107)
              java.lang.Thread.run(Compiled Code)
          "AWT-EventQueue-0" (TID:0xf6b860, sys_thread_t:0x8872d0,
      Win32ID:0xb7, state:CW) prio=5
              java.lang.Object.wait(Compiled Code)
          "MDDEServer" (TID:0xf6a6b0, sys_thread_t:0x886f00, Win32ID:0x79,
      state:R) prio=5
              com.marimba.desktop.MDDEServer.run(WindowsDesktop.java:770)
          "Timer" (TID:0xf693f0, sys_thread_t:0x87e5a0, Win32ID:0xe6,
      state:CW) prio=5
              marimba.util.Timer.run(Compiled Code)
              java.lang.Thread.run(Compiled Code)
          "Finalizer thread" (TID:0xf60088, sys_thread_t:0x865ec0,
      Win32ID:0xb8, state:CW) prio=2
          "main" (TID:0xf600b0, sys_thread_t:0x86e7d0, Win32ID:0xd7, state:CW)
      prio=5
      Monitor Cache Dump:
          sun.awt.ScreenUpdater@F78E48/1032C40: <unowned>
              Waiters: 1
          java.net.PlainSocketImpl@F78A30/1031620: owner "HTTP Proxy: 5283"
      (0x898c80, 1 entry)
          com.marimba.castanet.launch.Active@F79608/1033B50: <unowned>
              Waiters: 1
          java.net.PlainSocketImpl@F78AD8/1031368: owner "File Server"
      (0x8a5130, 1 entry)
          java.net.PlainSocketImpl@F76BB0/1020FE8: owner "RPC Listener:
      listener-7717-0" (0x8a2c40, 1 entry)
          java.net.PlainDatagramSocketImpl@F76DD8/1021BB8: owner "Multicast
      Listener:tuner" (0x8a8430, 1 entry)
          java.net.MulticastSocket@F76DF0/1021B50: owner "Multicast Listener:
      tuner" (0x8a8430, 1 entry)
          java.net.DatagramPacket@F76D58/1022610: owner "Multicast Listener:
      tuner" (0x8a8430, 1 entry)
          java.awt.EventQueue@F6B8A8/FD57E0: <unowned>
              Waiters: 1
      Registered Monitor Dump:
          SymcJIT Method Monitor: owner "Castanet Request" (0x8a9270, 1 entry)
          SymcJIT Method Monitor: <unowned>
          SymcJIT Method List Monitor: <unowned>
          SymcJIT Fixups Allocation: <unowned>
          SymcJIT Code Allocation: <unowned>
          SymcJIT Data Allocation: <unowned>
          Thread queue lock: <unowned>
              Waiters: 1
          Name and type hash table lock: <unowned>
          String intern lock: <unowned>
          JNI pinning lock: <unowned>
          JNI global reference lock: <unowned>
          BinClass lock: <unowned>
          Class loading lock: <unowned>
          Java stack lock: <unowned>
          Code rewrite lock: <unowned>
          Heap lock: <unowned>
          Has finalization queue lock: <unowned>
          Finalize me queue lock: <unowned>
              Waiters: 1
          Monitor registry: <unowned>



      --



      Full thread dump:
          "AWT-Finalizer" (TID:0xf7db78, sys_thread_t:0x8bccb0, Win32ID:0x108,
      state:CW) prio=8
              java.lang.Object.wait(Compiled Code)
          "Local" (TID:0xf7b218, sys_thread_t:0x8b08e0, Win32ID:0x103,
      state:CW) prio=6
              com.marimba.tools.util.ThreadPool.run(Compiled Code)
          "Init: http://mad:5282/amd/ChannelManager" (TID:0xf7ad28,
      sys_thread_t:0x8a8310, Win32ID:0xde, state:CW) prio=5
              java.lang.Object.wait(Compiled Code)
          "Castanet Request" (TID:0xf7ad50, sys_thread_t:0x8a8230,
      Win32ID:0xbe, state:R) prio=4
              com.marimba.castanet.tuner.Protocol_13.sendRequest(Compiled
      Code)
             
      com.marimba.castanet.tuner.Protocol.handleRequest(Protocol.java:99)
              com.marimba.castanet.tuner.Request.run(Request.java:169)
              com.marimba.tools.util.ThreadPool.runClient(Compiled Code)
          "Local" (TID:0xf78c18, sys_thread_t:0x8ac5f0, Win32ID:0x106,
      state:CW) prio=6
              com.marimba.tools.util.ThreadPool.run(Compiled Code)
          "Screen Updater" (TID:0xf79cc0, sys_thread_t:0x8a7f80, Win32ID:0x96,
      state:CW) prio=4
              java.lang.Object.wait(Compiled Code)
          "HTTP Proxy: 5283" (TID:0xf79748, sys_thread_t:0x882100,
      Win32ID:0x10a, state:R) prio=5
              java.net.PlainSocketImpl.accept(Compiled Code)
          "File Server" (TID:0xf797e8, sys_thread_t:0x8a9620, Win32ID:0x109,
      state:R)
      prio=4
              java.net.PlainSocketImpl.accept(Compiled Code)
          "Icon Notifier" (TID:0xf788a0, sys_thread_t:0x8a3a60, Win32ID:0xd1,
      state:R) prio=5
              com.marimba.desktop.WindowsDesktop.run(WindowsDesktop.java:222)
              java.lang.Thread.run(Compiled Code)
          "Multicast Listener: tuner" (TID:0xf77cb0, sys_thread_t:0x8a3600,
      Win32ID:0xbb, state:R) prio=4
              java.net.DatagramSocket.receive(Compiled Code)
          "RPC Listener: listener-7717-0" (TID:0xf77800,
      sys_thread_t:0x89f420, Win32ID:0xfc, state:R) prio=5
              java.net.PlainSocketImpl.accept(Compiled Code)
              java.net.ServerSocket.implAccept(Compiled Code)
              java.net.ServerSocket.accept(Compiled Code)
              com.marimba.rpc.RPCListener.run(Compiled Code)
              com.marimba.tools.util.ThreadPool.runClient(Compiled Code)
              com.marimba.tools.util.ThreadPool.run(Compiled Code)
          "Image Fetcher 0" (TID:0xf6bcc8, sys_thread_t:0x88e6a0,
      Win32ID:0xd5, state:CW) prio=8
              sun.awt.image.ImageFetcher.nextImage(Compiled Code)
          "AWT-Windows" (TID:0xf6ba58, sys_thread_t:0x883a30, Win32ID:0xdb,
      state:R) prio=5
              sun.awt.windows.WToolkit.run(WToolkit.java:107)
              java.lang.Thread.run(Compiled Code)
          "AWT-EventQueue-0" (TID:0xf6b6f8, sys_thread_t:0x88d830,
      Win32ID:0xdf, state:CW) prio=5
              java.lang.Object.wait(Compiled Code)
          "MDDEServer" (TID:0xf6a558, sys_thread_t:0x886e70, Win32ID:0xeb,
      state:R) prio=5
              com.marimba.desktop.MDDEServer.run(WindowsDesktop.java:770)
          "Timer" (TID:0xf693f0, sys_thread_t:0x87e5a0, Win32ID:0x9c, state:R)
      prio=5
              marimba.util.Timer.run(Compiled Code)
              java.lang.Thread.run(Compiled Code)
          "Finalizer thread" (TID:0xf60088, sys_thread_t:0x865ec0,
      Win32ID:0xe5, state:CW) prio=2
          "main" (TID:0xf600b0, sys_thread_t:0x86e7d0, Win32ID:0x86, state:CW)
      prio=5
      Monitor Cache Dump:
          java.awt.EventQueue@F6B740/FD5538: <unowned>
              Waiters: 1
          java.net.MulticastSocket@F77AD0/1030508: owner "Multicast Listener:
      tuner" (0x8a3600, 1 entry)
          java.net.PlainSocketImpl@F79800/103E948: owner "File Server"
      (0x8a9620, 1 entry)
          com.marimba.castanet.launch.Active@F78C08/10410F8: <unowned>
              Waiters: 1
          java.net.PlainSocketImpl@F77618/102F4C8: owner "RPC Listener:
      listener-7717-0" (0x89f420, 1 entry)
          sun.awt.ScreenUpdater@F79CC0/103FE30: <unowned>
              Waiters: 1
          java.net.DatagramPacket@F77A38/1030BC8: owner "Multicast Listener:
      tuner" (0x8a3600, 1 entry)
          java.net.PlainDatagramSocketImpl@F77B80/1030990: owner "Multicast
      Listener:
      tuner" (0x8a3600, 1 entry)
          java.net.PlainSocketImpl@F79758/103EC20: owner "HTTP Proxy: 5283"
      (0x882100, 1 entry)
          sun.awt.AWTFinalizer@F7DB78/FC9F20: <unowned>
              Waiters: 1
          java.util.Vector@F6BCE8/FD7648: <unowned>
              Waiters: 1
          com.marimba.tools.util.ThreadPool@F6D4C8/FEC930: <unowned>
              Waiters: 2
      Registered Monitor Dump:
          SymcJIT Method Monitor: owner "Castanet Request" (0x8a8230, 1 entry)
          SymcJIT Method Monitor: <unowned>
          SymcJIT Method Monitor: <unowned>
          SymcJIT Method List Monitor: <unowned>
          SymcJIT Fixups Allocation: <unowned>
          SymcJIT Code Allocation: <unowned>
          SymcJIT Data Allocation: <unowned>
          Thread queue lock: <unowned>
              Waiters: 1
          Name and type hash table lock: <unowned>
          String intern lock: <unowned>
          JNI pinning lock: <unowned>
          JNI global reference lock: <unowned>
          BinClass lock: <unowned>
          Class loading lock: <unowned>
          Java stack lock: <unowned>
          Code rewrite lock: <unowned>
          Heap lock: <unowned>
          Has finalization queue lock: <unowned>
          Finalize me queue lock: <unowned>
              Waiters: 1
          Monitor registry: <unowned>

            dviswanasunw Deepa Viswanathan (Inactive)
            prr Philip Race
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

              Created:
              Updated:
              Resolved:
              Imported:
              Indexed: