diff --git a/src/hotspot/share/opto/callnode.cpp b/src/hotspot/share/opto/callnode.cpp index 1e1692dc6f1..d3af76b8263 100644 --- a/src/hotspot/share/opto/callnode.cpp +++ b/src/hotspot/share/opto/callnode.cpp @@ -406,12 +406,23 @@ static void format_helper( PhaseRegAlloc *regalloc, outputStream* st, Node *n, c } } +//---------------------print_method_with_lineno-------------------------------- +void JVMState::print_method_with_lineno(outputStream* st, bool show_name) const { + if (show_name) _method->print_short_name(st); + + int lineno = _method->line_number_from_bci(_bci); + if (lineno != -1) { + st->print(" @ bci:%d (line %d)", _bci, lineno); + } else { + st->print(" @ bci:%d", _bci); + } +} + //------------------------------format----------------------------------------- void JVMState::format(PhaseRegAlloc *regalloc, const Node *n, outputStream* st) const { st->print(" #"); if (_method) { - _method->print_short_name(st); - st->print(" @ bci:%d ",_bci); + print_method_with_lineno(st, true); } else { st->print_cr(" runtime stub "); return; @@ -537,9 +548,7 @@ void JVMState::dump_spec(outputStream *st) const { printed = true; } } - if (!printed) - _method->print_short_name(st); - st->print(" @ bci:%d",_bci); + print_method_with_lineno(st, !printed); if(_reexecute == Reexecute_True) st->print(" reexecute"); } else { diff --git a/src/hotspot/share/opto/callnode.hpp b/src/hotspot/share/opto/callnode.hpp index 4688b01d534..e5b21fa79f0 100644 --- a/src/hotspot/share/opto/callnode.hpp +++ b/src/hotspot/share/opto/callnode.hpp @@ -306,6 +306,7 @@ public: int interpreter_frame_size() const; #ifndef PRODUCT + void print_method_with_lineno(outputStream* st, bool show_name) const; void format(PhaseRegAlloc *regalloc, const Node *n, outputStream* st) const; void dump_spec(outputStream *st) const; void dump_on(outputStream* st) const; diff --git a/test/hotspot/jtreg/compiler/arguments/TestPrintOptoAssemblyLineNumbers.java b/test/hotspot/jtreg/compiler/arguments/TestPrintOptoAssemblyLineNumbers.java new file mode 100644 index 00000000000..18e797fb4c1 --- /dev/null +++ b/test/hotspot/jtreg/compiler/arguments/TestPrintOptoAssemblyLineNumbers.java @@ -0,0 +1,75 @@ +/* + * Copyright Amazon.com Inc. or its affiliates. All Rights Reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8033441 + * @summary Test to ensure that line numbers are now present with the -XX:+PrintOptoAssembly command line option + * + * @requires vm.compiler2.enabled & vm.debug == true + * + * @library /compiler/patches /test/lib + * @run main/othervm compiler.arguments.TestPrintOptoAssemblyLineNumbers +*/ + +package compiler.arguments; + +import jdk.test.lib.Asserts; +import jdk.test.lib.process.OutputAnalyzer; +import jdk.test.lib.process.ProcessTools; + +public class TestPrintOptoAssemblyLineNumbers { + public static void main(String[] args) throws Throwable { + // create subprocess to run some code with -XX:+PrintOptoAssembly enabled + String[] procArgs = new String[]{ + "-XX:+UnlockDiagnosticVMOptions", + "-XX:-TieredCompilation", + "-XX:+PrintOptoAssembly", + "compiler.arguments.TestPrintOptoAssemblyLineNumbers$CheckC2OptoAssembly" + }; + + ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(procArgs); + String output = new OutputAnalyzer(pb.start()).getOutput(); + + if(output.contains("TestPrintOptoAssemblyLineNumbers$CheckC2OptoAssembly::main @ bci:11")){ + // if C2 optimizer invoked ensure output includes line numbers: + Asserts.assertTrue(output.contains("TestPrintOptoAssemblyLineNumbers$CheckC2OptoAssembly::main @ bci:11 (line 68)")); + } + } + + public static class CheckC2OptoAssembly{ // contents of this class serves to just invoke C2 + public static boolean foo(String arg){ + return arg.contains("45"); + } + + public static void main(String[] args){ + int count = 0; + for(int x = 0; x < 200_000; x++){ + if(foo("something" + x)){ // <- test expects this line of code to be on line 68 + count += 1; + } + } + System.out.println("count: " + count); + } + } +}