From 145f06a155abeb6c8e2ffcd00f811fa92d3a9137 Mon Sep 17 00:00:00 2001 From: Sergey Kuksenko Date: Thu, 30 May 2019 12:45:02 -0700 Subject: [PATCH] 8223504: Improve performance of forall loops by better inlining of "iterator()" methods Reviewed-by: vlivanov, shade --- src/hotspot/share/classfile/systemDictionary.hpp | 3 +++ src/hotspot/share/classfile/vmSymbols.hpp | 1 + src/hotspot/share/opto/bytecodeInfo.cpp | 9 ++++++++- 3 files changed, 12 insertions(+), 1 deletion(-) diff --git a/src/hotspot/share/classfile/systemDictionary.hpp b/src/hotspot/share/classfile/systemDictionary.hpp index 3cbb973fc48..ee9ea1bcbed 100644 --- a/src/hotspot/share/classfile/systemDictionary.hpp +++ b/src/hotspot/share/classfile/systemDictionary.hpp @@ -214,6 +214,9 @@ class OopStorage; do_klass(Integer_klass, java_lang_Integer ) \ do_klass(Long_klass, java_lang_Long ) \ \ + /* force inline of iterators */ \ + do_klass(Iterator_klass, java_util_Iterator ) \ + \ /*end*/ diff --git a/src/hotspot/share/classfile/vmSymbols.hpp b/src/hotspot/share/classfile/vmSymbols.hpp index d997070cc9f..59d6f5381eb 100644 --- a/src/hotspot/share/classfile/vmSymbols.hpp +++ b/src/hotspot/share/classfile/vmSymbols.hpp @@ -126,6 +126,7 @@ template(getBootClassPathEntryForClass_name, "getBootClassPathEntryForClass") \ template(jdk_internal_vm_PostVMInitHook, "jdk/internal/vm/PostVMInitHook") \ template(sun_net_www_ParseUtil, "sun/net/www/ParseUtil") \ + template(java_util_Iterator, "java/util/Iterator") \ \ template(jdk_internal_loader_ClassLoaders_AppClassLoader, "jdk/internal/loader/ClassLoaders$AppClassLoader") \ template(jdk_internal_loader_ClassLoaders_PlatformClassLoader, "jdk/internal/loader/ClassLoaders$PlatformClassLoader") \ diff --git a/src/hotspot/share/opto/bytecodeInfo.cpp b/src/hotspot/share/opto/bytecodeInfo.cpp index bcf9faff8bb..09480ca7cfe 100644 --- a/src/hotspot/share/opto/bytecodeInfo.cpp +++ b/src/hotspot/share/opto/bytecodeInfo.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, Oracle and/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 @@ -77,6 +77,8 @@ InlineTree::InlineTree(Compile* c, * Return true when EA is ON and a java constructor is called or * a super constructor is called from an inlined java constructor. * Also return true for boxing methods. + * Also return true for methods returning Iterator (including Iterable::iterator()) + * that is essential for forall-loops performance. */ static bool is_init_with_ea(ciMethod* callee_method, ciMethod* caller_method, Compile* C) { @@ -94,6 +96,11 @@ static bool is_init_with_ea(ciMethod* callee_method, if (C->eliminate_boxing() && callee_method->is_boxing_method()) { return true; } + ciType *retType = callee_method->signature()->return_type(); + ciKlass *iter = C->env()->Iterator_klass(); + if(retType->is_loaded() && iter->is_loaded() && retType->is_subtype_of(iter)) { + return true; + } return false; }