From c4f835b3a7ec0f11ca42fa43ac4eb01d0c6a55b0 Mon Sep 17 00:00:00 2001 From: Vladimir Kozlov Date: Mon, 13 Jul 2020 16:41:01 -0700 Subject: [PATCH] 8249165: Remove unneeded nops introduced by 8234160 changes Check for branch instruction at the end of code block Reviewed-by: vlivanov --- src/hotspot/cpu/x86/c2_intelJccErratum_x86.cpp | 6 +++--- src/hotspot/cpu/x86/c2_intelJccErratum_x86.hpp | 2 +- src/hotspot/cpu/x86/x86.ad | 5 +---- 3 files changed, 5 insertions(+), 8 deletions(-) diff --git a/src/hotspot/cpu/x86/c2_intelJccErratum_x86.cpp b/src/hotspot/cpu/x86/c2_intelJccErratum_x86.cpp index ba8f159ef4c..0444522e9fe 100644 --- a/src/hotspot/cpu/x86/c2_intelJccErratum_x86.cpp +++ b/src/hotspot/cpu/x86/c2_intelJccErratum_x86.cpp @@ -45,11 +45,11 @@ bool IntelJccErratum::is_crossing_or_ending_at_32_byte_boundary(uintptr_t start_ return boundary(start_pc) != boundary(end_pc); } -bool IntelJccErratum::is_jcc_erratum_branch(const Block* block, const MachNode* node, uint node_index) { +bool IntelJccErratum::is_jcc_erratum_branch(const MachNode* node) { if (node->is_MachCall() && !node->is_MachCallJava()) { return true; } - return node_index == (block->number_of_nodes() - 1); + return node->is_MachBranch(); } int IntelJccErratum::jcc_erratum_taint_node(MachNode* node, PhaseRegAlloc* regalloc) { @@ -70,7 +70,7 @@ int IntelJccErratum::tag_affected_machnodes(Compile* C, PhaseCFG* cfg, PhaseRegA continue; } MachNode* m = node->as_Mach(); - if (is_jcc_erratum_branch(block, m, j)) { + if (is_jcc_erratum_branch(m)) { // Found a root jcc erratum branch, flag it as problematic nop_size += jcc_erratum_taint_node(m, regalloc); diff --git a/src/hotspot/cpu/x86/c2_intelJccErratum_x86.hpp b/src/hotspot/cpu/x86/c2_intelJccErratum_x86.hpp index f0db7c9b207..f3f66f3d7bc 100644 --- a/src/hotspot/cpu/x86/c2_intelJccErratum_x86.hpp +++ b/src/hotspot/cpu/x86/c2_intelJccErratum_x86.hpp @@ -43,7 +43,7 @@ private: public: static bool is_crossing_or_ending_at_32_byte_boundary(uintptr_t start_pc, uintptr_t end_pc); - static bool is_jcc_erratum_branch(const Block* block, const MachNode* node, uint node_index); + static bool is_jcc_erratum_branch(const MachNode* node); // Analyze JCC erratum branches. Affected nodes get tagged with Flag_intel_jcc_erratum. // The function returns a conservative estimate of all required nops on all mach nodes. static int tag_affected_machnodes(Compile* C, PhaseCFG* cfg, PhaseRegAlloc* regalloc); diff --git a/src/hotspot/cpu/x86/x86.ad b/src/hotspot/cpu/x86/x86.ad index 6fc47c25b69..4108d628bb9 100644 --- a/src/hotspot/cpu/x86/x86.ad +++ b/src/hotspot/cpu/x86/x86.ad @@ -1188,10 +1188,7 @@ void PhaseOutput::pd_perform_mach_node_analysis() { } int MachNode::pd_alignment_required() const { - PhaseOutput* output = Compile::current()->output(); - Block* block = output->block(); - int index = output->index(); - if (VM_Version::has_intel_jcc_erratum() && IntelJccErratum::is_jcc_erratum_branch(block, this, index)) { + if (VM_Version::has_intel_jcc_erratum() && IntelJccErratum::is_jcc_erratum_branch(this)) { // Conservatively add worst case padding. We assume that relocInfo::addr_unit() is 1 on x86. return IntelJccErratum::largest_jcc_size() + 1; } else {