From da61b865b47995d649f9fe545b743d421a559721 Mon Sep 17 00:00:00 2001 From: Matthias Baesken Date: Mon, 4 Nov 2019 09:54:00 +0100 Subject: [PATCH] 8233078: fix minimal VM build on Linux ppc64(le) Reviewed-by: mdoerr, lucy --- src/hotspot/cpu/ppc/c1_globals_ppc.hpp | 6 +++++- src/hotspot/cpu/ppc/disassembler_ppc.cpp | 2 -- src/hotspot/cpu/ppc/globalDefinitions_ppc.hpp | 2 ++ src/hotspot/cpu/ppc/sharedRuntime_ppc.cpp | 17 ++--------------- src/hotspot/cpu/ppc/stubGenerator_ppc.cpp | 5 +++-- src/hotspot/cpu/ppc/vm_version_ppc.cpp | 4 ++++ 6 files changed, 16 insertions(+), 20 deletions(-) diff --git a/src/hotspot/cpu/ppc/c1_globals_ppc.hpp b/src/hotspot/cpu/ppc/c1_globals_ppc.hpp index 4a6c7149747..5a5dd1fb4d1 100644 --- a/src/hotspot/cpu/ppc/c1_globals_ppc.hpp +++ b/src/hotspot/cpu/ppc/c1_globals_ppc.hpp @@ -1,6 +1,6 @@ /* * Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved. - * Copyright (c) 2012, 2018 SAP SE. All rights reserved. + * Copyright (c) 2012, 2019 SAP SE. 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 @@ -48,8 +48,12 @@ define_pd_global(bool, ProfileInterpreter, false); define_pd_global(intx, FreqInlineSize, 325 ); define_pd_global(bool, ResizeTLAB, true); define_pd_global(uintx, ReservedCodeCacheSize, 32*M); +define_pd_global(uintx, NonProfiledCodeHeapSize, 13*M ); +define_pd_global(uintx, ProfiledCodeHeapSize, 14*M ); +define_pd_global(uintx, NonNMethodCodeHeapSize, 5*M ); define_pd_global(uintx, CodeCacheExpansionSize, 32*K); define_pd_global(uintx, CodeCacheMinBlockLength, 1); +define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K); define_pd_global(size_t, MetaspaceSize, 12*M); define_pd_global(bool, NeverActAsServerClassMachine, true); define_pd_global(size_t, NewSizeThreadIncrease, 16*K); diff --git a/src/hotspot/cpu/ppc/disassembler_ppc.cpp b/src/hotspot/cpu/ppc/disassembler_ppc.cpp index 9c89046a47a..eeae7eb19a5 100644 --- a/src/hotspot/cpu/ppc/disassembler_ppc.cpp +++ b/src/hotspot/cpu/ppc/disassembler_ppc.cpp @@ -27,8 +27,6 @@ #include "code/codeCache.hpp" #include "compiler/disassembler.hpp" #include "depChecker_ppc.hpp" -#include "gc/cms/concurrentMarkSweepGeneration.inline.hpp" -#include "gc/cms/parOopClosures.inline.hpp" #include "gc/shared/collectedHeap.hpp" #include "gc/shared/cardTableBarrierSet.hpp" #include "gc/shared/genOopClosures.inline.hpp" diff --git a/src/hotspot/cpu/ppc/globalDefinitions_ppc.hpp b/src/hotspot/cpu/ppc/globalDefinitions_ppc.hpp index 45b4f1c74b2..81d7b968be8 100644 --- a/src/hotspot/cpu/ppc/globalDefinitions_ppc.hpp +++ b/src/hotspot/cpu/ppc/globalDefinitions_ppc.hpp @@ -50,6 +50,8 @@ const bool CCallingConventionRequiresIntsAsLongs = true; #if defined(COMPILER2) && (defined(AIX) || defined(LINUX)) // Include Transactional Memory lock eliding optimization #define INCLUDE_RTM_OPT 1 +#else +#define INCLUDE_RTM_OPT 0 #endif #define SUPPORT_RESERVED_STACK_AREA diff --git a/src/hotspot/cpu/ppc/sharedRuntime_ppc.cpp b/src/hotspot/cpu/ppc/sharedRuntime_ppc.cpp index 37321574b9b..5e802e1381b 100644 --- a/src/hotspot/cpu/ppc/sharedRuntime_ppc.cpp +++ b/src/hotspot/cpu/ppc/sharedRuntime_ppc.cpp @@ -571,7 +571,6 @@ void SharedRuntime::generate_trampoline(MacroAssembler *masm, address destinatio __ bctr(); } -#ifdef COMPILER2 static int reg2slot(VMReg r) { return r->reg2stack() + SharedRuntime::out_preserve_stack_slots(); } @@ -579,7 +578,6 @@ static int reg2slot(VMReg r) { static int reg2offset(VMReg r) { return (r->reg2stack() + SharedRuntime::out_preserve_stack_slots()) * VMRegImpl::stack_slot_size; } -#endif // --------------------------------------------------------------------------- // Read the array of BasicTypes from a signature, and compute where the @@ -1305,7 +1303,6 @@ AdapterHandlerEntry* SharedRuntime::generate_i2c2i_adapters(MacroAssembler *masm return AdapterHandlerLibrary::new_entry(fingerprint, i2c_entry, c2i_entry, c2i_unverified_entry, c2i_no_clinit_check_entry); } -#ifdef COMPILER2 // An oop arg. Must pass a handle not the oop itself. static void object_move(MacroAssembler* masm, int frame_size_in_slots, @@ -1813,8 +1810,6 @@ static void gen_special_dispatch(MacroAssembler* masm, receiver_reg, member_reg, /*for_compiler_entry:*/ true); } -#endif // COMPILER2 - // --------------------------------------------------------------------------- // Generate a native wrapper for a given method. The method takes arguments // in the Java compiled code convention, marshals them to the native @@ -1851,7 +1846,6 @@ nmethod *SharedRuntime::generate_native_wrapper(MacroAssembler *masm, VMRegPair *in_regs, BasicType ret_type, address critical_entry) { -#ifdef COMPILER2 if (method->is_method_handle_intrinsic()) { vmIntrinsics::ID iid = method->intrinsic_id(); intptr_t start = (intptr_t)__ pc(); @@ -2108,7 +2102,7 @@ nmethod *SharedRuntime::generate_native_wrapper(MacroAssembler *masm, // Check ic: object class == cached class? if (!method_is_static) { - Register ic = as_Register(Matcher::inline_cache_reg_encode()); + Register ic = R19_inline_cache_reg; Register receiver_klass = r_temp_1; __ cmpdi(CCR0, R3_ARG1, 0); @@ -2638,12 +2632,10 @@ nmethod *SharedRuntime::generate_native_wrapper(MacroAssembler *masm, // Handler for pending exceptions (out-of-line). // -------------------------------------------------------------------------- - // Since this is a native call, we know the proper exception handler // is the empty function. We just pop this frame and then jump to // forward_exception_entry. if (!is_critical_native) { - __ align(InteriorEntryAlignment); __ bind(handle_pending_exception); __ pop_frame(); @@ -2656,7 +2648,6 @@ nmethod *SharedRuntime::generate_native_wrapper(MacroAssembler *masm, // -------------------------------------------------------------------------- if (!method_is_static) { - __ align(InteriorEntryAlignment); __ bind(ic_miss); __ b64_patchable((address)SharedRuntime::get_ic_miss_stub(), @@ -2683,10 +2674,6 @@ nmethod *SharedRuntime::generate_native_wrapper(MacroAssembler *masm, } return nm; -#else - ShouldNotReachHere(); - return NULL; -#endif // COMPILER2 } // This function returns the adjust size (in number of words) to a c2i adapter @@ -2863,7 +2850,7 @@ void SharedRuntime::generate_deopt_blob() { // We can't grab a free register here, because all registers may // contain live values, so let the RegisterSaver do the adjustment // of the return pc. - const int return_pc_adjustment_no_exception = -HandlerImpl::size_deopt_handler(); + const int return_pc_adjustment_no_exception = -MacroAssembler::bl64_patchable_size; // Push the "unpack frame" // Save everything in sight. diff --git a/src/hotspot/cpu/ppc/stubGenerator_ppc.cpp b/src/hotspot/cpu/ppc/stubGenerator_ppc.cpp index ea59a9558f5..f6a372e407f 100644 --- a/src/hotspot/cpu/ppc/stubGenerator_ppc.cpp +++ b/src/hotspot/cpu/ppc/stubGenerator_ppc.cpp @@ -3103,6 +3103,7 @@ class StubGenerator: public StubCodeGenerator { STUB_ENTRY(checkcast_arraycopy)); // fill routines +#ifdef COMPILER2 if (OptimizeFill) { StubRoutines::_jbyte_fill = generate_fill(T_BYTE, false, "jbyte_fill"); StubRoutines::_jshort_fill = generate_fill(T_SHORT, false, "jshort_fill"); @@ -3111,6 +3112,7 @@ class StubGenerator: public StubCodeGenerator { StubRoutines::_arrayof_jshort_fill = generate_fill(T_SHORT, true, "arrayof_jshort_fill"); StubRoutines::_arrayof_jint_fill = generate_fill(T_INT, true, "arrayof_jint_fill"); } +#endif } // Safefetch stubs. @@ -3579,8 +3581,6 @@ class StubGenerator: public StubCodeGenerator { if (UseMultiplyToLenIntrinsic) { StubRoutines::_multiplyToLen = generate_multiplyToLen(); } -#endif - if (UseSquareToLenIntrinsic) { StubRoutines::_squareToLen = generate_squareToLen(); } @@ -3595,6 +3595,7 @@ class StubGenerator: public StubCodeGenerator { StubRoutines::_montgomerySquare = CAST_FROM_FN_PTR(address, SharedRuntime::montgomery_square); } +#endif if (UseAESIntrinsics) { StubRoutines::_aescrypt_encryptBlock = generate_aescrypt_encryptBlock(); diff --git a/src/hotspot/cpu/ppc/vm_version_ppc.cpp b/src/hotspot/cpu/ppc/vm_version_ppc.cpp index 01bfe14b60e..5d1390f54dc 100644 --- a/src/hotspot/cpu/ppc/vm_version_ppc.cpp +++ b/src/hotspot/cpu/ppc/vm_version_ppc.cpp @@ -312,6 +312,7 @@ void VM_Version::initialize() { FLAG_SET_DEFAULT(UseSHA, false); } +#ifdef COMPILER2 if (FLAG_IS_DEFAULT(UseSquareToLenIntrinsic)) { UseSquareToLenIntrinsic = true; } @@ -327,6 +328,7 @@ void VM_Version::initialize() { if (FLAG_IS_DEFAULT(UseMontgomerySquareIntrinsic)) { UseMontgomerySquareIntrinsic = true; } +#endif if (UseVectorizedMismatchIntrinsic) { warning("UseVectorizedMismatchIntrinsic specified, but not available on this CPU."); @@ -373,9 +375,11 @@ void VM_Version::initialize() { if (UseRTMDeopt) { FLAG_SET_DEFAULT(UseRTMDeopt, false); } +#ifdef COMPILER2 if (PrintPreciseRTMLockingStatistics) { FLAG_SET_DEFAULT(PrintPreciseRTMLockingStatistics, false); } +#endif } // This machine allows unaligned memory accesses