From 0d6c0adef0b9dadae33819dbd18d9ef97fe228bf Mon Sep 17 00:00:00 2001 From: Lutz Schmidt Date: Mon, 23 Oct 2017 11:56:30 +0200 Subject: [PATCH] 8189616: [s390] Remove definition and all uses of STCK instruction Reviewed-by: mdoerr --- src/hotspot/cpu/s390/assembler_s390.hpp | 2 - .../cpu/s390/assembler_s390.inline.hpp | 1 - src/hotspot/cpu/s390/vm_version_s390.cpp | 49 ++----------------- 3 files changed, 3 insertions(+), 49 deletions(-) diff --git a/src/hotspot/cpu/s390/assembler_s390.hpp b/src/hotspot/cpu/s390/assembler_s390.hpp index a06b43ae3a8..a839700259c 100644 --- a/src/hotspot/cpu/s390/assembler_s390.hpp +++ b/src/hotspot/cpu/s390/assembler_s390.hpp @@ -1310,7 +1310,6 @@ class Assembler : public AbstractAssembler { #define LAOG_ZOPC (unsigned long)(0xebL << 40 | 0xe6L) // z196 // System Functions -#define STCK_ZOPC (unsigned int)(0xb2 << 24 | 0x05 << 16) #define STCKF_ZOPC (unsigned int)(0xb2 << 24 | 0x7c << 16) #define STFLE_ZOPC (unsigned int)(0xb2 << 24 | 0xb0 << 16) #define ECTG_ZOPC (unsigned long)(0xc8L <<40 | 0x01L << 32) // z10 @@ -3035,7 +3034,6 @@ class Assembler : public AbstractAssembler { inline void z_ahhlr(Register r1, Register r2, Register r3); // ADD halfword high low inline void z_tam(); - inline void z_stck(int64_t d2, Register b2); inline void z_stckf(int64_t d2, Register b2); inline void z_stmg(Register r1, Register r3, int64_t d2, Register b2); inline void z_lmg(Register r1, Register r3, int64_t d2, Register b2); diff --git a/src/hotspot/cpu/s390/assembler_s390.inline.hpp b/src/hotspot/cpu/s390/assembler_s390.inline.hpp index eaeb9d3ea1e..19c472787c5 100644 --- a/src/hotspot/cpu/s390/assembler_s390.inline.hpp +++ b/src/hotspot/cpu/s390/assembler_s390.inline.hpp @@ -689,7 +689,6 @@ inline void Assembler::z_ahhhr(Register r1, Register r2, Register r3) { emit_32( inline void Assembler::z_ahhlr(Register r1, Register r2, Register r3) { emit_32( AHHLR_ZOPC | reg(r3, 16, 32) | reg(r1, 24, 32) | reg(r2, 28, 32)); } inline void Assembler::z_tam() { emit_16( TAM_ZOPC); } -inline void Assembler::z_stck(int64_t d2, Register b2) { emit_32( STCK_ZOPC | uimm12(d2, 20, 32) | regz(b2, 16, 32)); } inline void Assembler::z_stckf(int64_t d2, Register b2) { emit_32( STCKF_ZOPC | uimm12(d2, 20, 32) | regz(b2, 16, 32)); } inline void Assembler::z_stmg(Register r1, Register r3, int64_t d2, Register b2) { emit_48( STMG_ZOPC | simm20(d2) | reg(r1, 8, 48) | reg(r3,12,48)| reg(b2,16,48) ); } inline void Assembler::z_lmg(Register r1, Register r3, int64_t d2, Register b2) { emit_48( LMG_ZOPC | simm20(d2) | reg(r1, 8, 48) | reg(r3,12,48)| reg(b2,16,48) ); } diff --git a/src/hotspot/cpu/s390/vm_version_s390.cpp b/src/hotspot/cpu/s390/vm_version_s390.cpp index 842f991b4c1..51383d6db75 100644 --- a/src/hotspot/cpu/s390/vm_version_s390.cpp +++ b/src/hotspot/cpu/s390/vm_version_s390.cpp @@ -707,13 +707,12 @@ void VM_Version::determine_features() { Label getCIPHERFEATURES; // fcode = -2 (cipher) Label getMSGDIGESTFEATURES; // fcode = -3 (SHA) Label getVECTORFEATURES; // fcode = -4 (OS support for vector instructions) - Label checkLongDispFast; - Label noLongDisp; - Label posDisp, negDisp; Label errRTN; a->z_ltgfr(Z_R0, Z_ARG2); // Buf len to r0 and test. a->z_brl(getFEATURES); // negative -> Get machine features not covered by facility list. - a->z_brz(checkLongDispFast); // zero -> Check for high-speed Long Displacement Facility. + a->z_lghi(Z_R1,0); + a->z_brz(errRTN); // zero -> Function code currently not used, indicate "aborted". + a->z_aghi(Z_R0, -1); a->z_stfle(0, Z_ARG1); a->z_lg(Z_R1, 0, Z_ARG1); // Get first DW of facility list. @@ -774,48 +773,6 @@ void VM_Version::determine_features() { a->z_vtm(Z_V0,Z_V0); // non-destructive vector instruction. Will cause SIGFPE if not supported. a->z_br(Z_R14); - // Check the performance of the Long Displacement Facility, i.e. find out if we are running on z900 or newer. - a->bind(checkLongDispFast); - a->z_llill(Z_R0, 0xffff); // preset #iterations - a->z_larl(Z_R1, posDisp); - a->z_stck(0, Z_ARG1); // Get begin timestamp. - - a->bind(posDisp); // Positive disp loop. - a->z_lg(Z_ARG2, 0, Z_ARG1); - a->z_bctgr(Z_R0, Z_R1); - - a->z_stck(0, Z_ARG1); // Get end timestamp. - a->z_sg(Z_ARG2, 0, Z_R0, Z_ARG1); // Calculate elapsed time. - a->z_lcgr(Z_ARG2, Z_ARG2); - a->z_srlg(Z_ARG2, Z_ARG2, 12); // LSB: now microseconds - a->z_stg(Z_ARG2, 8, Z_ARG1); // Store difference in buffer[1]. - - a->z_llill(Z_R0, 0xffff); // preset #iterations - a->z_larl(Z_R1, negDisp); - a->z_xgr(Z_ARG2, Z_ARG2); // Clear to detect absence of LongDisp facility. - a->z_stck(0, Z_ARG1); // Get begin timestamp. - a->z_la(Z_ARG1, 8, Z_ARG1); - - a->bind(negDisp); // Negative disp loop. - a->z_lg(Z_ARG2, -8, Z_ARG1); - a->z_bctgr(Z_R0, Z_R1); - - a->z_aghi(Z_ARG1, -8); - a->z_stck(0, Z_ARG1); // Get end timestamp. - a->z_ltgr(Z_ARG2, Z_ARG2); // Check for absence of LongDisp facility. - a->z_brz(noLongDisp); - a->z_sg(Z_ARG2, 0, Z_R0, Z_ARG1); // Calc elapsed time. - a->z_lcgr(Z_ARG2, Z_ARG2); - a->z_srlg(Z_ARG2, Z_ARG2, 12); // LSB: now microseconds - a->z_stg(Z_ARG2, 0, Z_ARG1); // store difference in buffer[0] - - a->z_llill(Z_RET,0xffff); - a->z_br(Z_R14); - - a->bind(noLongDisp); - a->z_lghi(Z_RET,-1); - a->z_br(Z_R14); - address code_end = a->pc(); a->flush();