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

runThese crash - NULL string passed to JNI GetStringLength

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Duplicate
    • Icon: P3 P3
    • None
    • 1.4.0
    • core-libs
    • None

      Run the attached script crash.sh; a NULL jstr is passed to
      GetStringLength. 1.4b70 and earlier will fail with an assertion in the
      VM ('allocating a handle inside a NoHandleMark'), later builds will SEGV
      in jni_GetStringLength (the code that triggered the assert in the VM is
      a bug and is being removed, since JNI routines are not required to check
      for NULL arguments).

      dbx t@X l@X 4> ignore SEGV
      dbx t@X l@X 4> run
      Running: java_g -Xint -classpath /net/sqesvr.eng/export/vsn/VM/testbase/runThese/classes runThese -thread 1 -repeat 1 -iter 1 -D:gc=5 -D:TESTBASE=/net/sqesvr.eng/export/vsn/VM/testbase/runThese/tests -runList crash.dat
      (process id 1760)
      Reading libjvm_g.so
      Reading libCrun.so.1
      Reading libsocket.so.1
      Reading libnsl.so.1
      Reading libm.so.1
      Reading libw.so.1
      Reading libmp.so.2
      Reading libhpi_g.so
      Reading libverify_g.so
      Reading libjava_g.so
      Reading libzip_g.so
      Reading en_US.so.2
      Reading libnio_g.so
      Reading libposix4.so.1
      Reading libnet_g.so
      Reading libaio.so.1
      ......................................
      [Enter:X]
      Test c2004101 Passed
      java.lang.NullPointerException
              at java.io.UnixFileSystem.resolve(UnixFileSystem.java:91)
              at java.io.UnixFileSystem.resolve(UnixFileSystem.java:108)
              at java.io.File.getCanonicalPath(File.java:449)
              at java.io.FilePermission$1.run(FilePermission.java:212)
              at java.security.AccessController.doPrivileged(Native Method)
              at java.io.FilePermission.init(FilePermission.java:206)
              at java.io.FilePermission.<init>(FilePermission.java:256)
              at java.lang.SecurityManager.checkDelete(SecurityManager.java:1005)
              at java.io.File.delete(File.java:724)
              at runThese$TestRunner.updateTable(runThese.java:691)
              at runThese$TestRunner.runTest(runThese.java:673)
              at runThese$TestRunner.run(runThese.java:578)
      runThese Finished
      #
      # HotSpot Virtual Machine Error, assertion failure
      # Please report this error at
      # http://java.sun.com/cgi-bin/bugreport.cgi
      #
      # Java VM: Java HotSpot(TM) Client VM (1.4.0-beta_refresh-b67-debug interpreted mode)
      #
      # assert(_no_handle_mark_nesting == 0, "allocating handle inside NoHandleMark")
      #
      # Error ID: /usr/re/hotspot/hotspot1.4/ws/solsparc/hotspot1.4beta_refresh/src/share/vm/runtime/handles.cpp, 23 [ Patched ]
      #
      # Problematic Thread: prio=5 tid=0xfa1f8 nid=0xd runnable
      #
      Dumping core....
      t@13 (l@1) signal ABRT (Abort) in __sigprocmask at 0xff379e54
      0xff379e54: __sigprocmask+0x0008: jmp %o7 + 0x8
      Current function is getString8859_1Chars
        412 jint len = (*env)->GetStringLength(env, jstr);
      dbx t@13 l@1 10> print jstr
      jstr = (nil)
      dbx t@13 l@1 11> where
      current thread: t@13
        [1] __sigprocmask(0x0, 0xf4c80368, 0x0, 0xffffffff, 0xffffffff, 0x0), at 0xff379e54
        [2] _resetsig(0xff38cae4, 0x0, 0xf4c81dc0, 0x0, 0x0, 0xf4c81e40), at 0xff36f3ec
        [3] _sigon(0xff394578, 0xff3943d8, 0xf4c81e38, 0xf4c8043c, 0x6, 0xff2cdf6c), at 0xff36eb10
        [4] _thrp_kill(0x0, 0xd, 0x6, 0xff38cae4, 0xf4c81dc0, 0xff393d54), at 0xff371a20
        [5] abort(0xff3359c8, 0xf4c80538, 0x0, 0xfffffff8, 0x0, 0xf4c80559), at 0xff2b95a8
        [6] os::abort(0x1, 0xfe1c3ab0, 0xf4c80ddc, 0xfe2eb95a, 0xfe2eb8c9, 0x1), at 0xfdd19fa8
        [7] report_error(0x1, 0xfe1de237, 0x17, 0xfe1c38fd, 0xfe1c390f, 0xfe1de21a), at 0xfda0f1d4
        [8] report_assertion_failure(0xfe1de21a, 0xfe1de237, 0x17, 0xfe1de296, 0xf5200000, 0x0), at 0xfda0e530
        [9] HandleArea::allocate_handle(0xfa7e0, 0xf9001800, 0x162, 0x162, 0xfe269f1b, 0x0), at 0xfda8dd6c
        [10] Handle::Handle(0xf4c810f4, 0xf9001800, 0x6, 0xffffffff, 0xfffffff8, 0xfa7b0), at 0xfdb846a0
        [11] symbolHandle::symbolHandle(0xf4c810f4, 0xf9001800, 0x9c, 0xf4c80ff0, 0xf4c80fec, 0xffffffff), at 0xfdb84700
        [12] jni_GetStringLength(0xfa28c, 0x0, 0x8, 0x4, 0x1, 0xf4c81274), at 0xfdb6f06c
      =>[13] getString8859_1Chars(env = 0xfa28c, jstr = (nil)), line 412 in "jni_util.c"
        [14] JNU_GetStringPlatformChars(env = 0xfa28c, jstr = (nil), isCopy = (nil)), line 738 in "jni_util.c"
        [15] Java_java_util_TimeZone_getSystemTimeZoneID(env = 0xfa28c, ign = 0xf4c81300, java_home = (nil), region = (nil)), line 32 in "TimeZone.c"
        [16] 0xfb40d4e4(0xfa1f8, 0xb8, 0x8, 0xfb420d5c, 0xf5200000, 0x0), at 0xfb40d4e3
        [17] 0xfb4063a0(0xfa1f8, 0xb8, 0xf4c81498, 0xfb42476c, 0x0, 0x0), at 0xfb40639f
        [18] 0xfb4063a0(0xf5003658, 0xb7, 0x7, 0xfb42476c, 0xf9136838, 0x0), at 0xfb40639f
        [19] 0xfb4064f4(0xf5003658, 0xb7, 0x7, 0xfb4243b8, 0xf9133690, 0x0), at 0xfb4064f3
        [20] 0xfb4064f4(0xf5002fb0, 0xf4c81624, 0xf4c81628, 0xfb424548, 0x1, 0x0), at 0xfb4064f3
        [21] 0xfb4063a0(0xf5002fb0, 0xf4c816b8, 0xf4c816bc, 0xfb423fa8, 0x0, 0x0), at 0xfb40639f
        [22] 0xfb4063a0(0xf5002c08, 0xb6, 0x2a, 0xfb42476c, 0xf90dc220, 0x0), at 0xfb40639f
        [23] 0xfb4063a0(0xfa1f8, 0xb8, 0x8, 0xfb42448c, 0xf91021b0, 0xf91021b0), at 0xfb40639f
        [24] 0xfb4064f4(0xf503bfc8, 0xfa1f8, 0x8, 0xfb4248fc, 0xf4c81b24, 0xfa7b0), at 0xfb4064f3
        [25] 0xfb400528(0xf4c81898, 0xf4c81bd0, 0xa, 0xf90df008, 0xfb40c358, 0xf4c81b18), at 0xfb400527
        [26] JavaCalls::call_helper(0xf4c81b14, 0xfb4004a0, 0xf4c81b0c, 0xfa1f8, 0xf4c818fc, 0x7), at 0xfdb2e57c
        [27] os::os_exception_wrapper(0xfdb2dfd8, 0xf4c81bc8, 0xf4c81a50, 0xf4c81b0c, 0xfa1f8, 0x1), at 0xfdd1d29c
        [28] JavaCalls::call(0xf4c81bc8, 0xf4c81a50, 0xf4c81b0c, 0xfa1f8, 0xf4c81a5c, 0xf4c81a58), at 0xfdb2df6c
        [29] JavaCalls::call_virtual(0xf4c81a58, 0xf4c81a54, 0xf4c81b00, 0xf4c81afc, 0xf4c81b0c, 0xfa1f8), at 0xfdb2d19c
        [30] JavaCalls::call_virtual(0xf4c81bc8, 0xf4c81bb8, 0xf4c81bb4, 0xf4c81bb0, 0xf4c81bac, 0xfa1f8), at 0xfdb2d28c
        [31] thread_entry(0xfa1f8, 0xfa1f8, 0x1, 0x0, 0x0, 0x0), at 0xfdba6844
      dbx: warning: can't find file "/usr/re/hotspot/hotspot1.4/ws/solsparc/hotspot1.4beta_refresh/build/solaris/solaris_sparc_compiler1/jvmg/thread.o"
        [32] JavaThread::thread_main_inner(0xfa1f8, 0xc8c48, 0x6, 0x0, 0x0, 0x0), at 0xfde233a8
        [33] JavaThread::run(0xfa1f8, 0x0, 0x0, 0x0, 0x0, 0x0), at 0xfde23240
        [34] _start(0xfa1f8, 0xff245d60, 0x1, 0xff399834, 0x0, 0xff0b5dc0), at 0xfdd18274
      dbx t@13 l@1 12>

            peytoia Yuka Kamiya (Inactive)
            jcoomes John Coomes (Inactive)
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

              Created:
              Updated:
              Resolved:
              Imported:
              Indexed: