-
Bug
-
Resolution: Duplicate
-
P2
-
hs25
JVM crashes in methods compiled by C1 when metaspace is exhausted with "implicit exception happened" message.
Here is output for run with -XX:+PrintAssembly:
implicit exception happened at 0xa8eb8bf0
Compiled method (c1) 669431 5384 2 javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum (8 bytes)
total in heap [0xa8eb8ac8,0xa8eb8d18] = 592
relocation [0xa8eb8b98,0xa8eb8bc0] = 40
main code [0xa8eb8bc0,0xa8eb8c80] = 192
stub code [0xa8eb8c80,0xa8eb8cb4] = 52
oops [0xa8eb8cb4,0xa8eb8cb8] = 4
metadata [0xa8eb8cb8,0xa8eb8cbc] = 4
scopes data [0xa8eb8cbc,0xa8eb8cd4] = 24
scopes pcs [0xa8eb8cd4,0xa8eb8d14] = 64
dependencies [0xa8eb8d14,0xa8eb8d18] = 4
0 iload_1
1 iload_1
2 imul
3 iload_2
4 iload_2
5 imul
6 iadd
7 ireturn
Decoding compiled method 0xa8eb8ac8:
Code:
[Entry Point]
[Constants]
# {method}
{0x7f90e3b0} 'qsum' '(II)I' in 'javasoft/sqe/tests/lang/clss021/clss02103/clss02103_b'
# this: ecx = 'javasoft/sqe/tests/lang/clss021/clss02103/clss02103_b'
# parm0: edx = int
# parm1: [sp+0x30] = int (sp of caller)
;; block B1 [0, 0]
<bunch of nops...>
0xa8eb8bd7: cmp 0x4(%ecx),%eax ;...3b4104
0xa8eb8bda: jne 0xa8b4b020 ;...0f854024 c9ff
; {runtime_call}
[Verified Entry Point]
0xa8eb8be0: mov %eax,-0x9000(%esp) ;...89842400 70ffff
0xa8eb8be7: push %ebp ;...55
0xa8eb8be8: sub $0x28,%esp ;...83ec28
0xa8eb8beb: mov $0x0,%eax ;...b8000000 00 <-- putting 0 into EAX
0xa8eb8bf0: mov 0x8(%eax),%esi ;...8b7008 <-- BOOOOM
0xa8eb8bf3: add $0x8,%esi ;...83c608
0xa8eb8bf6: mov %esi,0x8(%eax) ;...897008
0xa8eb8bf9: mov $0x7f90e3b0,%eax ;...b8b0e390 7f
{0x7f90e3b0} 'qsum' '(II)I' in 'javasoft/sqe/tests/lang/clss021/clss02103/clss02103_b')}
0xa8eb8bfe: and $0x3ff8,%esi ;...81e6f83f 0000
0xa8eb8c04: cmp $0x0,%esi ;...83fe00
;; 24 branch [EQ] [CounterOverflowStub: 0x7f30aa10]
0xa8eb8c07: je 0xa8eb8c2a ;...0f841d00 0000
;*iload_1
; - javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum@0 (line 55)
;; block B2 [0, 0]
0xa8eb8c0d: mov 0x30(%esp),%eax ;...8b442430
;; block B0 [0, 7]
0xa8eb8c11: mov %edx,%esi ;...8bf2
0xa8eb8c13: imul %edx,%esi ;...0faff2
0xa8eb8c16: mov %eax,%edi ;...8bf8
0xa8eb8c18: imul %eax,%edi ;...0faff8
0xa8eb8c1b: add %edi,%esi ;...03f7
0xa8eb8c1d: mov %esi,%eax ;...8bc6
0xa8eb8c1f: add $0x28,%esp ;...83c428
0xa8eb8c22: pop %ebp ;...5d
0xa8eb8c23: test %eax,0xb7f53100 ;...85050031 f5b7
0xa8eb8c29: ret ;...c3
;; CounterOverflowStub slow case
0xa8eb8c2a: mov %eax,0x4(%esp) ;...89442404
0xa8eb8c2e: movl $0xffffffff,(%esp) ;...c70424ff ffffff
0xa8eb8c35: call 0xa8bb1800 ;...e8c68bcf ff
; OopMap{ecx=Oop off=122}
;*synchronization entry
; - javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum@-1 (line 55)
; {runtime_call}
0xa8eb8c3a: jmp 0xa8eb8c0d ;...ebd1
0xa8eb8c3c: nop ;...90
0xa8eb8c3d: nop ;...90
;; Unwind handler
0xa8eb8c3e: mov %esp,%esi ;...8bf4
0xa8eb8c40: shr $0xc,%esi ;...c1ee0c
0xa8eb8c43: mov 0x1bb3500(,%esi,4),%esi ;...8b34b500 35bb01
0xa8eb8c4a: mov 0x1ac(%esi),%eax ;...8b86ac01 0000
0xa8eb8c50: movl $0x0,0x1ac(%esi) ;...c786ac01 000000
;...000000
0xa8eb8c5a: movl $0x0,0x1b0(%esi) ;...c786b001 000000
;...000000
0xa8eb8c64: add $0x28,%esp ;...83c428
0xa8eb8c67: pop %ebp ;...5d
0xa8eb8c68: jmp 0xa8bad740 ;...e9d34acf ff
; {runtime_call}
<bunch of htls...>
[Exception Handler]
[Stub Code]
0xa8eb8c80: mov $0xdead,%ebx ;...bbadde00 00
; {no_reloc}
0xa8eb8c85: mov $0xdead,%ecx ;...b9adde00 00
0xa8eb8c8a: mov $0xdead,%esi ;...beadde00 00
0xa8eb8c8f: mov $0xdead,%edi ;...bfadde00 00
0xa8eb8c94: call 0xa8bafcc0 ;...e82770cf ff
; {runtime_call}
0xa8eb8c99: push $0x19f8d99 ;...68998d9f 01
; {external_word}
0xa8eb8c9e: call 0xa8eb8ca3 ;...e8000000 00
0xa8eb8ca3: pusha ;...60
0xa8eb8ca4: call 0x016133e0 ;...e837a775 58
; {runtime_call}
0xa8eb8ca9: hlt ;...f4
[Deopt Handler Code]
0xa8eb8caa: push $0xa8eb8caa ;...68aa8ceb a8
; {section_word}
0xa8eb8caf: jmp 0xa8b4bd80 ;...e9cc30c9 ff
; {runtime_call}
pc-bytecode offsets:
PcDesc(pc=0xa8eb8bbf offset=ffffffff bits=0):
PcDesc(pc=0xa8eb8c0d offset=4d bits=0):
javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum @0
PcDesc(pc=0xa8eb8c3a offset=7a bits=0):
javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum @-1
PcDesc(pc=0xa8eb8cb5 offset=f5 bits=0):
#
# A fatal error has been detected by the Java Runtime Environment:
#
# SIGSEGV (0xb) at pc=0xa8eb8bf0, pid=31630, tid=2133187472
#
# JRE version: Java(TM) SE Runtime Environment (8.0-b92) (build 1.8.0-ea-fastdebug-b92)
# Java VM: Java HotSpot(TM) Server VM (25.0-b34-fastdebug compiled mode linux-x86 )
# Problematic frame:
# J javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b.qsum(II)I
#
# Core dump written. Default location: /export/JQA/pg_stress/core or core.31630
#
# An error report file with more information is saved as:
# /export/JQA/pg_stress/hs_err_pid31630.log
Compiled method (c1) 669558 5384 2 javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum (8 bytes)
total in heap [0xa8eb8ac8,0xa8eb8d18] = 592
relocation [0xa8eb8b98,0xa8eb8bc0] = 40
main code [0xa8eb8bc0,0xa8eb8c80] = 192
stub code [0xa8eb8c80,0xa8eb8cb4] = 52
oops [0xa8eb8cb4,0xa8eb8cb8] = 4
metadata [0xa8eb8cb8,0xa8eb8cbc] = 4
scopes data [0xa8eb8cbc,0xa8eb8cd4] = 24
scopes pcs [0xa8eb8cd4,0xa8eb8d14] = 64
dependencies [0xa8eb8d14,0xa8eb8d18] = 4
#
# If you would like to submit a bug report, please visit:
# http://bugreport.sun.com/bugreport/crash.jsp
#
I was able to reproduce issue in different linux hosts with latest JDK8 build.
Issue could be reproduced with C1 or with TieredCompilation turned on (in this case crash happens in method compiled by C1).
Failed VM test exhaust Metaspace and then starting multiple threads where different JCK-tests are executed.
I've attached logs for several runs.
Issue reproduces intermittently: approx. 1/30.
Here is output for run with -XX:+PrintAssembly:
implicit exception happened at 0xa8eb8bf0
Compiled method (c1) 669431 5384 2 javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum (8 bytes)
total in heap [0xa8eb8ac8,0xa8eb8d18] = 592
relocation [0xa8eb8b98,0xa8eb8bc0] = 40
main code [0xa8eb8bc0,0xa8eb8c80] = 192
stub code [0xa8eb8c80,0xa8eb8cb4] = 52
oops [0xa8eb8cb4,0xa8eb8cb8] = 4
metadata [0xa8eb8cb8,0xa8eb8cbc] = 4
scopes data [0xa8eb8cbc,0xa8eb8cd4] = 24
scopes pcs [0xa8eb8cd4,0xa8eb8d14] = 64
dependencies [0xa8eb8d14,0xa8eb8d18] = 4
0 iload_1
1 iload_1
2 imul
3 iload_2
4 iload_2
5 imul
6 iadd
7 ireturn
Decoding compiled method 0xa8eb8ac8:
Code:
[Entry Point]
[Constants]
# {method}
{0x7f90e3b0} 'qsum' '(II)I' in 'javasoft/sqe/tests/lang/clss021/clss02103/clss02103_b'
# this: ecx = 'javasoft/sqe/tests/lang/clss021/clss02103/clss02103_b'
# parm0: edx = int
# parm1: [sp+0x30] = int (sp of caller)
;; block B1 [0, 0]
<bunch of nops...>
0xa8eb8bd7: cmp 0x4(%ecx),%eax ;...3b4104
0xa8eb8bda: jne 0xa8b4b020 ;...0f854024 c9ff
; {runtime_call}
[Verified Entry Point]
0xa8eb8be0: mov %eax,-0x9000(%esp) ;...89842400 70ffff
0xa8eb8be7: push %ebp ;...55
0xa8eb8be8: sub $0x28,%esp ;...83ec28
0xa8eb8beb: mov $0x0,%eax ;...b8000000 00 <-- putting 0 into EAX
0xa8eb8bf0: mov 0x8(%eax),%esi ;...8b7008 <-- BOOOOM
0xa8eb8bf3: add $0x8,%esi ;...83c608
0xa8eb8bf6: mov %esi,0x8(%eax) ;...897008
0xa8eb8bf9: mov $0x7f90e3b0,%eax ;...b8b0e390 7f
{0x7f90e3b0} 'qsum' '(II)I' in 'javasoft/sqe/tests/lang/clss021/clss02103/clss02103_b')}
0xa8eb8bfe: and $0x3ff8,%esi ;...81e6f83f 0000
0xa8eb8c04: cmp $0x0,%esi ;...83fe00
;; 24 branch [EQ] [CounterOverflowStub: 0x7f30aa10]
0xa8eb8c07: je 0xa8eb8c2a ;...0f841d00 0000
;*iload_1
; - javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum@0 (line 55)
;; block B2 [0, 0]
0xa8eb8c0d: mov 0x30(%esp),%eax ;...8b442430
;; block B0 [0, 7]
0xa8eb8c11: mov %edx,%esi ;...8bf2
0xa8eb8c13: imul %edx,%esi ;...0faff2
0xa8eb8c16: mov %eax,%edi ;...8bf8
0xa8eb8c18: imul %eax,%edi ;...0faff8
0xa8eb8c1b: add %edi,%esi ;...03f7
0xa8eb8c1d: mov %esi,%eax ;...8bc6
0xa8eb8c1f: add $0x28,%esp ;...83c428
0xa8eb8c22: pop %ebp ;...5d
0xa8eb8c23: test %eax,0xb7f53100 ;...85050031 f5b7
0xa8eb8c29: ret ;...c3
;; CounterOverflowStub slow case
0xa8eb8c2a: mov %eax,0x4(%esp) ;...89442404
0xa8eb8c2e: movl $0xffffffff,(%esp) ;...c70424ff ffffff
0xa8eb8c35: call 0xa8bb1800 ;...e8c68bcf ff
; OopMap{ecx=Oop off=122}
;*synchronization entry
; - javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum@-1 (line 55)
; {runtime_call}
0xa8eb8c3a: jmp 0xa8eb8c0d ;...ebd1
0xa8eb8c3c: nop ;...90
0xa8eb8c3d: nop ;...90
;; Unwind handler
0xa8eb8c3e: mov %esp,%esi ;...8bf4
0xa8eb8c40: shr $0xc,%esi ;...c1ee0c
0xa8eb8c43: mov 0x1bb3500(,%esi,4),%esi ;...8b34b500 35bb01
0xa8eb8c4a: mov 0x1ac(%esi),%eax ;...8b86ac01 0000
0xa8eb8c50: movl $0x0,0x1ac(%esi) ;...c786ac01 000000
;...000000
0xa8eb8c5a: movl $0x0,0x1b0(%esi) ;...c786b001 000000
;...000000
0xa8eb8c64: add $0x28,%esp ;...83c428
0xa8eb8c67: pop %ebp ;...5d
0xa8eb8c68: jmp 0xa8bad740 ;...e9d34acf ff
; {runtime_call}
<bunch of htls...>
[Exception Handler]
[Stub Code]
0xa8eb8c80: mov $0xdead,%ebx ;...bbadde00 00
; {no_reloc}
0xa8eb8c85: mov $0xdead,%ecx ;...b9adde00 00
0xa8eb8c8a: mov $0xdead,%esi ;...beadde00 00
0xa8eb8c8f: mov $0xdead,%edi ;...bfadde00 00
0xa8eb8c94: call 0xa8bafcc0 ;...e82770cf ff
; {runtime_call}
0xa8eb8c99: push $0x19f8d99 ;...68998d9f 01
; {external_word}
0xa8eb8c9e: call 0xa8eb8ca3 ;...e8000000 00
0xa8eb8ca3: pusha ;...60
0xa8eb8ca4: call 0x016133e0 ;...e837a775 58
; {runtime_call}
0xa8eb8ca9: hlt ;...f4
[Deopt Handler Code]
0xa8eb8caa: push $0xa8eb8caa ;...68aa8ceb a8
; {section_word}
0xa8eb8caf: jmp 0xa8b4bd80 ;...e9cc30c9 ff
; {runtime_call}
pc-bytecode offsets:
PcDesc(pc=0xa8eb8bbf offset=ffffffff bits=0):
PcDesc(pc=0xa8eb8c0d offset=4d bits=0):
javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum @0
PcDesc(pc=0xa8eb8c3a offset=7a bits=0):
javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum @-1
PcDesc(pc=0xa8eb8cb5 offset=f5 bits=0):
#
# A fatal error has been detected by the Java Runtime Environment:
#
# SIGSEGV (0xb) at pc=0xa8eb8bf0, pid=31630, tid=2133187472
#
# JRE version: Java(TM) SE Runtime Environment (8.0-b92) (build 1.8.0-ea-fastdebug-b92)
# Java VM: Java HotSpot(TM) Server VM (25.0-b34-fastdebug compiled mode linux-x86 )
# Problematic frame:
# J javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b.qsum(II)I
#
# Core dump written. Default location: /export/JQA/pg_stress/core or core.31630
#
# An error report file with more information is saved as:
# /export/JQA/pg_stress/hs_err_pid31630.log
Compiled method (c1) 669558 5384 2 javasoft.sqe.tests.lang.clss021.clss02103.clss02103_b::qsum (8 bytes)
total in heap [0xa8eb8ac8,0xa8eb8d18] = 592
relocation [0xa8eb8b98,0xa8eb8bc0] = 40
main code [0xa8eb8bc0,0xa8eb8c80] = 192
stub code [0xa8eb8c80,0xa8eb8cb4] = 52
oops [0xa8eb8cb4,0xa8eb8cb8] = 4
metadata [0xa8eb8cb8,0xa8eb8cbc] = 4
scopes data [0xa8eb8cbc,0xa8eb8cd4] = 24
scopes pcs [0xa8eb8cd4,0xa8eb8d14] = 64
dependencies [0xa8eb8d14,0xa8eb8d18] = 4
#
# If you would like to submit a bug report, please visit:
# http://bugreport.sun.com/bugreport/crash.jsp
#
I was able to reproduce issue in different linux hosts with latest JDK8 build.
Issue could be reproduced with C1 or with TieredCompilation turned on (in this case crash happens in method compiled by C1).
Failed VM test exhaust Metaspace and then starting multiple threads where different JCK-tests are executed.
I've attached logs for several runs.
Issue reproduces intermittently: approx. 1/30.
- duplicates
-
JDK-8025566 EXCEPTION_ACCESS_VIOLATION in compiled by C1 String.valueOf method
-
- Resolved
-