From d1f090f5690766ab6de0e8848172aab967803b54 Mon Sep 17 00:00:00 2001 From: Aleksey Shipilev Date: Wed, 14 Mar 2018 15:28:31 +0100 Subject: [PATCH] 8199603: Build failures after JDK-8199421 "Add support for vector popcount" Reviewed-by: thartmann --- src/hotspot/cpu/x86/assembler_x86.cpp | 18 +++++++++--------- src/hotspot/cpu/x86/assembler_x86.hpp | 4 ++-- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/hotspot/cpu/x86/assembler_x86.cpp b/src/hotspot/cpu/x86/assembler_x86.cpp index 3dc5c9cc564..0e2dc67783a 100644 --- a/src/hotspot/cpu/x86/assembler_x86.cpp +++ b/src/hotspot/cpu/x86/assembler_x86.cpp @@ -3915,6 +3915,15 @@ void Assembler::popcntl(Register dst, Register src) { emit_int8((unsigned char)(0xC0 | encode)); } +void Assembler::vpopcntd(XMMRegister dst, XMMRegister src, int vector_len) { + assert(VM_Version::supports_vpopcntdq(), "must support vpopcntdq feature"); + InstructionAttr attributes(vector_len, /* vex_w */ false, /* legacy_mode */ false, /* no_mask_reg */ false, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(dst->encoding(), 0, src->encoding(), VEX_SIMD_66, VEX_OPCODE_0F_38, &attributes); + emit_int8(0x55); + emit_int8((unsigned char)(0xC0 | encode)); +} + void Assembler::popf() { emit_int8((unsigned char)0x9D); } @@ -8709,15 +8718,6 @@ void Assembler::popcntq(Register dst, Register src) { emit_int8((unsigned char)(0xC0 | encode)); } -void Assembler::vpopcntd(XMMRegister dst, XMMRegister src, int vector_len) { - assert(VM_Version::supports_vpopcntdq(), "must support vpopcntdq feature"); - InstructionAttr attributes(vector_len, /* vex_w */ false, /* legacy_mode */ false, /* no_mask_reg */ false, /* uses_vl */ true); - attributes.set_is_evex_instruction(); - int encode = vex_prefix_and_encode(dst->encoding(), 0, src->encoding(), VEX_SIMD_66, VEX_OPCODE_0F_38, &attributes); - emit_int8(0x55); - emit_int8((unsigned char)(0xC0 | encode)); -} - void Assembler::popq(Address dst) { InstructionMark im(this); prefixq(dst); diff --git a/src/hotspot/cpu/x86/assembler_x86.hpp b/src/hotspot/cpu/x86/assembler_x86.hpp index 8d4bedef055..e1e6adb35ac 100644 --- a/src/hotspot/cpu/x86/assembler_x86.hpp +++ b/src/hotspot/cpu/x86/assembler_x86.hpp @@ -1633,13 +1633,13 @@ private: void popcntl(Register dst, Address src); void popcntl(Register dst, Register src); + void vpopcntd(XMMRegister dst, XMMRegister src, int vector_len); + #ifdef _LP64 void popcntq(Register dst, Address src); void popcntq(Register dst, Register src); #endif - void vpopcntd(XMMRegister dst, XMMRegister src, int vector_len); - // Prefetches (SSE, SSE2, 3DNOW only) void prefetchnta(Address src);